1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-11 13:42:49 +01:00
invoiceninja/app/Http/Requests/BankTransaction/MatchBankTransactionRequest.php

92 lines
3.8 KiB
PHP
Raw Normal View History

2022-09-15 05:58:42 +02:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\Http\Requests\BankTransaction;
use App\Http\Requests\Request;
use App\Models\BankTransaction;
use App\Models\Expense;
use App\Models\Payment;
2022-09-15 05:58:42 +02:00
class MatchBankTransactionRequest extends Request
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize() : bool
{
return auth()->user()->isAdmin();
}
2022-09-15 06:15:02 +02:00
public function rules()
{
2022-09-22 07:54:58 +02:00
$rules = [
2022-10-24 10:50:45 +02:00
'transactions' => 'bail|array',
'transactions.*.invoice_ids' => 'nullable|string|sometimes',
2022-09-15 06:15:02 +02:00
];
2022-11-03 11:56:04 +01:00
$rules['transactions.*.ninja_category_id'] = 'bail|nullable|sometimes|exists:expense_categories,id,company_id,'.auth()->user()->company()->id.',is_deleted,0';
$rules['transactions.*.vendor_id'] = 'bail|nullable|sometimes|exists:vendors,id,company_id,'.auth()->user()->company()->id.',is_deleted,0';
2022-11-17 00:15:22 +01:00
$rules['transactions.*.id'] = 'bail|required|exists:bank_transactions,id,company_id,'.auth()->user()->company()->id.',is_deleted,0';
$rules['transactions.*.payment_id'] = 'bail|sometimes|nullable|exists:payments,id,company_id,'.auth()->user()->company()->id.',is_deleted,0';
$rules['transactions.*.expense_id'] = 'bail|sometimes|nullable|exists:expenses,id,company_id,'.auth()->user()->company()->id.',is_deleted,0';
2022-09-22 07:54:58 +02:00
return $rules;
2022-09-15 06:15:02 +02:00
}
public function prepareForValidation()
{
2022-10-24 10:11:37 +02:00
$inputs = $this->all();
2022-10-24 10:27:40 +02:00
2022-10-24 11:10:01 +02:00
foreach($inputs['transactions'] as $key => $input)
2022-10-24 10:11:37 +02:00
{
2022-10-24 11:10:01 +02:00
if(array_key_exists('id', $inputs['transactions'][$key]))
$inputs['transactions'][$key]['id'] = $this->decodePrimaryKey($input['id']);
2022-09-22 08:20:54 +02:00
2022-10-24 11:10:01 +02:00
if(array_key_exists('ninja_category_id', $inputs['transactions'][$key]) && strlen($inputs['transactions'][$key]['ninja_category_id']) >= 1)
$inputs['transactions'][$key]['ninja_category_id'] = $this->decodePrimaryKey($inputs['transactions'][$key]['ninja_category_id']);
2022-09-22 08:20:54 +02:00
2022-10-24 12:20:29 +02:00
if(array_key_exists('vendor_id', $inputs['transactions'][$key]) && strlen($inputs['transactions'][$key]['vendor_id']) >= 1)
$inputs['transactions'][$key]['vendor_id'] = $this->decodePrimaryKey($inputs['transactions'][$key]['vendor_id']);
if(array_key_exists('payment_id', $inputs['transactions'][$key]) && strlen($inputs['transactions'][$key]['payment_id']) >= 1){
$inputs['transactions'][$key]['payment_id'] = $this->decodePrimaryKey($inputs['transactions'][$key]['payment_id']);
2022-12-16 00:40:03 +01:00
$p = Payment::withTrashed()->where('company_id', auth()->user()->company()->id)->where('id', $inputs['transactions'][$key]['payment_id'])->first();
/*Ensure we don't relink an existing payment*/
2022-12-16 00:36:53 +01:00
if(!$p || is_numeric($p->transaction_id)){
unset($inputs['transactions'][$key]);
}
}
if(array_key_exists('expense_id', $inputs['transactions'][$key]) && strlen($inputs['transactions'][$key]['expense_id']) >= 1){
$inputs['transactions'][$key]['expense_id'] = $this->decodePrimaryKey($inputs['transactions'][$key]['expense_id']);
2022-12-16 00:40:03 +01:00
$e = Expense::withTrashed()->where('company_id', auth()->user()->company()->id)->where('id', $inputs['transactions'][$key]['expense_id'])->first();
/*Ensure we don't relink an existing expense*/
2022-12-16 00:36:53 +01:00
if(!$e || is_numeric($e->transaction_id))
unset($inputs['transactions'][$key]['expense_id']);
}
2022-10-24 10:11:37 +02:00
}
2022-10-24 10:18:50 +02:00
2022-10-24 10:11:37 +02:00
$this->replace($inputs);
2022-09-15 06:15:02 +02:00
}
2022-09-15 05:58:42 +02:00
}