| 
									
										
										
										
											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
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Requests; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 11:51:26 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											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'
 | 
					
						
							|  |  |  |             'date'                     => new Carbon($this->get('date')), | 
					
						
							|  |  |  |             'tags'                     => explode(',', $this->getFieldOrEmptyString('tags')), | 
					
						
							|  |  |  |             'currency_id'              => intval($this->get('amount_currency_id_amount')), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // all custom fields:
 | 
					
						
							|  |  |  |             'interest_date'            => $this->getDateOrNull('interest_date'), | 
					
						
							|  |  |  |             'book_date'                => $this->getDateOrNull('book_date'), | 
					
						
							|  |  |  |             'process_date'             => $this->getDateOrNull('process_date'), | 
					
						
							|  |  |  |             'due_date'                 => $this->getDateOrNull('due_date'), | 
					
						
							|  |  |  |             'payment_date'             => $this->getDateOrNull('payment_date'), | 
					
						
							|  |  |  |             'invoice_date'             => $this->getDateOrNull('invoice_date'), | 
					
						
							|  |  |  |             'internal_reference'       => trim(strval($this->get('internal_reference'))), | 
					
						
							|  |  |  |             'notes'                    => trim(strval($this->get('notes'))), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // transaction / journal data:
 | 
					
						
							|  |  |  |             'description'              => $this->getFieldOrEmptyString('description'), | 
					
						
							| 
									
										
										
										
											2016-12-30 13:45:02 +01:00
										 |  |  |             'amount'                   => round($this->get('amount'), 12), | 
					
						
							| 
									
										
										
										
											2016-10-21 19:06:22 +02:00
										 |  |  |             'budget_id'                => intval($this->get('budget_id')), | 
					
						
							|  |  |  |             'category'                 => $this->getFieldOrEmptyString('category'), | 
					
						
							|  |  |  |             'source_account_id'        => intval($this->get('source_account_id')), | 
					
						
							|  |  |  |             'source_account_name'      => $this->getFieldOrEmptyString('source_account_name'), | 
					
						
							|  |  |  |             'destination_account_id'   => $this->getFieldOrEmptyString('destination_account_id'), | 
					
						
							|  |  |  |             'destination_account_name' => $this->getFieldOrEmptyString('destination_account_name'), | 
					
						
							|  |  |  |             'piggy_bank_id'            => intval($this->get('piggy_bank_id')), | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +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', | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-25 08:32:53 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $field | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Carbon|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getDateOrNull(string $field) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->get($field) ? new Carbon($this->get($field)) : null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $field | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getFieldOrEmptyString(string $field): string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-11-24 19:20:04 +01:00
										 |  |  |         $string = $this->get($field) ?? ''; | 
					
						
							| 
									
										
										
										
											2016-12-14 18:59:12 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-24 19:15:16 +01:00
										 |  |  |         return trim($string); | 
					
						
							| 
									
										
										
										
											2016-09-25 08:32:53 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-03-29 08:14:32 +02:00
										 |  |  | } |