mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-02-25 18:45:27 -06:00 
			
		
		
		
	chore: reformat code.
This commit is contained in:
		| @@ -34,7 +34,7 @@ interface RuleEngineInterface | ||||
|     /** | ||||
|      * Add operators added to each search by the rule engine. | ||||
|      * | ||||
|      * @param  array  $operator | ||||
|      * @param array $operator | ||||
|      */ | ||||
|     public function addOperator(array $operator): void; | ||||
|  | ||||
| @@ -56,7 +56,7 @@ interface RuleEngineInterface | ||||
|     public function getResults(): int; | ||||
|  | ||||
|     /** | ||||
|      * @param  bool  $refreshTriggers | ||||
|      * @param bool $refreshTriggers | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setRefreshTriggers(bool $refreshTriggers): void; | ||||
| @@ -64,19 +64,19 @@ interface RuleEngineInterface | ||||
|     /** | ||||
|      * Add entire rule groups for the engine to execute. | ||||
|      * | ||||
|      * @param  Collection  $ruleGroups | ||||
|      * @param Collection $ruleGroups | ||||
|      */ | ||||
|     public function setRuleGroups(Collection $ruleGroups): void; | ||||
|  | ||||
|     /** | ||||
|      * Add rules for the engine to execute. | ||||
|      * | ||||
|      * @param  Collection  $rules | ||||
|      * @param Collection $rules | ||||
|      */ | ||||
|     public function setRules(Collection $rules): void; | ||||
|  | ||||
|     /** | ||||
|      * @param  User  $user | ||||
|      * @param User $user | ||||
|      */ | ||||
|     public function setUser(User $user): void; | ||||
| } | ||||
|   | ||||
| @@ -91,79 +91,129 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     public function fire(): void | ||||
|     { | ||||
|         $this->resultCount = []; | ||||
|         Log::debug('SearchRuleEngine::fire()!'); | ||||
|  | ||||
|         // if rules and no rule groups, file each rule separately. | ||||
|         if (0 !== $this->rules->count()) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: found %d rule(s) to fire.', $this->rules->count())); | ||||
|             foreach ($this->rules as $rule) { | ||||
|                 $this->fireRule($rule); | ||||
|             } | ||||
|             Log::debug('SearchRuleEngine:: done processing all rules!'); | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         if (0 !== $this->groups->count()) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: found %d rule group(s) to fire.', $this->groups->count())); | ||||
|             // fire each group: | ||||
|             /** @var RuleGroup $group */ | ||||
|             foreach ($this->groups as $group) { | ||||
|                 $this->fireGroup($group); | ||||
|             } | ||||
|         } | ||||
|         Log::debug('SearchRuleEngine:: done processing all rules!'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return the number of changed transactions from the previous "fire" action. | ||||
|      * Finds the transactions a strict rule will execute on. | ||||
|      * | ||||
|      * @return int | ||||
|      * @param Rule $rule | ||||
|      * | ||||
|      * @return Collection | ||||
|      */ | ||||
|     public function getResults(): int | ||||
|     private function findStrictRule(Rule $rule): Collection | ||||
|     { | ||||
|         return count($this->resultCount); | ||||
|     } | ||||
|         Log::debug(sprintf('Now in findStrictRule(#%d)', $rule->id ?? 0)); | ||||
|         $searchArray = []; | ||||
|         $triggers    = []; | ||||
|         if ($this->refreshTriggers) { | ||||
|             $triggers = $rule->ruleTriggers()->orderBy('order', 'ASC')->get(); | ||||
|         } | ||||
|         if (!$this->refreshTriggers) { | ||||
|             $triggers = $rule->ruleTriggers; | ||||
|         } | ||||
|  | ||||
|     /** | ||||
|      * @param  bool  $refreshTriggers | ||||
|      */ | ||||
|     public function setRefreshTriggers(bool $refreshTriggers): void | ||||
|     { | ||||
|         $this->refreshTriggers = $refreshTriggers; | ||||
|     } | ||||
|         /** @var RuleTrigger $ruleTrigger */ | ||||
|         foreach ($triggers as $ruleTrigger) { | ||||
|             if (false === $ruleTrigger->active) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      */ | ||||
|     public function setRuleGroups(Collection $ruleGroups): void | ||||
|     { | ||||
|         Log::debug(__METHOD__); | ||||
|         foreach ($ruleGroups as $group) { | ||||
|             if ($group instanceof RuleGroup) { | ||||
|                 Log::debug(sprintf('Adding a rule group to the SearchRuleEngine: #%d ("%s")', $group->id, $group->title)); | ||||
|                 $this->groups->push($group); | ||||
|             // if needs no context, value is different: | ||||
|             $needsContext = config(sprintf('search.operators.%s.needs_context', $ruleTrigger->trigger_type)) ?? true; | ||||
|             if (false === $needsContext) { | ||||
|                 Log::debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:true', $ruleTrigger->trigger_type)); | ||||
|                 $searchArray[$ruleTrigger->trigger_type][] = 'true'; | ||||
|             } | ||||
|             if (true === $needsContext) { | ||||
|                 Log::debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:"%s"', $ruleTrigger->trigger_type, $ruleTrigger->trigger_value)); | ||||
|                 $searchArray[$ruleTrigger->trigger_type][] = sprintf('"%s"', $ruleTrigger->trigger_value); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|  | ||||
|         // add local operators: | ||||
|         foreach ($this->operators as $operator) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: add local added operator: %s:"%s"', $operator['type'], $operator['value'])); | ||||
|             $searchArray[$operator['type']][] = sprintf('"%s"', $operator['value']); | ||||
|         } | ||||
|         $date = today(config('app.timezone')); | ||||
|         if ($this->hasSpecificJournalTrigger($searchArray)) { | ||||
|             $date = $this->setDateFromJournalTrigger($searchArray); | ||||
|         } | ||||
|         // build and run the search engine. | ||||
|         $searchEngine = app(SearchInterface::class); | ||||
|         $searchEngine->setUser($this->user); | ||||
|         $searchEngine->setPage(1); | ||||
|         $searchEngine->setLimit(31337); | ||||
|         $searchEngine->setDate($date); | ||||
|  | ||||
|         foreach ($searchArray as $type => $searches) { | ||||
|             foreach ($searches as $value) { | ||||
|                 $searchEngine->parseQuery(sprintf('%s:%s', $type, $value)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $result = $searchEngine->searchTransactions(); | ||||
|  | ||||
|         return $result->getCollection(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      * Search in the triggers of this particular search and if it contains | ||||
|      * one search operator for "journal_id" it means the date ranges | ||||
|      * in the search may need to be updated. | ||||
|      * | ||||
|      * @param array $array | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function setRules(Collection $rules): void | ||||
|     private function hasSpecificJournalTrigger(array $array): bool | ||||
|     { | ||||
|         Log::debug(__METHOD__); | ||||
|         foreach ($rules as $rule) { | ||||
|             if ($rule instanceof Rule) { | ||||
|                 Log::debug(sprintf('Adding a rule to the SearchRuleEngine: #%d ("%s")', $rule->id, $rule->title)); | ||||
|                 $this->rules->push($rule); | ||||
|         Log::debug('Now in hasSpecificJournalTrigger.'); | ||||
|         $journalTrigger = false; | ||||
|         $dateTrigger    = false; | ||||
|         foreach ($array as $triggerName => $values) { | ||||
|             if ('journal_id' === $triggerName && is_array($values) && 1 === count($values)) { | ||||
|                 Log::debug('Found a journal_id trigger with 1 journal, true.'); | ||||
|                 $journalTrigger = true; | ||||
|             } | ||||
|             if (in_array($triggerName, ['date_is', 'date', 'on', 'date_before', 'before', 'date_after', 'after'], true)) { | ||||
|                 Log::debug('Found a date related trigger, set to true.'); | ||||
|                 $dateTrigger = true; | ||||
|             } | ||||
|         } | ||||
|         $result = $journalTrigger && $dateTrigger; | ||||
|         Log::debug(sprintf('Result of hasSpecificJournalTrigger is %s.', var_export($result, true))); | ||||
|  | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param array $array | ||||
|      * | ||||
|      * @return Carbon | ||||
|      */ | ||||
|     private function setDateFromJournalTrigger(array $array): Carbon | ||||
|     { | ||||
|         Log::debug('Now in setDateFromJournalTrigger()'); | ||||
|         $journalId = 0; | ||||
|         foreach ($array as $triggerName => $values) { | ||||
|             if ('journal_id' === $triggerName && is_array($values) && 1 === count($values)) { | ||||
|                 $journalId = (int)trim(($values[0] ?? '"0"'), '"'); // follows format "123". | ||||
|                 Log::debug(sprintf('Found journal ID #%d', $journalId)); | ||||
|             } | ||||
|         } | ||||
|         if (0 !== $journalId) { | ||||
|             $repository = app(JournalRepositoryInterface::class); | ||||
|             $repository->setUser($this->user); | ||||
|             $journal = $repository->find($journalId); | ||||
|             if (null !== $journal) { | ||||
|                 $date = $journal->date; | ||||
|                 Log::debug(sprintf('Found journal #%d with date %s.', $journal->id, $journal->date->format('Y-m-d'))); | ||||
|  | ||||
|                 return $date; | ||||
|             } | ||||
|         } | ||||
|         Log::debug('Found no journal, return default date.'); | ||||
|  | ||||
|         return today(config('app.timezone')); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -176,7 +226,7 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  Rule  $rule | ||||
|      * @param Rule $rule | ||||
|      * | ||||
|      * @return Collection | ||||
|      */ | ||||
| @@ -259,118 +309,39 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finds the transactions a strict rule will execute on. | ||||
|      * | ||||
|      * @param  Rule  $rule | ||||
|      * | ||||
|      * @return Collection | ||||
|      */ | ||||
|     private function findStrictRule(Rule $rule): Collection | ||||
|     { | ||||
|         Log::debug(sprintf('Now in findStrictRule(#%d)', $rule->id ?? 0)); | ||||
|         $searchArray = []; | ||||
|         $triggers    = []; | ||||
|         if ($this->refreshTriggers) { | ||||
|             $triggers = $rule->ruleTriggers()->orderBy('order', 'ASC')->get(); | ||||
|         } | ||||
|         if (!$this->refreshTriggers) { | ||||
|             $triggers = $rule->ruleTriggers; | ||||
|         } | ||||
|  | ||||
|         /** @var RuleTrigger $ruleTrigger */ | ||||
|         foreach ($triggers as $ruleTrigger) { | ||||
|             if (false === $ruleTrigger->active) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // if needs no context, value is different: | ||||
|             $needsContext = config(sprintf('search.operators.%s.needs_context', $ruleTrigger->trigger_type)) ?? true; | ||||
|             if (false === $needsContext) { | ||||
|                 Log::debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:true', $ruleTrigger->trigger_type)); | ||||
|                 $searchArray[$ruleTrigger->trigger_type][] = 'true'; | ||||
|             } | ||||
|             if (true === $needsContext) { | ||||
|                 Log::debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:"%s"', $ruleTrigger->trigger_type, $ruleTrigger->trigger_value)); | ||||
|                 $searchArray[$ruleTrigger->trigger_type][] = sprintf('"%s"', $ruleTrigger->trigger_value); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|  | ||||
|         // add local operators: | ||||
|         foreach ($this->operators as $operator) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: add local added operator: %s:"%s"', $operator['type'], $operator['value'])); | ||||
|             $searchArray[$operator['type']][] = sprintf('"%s"', $operator['value']); | ||||
|         } | ||||
|         $date = today(config('app.timezone')); | ||||
|         if ($this->hasSpecificJournalTrigger($searchArray)) { | ||||
|             $date = $this->setDateFromJournalTrigger($searchArray); | ||||
|         } | ||||
|         // build and run the search engine. | ||||
|         $searchEngine = app(SearchInterface::class); | ||||
|         $searchEngine->setUser($this->user); | ||||
|         $searchEngine->setPage(1); | ||||
|         $searchEngine->setLimit(31337); | ||||
|         $searchEngine->setDate($date); | ||||
|  | ||||
|         foreach ($searchArray as $type => $searches) { | ||||
|             foreach ($searches as $value) { | ||||
|                 $searchEngine->parseQuery(sprintf('%s:%s', $type, $value)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $result = $searchEngine->searchTransactions(); | ||||
|  | ||||
|         return $result->getCollection(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  RuleGroup  $group | ||||
|      * | ||||
|      * @return void | ||||
|      * @inheritDoc | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function fireGroup(RuleGroup $group): void | ||||
|     public function fire(): void | ||||
|     { | ||||
|         $all = false; | ||||
|         Log::debug(sprintf('Going to fire group #%d with %d rule(s)', $group->id, $group->rules->count())); | ||||
|         /** @var Rule $rule */ | ||||
|         foreach ($group->rules as $rule) { | ||||
|             Log::debug(sprintf('Going to fire rule #%d from group #%d', $rule->id, $group->id)); | ||||
|             $result = $this->fireRule($rule); | ||||
|             if (true === $result) { | ||||
|                 $all = true; | ||||
|             } | ||||
|             if (true === $result && true === $rule->stop_processing) { | ||||
|                 Log::debug(sprintf('The rule was triggered and rule->stop_processing = true, so group #%d will stop processing further rules.', $group->id)); | ||||
|         $this->resultCount = []; | ||||
|         Log::debug('SearchRuleEngine::fire()!'); | ||||
|  | ||||
|                 return; | ||||
|         // if rules and no rule groups, file each rule separately. | ||||
|         if (0 !== $this->rules->count()) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: found %d rule(s) to fire.', $this->rules->count())); | ||||
|             foreach ($this->rules as $rule) { | ||||
|                 $this->fireRule($rule); | ||||
|             } | ||||
|             Log::debug('SearchRuleEngine:: done processing all rules!'); | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         if (0 !== $this->groups->count()) { | ||||
|             Log::debug(sprintf('SearchRuleEngine:: found %d rule group(s) to fire.', $this->groups->count())); | ||||
|             // fire each group: | ||||
|             /** @var RuleGroup $group */ | ||||
|             foreach ($this->groups as $group) { | ||||
|                 $this->fireGroup($group); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return true if the rule is fired (the collection is larger than zero). | ||||
|      * | ||||
|      * @param  Rule  $rule | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function fireNonStrictRule(Rule $rule): bool | ||||
|     { | ||||
|         Log::debug(sprintf('SearchRuleEngine::fireNonStrictRule(%d)!', $rule->id)); | ||||
|         $collection = $this->findNonStrictRule($rule); | ||||
|  | ||||
|         $this->processResults($rule, $collection); | ||||
|         Log::debug(sprintf('SearchRuleEngine:: done processing non-strict rule #%d', $rule->id)); | ||||
|  | ||||
|         return $collection->count() > 0; | ||||
|         Log::debug('SearchRuleEngine:: done processing all rules!'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns true if the rule has been triggered. | ||||
|      * | ||||
|      * @param  Rule  $rule | ||||
|      * @param Rule $rule | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws FireflyException | ||||
| @@ -396,7 +367,7 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     /** | ||||
|      * Return true if the rule is fired (the collection is larger than zero). | ||||
|      * | ||||
|      * @param  Rule  $rule | ||||
|      * @param Rule $rule | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws FireflyException | ||||
| @@ -421,38 +392,8 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Search in the triggers of this particular search and if it contains | ||||
|      * one search operator for "journal_id" it means the date ranges | ||||
|      * in the search may need to be updated. | ||||
|      * | ||||
|      * @param  array  $array | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     private function hasSpecificJournalTrigger(array $array): bool | ||||
|     { | ||||
|         Log::debug('Now in hasSpecificJournalTrigger.'); | ||||
|         $journalTrigger = false; | ||||
|         $dateTrigger    = false; | ||||
|         foreach ($array as $triggerName => $values) { | ||||
|             if ('journal_id' === $triggerName && is_array($values) && 1 === count($values)) { | ||||
|                 Log::debug('Found a journal_id trigger with 1 journal, true.'); | ||||
|                 $journalTrigger = true; | ||||
|             } | ||||
|             if (in_array($triggerName, ['date_is', 'date', 'on', 'date_before', 'before', 'date_after', 'after'], true)) { | ||||
|                 Log::debug('Found a date related trigger, set to true.'); | ||||
|                 $dateTrigger = true; | ||||
|             } | ||||
|         } | ||||
|         $result = $journalTrigger && $dateTrigger; | ||||
|         Log::debug(sprintf('Result of hasSpecificJournalTrigger is %s.', var_export($result, true))); | ||||
|  | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  Rule  $rule | ||||
|      * @param  Collection  $collection | ||||
|      * @param Rule       $rule | ||||
|      * @param Collection $collection | ||||
|      * | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
| @@ -466,8 +407,45 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  RuleAction  $ruleAction | ||||
|      * @param  array  $transaction | ||||
|      * @param Rule  $rule | ||||
|      * @param array $group | ||||
|      * | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function processTransactionGroup(Rule $rule, array $group): void | ||||
|     { | ||||
|         Log::debug(sprintf('SearchRuleEngine:: Will now execute actions on transaction group #%d', $group['id'])); | ||||
|         /** @var array $transaction */ | ||||
|         foreach ($group['transactions'] as $transaction) { | ||||
|             $this->processTransactionJournal($rule, $transaction); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param Rule  $rule | ||||
|      * @param array $transaction | ||||
|      * | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function processTransactionJournal(Rule $rule, array $transaction): void | ||||
|     { | ||||
|         Log::debug(sprintf('SearchRuleEngine:: Will now execute actions on transaction journal #%d', $transaction['transaction_journal_id'])); | ||||
|         $actions = $rule->ruleActions()->orderBy('order', 'ASC')->get(); | ||||
|         /** @var RuleAction $ruleAction */ | ||||
|         foreach ($actions as $ruleAction) { | ||||
|             if (false === $ruleAction->active) { | ||||
|                 continue; | ||||
|             } | ||||
|             $break = $this->processRuleAction($ruleAction, $transaction); | ||||
|             if (true === $break) { | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param RuleAction $ruleAction | ||||
|      * @param array      $transaction | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws FireflyException | ||||
| @@ -504,70 +482,92 @@ class SearchRuleEngine implements RuleEngineInterface | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  Rule  $rule | ||||
|      * @param  array  $group | ||||
|      * Return true if the rule is fired (the collection is larger than zero). | ||||
|      * | ||||
|      * @param Rule $rule | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function processTransactionGroup(Rule $rule, array $group): void | ||||
|     private function fireNonStrictRule(Rule $rule): bool | ||||
|     { | ||||
|         Log::debug(sprintf('SearchRuleEngine:: Will now execute actions on transaction group #%d', $group['id'])); | ||||
|         /** @var array $transaction */ | ||||
|         foreach ($group['transactions'] as $transaction) { | ||||
|             $this->processTransactionJournal($rule, $transaction); | ||||
|         } | ||||
|         Log::debug(sprintf('SearchRuleEngine::fireNonStrictRule(%d)!', $rule->id)); | ||||
|         $collection = $this->findNonStrictRule($rule); | ||||
|  | ||||
|         $this->processResults($rule, $collection); | ||||
|         Log::debug(sprintf('SearchRuleEngine:: done processing non-strict rule #%d', $rule->id)); | ||||
|  | ||||
|         return $collection->count() > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  Rule  $rule | ||||
|      * @param  array  $transaction | ||||
|      * @param RuleGroup $group | ||||
|      * | ||||
|      * @return void | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     private function processTransactionJournal(Rule $rule, array $transaction): void | ||||
|     private function fireGroup(RuleGroup $group): void | ||||
|     { | ||||
|         Log::debug(sprintf('SearchRuleEngine:: Will now execute actions on transaction journal #%d', $transaction['transaction_journal_id'])); | ||||
|         $actions = $rule->ruleActions()->orderBy('order', 'ASC')->get(); | ||||
|         /** @var RuleAction $ruleAction */ | ||||
|         foreach ($actions as $ruleAction) { | ||||
|             if (false === $ruleAction->active) { | ||||
|                 continue; | ||||
|         $all = false; | ||||
|         Log::debug(sprintf('Going to fire group #%d with %d rule(s)', $group->id, $group->rules->count())); | ||||
|         /** @var Rule $rule */ | ||||
|         foreach ($group->rules as $rule) { | ||||
|             Log::debug(sprintf('Going to fire rule #%d from group #%d', $rule->id, $group->id)); | ||||
|             $result = $this->fireRule($rule); | ||||
|             if (true === $result) { | ||||
|                 $all = true; | ||||
|             } | ||||
|             $break = $this->processRuleAction($ruleAction, $transaction); | ||||
|             if (true === $break) { | ||||
|                 break; | ||||
|             if (true === $result && true === $rule->stop_processing) { | ||||
|                 Log::debug(sprintf('The rule was triggered and rule->stop_processing = true, so group #%d will stop processing further rules.', $group->id)); | ||||
|  | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param  array  $array | ||||
|      * Return the number of changed transactions from the previous "fire" action. | ||||
|      * | ||||
|      * @return Carbon | ||||
|      * @return int | ||||
|      */ | ||||
|     private function setDateFromJournalTrigger(array $array): Carbon | ||||
|     public function getResults(): int | ||||
|     { | ||||
|         Log::debug('Now in setDateFromJournalTrigger()'); | ||||
|         $journalId = 0; | ||||
|         foreach ($array as $triggerName => $values) { | ||||
|             if ('journal_id' === $triggerName && is_array($values) && 1 === count($values)) { | ||||
|                 $journalId = (int)trim(($values[0] ?? '"0"'), '"'); // follows format "123". | ||||
|                 Log::debug(sprintf('Found journal ID #%d', $journalId)); | ||||
|         return count($this->resultCount); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param bool $refreshTriggers | ||||
|      */ | ||||
|     public function setRefreshTriggers(bool $refreshTriggers): void | ||||
|     { | ||||
|         $this->refreshTriggers = $refreshTriggers; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      */ | ||||
|     public function setRuleGroups(Collection $ruleGroups): void | ||||
|     { | ||||
|         Log::debug(__METHOD__); | ||||
|         foreach ($ruleGroups as $group) { | ||||
|             if ($group instanceof RuleGroup) { | ||||
|                 Log::debug(sprintf('Adding a rule group to the SearchRuleEngine: #%d ("%s")', $group->id, $group->title)); | ||||
|                 $this->groups->push($group); | ||||
|             } | ||||
|         } | ||||
|         if (0 !== $journalId) { | ||||
|             $repository = app(JournalRepositoryInterface::class); | ||||
|             $repository->setUser($this->user); | ||||
|             $journal = $repository->find($journalId); | ||||
|             if (null !== $journal) { | ||||
|                 $date = $journal->date; | ||||
|                 Log::debug(sprintf('Found journal #%d with date %s.', $journal->id, $journal->date->format('Y-m-d'))); | ||||
|     } | ||||
|  | ||||
|                 return $date; | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      */ | ||||
|     public function setRules(Collection $rules): void | ||||
|     { | ||||
|         Log::debug(__METHOD__); | ||||
|         foreach ($rules as $rule) { | ||||
|             if ($rule instanceof Rule) { | ||||
|                 Log::debug(sprintf('Adding a rule to the SearchRuleEngine: #%d ("%s")', $rule->id, $rule->title)); | ||||
|                 $this->rules->push($rule); | ||||
|             } | ||||
|         } | ||||
|         Log::debug('Found no journal, return default date.'); | ||||
|  | ||||
|         return today(config('app.timezone')); | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user