. */ declare(strict_types=1); namespace FireflyIII\Http\Requests; use FireflyIII\Models\Account; use FireflyIII\Models\Location; use FireflyIII\Models\UserRole; use FireflyIII\Rules\UniqueIban; use FireflyIII\Support\Request\AppendsLocationData; use FireflyIII\Support\Request\ChecksLogin; use FireflyIII\Support\Request\ConvertsDataTypes; use FireflyIII\Validation\Administration\ValidatesAdministrationAccess; use Illuminate\Foundation\Http\FormRequest; use Illuminate\Validation\Validator; /** * Class AccountFormRequest. */ class AccountFormRequest extends FormRequest { use ConvertsDataTypes; use AppendsLocationData; use ChecksLogin; use ValidatesAdministrationAccess; /** * Get all data. * * @return array */ public function getAccountData(): array { $data = [ 'administration_id' => $this->convertInteger('administration_id'), 'name' => $this->convertString('name'), 'active' => $this->boolean('active'), 'account_type_name' => $this->convertString('objectType'), 'currency_id' => $this->convertInteger('currency_id'), 'virtual_balance' => $this->convertString('virtual_balance'), 'iban' => $this->convertString('iban'), 'BIC' => $this->convertString('BIC'), 'account_number' => $this->convertString('account_number'), 'account_role' => $this->convertString('account_role'), 'opening_balance' => $this->convertString('opening_balance'), 'opening_balance_date' => $this->getCarbonDate('opening_balance_date'), 'cc_type' => $this->convertString('cc_type'), 'cc_monthly_payment_date' => $this->convertString('cc_monthly_payment_date'), 'notes' => $this->stringWithNewlines('notes'), 'interest' => $this->convertString('interest'), 'interest_period' => $this->convertString('interest_period'), 'include_net_worth' => '1', 'liability_direction' => $this->convertString('liability_direction'), ]; if (0 === $data['administration_id']) { $data['administration_id'] = auth()->user()->getAdministrationId(); } $data = $this->appendLocationData($data, 'location'); if (false === $this->boolean('include_net_worth')) { $data['include_net_worth'] = '0'; } if ('0' === $data['opening_balance']) { $data['opening_balance'] = ''; } // if the account type is "liabilities" there are actually four types of liability // that could have been selected. if ('liabilities' === $data['account_type_name']) { $data['account_type_name'] = null; $data['account_type_id'] = $this->convertInteger('liability_type_id'); if ('' !== $data['opening_balance']) { // opening balance is always positive for liabilities $data['opening_balance'] = app('steam')->positive($data['opening_balance']); } } return $data; } /** * Rules for this request. * * @return array */ public function rules(): array { $accountRoles = implode(',', config('firefly.accountRoles')); $types = implode(',', array_keys(config('firefly.subTitlesByIdentifier'))); $ccPaymentTypes = implode(',', array_keys(config('firefly.ccTypes'))); $rules = [ 'administration_id' => 'min:1|max:16777216|numeric', 'name' => 'required|min:1|uniqueAccountForUser', 'opening_balance' => 'numeric|nullable|max:1000000000', 'opening_balance_date' => 'date|required_with:opening_balance|nullable', 'iban' => ['iban', 'nullable', new UniqueIban(null, $this->convertString('objectType'))], 'BIC' => 'bic|nullable', 'virtual_balance' => 'numeric|nullable|max:1000000000', 'currency_id' => 'exists:transaction_currencies,id', 'account_number' => 'between:1,255|uniqueAccountNumberForUser|nullable', 'account_role' => 'in:'.$accountRoles, 'active' => 'boolean', 'cc_type' => 'in:'.$ccPaymentTypes, 'amount_currency_id_opening_balance' => 'exists:transaction_currencies,id', 'amount_currency_id_virtual_balance' => 'exists:transaction_currencies,id', 'what' => 'in:'.$types, 'interest_period' => 'in:daily,monthly,yearly', ]; $rules = Location::requestRules($rules); /** @var Account $account */ $account = $this->route()->parameter('account'); if (null !== $account) { // add rules: $rules['id'] = 'belongsToUser:accounts'; $rules['name'] = 'required|min:1|uniqueAccountForUser:'.$account->id; $rules['iban'] = ['iban', 'nullable', new UniqueIban($account, $account->accountType->type)]; } return $rules; } /** * Configure the validator instance with special rules for after the basic validation rules. * * @param Validator $validator * * @return void */ public function withValidator(Validator $validator): void { $validator->after( function (Validator $validator) { // validate if the account can access this administration $this->validateAdministration($validator, [UserRole::CHANGE_TRANSACTIONS]); } ); } }