rule = $rule; $this->journal = $journal; $this->triggerTypes = Domain::getRuleTriggers(); $this->actionTypes = Domain::getRuleActions(); } /** * @return TransactionJournal */ public function getJournal() { return $this->journal; } /** * @param TransactionJournal $journal */ public function setJournal($journal) { $this->journal = $journal; } /** * @return Rule */ public function getRule() { return $this->rule; } /** * @param Rule $rule */ public function setRule($rule) { $this->rule = $rule; } public function handle() { // get all triggers: $triggered = $this->triggered(); if ($triggered) { Log::debug('Rule #' . $this->rule->id . ' was triggered. Now process each action.'); $this->actions(); } } /** * @return bool */ protected function actions() { /** * @var int $index * @var RuleAction $action */ foreach ($this->rule->ruleActions()->orderBy('order', 'ASC')->get() as $action) { $type = $action->action_type; $class = $this->actionTypes[$type]; Log::debug('Action #' . $action->id . ' for rule #' . $action->rule_id . ' (' . $type . ')'); if (!class_exists($class)) { abort(500, 'Could not instantiate class for rule action type "' . $type . '" (' . $class . ').'); } /** @var ActionInterface $actionClass */ $actionClass = new $class($action, $this->journal); $actionClass->act(); if ($action->stop_processing) { break; } } return true; } /** * @return bool */ protected function triggered() { $foundTriggers = 0; $hitTriggers = 0; /** @var RuleTrigger $trigger */ foreach ($this->rule->ruleTriggers()->orderBy('order', 'ASC')->get() as $trigger) { $foundTriggers++; $type = $trigger->trigger_type; if (!isset($this->triggerTypes[$type])) { abort(500, 'No such trigger exists ("' . $type . '").'); } $class = $this->triggerTypes[$type]; Log::debug('Trigger #' . $trigger->id . ' for rule #' . $trigger->rule_id . ' (' . $type . ')'); if (!class_exists($class)) { abort(500, 'Could not instantiate class for rule trigger type "' . $type . '" (' . $class . ').'); } /** @var TriggerInterface $triggerClass */ $triggerClass = new $class($trigger, $this->journal); if ($triggerClass->triggered()) { $hitTriggers++; } if ($trigger->stop_processing) { break; } } Log::debug('Total: ' . $foundTriggers . ' found triggers. ' . $hitTriggers . ' triggers were hit.'); return ($hitTriggers == $foundTriggers); } }