| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * ActionFactory.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 Robert Horlings | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-18 06:34:16 +01:00
										 |  |  | namespace FireflyIII\Rules\Factory; | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | use FireflyIII\Models\RuleAction; | 
					
						
							| 
									
										
										
										
											2016-02-18 06:34:16 +01:00
										 |  |  | use FireflyIII\Rules\Actions\ActionInterface; | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | use FireflyIII\Support\Domain; | 
					
						
							| 
									
										
										
										
											2016-09-21 20:30:09 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Interface ActionInterface | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Rules\Actions | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ActionFactory | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-02-18 06:45:10 +01:00
										 |  |  |     protected static $actionTypes = []; | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-18 06:45:10 +01:00
										 |  |  |      * This method returns the actual implementation (Rules/Actions/[object]) for a given | 
					
						
							| 
									
										
										
										
											2016-02-18 06:38:37 +01:00
										 |  |  |      * RuleAction (database object). If for example the database object contains action_type "change_category" | 
					
						
							|  |  |  |      * with value "Groceries" this method will return a corresponding SetCategory object preset | 
					
						
							|  |  |  |      * to "Groceries". Any transaction journal then fed to this object will have its category changed. | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-17 21:59:47 +01:00
										 |  |  |      * @param RuleAction $action | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return ActionInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-17 19:56:05 +01:00
										 |  |  |     public static function getAction(RuleAction $action): ActionInterface | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-18 06:38:37 +01:00
										 |  |  |         $class = self::getActionClass($action->action_type); | 
					
						
							| 
									
										
										
										
											2016-09-21 20:30:09 +02:00
										 |  |  |         Log::debug(sprintf('self::getActionClass("%s") = "%s"', $action->action_type, $class)); | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 19:56:05 +01:00
										 |  |  |         return new $class($action); | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-18 06:38:37 +01:00
										 |  |  |      * Returns the class name to be used for actions with the given name. This is a lookup function
 | 
					
						
							|  |  |  |      * that will match the given action type (ie. "change_category") to the matching class name | 
					
						
							|  |  |  |      * (SetCategory) using the configuration (firefly.php). | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |      * @param string $actionType | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-18 06:38:37 +01:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |     public static function getActionClass(string $actionType): string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         $actionTypes = self::getActionTypes(); | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         if (!array_key_exists($actionType, $actionTypes)) { | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |             throw new FireflyException('No such action exists ("' . e($actionType) . '").'); | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         $class = $actionTypes[$actionType]; | 
					
						
							|  |  |  |         if (!class_exists($class)) { | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |             throw new FireflyException('Could not instantiate class for rule action type "' . e($actionType) . '" (' . e($class) . ').'); | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         return $class; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns a map with actiontypes, mapped to the class representing that type | 
					
						
							| 
									
										
										
										
											2016-02-18 06:45:10 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-18 06:45:10 +01:00
										 |  |  |     protected static function getActionTypes(): array | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-18 06:45:10 +01:00
										 |  |  |         if (count(self::$actionTypes) === 0) { | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |             self::$actionTypes = Domain::getRuleActions(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-17 15:52:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-17 13:24:56 +01:00
										 |  |  |         return self::$actionTypes; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |