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

82 lines
2.3 KiB
PHP
Raw Normal View History

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