⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.45
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
work
/
modules
/
User
/
Controllers
/
View File Name :
UserController.php
<?php namespace Modules\User\Controllers; use Illuminate\Support\Facades\Log; use Illuminate\Validation\Rule; use Matrix\Exception; use Modules\Boat\Models\Boat; use Modules\Booking\Models\Service; use Modules\Car\Models\Car; use Modules\Event\Models\Event; use Modules\Flight\Models\Flight; use Modules\FrontendController; use Modules\Hotel\Models\Hotel; use Modules\Space\Models\Space; use Modules\Tour\Models\Tour; use Modules\User\Events\NewVendorRegistered; use Modules\User\Events\UserSubscriberSubmit; use Modules\User\Models\Subscriber; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use Modules\Vendor\Models\VendorRequest; use Validator; use Modules\Booking\Models\Booking; use Illuminate\Foundation\Auth\AuthenticatesUsers; use Modules\Booking\Models\Enquiry; use Illuminate\Support\Str; class UserController extends FrontendController { use AuthenticatesUsers; protected $enquiryClass; private Booking $booking; public function __construct(Booking $booking, Enquiry $enquiry) { $this->enquiryClass = $enquiry; parent::__construct(); $this->booking = $booking; } public function dashboard(Request $request) { $this->checkPermission('dashboard_vendor_access'); $user_id = Auth::id(); $data = [ 'cards_report' => $this->booking->getTopCardsReportForVendor($user_id), 'earning_chart_data' => $this->booking->getEarningChartDataForVendor(strtotime('monday this week'), time(), $user_id), 'page_title' => __("Vendor Dashboard"), 'breadcrumbs' => [ [ 'name' => __('Dashboard'), 'class' => 'active' ] ] ]; return view('User::frontend.dashboard', $data); } public function reloadChart(Request $request) { $chart = $request->input('chart'); $user_id = Auth::id(); switch ($chart) { case "earning": $from = $request->input('from'); $to = $request->input('to'); return $this->sendSuccess([ 'data' => $this->booking->getEarningChartDataForVendor(strtotime($from), strtotime($to), $user_id) ]); break; } } public function profile(Request $request) { $user = Auth::user(); $data = [ 'dataUser' => $user, 'page_title' => __("Profile"), 'breadcrumbs' => [ [ 'name' => __('Setting'), 'class' => 'active' ] ], 'is_vendor_access' => $this->hasPermission('dashboard_vendor_access') ]; return view('User::frontend.profile', $data); } public function profileUpdate(Request $request){ if(is_demo_mode()){ return back()->with('error',"Demo mode: disabled"); } $user = Auth::user(); $messages = [ 'user_name.required' => __('The User name field is required.'), ]; $request->validate([ 'first_name' => 'required|max:255', 'last_name' => 'required|max:255', 'email' => [ 'required', 'email', 'max:255', Rule::unique('users')->ignore($user->id) ], 'user_name'=> [ 'required', 'max:255', 'min:4', 'string', 'alpha_dash', Rule::unique('users')->ignore($user->id) ], 'phone' => [ 'required', Rule::unique('users')->ignore($user->id) ], ],$messages); $input = $request->except('bio'); $user->fill($input); $user->bio = clean($request->input('bio')); $user->birthday = date("Y-m-d", strtotime($user->birthday)); $user->user_name = Str::slug( $request->input('user_name') ,"_"); $user->save(); return redirect()->back()->with('success', __('Update successfully')); } public function bookingHistory(Request $request) { $user_id = Auth::id(); $data = [ 'bookings' => $this->booking->getBookingHistory($request->input('status'), $user_id), 'statues' => config('booking.statuses'), 'breadcrumbs' => [ [ 'name' => __('Booking History'), 'class' => 'active' ] ], 'page_title' => __("Booking History"), ]; return view('User::frontend.bookingHistory', $data); } public function subscribe(Request $request) { $this->validate($request, [ 'email' => 'required|email|max:255' ]); $check = Subscriber::withTrashed()->where('email', $request->input('email'))->first(); if ($check) { if ($check->trashed()) { $check->restore(); return $this->sendSuccess([], __('Thank you for subscribing')); } return $this->sendError(__('You are already subscribed')); } else { $a = new Subscriber(); $a->email = $request->input('email'); $a->first_name = $request->input('first_name'); $a->last_name = $request->input('last_name'); $a->save(); event(new UserSubscriberSubmit($a)); return $this->sendSuccess([], __('Thank you for subscribing')); } } public function upgradeVendor(Request $request){ $user = Auth::user(); $vendorRequest = VendorRequest::query()->where("user_id",$user->id)->where("status","pending")->first(); if(!empty($vendorRequest)){ return redirect()->back()->with('warning', __("You have just done the become vendor request, please wait for the Admin's approved")); } // check vendor auto approved $vendorAutoApproved = setting_item('vendor_auto_approved'); $dataVendor['role_request'] = setting_item('vendor_role'); if ($vendorAutoApproved) { if ($dataVendor['role_request']) { $user->assignRole($dataVendor['role_request']); } $dataVendor['status'] = 'approved'; $dataVendor['approved_time'] = now(); } else { $dataVendor['status'] = 'pending'; } $vendorRequestData = $user->vendorRequest()->save(new VendorRequest($dataVendor)); try { event(new NewVendorRegistered($user, $vendorRequestData)); } catch (Exception $exception) { Log::warning("NewVendorRegistered: " . $exception->getMessage()); } return redirect()->back()->with('success', __('Request vendor success!')); } public function permanentlyDelete(Request $request){ if(is_demo_mode()){ return back()->with('error',"Demo mode: disabled"); } if(!empty(setting_item('user_enable_permanently_delete'))) { $user = Auth::user(); \DB::beginTransaction(); try { Service::where('author_id',$user->id)->delete(); Tour::where('author_id',$user->id)->delete(); Car::where('author_id',$user->id)->delete(); Space::where('author_id',$user->id)->delete(); Hotel::where('author_id',$user->id)->delete(); Event::where('author_id',$user->id)->delete(); Boat::where('author_id',$user->id)->delete(); Flight::where('author_id',$user->id)->delete(); $user->sendEmailPermanentlyDelete(); $user->delete(); \DB::commit(); Auth::logout(); if(is_api()){ return $this->sendSuccess([],'Deleted'); } return redirect(route('home')); }catch (\Exception $exception){ \DB::rollBack(); } } if(is_api()){ return $this->sendError('Error. You can\'t permanently delete'); } return back()->with('error',__('Error. You can\'t permanently delete')); } }