![]() 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/syn.corals.io/Corals/modules/Syndicate/Http/Requests/ |
<?php namespace Corals\Modules\Syndicate\Http\Requests; use Corals\Foundation\Http\Requests\BaseRequest; use Corals\Modules\Syndicate\Models\Loan; class LoanRequest extends BaseRequest { /** * Determine if the user is authorized to make this request. * * @return bool */ public function authorize() { $this->setModel(Loan::class); return $this->isAuthorized(); } /** * Get the validation rules that apply to the request. * * @return array */ public function rules() { $this->setModel(Loan::class); $rules = parent::rules(); if ($this->isUpdate() || $this->isStore()) { $rules = array_merge($rules, [ 'amount' => 'required|integer', 'currency_code' => 'required|exists:utility_list_of_values,code', 'status' => 'required', 'loan-validation' => [ function ($attribute, $value, $fail) { $pharmacist = $this->route('pharmacist'); $loan = $this->route('loan'); if (Loan::query()->where([ ['user_id', '=', $pharmacist->id], ['status', '!=', 'paid'], ])->when($loan, function ($query, $loan) { $query->where('id', '<>', $loan->id); })->exists()) { $fail(trans('Syndicate::attributes.loan.exception')); } } ], ]); } return $rules; } public function attributes() { return [ 'amount' => trans('Syndicate::attributes.loan.amount'), 'currency_code' => trans('Syndicate::attributes.loan.currency'), 'email' => trans('Syndicate::attributes.user.email'), 'status' => trans('Syndicate::attributes.user.status'), ]; } }