Files
firefly-iii/app/TransactionRules/Actions/SetBudget.php

111 lines
4.2 KiB
PHP
Raw Normal View History

<?php
2022-12-29 19:42:26 +01:00
/**
* SetBudget.php
2020-02-16 13:57:05 +01:00
* Copyright (c) 2019 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
2017-10-21 08:40:00 +02:00
*
* This program is distributed in the hope that it will be useful,
2017-10-21 08:40:00 +02:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
2017-10-21 08:40:00 +02:00
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
declare(strict_types=1);
2017-09-13 07:49:58 +02:00
namespace FireflyIII\TransactionRules\Actions;
2023-08-13 15:01:12 +02:00
use FireflyIII\Events\Model\Rule\RuleActionFailedOnArray;
2022-10-02 06:23:31 +02:00
use FireflyIII\Events\TriggeredAuditLog;
use FireflyIII\Models\RuleAction;
2022-10-02 06:23:31 +02:00
use FireflyIII\Models\TransactionJournal;
2016-09-24 09:12:17 +02:00
use FireflyIII\Models\TransactionType;
use FireflyIII\TransactionRules\Expressions\ActionExpression;
2020-08-23 09:21:50 +02:00
use FireflyIII\User;
2016-01-15 23:12:52 +01:00
/**
2017-11-15 12:25:49 +01:00
* Class SetBudget.
*/
class SetBudget implements ActionInterface
{
private RuleAction $action;
private ActionExpression $expr;
/**
* TriggerInterface constructor.
*/
public function __construct(RuleAction $action, ActionExpression $expr)
{
$this->action = $action;
$this->expr = $expr;
}
2020-08-23 07:42:14 +02:00
public function actOnArray(array $journal): bool
{
2023-11-28 17:18:31 +01:00
/** @var User $user */
$user = User::find($journal['user_id']);
$search = $this->expr->evaluate($journal);
2020-08-23 09:21:50 +02:00
$budget = $user->budgets()->where('name', $search)->first();
2020-08-23 09:21:50 +02:00
if (null === $budget) {
2023-10-29 06:33:43 +01:00
app('log')->debug(
sprintf(
2022-10-30 14:24:37 +01:00
'RuleAction SetBudget could not set budget of journal #%d to "%s" because no such budget exists.',
$journal['transaction_journal_id'],
$search
)
);
2023-08-13 15:01:12 +02:00
event(new RuleActionFailedOnArray($this->action, $journal, trans('rules.cannot_find_budget', ['name' => $search])));
2023-12-20 19:35:52 +01:00
2020-08-23 09:21:50 +02:00
return false;
}
if (TransactionType::WITHDRAWAL !== $journal['transaction_type_type']) {
2023-10-29 06:33:43 +01:00
app('log')->debug(
2020-08-23 09:21:50 +02:00
sprintf(
'RuleAction SetBudget could not set budget of journal #%d to "%s" because journal is a %s.',
$journal['transaction_journal_id'],
$search,
$journal['transaction_type_type']
)
);
2023-08-13 15:01:12 +02:00
event(new RuleActionFailedOnArray($this->action, $journal, trans('rules.cannot_set_budget', ['type' => $journal['transaction_type_type'], 'name' => $search])));
2023-12-20 19:35:52 +01:00
2022-10-02 06:23:31 +02:00
return false;
2020-08-23 09:21:50 +02:00
}
// find previous budget
/** @var TransactionJournal $object */
$object = $user->transactionJournals()->find($journal['transaction_journal_id']);
$oldBudget = $object->budgets()->first();
$oldBudgetName = $oldBudget?->name;
2023-11-05 19:41:37 +01:00
if ((int)$oldBudget?->id === $budget->id) {
event(new RuleActionFailedOnArray($this->action, $journal, trans('rules.already_linked_to_budget', ['name' => $budget->name])));
2023-12-20 19:35:52 +01:00
return false;
}
2023-10-29 06:33:43 +01:00
app('log')->debug(
sprintf('RuleAction SetBudget set the budget of journal #%d to budget #%d ("%s").', $journal['transaction_journal_id'], $budget->id, $budget->name)
);
2020-08-23 09:21:50 +02:00
2023-12-20 19:35:52 +01:00
\DB::table('budget_transaction_journal')->where('transaction_journal_id', '=', $journal['transaction_journal_id'])->delete();
\DB::table('budget_transaction_journal')->insert(['transaction_journal_id' => $journal['transaction_journal_id'], 'budget_id' => $budget->id]);
2020-08-23 09:21:50 +02:00
2022-10-02 20:23:11 +02:00
/** @var TransactionJournal $object */
$object = TransactionJournal::where('user_id', $journal['user_id'])->find($journal['transaction_journal_id']);
event(new TriggeredAuditLog($this->action->rule, $object, 'set_budget', $oldBudgetName, $budget->name));
2022-10-02 06:23:31 +02:00
2020-08-23 09:21:50 +02:00
return true;
2020-08-23 07:42:14 +02:00
}
}