. */ declare(strict_types=1); namespace FireflyIII\Handlers\Events; use FireflyIII\Events\StoredTransactionGroup; use FireflyIII\Models\TransactionJournal; use FireflyIII\TransactionRules\Engine\RuleEngine; use Log; /** * Class StoredGroupEventHandler */ class StoredGroupEventHandler { /** * This method grabs all the users rules and processes them. * * @param StoredTransactionGroup $storedGroupEvent */ public function processRules(StoredTransactionGroup $storedGroupEvent): void { if (false === $storedGroupEvent->applyRules) { Log::info(sprintf('Will not run rules on group #%d', $storedGroupEvent->transactionGroup->id)); return; } Log::debug('Now in StoredGroupEventHandler::processRules()'); /** @var RuleEngine $ruleEngine */ $ruleEngine = app(RuleEngine::class); $ruleEngine->setUser($storedGroupEvent->transactionGroup->user); $ruleEngine->setAllRules(true); $ruleEngine->setTriggerMode(RuleEngine::TRIGGER_STORE); $journals = $storedGroupEvent->transactionGroup->transactionJournals; /** @var TransactionJournal $journal */ foreach ($journals as $journal) { $ruleEngine->processTransactionJournal($journal); } } }