user(); return $user->can('create', Payment::class); } public function rules() { /** @var \App\Models\User $user */ $user = auth()->user(); $rules = [ 'client_id' => ['bail','required',Rule::exists('clients','id')->where('company_id',$user->company()->id)->where('is_deleted', 0)], 'amount' => ['bail', 'numeric', new PaymentAmountsBalanceRule()], 'invoices.*.amount' => ['bail','required'], 'invoices.*.invoice_id' => ['bail','required','distinct', new ValidInvoicesRules($this->all()),Rule::exists('invoices','id')->where('company_id', $user->company()->id)->where('client_id', $this->client_id)], 'credits.*.credit_id' => ['bail','required','distinct', new ValidCreditsRules($this->all()),Rule::exists('credits','id')->where('company_id', $user->company()->id)->where('client_id', $this->client_id)], 'credits.*.amount' => ['bail','required', new CreditsSumRule($this->all())], 'invoices' => ['bail','sometimes','array', new ValidPayableInvoicesRule()], 'number' => ['bail', 'nullable', Rule::unique('payments')->where('company_id', $user->company()->id)], 'idempotency_key' => ['nullable', 'bail', 'string','max:64', Rule::unique('payments')->where('company_id', $user->company()->id)], ]; if ($this->file('documents') && is_array($this->file('documents'))) { $rules['documents.*'] = $this->fileValidation(); } elseif ($this->file('documents')) { $rules['documents'] = $this->fileValidation(); }else { $rules['documents'] = 'bail|sometimes|array'; } if ($this->file('file') && is_array($this->file('file'))) { $rules['file.*'] = $this->fileValidation(); } elseif ($this->file('file')) { $rules['file'] = $this->fileValidation(); } return $rules; } public function prepareForValidation() { /** @var \App\Models\User $user */ $user = auth()->user(); $input = $this->all(); $invoices_total = 0; $credits_total = 0; if (isset($input['client_id']) && is_string($input['client_id'])) { $input['client_id'] = $this->decodePrimaryKey($input['client_id'], true); } if (array_key_exists('assigned_user_id', $input) && is_string($input['assigned_user_id'])) { $input['assigned_user_id'] = $this->decodePrimaryKey($input['assigned_user_id']); } if (isset($input['invoices']) && is_array($input['invoices']) !== false) { foreach ($input['invoices'] as $key => $value) { if (is_string($value['invoice_id'])) { $input['invoices'][$key]['invoice_id'] = $this->decodePrimaryKey($value['invoice_id']); } if (array_key_exists('amount', $value)) { $invoices_total += $value['amount']; } } } if (isset($input['invoices']) && is_array($input['invoices']) === false) { $input['invoices'] = null; } if (isset($input['credits']) && is_array($input['credits']) !== false) { foreach ($input['credits'] as $key => $value) { if (array_key_exists('credit_id', $input['credits'][$key])) { $input['credits'][$key]['credit_id'] = $this->decodePrimaryKey($value['credit_id']); $credits_total += $value['amount']; } } } if (isset($input['credits']) && is_array($input['credits']) === false) { $input['credits'] = null; } if (! isset($input['amount']) || $input['amount'] == 0) { $input['amount'] = $invoices_total - $credits_total; } if (! isset($input['date'])) { $input['date'] = now()->addSeconds($user->company()->utc_offset())->format('Y-m-d'); } if (! isset($input['idempotency_key'])) { $input['idempotency_key'] = substr(sha1(json_encode($input)).time()."{$input['date']}{$input['amount']}{$user->id}", 0, 64); } nlog($input); $i = \App\Models\Invoice::find($input['invoices'][0]['invoice_id']); nlog($i->client_id); nlog($i->id); nlog($user->company()->id); nlog($i->company_id); $this->replace($input); } }