Files

111 lines
4.1 KiB
PHP
Raw Permalink 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;
2025-01-03 09:05:19 +01:00
use FireflyIII\Enums\TransactionTypeEnum;
2023-08-13 15:01:12 +02:00
use FireflyIII\Events\Model\Rule\RuleActionFailedOnArray;
2026-01-24 13:52:35 +01:00
use FireflyIII\Events\Model\TransactionGroup\TransactionGroupRequestsAuditLogEntry;
use FireflyIII\Models\RuleAction;
2022-10-02 06:23:31 +02:00
use FireflyIII\Models\TransactionJournal;
2020-08-23 09:21:50 +02:00
use FireflyIII\User;
2025-02-23 12:47:04 +01:00
use Illuminate\Support\Facades\DB;
2026-01-23 15:09:50 +01:00
use Illuminate\Support\Facades\Log;
2016-01-15 23:12:52 +01:00
/**
2017-11-15 12:25:49 +01:00
* Class SetBudget.
*/
class SetBudget implements ActionInterface
{
/**
* TriggerInterface constructor.
*/
2026-01-23 15:09:50 +01:00
public function __construct(
private readonly RuleAction $action
) {}
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->action->getValue($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) {
2026-01-23 15:09:50 +01:00
Log::debug(sprintf(
'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;
}
2025-01-03 09:05:19 +01:00
if (TransactionTypeEnum::WITHDRAWAL->value !== $journal['transaction_type_type']) {
2026-01-23 15:09:50 +01:00
Log::debug(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']
));
event(new RuleActionFailedOnArray($this->action, $journal, trans('rules.cannot_set_budget', [
'type' => $journal['transaction_type_type'],
'name' => $search,
2026-01-23 15:09:50 +01:00
])));
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;
2024-12-22 08:43:12 +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;
}
2026-01-23 15:09:50 +01:00
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
2025-02-23 12:47:04 +01:00
DB::table('budget_transaction_journal')->where('transaction_journal_id', '=', $journal['transaction_journal_id'])->delete();
2026-01-23 15:09:50 +01:00
DB::table('budget_transaction_journal')->insert([
'transaction_journal_id' => $journal['transaction_journal_id'],
'budget_id' => $budget->id,
2026-01-23 15:09:50 +01:00
]);
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']);
2026-01-24 13:52:35 +01:00
event(new TransactionGroupRequestsAuditLogEntry($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
}
}