mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-30 19:42:57 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Requests;
 | |
| 
 | |
| use App\Models\Invoice;
 | |
| 
 | |
| class CreatePaymentRequest extends PaymentRequest
 | |
| {
 | |
|     /**
 | |
|      * Determine if the user is authorized to make this request.
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function authorize()
 | |
|     {
 | |
|         return $this->user()->can('create', ENTITY_PAYMENT);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the validation rules that apply to the request.
 | |
|      *
 | |
|      * @return array
 | |
|      */
 | |
|     public function rules()
 | |
|     {
 | |
|         $input = $this->input();
 | |
|         $this->invoice = $invoice = Invoice::scope($input['invoice'])
 | |
|             ->withArchived()
 | |
|             ->invoices()
 | |
|             ->firstOrFail();
 | |
| 
 | |
|         $this->merge([
 | |
|             'invoice_id' => $invoice->id,
 | |
|             'client_id' => $invoice->client->id,
 | |
|         ]);
 | |
| 
 | |
|         $rules = [
 | |
|             'client' => 'required', // TODO: change to client_id once views are updated
 | |
|             'invoice' => 'required', // TODO: change to invoice_id once views are updated
 | |
|             'amount' => 'required|numeric|not_in:0',
 | |
|             'payment_date' => 'required',
 | |
|         ];
 | |
| 
 | |
|         if (! empty($input['payment_type_id']) && $input['payment_type_id'] == PAYMENT_TYPE_CREDIT) {
 | |
|             $rules['payment_type_id'] = 'has_credit:'.$input['client'].','.$input['amount'];
 | |
|         }
 | |
| 
 | |
|         return $rules;
 | |
|     }
 | |
| }
 |