firefly-iii/app/TransactionRules/Actions/AppendNotes.php

78 lines
2.6 KiB
PHP
Raw Normal View History

<?php
2022-12-29 12:42:26 -06:00
/**
* AppendNotes.php
2020-02-16 06:57:05 -06:00
* Copyright (c) 2019 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2017-10-21 01:40:00 -05:00
*
* 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 01:40:00 -05:00
*
* This program is distributed in the hope that it will be useful,
2017-10-21 01:40:00 -05: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 01:40:00 -05: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);
namespace FireflyIII\TransactionRules\Actions;
2022-10-01 23:23:31 -05:00
use FireflyIII\Events\TriggeredAuditLog;
2017-10-03 03:41:48 -05:00
use FireflyIII\Models\Note;
use FireflyIII\Models\RuleAction;
use FireflyIII\Models\TransactionJournal;
2024-03-10 01:11:58 -06:00
use FireflyIII\TransactionRules\Traits\RefreshNotesTrait;
/**
2017-11-15 05:25:49 -06:00
* Class AppendNotes.
* TODO Can be replaced (and migrated) to action "set notes" with a prefilled expression
*/
class AppendNotes implements ActionInterface
{
2024-03-10 01:11:58 -06:00
use RefreshNotesTrait;
2024-03-16 17:06:16 -05:00
private RuleAction $action;
/**
* TriggerInterface constructor.
*/
public function __construct(RuleAction $action)
{
$this->action = $action;
}
2020-08-22 10:18:15 -05:00
public function actOnArray(array $journal): bool
{
2024-03-10 01:11:58 -06:00
$this->refreshNotes($journal);
$dbNote = Note::where('noteable_id', (int)$journal['transaction_journal_id'])
->where('noteable_type', TransactionJournal::class)
->first(['notes.*'])
;
2020-08-22 10:18:15 -05:00
if (null === $dbNote) {
2022-10-30 08:24:37 -05:00
$dbNote = new Note();
2022-12-29 12:42:26 -06:00
$dbNote->noteable_id = (int)$journal['transaction_journal_id'];
2020-08-22 10:18:15 -05:00
$dbNote->noteable_type = TransactionJournal::class;
$dbNote->text = '';
}
2022-10-01 23:23:31 -05:00
$before = $dbNote->text;
$append = $this->action->getValue($journal);
$text = sprintf('%s%s', $dbNote->text, $append);
2020-08-22 10:18:15 -05:00
$dbNote->text = $text;
$dbNote->save();
2022-10-02 13:23:11 -05:00
/** @var TransactionJournal $object */
$object = TransactionJournal::where('user_id', $journal['user_id'])->find($journal['transaction_journal_id']);
2022-10-01 23:23:31 -05:00
app('log')->debug(sprintf('RuleAction AppendNotes appended "%s" to "%s".', $append, $before));
2022-10-02 13:23:11 -05:00
event(new TriggeredAuditLog($this->action->rule, $object, 'update_notes', $before, $text));
2022-10-01 23:23:31 -05:00
2020-08-22 10:18:15 -05:00
return true;
}
}