. */ declare(strict_types=1); namespace FireflyIII\Api\V1\Requests\Models\Budget; use FireflyIII\Rules\IsBoolean; use FireflyIII\Support\Request\ChecksLogin; use FireflyIII\Support\Request\ConvertsDataTypes; use FireflyIII\Validation\AutoBudget\ValidatesAutoBudgetRequest; use Illuminate\Foundation\Http\FormRequest; use Illuminate\Validation\Validator; /** * Class UpdateRequest * * @codeCoverageIgnore */ class UpdateRequest extends FormRequest { use ConvertsDataTypes, ValidatesAutoBudgetRequest, ChecksLogin; /** * Get all data from the request. * * @return array */ public function getAll(): array { // this is the way: $fields = [ 'name' => ['name', 'string'], 'active' => ['active', 'boolean'], 'order' => ['order', 'integer'], 'currency_id' => ['auto_budget_currency_id', 'integer'], 'currency_code' => ['auto_budget_currency_code', 'string'], 'auto_budget_type' => ['auto_budget_type', 'string'], 'auto_budget_amount' => ['auto_budget_amount', 'string'], 'auto_budget_period' => ['auto_budget_period', 'string'], ]; return $this->getAllData($fields); } /** * The rules that the incoming request must be matched against. * * @return array */ public function rules(): array { $budget = $this->route()->parameter('budget'); return [ 'name' => sprintf('between:1,100|uniqueObjectForUser:budgets,name,%d', $budget->id), 'active' => [new IsBoolean], 'auto_budget_type' => 'in:reset,rollover,none', 'auto_budget_currency_id' => 'exists:transaction_currencies,id', 'auto_budget_currency_code' => 'exists:transaction_currencies,code', 'auto_budget_amount' => 'min:0|max:1000000000', 'auto_budget_period' => 'in:daily,weekly,monthly,quarterly,half_year,yearly', ]; } /** * 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 all account info $this->validateAutoBudgetAmount($validator); } ); } }