Files
firefly-iii/app/Api/V1/Requests/BudgetLimitRequest.php

107 lines
3.1 KiB
PHP
Raw Normal View History

2018-06-24 13:20:29 +02:00
<?php
/**
* BudgetLimitRequest.php
* Copyright (c) 2019 james@firefly-iii.org
2018-06-24 13:20:29 +02:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2018-06-24 13:20:29 +02: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-06-24 13:20:29 +02:00
*
* This program is distributed in the hope that it will be useful,
2018-06-24 13:20:29 +02: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-06-24 13:20:29 +02: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-06-24 13:20:29 +02:00
*/
declare(strict_types=1);
namespace FireflyIII\Api\V1\Requests;
2020-07-18 08:34:00 +02:00
use FireflyIII\Support\Request\ConvertsDataTypes;
use Illuminate\Foundation\Http\FormRequest;
2018-06-24 13:20:29 +02:00
/**
* Class BudgetLimitRequest
*
* @codeCoverageIgnore
* TODO AFTER 4.8,0: split this into two request classes.
2018-06-24 13:20:29 +02:00
*/
class BudgetLimitRequest extends FormRequest
2018-06-24 13:20:29 +02:00
{
2020-07-18 08:34:00 +02:00
use ConvertsDataTypes;
2020-08-02 11:53:04 +02:00
2018-06-24 13:20:29 +02:00
/**
* Authorize logged in users.
*
2018-06-24 13:20:29 +02:00
* @return bool
*/
public function authorize(): bool
{
// Only allow authenticated users
return auth()->check();
}
/**
* Get all data from the request.
*
2018-06-24 13:20:29 +02:00
* @return array
*/
public function getAll(): array
{
2020-08-02 11:53:04 +02:00
$data = [
2018-12-09 08:45:53 +01:00
'budget_id' => $this->integer('budget_id'),
'start' => $this->date('start'),
'end' => $this->date('end'),
'amount' => $this->string('amount'),
'currency_id' => $this->integer('currency_id'),
'currency_code' => $this->string('currency_code'),
2018-06-24 13:20:29 +02:00
];
2020-08-02 11:53:04 +02:00
// if request has a budget already, drop the rule.
$budget = $this->route()->parameter('budget');
if (null !== $budget) {
$data['budget_id'] = $budget->id;
}
return $data;
2018-06-24 13:20:29 +02:00
}
/**
* The rules that the incoming request must be matched against.
*
2018-06-24 13:20:29 +02:00
* @return array
*/
public function rules(): array
{
$rules = [
2018-12-09 08:45:53 +01:00
'budget_id' => 'required|exists:budgets,id|belongsToUser:budgets,id',
'start' => 'required|before:end|date',
'end' => 'required|after:start|date',
2020-07-06 06:55:27 +02:00
'amount' => 'required|gt:0',
2018-12-09 08:45:53 +01:00
'currency_id' => 'numeric|exists:transaction_currencies,id',
'currency_code' => 'min:3|max:3|exists:transaction_currencies,code',
2018-06-24 13:20:29 +02:00
];
switch ($this->method()) {
default:
break;
case 'PUT':
case 'PATCH':
$rules['budget_id'] = 'required|exists:budgets,id|belongsToUser:budgets,id';
break;
}
2018-12-09 08:45:53 +01:00
// if request has a budget already, drop the rule.
$budget = $this->route()->parameter('budget');
if (null !== $budget) {
unset($rules['budget_id']);
}
2018-06-24 13:20:29 +02:00
return $rules;
}
}