Files
firefly-iii/app/Http/Requests/RuleGroupFormRequest.php

80 lines
2.3 KiB
PHP
Raw Normal View History

2016-01-13 18:34:56 +01:00
<?php
/**
* RuleGroupFormRequest.php
2020-01-31 07:32:04 +01:00
* Copyright (c) 2019 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* 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.
2017-10-21 08:40:00 +02:00
*
* This program is distributed in the hope that it will be useful,
2017-10-21 08:40:00 +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.
2017-10-21 08:40:00 +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/>.
*/
declare(strict_types=1);
2016-01-13 18:34:56 +01:00
namespace FireflyIII\Http\Requests;
2018-08-07 19:24:07 +02:00
use FireflyIII\Models\RuleGroup;
2018-12-21 09:01:21 +01:00
use FireflyIII\Rules\IsBoolean;
2020-10-24 07:55:09 +02:00
use FireflyIII\Support\Request\ChecksLogin;
2020-07-18 08:42:13 +02:00
use FireflyIII\Support\Request\ConvertsDataTypes;
2020-10-24 07:55:09 +02:00
use Illuminate\Foundation\Http\FormRequest;
2016-01-13 18:34:56 +01:00
/**
2017-11-15 12:25:49 +01:00
* Class RuleGroupFormRequest.
2016-01-13 18:34:56 +01:00
*/
2020-10-24 07:55:09 +02:00
class RuleGroupFormRequest extends FormRequest
2016-01-13 18:34:56 +01:00
{
2020-10-24 07:55:09 +02:00
use ConvertsDataTypes, ChecksLogin;
2016-01-13 18:34:56 +01:00
/**
2018-07-22 08:10:16 +02:00
* Get all data for controller.
*
2016-01-13 18:34:56 +01:00
* @return array
*/
2016-10-23 12:10:22 +02:00
public function getRuleGroupData(): array
2016-01-13 18:34:56 +01:00
{
2018-12-21 09:01:21 +01:00
$active = true;
if (null !== $this->get('active')) {
$active = $this->boolean('active');
}
2016-10-23 12:10:22 +02:00
return [
2022-05-02 19:35:35 +02:00
'title' => $this->convertString('title'),
2021-04-06 13:30:09 +02:00
'description' => $this->stringWithNewlines('description'),
2018-12-21 09:01:21 +01:00
'active' => $active,
2016-10-23 12:10:22 +02:00
];
}
2016-01-13 18:34:56 +01:00
2016-10-23 12:10:22 +02:00
/**
2018-07-22 08:10:16 +02:00
* Rules for this request.
*
2016-10-23 12:10:22 +02:00
* @return array
*/
2018-07-08 12:28:42 +02:00
public function rules(): array
2016-10-23 12:10:22 +02:00
{
2018-08-10 17:05:37 +02:00
$titleRule = 'required|between:1,100|uniqueObjectForUser:rule_groups,title';
2018-08-07 19:24:07 +02:00
/** @var RuleGroup $ruleGroup */
$ruleGroup = $this->route()->parameter('ruleGroup');
if (null !== $ruleGroup) {
$titleRule = 'required|between:1,100|uniqueObjectForUser:rule_groups,title,' . $ruleGroup->id;
2016-01-13 18:34:56 +01:00
}
return [
2016-01-15 23:12:52 +01:00
'title' => $titleRule,
2017-09-12 19:47:29 +02:00
'description' => 'between:1,5000|nullable',
2018-12-21 09:01:21 +01:00
'active' => [new IsBoolean],
2016-01-13 18:34:56 +01:00
];
}
}