user()->isAdmin(); } protected function prepareForValidation() { $input = $this->all(); if(!isset($input['gateway_refund'])) $input['gateway_refund'] = false; if(!isset($input['send_email'])) $input['send_email'] = false; if(isset($input['id'])) $input['id'] = $this->decodePrimaryKey($input['id']); if(isset($input['invoices'])) { foreach($input['invoices'] as $key => $invoice) $input['invoices'][$key]['invoice_id'] = $this->decodePrimaryKey($invoice['invoice_id']); } if(isset($input['credits'])) { unset($input['credits']); // foreach($input['credits'] as $key => $credit) // $input['credits'][$key]['credit_id'] = $this->decodePrimaryKey($credit['credit_id']); } $this->replace($input); } public function rules() { $input = $this->all(); $rules = [ 'id' => 'required', 'id' => new ValidRefundableRequest($input), 'amount' => 'numeric', 'date' => 'required', 'invoices.*.invoice_id' => 'required', 'invoices.*.amount' => 'required', 'invoices' => new ValidRefundableInvoices($input), ]; return $rules; } public function payment() :?Payment { $input = $this->all(); return Payment::whereId($input['id'])->first(); } }