| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2024-11-25 04:18:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * JournalCLIRepository.php | 
					
						
							| 
									
										
										
										
											2020-02-16 14:00:57 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 12:09:03 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Repositories\Journal; | 
					
						
							| 
									
										
										
										
											2021-04-07 07:28:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2025-01-03 19:07:29 +01:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							|  |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2025-02-23 12:28:27 +01:00
										 |  |  | use FireflyIII\Support\Repositories\UserGroup\UserGroupInterface; | 
					
						
							|  |  |  | use FireflyIII\Support\Repositories\UserGroup\UserGroupTrait; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2025-02-23 12:47:04 +01:00
										 |  |  | use Illuminate\Support\Facades\DB; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class JournalCLIRepository | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-02-23 12:28:27 +01:00
										 |  |  | class JournalCLIRepository implements JournalCLIRepositoryInterface, UserGroupInterface | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2025-02-23 12:28:27 +01:00
										 |  |  |     use UserGroupTrait; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get all transaction journals with a specific type, regardless of user. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAllJournals(array $types): Collection | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-10-30 14:24:28 +01:00
										 |  |  |         return TransactionJournal::leftJoin('transaction_types', 'transaction_types.id', '=', 'transaction_journals.transaction_type_id') | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             ->whereIn('transaction_types.type', $types) | 
					
						
							|  |  |  |             ->with(['user', 'transactionType', 'transactionCurrency', 'transactions', 'transactions.account']) | 
					
						
							|  |  |  |             ->get(['transaction_journals.*']) | 
					
						
							|  |  |  |         ; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return the ID of the budget linked to the journal (if any) or the transactions (if any). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getJournalBudgetId(TransactionJournal $journal): int | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  |         $budget      = $journal->budgets()->first(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         if (null !== $budget) { | 
					
						
							|  |  |  |             return $budget->id; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var null|Transaction $transaction */ | 
					
						
							| 
									
										
										
										
											2025-01-03 19:07:29 +01:00
										 |  |  |         $transaction = $journal->transactions()->first(); | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  |         $budget      = $transaction?->budgets()->first(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         if (null !== $budget) { | 
					
						
							|  |  |  |             return $budget->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return the ID of the category linked to the journal (if any) or to the transactions (if any). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getJournalCategoryId(TransactionJournal $journal): int | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  |         $category    = $journal->categories()->first(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         if (null !== $category) { | 
					
						
							|  |  |  |             return $category->id; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var null|Transaction $transaction */ | 
					
						
							| 
									
										
										
										
											2025-01-03 19:07:29 +01:00
										 |  |  |         $transaction = $journal->transactions()->first(); | 
					
						
							| 
									
										
										
										
											2025-01-04 07:39:16 +01:00
										 |  |  |         $category    = $transaction?->categories()->first(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         if (null !== $category) { | 
					
						
							|  |  |  |             return $category->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return all journals without a group, used in an upgrade routine. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getJournalsWithoutGroup(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return TransactionJournal::whereNull('transaction_group_id')->get(['id', 'user_id'])->toArray(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return Carbon value of a meta field (or NULL). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getMetaDate(TransactionJournal $journal, string $field): ?Carbon | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-10-30 14:24:28 +01:00
										 |  |  |         $cache = new CacheProperties(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         $cache->addProperty('journal-meta-updated'); | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty($field); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2022-12-30 20:25:04 +01:00
										 |  |  |             return new Carbon($cache->get()); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $entry = $journal->transactionJournalMeta()->where('name', $field)->first(); | 
					
						
							|  |  |  |         if (null === $entry) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-12-30 20:25:04 +01:00
										 |  |  |         $value = new Carbon($entry->data); | 
					
						
							|  |  |  |         $cache->store($value); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $value; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return value of a meta field (or NULL) as a string. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getMetaField(TransactionJournal $journal, string $field): ?string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $cache  = new CacheProperties(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         $cache->addProperty('journal-meta-updated'); | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty($field); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |             return $cache->get(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $entry  = $journal->transactionJournalMeta()->where('name', $field)->first(); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         if (null === $entry) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $value  = $entry->data; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (is_array($value)) { | 
					
						
							|  |  |  |             $return = implode(',', $value); | 
					
						
							|  |  |  |             $cache->store($return); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return $return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // return when something else:
 | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |         $return = (string) $value; | 
					
						
							| 
									
										
										
										
											2022-12-30 20:25:04 +01:00
										 |  |  |         $cache->store($return); | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return text of a note attached to journal, or NULL | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getNoteText(TransactionJournal $journal): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $note = $journal->notes()->first(); | 
					
						
							|  |  |  |         if (null === $note) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $note->text; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Returns all journals with more than 2 transactions. Should only return empty collections | 
					
						
							| 
									
										
										
										
											2019-08-12 17:10:58 +02:00
										 |  |  |      * in Firefly III > v4.8,0. | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function getSplitJournals(): Collection | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $query      = TransactionJournal::leftJoin('transactions', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             ->groupBy('transaction_journals.id') | 
					
						
							|  |  |  |         ; | 
					
						
							| 
									
										
										
										
											2025-02-23 12:47:04 +01:00
										 |  |  |         $result     = $query->get(['transaction_journals.id as id', DB::raw('count(transactions.id) as transaction_count')]); // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         $journalIds = []; | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var \stdClass $row */ | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |         foreach ($result as $row) { | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |             if ((int) $row->transaction_count > 2) { | 
					
						
							|  |  |  |                 $journalIds[] = (int) $row->id; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $journalIds = array_unique($journalIds); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 14:24:28 +01:00
										 |  |  |         return TransactionJournal::with(['transactions']) | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             ->whereIn('id', $journalIds)->get() | 
					
						
							|  |  |  |         ; | 
					
						
							| 
									
										
										
										
											2019-08-10 14:41:08 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return all tags as strings in an array. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getTags(TransactionJournal $journal): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $journal->tags()->get()->pluck('tag')->toArray(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-08-17 12:09:03 +02:00
										 |  |  | } |