| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2021-03-06 16:15:39 +01:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2019-04-12 04:53:18 +02:00
										 |  |  |  * RecurrenceStoreRequest.php | 
					
						
							| 
									
										
										
										
											2021-03-06 16:15:39 +01:00
										 |  |  |  * Copyright (c) 2021 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +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-29 19:27:07 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +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-29 19:27:07 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-06 16:15:39 +01:00
										 |  |  | namespace FireflyIII\Api\V1\Requests\Models\Recurrence; | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  | use FireflyIII\Rules\BelongsUser; | 
					
						
							|  |  |  | use FireflyIII\Rules\IsBoolean; | 
					
						
							| 
									
										
										
										
											2020-11-08 13:36:13 +01:00
										 |  |  | use FireflyIII\Support\Request\ChecksLogin; | 
					
						
							| 
									
										
										
										
											2020-07-18 08:34:00 +02:00
										 |  |  | use FireflyIII\Support\Request\ConvertsDataTypes; | 
					
						
							| 
									
										
										
										
											2020-07-18 08:25:25 +02:00
										 |  |  | use FireflyIII\Support\Request\GetRecurrenceData; | 
					
						
							| 
									
										
										
										
											2020-03-21 06:00:36 +01:00
										 |  |  | use FireflyIII\Validation\CurrencyValidation; | 
					
						
							| 
									
										
										
										
											2018-07-05 18:02:02 +02:00
										 |  |  | use FireflyIII\Validation\RecurrenceValidation; | 
					
						
							|  |  |  | use FireflyIII\Validation\TransactionValidation; | 
					
						
							| 
									
										
										
										
											2020-07-18 08:25:25 +02:00
										 |  |  | use Illuminate\Foundation\Http\FormRequest; | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  | use Illuminate\Validation\Validator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2021-03-06 16:15:39 +01:00
										 |  |  |  * Class StoreRequest | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2021-03-06 16:15:39 +01:00
										 |  |  | class StoreRequest extends FormRequest | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-11-08 13:36:13 +01:00
										 |  |  |     use ConvertsDataTypes, RecurrenceValidation, TransactionValidation, CurrencyValidation, GetRecurrenceData, ChecksLogin; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-26 18:44:04 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get all data from the request. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAll(): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |         $fields     = [ | 
					
						
							|  |  |  |             'type'              => ['type', 'string'], | 
					
						
							|  |  |  |             'title'             => ['title', 'string'], | 
					
						
							|  |  |  |             'description'       => ['description', 'string'], | 
					
						
							|  |  |  |             'first_date'        => ['first_date', 'date'], | 
					
						
							|  |  |  |             'repeat_until'      => ['repeat_until', 'date'], | 
					
						
							|  |  |  |             'nr_of_repetitions' => ['nr_of_repetitions', 'integer'], | 
					
						
							|  |  |  |             'apply_rules'       => ['apply_rules', 'boolean'], | 
					
						
							|  |  |  |             'active'            => ['active', 'boolean'], | 
					
						
							| 
									
										
										
										
											2021-04-06 13:30:09 +02:00
										 |  |  |             'notes'             => ['notes', 'stringWithNewlines'], | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         $recurrence = $this->getAllData($fields); | 
					
						
							| 
									
										
										
										
											2020-03-15 08:16:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return [ | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |             'recurrence'   => $recurrence, | 
					
						
							| 
									
										
										
										
											2019-08-26 19:09:55 +02:00
										 |  |  |             'transactions' => $this->getTransactionData(), | 
					
						
							|  |  |  |             'repetitions'  => $this->getRepetitionData(), | 
					
						
							| 
									
										
										
										
											2019-08-26 18:44:04 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-18 08:00:49 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns the transaction data as it is found in the submitted data. It's a complex method according to code | 
					
						
							|  |  |  |      * standards but it just has a lot of ??-statements because of the fields that may or may not exist. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getTransactionData(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $return = []; | 
					
						
							|  |  |  |         // transaction data:
 | 
					
						
							| 
									
										
										
										
											2021-04-06 08:51:27 +02:00
										 |  |  |         /** @var array|null $transactions */ | 
					
						
							| 
									
										
										
										
											2020-10-18 08:00:49 +02:00
										 |  |  |         $transactions = $this->get('transactions'); | 
					
						
							|  |  |  |         if (null === $transactions) { | 
					
						
							|  |  |  |             return []; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /** @var array $transaction */ | 
					
						
							|  |  |  |         foreach ($transactions as $transaction) { | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |             $return[] = $this->getSingleTransactionData($transaction); | 
					
						
							| 
									
										
										
										
											2020-10-18 08:00:49 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Returns the repetition data as it is found in the submitted data. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getRepetitionData(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $return = []; | 
					
						
							|  |  |  |         // repetition data:
 | 
					
						
							| 
									
										
										
										
											2021-04-06 08:51:27 +02:00
										 |  |  |         /** @var array|null $repetitions */ | 
					
						
							| 
									
										
										
										
											2020-10-18 08:00:49 +02:00
										 |  |  |         $repetitions = $this->get('repetitions'); | 
					
						
							|  |  |  |         if (null === $repetitions) { | 
					
						
							|  |  |  |             return []; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /** @var array $repetition */ | 
					
						
							|  |  |  |         foreach ($repetitions as $repetition) { | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |             $current = []; | 
					
						
							|  |  |  |             if (array_key_exists('type', $repetition)) { | 
					
						
							|  |  |  |                 $current['type'] = $repetition['type']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (array_key_exists('moment', $repetition)) { | 
					
						
							|  |  |  |                 $current['moment'] = $repetition['moment']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (array_key_exists('skip', $repetition)) { | 
					
						
							|  |  |  |                 $current['skip'] = (int)$repetition['skip']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (array_key_exists('weekend', $repetition)) { | 
					
						
							|  |  |  |                 $current['weekend'] = (int)$repetition['weekend']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $return[] = $current; | 
					
						
							| 
									
										
										
										
											2020-10-18 08:00:49 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-06 07:15:42 +02:00
										 |  |  |      * The rules that the incoming request must be matched against. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function rules(): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |         return [ | 
					
						
							|  |  |  |             'type'                                 => 'required|in:withdrawal,transfer,deposit', | 
					
						
							|  |  |  |             'title'                                => 'required|between:1,255|uniqueObjectForUser:recurrences,title', | 
					
						
							|  |  |  |             'description'                          => 'between:1,65000', | 
					
						
							| 
									
										
										
										
											2019-08-27 05:55:46 +02:00
										 |  |  |             'first_date'                           => 'required|date', | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |             'apply_rules'                          => [new IsBoolean], | 
					
						
							|  |  |  |             'active'                               => [new IsBoolean], | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |             'repeat_until'                         => 'date', | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |             'nr_of_repetitions'                    => 'numeric|between:1,31', | 
					
						
							|  |  |  |             'repetitions.*.type'                   => 'required|in:daily,weekly,ndom,monthly,yearly', | 
					
						
							|  |  |  |             'repetitions.*.moment'                 => 'between:0,10', | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |             'repetitions.*.skip'                   => 'numeric|between:0,31', | 
					
						
							|  |  |  |             'repetitions.*.weekend'                => 'numeric|min:1|max:4', | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |             'transactions.*.description'           => 'required|between:1,255', | 
					
						
							| 
									
										
										
										
											2020-07-06 06:55:27 +02:00
										 |  |  |             'transactions.*.amount'                => 'required|numeric|gt:0', | 
					
						
							|  |  |  |             'transactions.*.foreign_amount'        => 'numeric|gt:0', | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |             'transactions.*.currency_id'           => 'numeric|exists:transaction_currencies,id', | 
					
						
							|  |  |  |             'transactions.*.currency_code'         => 'min:3|max:3|exists:transaction_currencies,code', | 
					
						
							|  |  |  |             'transactions.*.foreign_currency_id'   => 'numeric|exists:transaction_currencies,id', | 
					
						
							|  |  |  |             'transactions.*.foreign_currency_code' => 'min:3|max:3|exists:transaction_currencies,code', | 
					
						
							|  |  |  |             'transactions.*.source_id'             => ['numeric', 'nullable', new BelongsUser], | 
					
						
							|  |  |  |             'transactions.*.source_name'           => 'between:1,255|nullable', | 
					
						
							|  |  |  |             'transactions.*.destination_id'        => ['numeric', 'nullable', new BelongsUser], | 
					
						
							|  |  |  |             'transactions.*.destination_name'      => 'between:1,255|nullable', | 
					
						
							| 
									
										
										
										
											2019-08-26 18:15:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // new and updated fields:
 | 
					
						
							|  |  |  |             'transactions.*.budget_id'             => ['mustExist:budgets,id', new BelongsUser], | 
					
						
							| 
									
										
										
										
											2019-08-26 18:44:04 +02:00
										 |  |  |             'transactions.*.budget_name'           => ['between:1,255', 'nullable', new BelongsUser], | 
					
						
							| 
									
										
										
										
											2019-08-26 18:15:21 +02:00
										 |  |  |             'transactions.*.category_id'           => ['mustExist:categories,id', new BelongsUser], | 
					
						
							|  |  |  |             'transactions.*.category_name'         => 'between:1,255|nullable', | 
					
						
							|  |  |  |             'transactions.*.piggy_bank_id'         => ['numeric', 'mustExist:piggy_banks,id', new BelongsUser], | 
					
						
							| 
									
										
										
										
											2019-08-26 19:09:55 +02:00
										 |  |  |             'transactions.*.piggy_bank_name'       => ['between:1,255', 'nullable', new BelongsUser], | 
					
						
							|  |  |  |             'transactions.*.tags'                  => 'between:1,64000', | 
					
						
							| 
									
										
										
										
											2019-08-22 17:56:48 +02:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Configure the validator instance. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @param Validator $validator | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withValidator(Validator $validator): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $validator->after( | 
					
						
							|  |  |  |             function (Validator $validator) { | 
					
						
							| 
									
										
										
										
											2021-03-14 16:08:49 +01:00
										 |  |  |                 $this->validateRecurringConfig($validator); | 
					
						
							| 
									
										
										
										
											2019-06-09 08:26:23 +02:00
										 |  |  |                 $this->validateOneRecurrenceTransaction($validator); | 
					
						
							| 
									
										
										
										
											2018-07-05 18:02:02 +02:00
										 |  |  |                 $this->validateOneRepetition($validator); | 
					
						
							|  |  |  |                 $this->validateRecurrenceRepetition($validator); | 
					
						
							|  |  |  |                 $this->validateRepetitionMoment($validator); | 
					
						
							|  |  |  |                 $this->validateForeignCurrencyInformation($validator); | 
					
						
							| 
									
										
										
										
											2018-06-29 19:27:07 +02:00
										 |  |  |                 $this->validateAccountInformation($validator); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-07-22 20:32:02 +02:00
										 |  |  | } |