mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-02-25 18:45:27 -06:00
Refactored method to check whether a transaction is triggered by a list of triggers
This commit is contained in:
parent
e7bb4a8ec6
commit
b9620b3a21
@ -92,6 +92,22 @@ class Processor
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether the current transaction is triggered by the current rule
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public function isTriggered() {
|
||||||
|
return $this->triggered();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether the current transaction is triggered by the list of given triggers
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public function isTriggeredBy(array $triggers) {
|
||||||
|
return $this->triggeredBy($triggers);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
@ -121,21 +137,22 @@ class Processor
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Method to check whether the current transaction would be triggered
|
||||||
|
* by the given list of triggers
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
protected function triggered()
|
protected function triggeredBy($triggers) {
|
||||||
{
|
|
||||||
$foundTriggers = 0;
|
$foundTriggers = 0;
|
||||||
$hitTriggers = 0;
|
$hitTriggers = 0;
|
||||||
/** @var RuleTrigger $trigger */
|
/** @var RuleTrigger $trigger */
|
||||||
foreach ($this->rule->ruleTriggers()->orderBy('order', 'ASC')->get() as $trigger) {
|
foreach ($triggers as $trigger) {
|
||||||
$foundTriggers++;
|
$foundTriggers++;
|
||||||
$type = $trigger->trigger_type;
|
$type = $trigger->trigger_type;
|
||||||
|
|
||||||
if (!isset($this->triggerTypes[$type])) {
|
if (!isset($this->triggerTypes[$type])) {
|
||||||
abort(500, 'No such trigger exists ("' . $type . '").');
|
abort(500, 'No such trigger exists ("' . $type . '").');
|
||||||
}
|
}
|
||||||
|
|
||||||
$class = $this->triggerTypes[$type];
|
$class = $this->triggerTypes[$type];
|
||||||
Log::debug('Trigger #' . $trigger->id . ' for rule #' . $trigger->rule_id . ' (' . $type . ')');
|
Log::debug('Trigger #' . $trigger->id . ' for rule #' . $trigger->rule_id . ' (' . $type . ')');
|
||||||
if (!class_exists($class)) {
|
if (!class_exists($class)) {
|
||||||
@ -149,12 +166,20 @@ class Processor
|
|||||||
if ($trigger->stop_processing) {
|
if ($trigger->stop_processing) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
Log::debug('Total: ' . $foundTriggers . ' found triggers. ' . $hitTriggers . ' triggers were hit.');
|
Log::debug('Total: ' . $foundTriggers . ' found triggers. ' . $hitTriggers . ' triggers were hit.');
|
||||||
|
|
||||||
return ($hitTriggers == $foundTriggers);
|
return ($hitTriggers == $foundTriggers);
|
||||||
|
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Checks whether the current transaction is triggered by the current rule
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
protected function triggered()
|
||||||
|
{
|
||||||
|
return $this->triggeredBy($this->rule->ruleTriggers()->orderBy('order', 'ASC')->get());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user