| 
									
										
										
										
											2016-05-20 12:42:21 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * FireflyValidator.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This software may be modified and distributed under the terms | 
					
						
							|  |  |  |  * of the MIT license.  See the LICENSE file for details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2015-02-08 01:15:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Validation; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | use Auth; | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  | use Config; | 
					
						
							| 
									
										
										
										
											2015-03-30 20:16:33 +02:00
										 |  |  | use Crypt; | 
					
						
							| 
									
										
										
										
											2015-02-08 01:15:15 +01:00
										 |  |  | use DB; | 
					
						
							| 
									
										
										
										
											2015-03-30 20:08:27 +02:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:40:16 +01:00
										 |  |  | use FireflyIII\Models\AccountMeta; | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  | use FireflyIII\Models\AccountType; | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  | use FireflyIII\Models\Budget; | 
					
						
							| 
									
										
										
										
											2015-06-27 08:06:24 +02:00
										 |  |  | use FireflyIII\Models\PiggyBank; | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-02-17 18:06:49 +01:00
										 |  |  | use FireflyIII\Rules\Triggers\TriggerInterface; | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  | use FireflyIII\User; | 
					
						
							| 
									
										
										
										
											2016-03-20 16:49:49 +01:00
										 |  |  | use Google2FA; | 
					
						
							| 
									
										
										
										
											2015-06-05 12:34:45 +02:00
										 |  |  | use Illuminate\Contracts\Encryption\DecryptException; | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  | use Illuminate\Validation\Validator; | 
					
						
							| 
									
										
										
										
											2016-03-19 07:56:57 +01:00
										 |  |  | use Session; | 
					
						
							| 
									
										
										
										
											2015-05-01 18:44:49 +02:00
										 |  |  | use Symfony\Component\Translation\TranslatorInterface; | 
					
						
							| 
									
										
										
										
											2015-02-08 01:15:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class FireflyValidator | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Validation | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-02-08 01:15:15 +01:00
										 |  |  | class FireflyValidator extends Validator | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-01 18:44:49 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TranslatorInterface $translator | 
					
						
							|  |  |  |      * @param array               $data | 
					
						
							|  |  |  |      * @param array               $rules | 
					
						
							|  |  |  |      * @param array               $messages | 
					
						
							|  |  |  |      * @param array               $customAttributes | 
					
						
							| 
									
										
										
										
											2016-01-15 18:21:59 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-05-01 18:44:49 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct(TranslatorInterface $translator, array $data, array $rules, array $messages = [], array $customAttributes = []) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-05-17 10:10:58 +02:00
										 |  |  |         parent::__construct($translator, $data, $rules, $messages, $customAttributes); | 
					
						
							| 
									
										
										
										
											2015-05-01 18:44:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 20:45:27 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							| 
									
										
										
										
											2016-08-26 09:30:52 +02:00
										 |  |  |      * @internal param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-03-03 20:45:27 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-03-29 16:13:36 +02:00
										 |  |  |     public function validate2faCode($attribute, $value): bool | 
					
						
							| 
									
										
										
										
											2016-03-03 20:45:27 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (!is_string($value) || is_null($value) || strlen($value) <> 6) { | 
					
						
							|  |  |  |             return false; | 
					
						
							| 
									
										
										
										
											2016-03-14 20:53:56 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-03 20:45:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 16:16:14 +02:00
										 |  |  |         $secret = Session::get('two-factor-secret'); | 
					
						
							| 
									
										
										
										
											2016-03-14 20:53:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 21:58:57 +02:00
										 |  |  |         return Google2FA::verifyKey($secret, $value); | 
					
						
							| 
									
										
										
										
											2016-03-03 20:45:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateBelongsToUser($attribute, $value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |         $field = $parameters[1] ?? 'id'; | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-05 18:59:46 +02:00
										 |  |  |         if (intval($value) === 0) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-04 17:16:16 +01:00
										 |  |  |         $count = DB::table($parameters[0])->where('user_id', Auth::user()->id)->where($field, $value)->count(); | 
					
						
							| 
									
										
										
										
											2016-04-23 09:33:54 +02:00
										 |  |  |         if ($count === 1) { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateIban($attribute, $value): bool | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (!is_string($value) || is_null($value) || strlen($value) < 6) { | 
					
						
							|  |  |  |             return false; | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $value = strtoupper($value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $search  = [' ', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']; | 
					
						
							|  |  |  |         $replace = ['', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', | 
					
						
							|  |  |  |                     '32', '33', '34', '35']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // take
 | 
					
						
							|  |  |  |         $first    = substr($value, 0, 4); | 
					
						
							|  |  |  |         $last     = substr($value, 4); | 
					
						
							|  |  |  |         $iban     = $last . $first; | 
					
						
							|  |  |  |         $iban     = str_replace($search, $replace, $iban); | 
					
						
							|  |  |  |         $checksum = bcmod($iban, '97'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return (intval($checksum) === 1); | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateRuleActionValue($attribute): bool | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  |         // get the index from a string like "rule-action-value.2".
 | 
					
						
							|  |  |  |         $parts = explode('.', $attribute); | 
					
						
							|  |  |  |         $index = $parts[count($parts) - 1]; | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |         // loop all rule-actions.
 | 
					
						
							|  |  |  |         // check if rule-action-value matches the thing.
 | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |         if (is_array($this->data['rule-action'])) { | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |             $name  = $this->data['rule-action'][$index] ?? 'invalid'; | 
					
						
							|  |  |  |             $value = $this->data['rule-action-value'][$index] ?? false; | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  |             switch ($name) { | 
					
						
							|  |  |  |                 default: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     return true; | 
					
						
							|  |  |  |                 case 'set_budget': | 
					
						
							|  |  |  |                     /** @var BudgetRepositoryInterface $repository */ | 
					
						
							| 
									
										
										
										
											2016-05-02 20:49:19 +02:00
										 |  |  |                     $repository = app(BudgetRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2016-01-15 09:25:32 +01:00
										 |  |  |                     $budgets    = $repository->getBudgets(); | 
					
						
							|  |  |  |                     // count budgets, should have at least one
 | 
					
						
							|  |  |  |                     $count = $budgets->filter( | 
					
						
							|  |  |  |                         function (Budget $budget) use ($value) { | 
					
						
							|  |  |  |                             return $budget->name == $value; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     )->count(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     return ($count === 1); | 
					
						
							|  |  |  |                 case 'invalid': | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 21:34:17 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							| 
									
										
										
										
											2016-01-02 16:31:14 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateRuleTriggerValue($attribute): bool | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         // get the index from a string like "rule-trigger-value.2".
 | 
					
						
							|  |  |  |         $parts = explode('.', $attribute); | 
					
						
							|  |  |  |         $index = $parts[count($parts) - 1]; | 
					
						
							| 
									
										
										
										
											2015-03-30 20:08:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         // loop all rule-triggers.
 | 
					
						
							|  |  |  |         // check if rule-value matches the thing.
 | 
					
						
							|  |  |  |         if (is_array($this->data['rule-trigger'])) { | 
					
						
							|  |  |  |             $name  = $this->getRuleTriggerName($index); | 
					
						
							|  |  |  |             $value = $this->getRuleTriggerValue($index); | 
					
						
							| 
									
										
										
										
											2016-02-17 18:06:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // break on some easy checks:
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |             switch ($name) { | 
					
						
							|  |  |  |                 case 'amount_less': | 
					
						
							| 
									
										
										
										
											2016-02-17 18:06:49 +01:00
										 |  |  |                     $result = is_numeric($value); | 
					
						
							|  |  |  |                     if ($result === false) { | 
					
						
							|  |  |  |                         return false; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     break; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |                 case 'transaction_type': | 
					
						
							|  |  |  |                     $count = TransactionType::where('type', $value)->count(); | 
					
						
							| 
									
										
										
										
											2016-02-17 18:06:49 +01:00
										 |  |  |                     if (!($count === 1)) { | 
					
						
							|  |  |  |                         return false; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     break; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |                 case 'invalid': | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-02-17 18:06:49 +01:00
										 |  |  |             // still a special case where the trigger is
 | 
					
						
							|  |  |  |             // triggered in such a way that it would trigger ANYTHING. We can check for such things
 | 
					
						
							|  |  |  |             // with function willmatcheverything
 | 
					
						
							|  |  |  |             // we know which class it is so dont bother checking that.
 | 
					
						
							|  |  |  |             $classes = Config::get('firefly.rule-triggers'); | 
					
						
							|  |  |  |             /** @var TriggerInterface $class */ | 
					
						
							|  |  |  |             $class = $classes[$name]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return !($class::willMatchEverything($value)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-07 01:07:19 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-29 07:35:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							| 
									
										
										
										
											2015-07-03 12:51:14 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * @param $value | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-02 16:31:14 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateUniqueAccountForUser($attribute, $value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |         // because a user does not have to be logged in (tests and what-not).
 | 
					
						
							| 
									
										
										
										
											2016-09-16 12:07:45 +02:00
										 |  |  |         if (!auth()->check()) { | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |             return $this->validateAccountAnonymously(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (isset($this->data['what'])) { | 
					
						
							|  |  |  |             return $this->validateByAccountTypeString($value, $parameters); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (isset($this->data['account_type_id'])) { | 
					
						
							|  |  |  |             return $this->validateByAccountTypeId($value, $parameters); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-06-29 07:22:51 +02:00
										 |  |  |         if (isset($this->data['id'])) { | 
					
						
							|  |  |  |             return $this->validateByAccountId($value); | 
					
						
							| 
									
										
										
										
											2015-06-28 21:13:08 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-27 09:24:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:34:45 +02:00
										 |  |  |         return false; | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-03-30 20:16:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-12 17:34:42 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-11 06:40:16 +01:00
										 |  |  |     public function validateUniqueAccountNumberForUser($attribute, $value, $parameters): bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $accountId = $this->data['id'] ?? 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $query = AccountMeta:: | 
					
						
							|  |  |  |         leftJoin('accounts', 'accounts.id', '=', 'account_meta.account_id') | 
					
						
							|  |  |  |                             ->where('accounts.user_id', Auth::user()->id) | 
					
						
							|  |  |  |                             ->where('account_meta.name', 'accountNumber'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (intval($accountId) > 0) { | 
					
						
							|  |  |  |             // exclude current account from check.
 | 
					
						
							|  |  |  |             $query->where('account_meta.account_id', '!=', intval($accountId)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $set = $query->get(['account_meta.*']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var AccountMeta $entry */ | 
					
						
							|  |  |  |         foreach ($set as $entry) { | 
					
						
							|  |  |  |             if ($entry->data == $value) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * @param $attribute | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateUniqueForUser($attribute, $value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $query = DB::table($parameters[0])->where($parameters[1], $value); | 
					
						
							|  |  |  |         $query->where('user_id', Auth::user()->id); | 
					
						
							|  |  |  |         if (isset($parameters[2])) { | 
					
						
							|  |  |  |             $query->where('id', '!=', $parameters[2]); | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $count = $query->count(); | 
					
						
							|  |  |  |         if ($count == 0) { | 
					
						
							|  |  |  |             return true; | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         return false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * Validate an object and its unicity. Checks for encryption / encrypted values as well. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * parameter 0: the table | 
					
						
							|  |  |  |      * parameter 1: the field | 
					
						
							|  |  |  |      * parameter 2: an id to ignore (when editing) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param $attribute | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |      * @param $value | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * @param $parameters | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateUniqueObjectForUser($attribute, $value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $value = $this->tryDecrypt($value); | 
					
						
							|  |  |  |         // exclude?
 | 
					
						
							|  |  |  |         $table   = $parameters[0]; | 
					
						
							|  |  |  |         $field   = $parameters[1]; | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |         $exclude = $parameters[2] ?? 0; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // get entries from table
 | 
					
						
							|  |  |  |         $set = DB::table($table)->where('user_id', Auth::user()->id) | 
					
						
							|  |  |  |                  ->where('id', '!=', $exclude)->get([$field]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($set as $entry) { | 
					
						
							|  |  |  |             $fieldValue = $this->tryDecrypt($entry->$field); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($fieldValue === $value) { | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2015-06-05 12:48:58 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * @param $attribute | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     public function validateUniquePiggyBankForUser($attribute, $value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |         $exclude = $parameters[0] ?? null; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $query   = DB::table('piggy_banks')->whereNull('piggy_banks.deleted_at') | 
					
						
							|  |  |  |                      ->leftJoin('accounts', 'accounts.id', '=', 'piggy_banks.account_id')->where('accounts.user_id', Auth::user()->id); | 
					
						
							|  |  |  |         if (!is_null($exclude)) { | 
					
						
							|  |  |  |             $query->where('piggy_banks.id', '!=', $exclude); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $set = $query->get(['piggy_banks.*']); | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         /** @var PiggyBank $entry */ | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |         foreach ($set as $entry) { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |             $fieldValue = $this->tryDecrypt($entry->name); | 
					
						
							|  |  |  |             if ($fieldValue == $value) { | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param int $index | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getRuleTriggerName($index): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->data['rule-trigger'][$index] ?? 'invalid'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param int $index | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getRuleTriggerValue($index): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->data['rule-trigger-value'][$index] ?? ''; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     private function tryDecrypt($value) | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             $value = Crypt::decrypt($value); | 
					
						
							|  |  |  |         } catch (DecryptException $e) { | 
					
						
							|  |  |  |             // do not care.
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $value; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     private function validateAccountAnonymously(): bool | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         if (!isset($this->data['user_id'])) { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-06-05 12:18:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $user  = User::find($this->data['user_id']); | 
					
						
							|  |  |  |         $type  = AccountType::find($this->data['account_type_id'])->first(); | 
					
						
							|  |  |  |         $value = $this->tryDecrypt($this->data['name']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $set = $user->accounts()->where('account_type_id', $type->id)->get(); | 
					
						
							| 
									
										
										
										
											2015-03-30 20:08:27 +02:00
										 |  |  |         /** @var Account $entry */ | 
					
						
							|  |  |  |         foreach ($set as $entry) { | 
					
						
							|  |  |  |             if ($entry->name == $value) { | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-30 20:08:27 +02:00
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2015-03-26 18:05:23 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-28 21:13:08 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							| 
									
										
										
										
											2015-07-06 22:23:34 +02:00
										 |  |  |      * @internal param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-06-28 21:13:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     private function validateByAccountId($value): bool | 
					
						
							| 
									
										
										
										
											2015-06-28 21:13:08 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |         /** @var Account $existingAccount */ | 
					
						
							|  |  |  |         $existingAccount = Account::find($this->data['id']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $type   = $existingAccount->accountType; | 
					
						
							|  |  |  |         $ignore = $existingAccount->id; | 
					
						
							|  |  |  |         $value  = $this->tryDecrypt($value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $set = Auth::user()->accounts()->where('account_type_id', $type->id)->where('id', '!=', $ignore)->get(); | 
					
						
							|  |  |  |         /** @var Account $entry */ | 
					
						
							|  |  |  |         foreach ($set as $entry) { | 
					
						
							|  |  |  |             if ($entry->name == $value) { | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     private function validateByAccountTypeId($value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $type   = AccountType::find($this->data['account_type_id'])->first(); | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |         $ignore = $parameters[0] ?? 0; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $value  = $this->tryDecrypt($value); | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $set = Auth::user()->accounts()->where('account_type_id', $type->id)->where('id', '!=', $ignore)->get(); | 
					
						
							|  |  |  |         /** @var Account $entry */ | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |         foreach ($set as $entry) { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |             if ($entry->name == $value) { | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-27 20:20:52 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * @param $parameters | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 10:11:06 +01:00
										 |  |  |     private function validateByAccountTypeString($value, $parameters): bool | 
					
						
							| 
									
										
										
										
											2015-03-27 20:20:52 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $search = Config::get('firefly.accountTypeByIdentifier.' . $this->data['what']); | 
					
						
							|  |  |  |         $type   = AccountType::whereType($search)->first(); | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |         $ignore = $parameters[0] ?? 0; | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |         $set = Auth::user()->accounts()->where('account_type_id', $type->id)->where('id', '!=', $ignore)->get(); | 
					
						
							|  |  |  |         /** @var Account $entry */ | 
					
						
							| 
									
										
										
										
											2015-04-07 18:26:14 +02:00
										 |  |  |         foreach ($set as $entry) { | 
					
						
							| 
									
										
										
										
											2016-01-20 15:23:36 +01:00
										 |  |  |             if ($entry->name == $value) { | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-03-27 20:20:52 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-31 14:16:25 +02:00
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2015-03-27 20:20:52 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-02-08 01:15:15 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 |