| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * JournalFormRequest.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * This software may be modified and distributed under the terms of the | 
					
						
							|  |  |  |  * Creative Commons Attribution-ShareAlike 4.0 International License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See the LICENSE file for details. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Requests; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class JournalFormRequest | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-02-04 07:28:39 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |  * @package FireflyIII\Http\Requests | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class JournalFormRequest extends Request | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function authorize() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Only allow logged in users
 | 
					
						
							| 
									
										
										
										
											2016-09-16 12:07:45 +02:00
										 |  |  |         return auth()->check(); | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |      * Returns and validates the data required to store a new journal. Can handle both single transaction journals and split journals. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getJournalData() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'what'                     => $this->get('what'), // type. can be 'deposit', 'withdrawal' or 'transfer'
 | 
					
						
							| 
									
										
										
										
											2017-01-21 08:32:23 +01:00
										 |  |  |             'date'                     => $this->date('date'), | 
					
						
							|  |  |  |             'tags'                     => explode(',', $this->string('tags')), | 
					
						
							|  |  |  |             'currency_id'              => $this->integer('amount_currency_id_amount'), | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // all custom fields:
 | 
					
						
							| 
									
										
										
										
											2017-01-21 08:32:23 +01:00
										 |  |  |             'interest_date'            => $this->date('interest_date'), | 
					
						
							|  |  |  |             'book_date'                => $this->date('book_date'), | 
					
						
							|  |  |  |             'process_date'             => $this->date('process_date'), | 
					
						
							|  |  |  |             'due_date'                 => $this->date('due_date'), | 
					
						
							|  |  |  |             'payment_date'             => $this->date('payment_date'), | 
					
						
							|  |  |  |             'invoice_date'             => $this->date('invoice_date'), | 
					
						
							|  |  |  |             'internal_reference'       => $this->string('internal_reference'), | 
					
						
							|  |  |  |             'notes'                    => $this->string('notes'), | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // transaction / journal data:
 | 
					
						
							| 
									
										
										
										
											2017-01-21 08:32:23 +01:00
										 |  |  |             'description'              => $this->string('description'), | 
					
						
							|  |  |  |             'amount'                   => $this->float('amount'), | 
					
						
							|  |  |  |             'budget_id'                => $this->integer('budget_id'), | 
					
						
							|  |  |  |             'category'                 => $this->string('category'), | 
					
						
							|  |  |  |             'source_account_id'        => $this->integer('source_account_id'), | 
					
						
							|  |  |  |             'source_account_name'      => $this->string('source_account_name'), | 
					
						
							|  |  |  |             'destination_account_id'   => $this->string('destination_account_id'), | 
					
						
							|  |  |  |             'destination_account_name' => $this->string('destination_account_name'), | 
					
						
							|  |  |  |             'piggy_bank_id'            => $this->integer('piggy_bank_id'), | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-14 22:25:48 +02:00
										 |  |  |             // native amount and stuff like that:
 | 
					
						
							| 
									
										
										
										
											2017-04-14 15:42:54 +02:00
										 |  |  |             'native_amount'            => $this->float('native_amount'), | 
					
						
							| 
									
										
										
										
											2017-04-14 22:25:48 +02:00
										 |  |  |             'source_amount'            => $this->float('source_amount'), | 
					
						
							|  |  |  |             'destination_amount'       => $this->float('destination_amount'), | 
					
						
							| 
									
										
										
										
											2017-04-14 11:19:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $data; | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function rules() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-10-23 12:19:32 +02:00
										 |  |  |         $what  = $this->get('what'); | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         $rules = [ | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |             'what'                     => 'required|in:withdrawal,deposit,transfer', | 
					
						
							|  |  |  |             'date'                     => 'required|date', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // then, custom fields:
 | 
					
						
							|  |  |  |             'interest_date'            => 'date', | 
					
						
							|  |  |  |             'book_date'                => 'date', | 
					
						
							|  |  |  |             'process_date'             => 'date', | 
					
						
							|  |  |  |             'due_date'                 => 'date', | 
					
						
							|  |  |  |             'payment_date'             => 'date', | 
					
						
							|  |  |  |             'invoice_date'             => 'date', | 
					
						
							|  |  |  |             'internal_reference'       => 'min:1,max:255', | 
					
						
							|  |  |  |             'notes'                    => 'min:1,max:50000', | 
					
						
							|  |  |  |             // and then transaction rules:
 | 
					
						
							|  |  |  |             'description'              => 'required|between:1,255', | 
					
						
							| 
									
										
										
										
											2017-01-04 17:25:28 +01:00
										 |  |  |             'amount'                   => 'numeric|required|more:0', | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |             'budget_id'                => 'mustExist:budgets,id|belongsToUser:budgets,id', | 
					
						
							|  |  |  |             'category'                 => 'between:1,255', | 
					
						
							|  |  |  |             'source_account_id'        => 'numeric|belongsToUser:accounts,id', | 
					
						
							|  |  |  |             'source_account_name'      => 'between:1,255', | 
					
						
							|  |  |  |             'destination_account_id'   => 'numeric|belongsToUser:accounts,id', | 
					
						
							|  |  |  |             'destination_account_name' => 'between:1,255', | 
					
						
							|  |  |  |             'piggy_bank_id'            => 'between:1,255', | 
					
						
							| 
									
										
										
										
											2017-04-14 14:37:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-14 22:25:48 +02:00
										 |  |  |             // foreign currency amounts
 | 
					
						
							|  |  |  |             'native_amount'            => 'numeric|more:0', | 
					
						
							|  |  |  |             'source_amount'            => 'numeric|more:0', | 
					
						
							|  |  |  |             'destination_amount'       => 'numeric|more:0', | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |         // some rules get an upgrade depending on the type of data:
 | 
					
						
							|  |  |  |         $rules = $this->enhanceRules($what, $rules); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $rules; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Inspired by https://www.youtube.com/watch?v=WwnI0RS6J5A | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $what | 
					
						
							|  |  |  |      * @param array  $rules | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function enhanceRules(string $what, array $rules): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         switch ($what) { | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |             case strtolower(TransactionType::WITHDRAWAL): | 
					
						
							| 
									
										
										
										
											2016-04-29 17:29:13 +02:00
										 |  |  |                 $rules['source_account_id']        = 'required|exists:accounts,id|belongsToUser:accounts'; | 
					
						
							|  |  |  |                 $rules['destination_account_name'] = 'between:1,255'; | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |             case strtolower(TransactionType::DEPOSIT): | 
					
						
							| 
									
										
										
										
											2016-04-29 17:29:13 +02:00
										 |  |  |                 $rules['source_account_name']    = 'between:1,255'; | 
					
						
							|  |  |  |                 $rules['destination_account_id'] = 'required|exists:accounts,id|belongsToUser:accounts'; | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |             case strtolower(TransactionType::TRANSFER): | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |                 // this may not work:
 | 
					
						
							| 
									
										
										
										
											2016-04-29 17:29:13 +02:00
										 |  |  |                 $rules['source_account_id']      = 'required|exists:accounts,id|belongsToUser:accounts|different:destination_account_id'; | 
					
						
							|  |  |  |                 $rules['destination_account_id'] = 'required|exists:accounts,id|belongsToUser:accounts|different:source_account_id'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |                 break; | 
					
						
							|  |  |  |             default: | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |                 throw new FireflyException('Cannot handle transaction type of type ' . e($what) . ' . '); | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $rules; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-03-29 08:14:32 +02:00
										 |  |  | } |