/** * Determine if the user is authorized to make this request. * * @return bool */ public function authorize() { $appointmentId = $this->get('appointment'); $businessId = $this->get('business'); $issuer = auth()->user(); $appointment = Appointment::find($appointmentId); $authorize = $appointment->issuer->id == $issuer->id || $issuer->isOwner($businessId); return $authorize; }
/** * post Action for booking * * @param AlterAppointmentRequest $request * @return JSON Action result object */ public function postAction(AlterAppointmentRequest $request) { $this->log->info(__METHOD__); ////////////////// // FOR REFACOTR // ////////////////// $issuer = auth()->user(); $businessId = $request->input('business'); $appointmentId = $request->input('appointment'); $action = $request->input('action'); $widget = $request->input('widget'); $this->log->info(sprintf("AJAX postAction.request:[issuer:%s, action:%s, business:%s, appointment:%s]", $issuer->email, $action, $businessId, $appointmentId)); $appointment = Appointment::find($appointmentId); switch ($action) { case 'annulate': $appointment->doAnnulate(); break; case 'confirm': $appointment->doConfirm(); break; case 'serve': $appointment->doServe(); break; default: // Ignore Invalid Action $this->log->warning('Invalid Action request'); return response()->json(['code' => 'ERROR', 'html' => '']); break; } /** * Widgets MUST be rendered before being returned on Response * as they need to be interpreted as HTML */ switch ($widget) { case 'row': $html = Widget::AppointmentsTableRow(['appointment' => $appointment, 'user' => auth()->user()])->render(); break; case 'panel': default: $html = Widget::AppointmentPanel(['appointment' => $appointment, 'user' => auth()->user()])->render(); break; } $appointmentPresenter = $appointment->getPresenter(); $date = $appointment->start_at->toDateString(); $code = $appointmentPresenter->code(); Notifynder::category('appointment.' . $action)->from('App\\Models\\User', auth()->user()->id)->to('App\\Models\\Business', $appointment->business->id)->url('http://localhost')->extra(compact('code', 'action', 'date'))->send(); $this->log->info("postAction.response:[appointment:{$appointment->toJson()}]"); return response()->json(['code' => 'OK', 'html' => $html]); }