2016-01-12 21:38:12 +01:00
|
|
|
<?php
|
2016-02-05 12:08:25 +01:00
|
|
|
declare(strict_types = 1);
|
2016-01-12 21:38:12 +01:00
|
|
|
/**
|
|
|
|
* FireRulesForStore.php
|
|
|
|
* Copyright (C) 2016 Sander Dorigo
|
|
|
|
*
|
|
|
|
* This software may be modified and distributed under the terms
|
|
|
|
* of the MIT license. See the LICENSE file for details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace FireflyIII\Handlers\Events;
|
|
|
|
|
|
|
|
|
|
|
|
use FireflyIII\Events\TransactionJournalStored;
|
2016-01-13 07:16:29 +01:00
|
|
|
use FireflyIII\Models\Rule;
|
2016-01-12 21:41:45 +01:00
|
|
|
use FireflyIII\Models\RuleGroup;
|
2016-01-13 08:14:14 +01:00
|
|
|
use FireflyIII\Rules\Processor;
|
2016-01-12 21:41:45 +01:00
|
|
|
use FireflyIII\User;
|
|
|
|
use Illuminate\Support\Facades\Auth;
|
2016-01-13 05:37:25 +01:00
|
|
|
use Log;
|
2016-01-12 21:38:12 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class FireRulesForStore
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Handlers\Events
|
|
|
|
*/
|
|
|
|
class FireRulesForStore
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Connect a new transaction journal to any related piggy banks.
|
|
|
|
*
|
|
|
|
* @param TransactionJournalStored $event
|
|
|
|
*
|
2016-02-18 07:21:48 +01:00
|
|
|
* @return bool
|
2016-01-12 21:38:12 +01:00
|
|
|
*/
|
2016-02-18 07:21:48 +01:00
|
|
|
public function handle(TransactionJournalStored $event): bool
|
2016-01-12 21:38:12 +01:00
|
|
|
{
|
|
|
|
// get all the user's rule groups, with the rules, order by 'order'.
|
2016-01-13 07:16:29 +01:00
|
|
|
/** @var User $user */
|
|
|
|
$user = Auth::user();
|
2016-01-15 09:25:32 +01:00
|
|
|
$groups = $user->ruleGroups()->where('rule_groups.active', 1)->orderBy('order', 'ASC')->get();
|
2016-01-13 07:16:29 +01:00
|
|
|
//
|
|
|
|
/** @var RuleGroup $group */
|
|
|
|
foreach ($groups as $group) {
|
2016-01-13 14:02:22 +01:00
|
|
|
Log::debug('Now processing group "' . $group->title . '".');
|
2016-01-13 09:08:13 +01:00
|
|
|
$rules = $group->rules()
|
|
|
|
->leftJoin('rule_triggers', 'rules.id', '=', 'rule_triggers.rule_id')
|
|
|
|
->where('rule_triggers.trigger_type', 'user_action')
|
|
|
|
->where('rule_triggers.trigger_value', 'store-journal')
|
2016-01-15 09:25:32 +01:00
|
|
|
->where('rules.active', 1)
|
2016-01-13 09:08:13 +01:00
|
|
|
->get(['rules.*']);
|
2016-01-13 07:16:29 +01:00
|
|
|
/** @var Rule $rule */
|
|
|
|
foreach ($rules as $rule) {
|
|
|
|
|
2016-02-17 18:47:05 +01:00
|
|
|
Log::debug('Now handling rule #' . $rule->id . ' (' . $rule->title . ')');
|
|
|
|
$processor = Processor::make($rule);
|
|
|
|
$processor->handleTransactionJournal($event->journal);
|
2016-01-13 07:16:29 +01:00
|
|
|
|
2016-01-15 09:25:32 +01:00
|
|
|
if ($rule->stop_processing) {
|
2016-01-15 06:43:00 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2016-01-13 07:16:29 +01:00
|
|
|
}
|
|
|
|
}
|
2016-01-12 21:38:12 +01:00
|
|
|
}
|
2016-01-28 21:50:20 +01:00
|
|
|
}
|