| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * FromAccountEnds.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 Sander Dorigo | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This software may be modified and distributed under the terms | 
					
						
							|  |  |  |  * of the MIT license.  See the LICENSE file for details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Rules\Triggers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							|  |  |  | use Log; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class FromAccountEnds | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Rules\Triggers | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-02-17 20:09:03 +01:00
										 |  |  | class FromAccountEnds extends AbstractTrigger implements TriggerInterface | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-02-17 19:07:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * A trigger is said to "match anything", or match any given transaction, | 
					
						
							|  |  |  |      * when the trigger value is very vague or has no restrictions. Easy examples | 
					
						
							|  |  |  |      * are the "AmountMore"-trigger combined with an amount of 0: any given transaction | 
					
						
							|  |  |  |      * has an amount of more than zero! Other examples are all the "Description"-triggers | 
					
						
							|  |  |  |      * which have hard time handling empty trigger values such as "" or "*" (wild cards). | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * If the user tries to create such a trigger, this method MUST return true so Firefly III | 
					
						
							|  |  |  |      * can stop the storing / updating the trigger. If the trigger is in any way restrictive | 
					
						
							|  |  |  |      * (even if it will still include 99.9% of the users transactions), this method MUST return | 
					
						
							|  |  |  |      * false. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param null $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function willMatchEverything($value = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!is_null($value)) { | 
					
						
							|  |  |  |             return strval($value) === ""; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-17 19:07:20 +01:00
										 |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-17 19:07:20 +01:00
										 |  |  |     public function triggered(TransactionJournal $journal) | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-17 19:07:20 +01:00
										 |  |  |         $name         = strtolower($journal->source_account->name); | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         $nameLength   = strlen($name); | 
					
						
							| 
									
										
										
										
											2016-02-17 20:19:44 +01:00
										 |  |  |         $search       = strtolower($this->triggerValue); | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         $searchLength = strlen($search); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // if the string to search for is longer than the account name,
 | 
					
						
							|  |  |  |         // shorten the search string.
 | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         if ($searchLength > $nameLength) { | 
					
						
							|  |  |  |             Log::debug('Search string "' . $search . '" (' . $searchLength . ') is longer than "' . $name . '" (' . $nameLength . '). '); | 
					
						
							|  |  |  |             $search       = substr($search, ($nameLength * -1)); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  |             $searchLength = strlen($search); | 
					
						
							|  |  |  |             Log::debug('Search string is now "' . $search . '" (' . $searchLength . ') instead.'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         $part = substr($name, $searchLength * -1); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($part == $search) { | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |             Log::debug('"' . $name . '" ends with "' . $search . '". Return true.'); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         Log::debug('"' . $name . '" does not end with "' . $search . '". Return false.'); | 
					
						
							| 
									
										
										
										
											2016-01-13 14:02:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-01-28 21:50:20 +01:00
										 |  |  | } |