. */ declare(strict_types=1); namespace FireflyIII\Http\Requests; use FireflyIII\Models\Budget; use Illuminate\Validation\Validator; /** * @codeCoverageIgnore * Class BudgetFormUpdateRequest */ class BudgetFormUpdateRequest extends Request { /** * Verify the request. * * @return bool */ public function authorize(): bool { return auth()->check(); } /** * Returns the data required by the controller. * * @return array */ public function getBudgetData(): array { return [ 'name' => $this->string('name'), 'active' => $this->boolean('active'), 'auto_budget_type' => $this->integer('auto_budget_type'), 'transaction_currency_id' => $this->integer('auto_budget_currency_id'), 'auto_budget_amount' => $this->string('auto_budget_amount'), 'auto_budget_period' => $this->string('auto_budget_period'), ]; } /** * Rules for this request. * * @return array */ public function rules(): array { $nameRule = 'required|between:1,100|uniqueObjectForUser:budgets,name'; /** @var Budget $budget */ $budget = $this->route()->parameter('budget'); if (null !== $budget) { $nameRule = 'required|between:1,100|uniqueObjectForUser:budgets,name,' . $budget->id; } return [ 'name' => $nameRule, 'active' => 'numeric|between:0,1', 'auto_budget_option' => 'numeric|between:0,2', 'auto_budget_currency_id' => 'exists:transaction_currencies,id', '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); } ); } }