firefly-iii/app/Api/V1/Requests/AccountStoreRequest.php

134 lines
5.6 KiB
PHP
Raw Normal View History

2018-02-13 11:24:06 -06:00
<?php
2018-05-11 03:08:34 -05:00
2018-02-13 11:24:06 -06:00
/**
2019-04-10 23:06:25 -05:00
* AccountStoreRequest.php
* Copyright (c) 2019 james@firefly-iii.org
2018-02-13 11:24:06 -06:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2018-02-13 11:24:06 -06:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
2018-02-13 11:24:06 -06:00
*
* This program is distributed in the hope that it will be useful,
2018-02-13 11:24:06 -06:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
2018-02-13 11:24:06 -06:00
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
2018-02-13 11:24:06 -06:00
*/
2018-05-11 03:08:34 -05:00
declare(strict_types=1);
2018-02-13 11:24:06 -06:00
namespace FireflyIII\Api\V1\Requests;
use FireflyIII\Models\Location;
use FireflyIII\Rules\IsBoolean;
2018-02-13 11:24:06 -06:00
/**
2019-04-10 23:06:25 -05:00
* Class AccountStoreRequest
2019-09-04 10:39:39 -05:00
*
* @codeCoverageIgnore
2018-02-13 11:24:06 -06:00
*/
2019-04-10 23:06:25 -05:00
class AccountStoreRequest extends Request
2018-02-13 11:24:06 -06:00
{
/**
* Authorize logged in users.
*
2018-02-13 11:24:06 -06:00
* @return bool
*/
2018-02-16 09:42:23 -06:00
public function authorize(): bool
2018-02-13 11:24:06 -06:00
{
// Only allow authenticated users
return auth()->check();
}
2020-01-01 07:27:08 -06:00
/**
* @return array
*/
public function getAllAccountData(): array
{
$active = true;
$includeNetWorth = true;
if (null !== $this->get('active')) {
$active = $this->boolean('active');
}
if (null !== $this->get('include_net_worth')) {
$includeNetWorth = $this->boolean('include_net_worth');
}
$data = [
'name' => $this->string('name'),
'active' => $active,
'include_net_worth' => $includeNetWorth,
'account_type' => $this->string('type'),
'account_type_id' => null,
'currency_id' => $this->integer('currency_id'),
'currency_code' => $this->string('currency_code'),
'virtual_balance' => $this->string('virtual_balance'),
'iban' => $this->string('iban'),
'BIC' => $this->string('bic'),
'account_number' => $this->string('account_number'),
'account_role' => $this->string('account_role'),
'opening_balance' => $this->string('opening_balance'),
'opening_balance_date' => $this->date('opening_balance_date'),
'cc_type' => $this->string('credit_card_type'),
2020-07-15 14:21:09 -05:00
'cc_monthly_payment_date' => $this->string('monthly_payment_date'),
2020-01-01 07:27:08 -06:00
'notes' => $this->nlString('notes'),
'interest' => $this->string('interest'),
'interest_period' => $this->string('interest_period'),
];
// append Location information.
$data = $this->appendLocationData($data, null);
2020-01-01 07:27:08 -06:00
if ('liability' === $data['account_type']) {
$data['opening_balance'] = bcmul($this->string('liability_amount'), '-1');
$data['opening_balance_date'] = $this->date('liability_start_date');
$data['account_type'] = $this->string('liability_type');
$data['account_type_id'] = null;
}
return $data;
}
2018-02-13 11:24:06 -06:00
/**
* The rules that the incoming request must be matched against.
*
2018-02-13 11:24:06 -06:00
* @return array
*/
2018-02-16 09:42:23 -06:00
public function rules(): array
2018-02-13 11:24:06 -06:00
{
2018-03-26 12:19:11 -05:00
$accountRoles = implode(',', config('firefly.accountRoles'));
$types = implode(',', array_keys(config('firefly.subTitlesByIdentifier')));
$ccPaymentTypes = implode(',', array_keys(config('firefly.ccTypes')));
2018-02-13 11:24:06 -06:00
$rules = [
'name' => 'required|min:1|uniqueAccountForUser',
2019-06-10 13:14:00 -05:00
'type' => 'required|' . sprintf('in:%s', $types),
'iban' => 'iban|nullable',
'bic' => 'bic|nullable',
'account_number' => 'between:1,255|nullable|uniqueAccountNumberForUser',
'opening_balance' => 'numeric|required_with:opening_balance_date|nullable',
'opening_balance_date' => 'date|required_with:opening_balance|nullable',
'virtual_balance' => 'numeric|nullable',
'currency_id' => 'numeric|exists:transaction_currencies,id',
'currency_code' => 'min:3|max:3|exists:transaction_currencies,code',
'active' => [new IsBoolean],
'include_net_worth' => [new IsBoolean],
2019-04-10 23:06:25 -05:00
'account_role' => sprintf('in:%s|required_if:type,asset', $accountRoles),
'credit_card_type' => sprintf('in:%s|required_if:account_role,ccAsset', $ccPaymentTypes),
'monthly_payment_date' => 'date' . '|required_if:account_role,ccAsset|required_if:credit_card_type,monthlyFull',
'liability_type' => 'required_if:type,liability|in:loan,debt,mortgage',
'liability_amount' => 'required_if:type,liability|min:0|numeric',
'liability_start_date' => 'required_if:type,liability|date',
'interest' => 'required_if:type,liability|between:0,100|numeric',
'interest_period' => 'required_if:type,liability|in:daily,monthly,yearly',
'notes' => 'min:0|max:65536',
2018-02-13 11:24:06 -06:00
];
$rules = Location::requestRules($rules);
2018-02-13 11:24:06 -06:00
return $rules;
}
2018-03-05 12:35:58 -06:00
}