![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/job-board.corals.io/Corals/modules/Reservation/Http/Requests/ |
<?php namespace Corals\Modules\Reservation\Http\Requests; use Corals\Foundation\Http\Requests\BaseRequest; use Corals\Modules\Reservation\Models\Reservation; use Corals\Modules\Reservation\Models\Service; class ReservationRequest extends BaseRequest { /** * Determine if the user is authorized to make this request. * * @return bool */ public function authorize() { $this->setModel(Reservation::class); return $this->isAuthorized(); } /** * Get the validation rules that apply to the request. * * @return array */ public function rules() { $this->setModel(Reservation::class); $rules = parent::rules(); if ($this->isUpdate() || $this->isStore()) { $rules = array_merge($rules, [ 'owner_id' => 'required', 'owner_type' => 'required', 'starts_at' => 'required|date_format:Y-m-d H:i:s', 'ends_at' => 'required|date_format:Y-m-d H:i:s|after:starts_at', 'notes' => '', 'status' => 'required', 'service_id' => 'required', 'object_id' => 'required', ]); } if ($this->isStore()) { $rules = array_merge($rules, [ // 'code' => 'required|unique:res_reservations,code' ]); } if ($this->isUpdate()) { $reservation = $this->route('reservation'); $rules = array_merge($rules, [ // 'code' => 'required|unique:res_reservations,code,' . $reservation->id, ]); } return $rules; } protected function getValidatorInstance() { if ($this->isStore() || $this->isUpdate()) { $data = $this->all(); if ($this->isStore()) { $data['code'] = Reservation::getCode('RES'); } $service = Service::find(data_get($data, 'service_id')); if (empty($service->object_type)) { $data['object_type'] = getMorphAlias(Service::class); $data['object_id'] = $service->id; } $this->getInputSource()->replace($data); } return parent::getValidatorInstance(); } }