. */ declare(strict_types=1); namespace FireflyIII\TransactionRules\Actions; use FireflyIII\Events\TriggeredAuditLog; use FireflyIII\Models\Note; use FireflyIII\Models\RuleAction; use FireflyIII\Models\TransactionJournal; use Illuminate\Support\Facades\Log; class AppendDescriptionToNotes implements ActionInterface { private RuleAction $action; /** * TriggerInterface constructor. * * @param RuleAction $action */ public function __construct(RuleAction $action) { $this->action = $action; } /** * @inheritDoc */ public function actOnArray(array $journal): bool { /** @var TransactionJournal $journal */ $object = TransactionJournal::where('user_id', $journal['user_id'])->find($journal['transaction_journal_id']); if (null === $object) { Log::error(sprintf('No journal #%d belongs to user #%d.', $journal['transaction_journal_id'], $journal['user_id'])); return false; } $note = $object->notes()->first(); if (null === $note) { $note = new Note(); $note->noteable()->associate($object); $note->text = ''; } $before = $note->text; if ('' !== $note->text) { $note->text = trim(sprintf("%s \n%s", $note->text, $object->description)); } if ('' === $note->text) { $note->text = (string) $object->description; } $after = $note->text; // event for audit log entry event(new TriggeredAuditLog($this->action->rule, $object, 'update_notes', $before, $after)); $note->save(); return true; } }