| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * AccountEnricher.php | 
					
						
							|  |  |  |  * Copyright (c) 2024 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Support\JsonApi\Enrichments; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							|  |  |  | use FireflyIII\Models\AccountType; | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | use FireflyIII\Repositories\UserGroups\Account\AccountRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | use FireflyIII\Repositories\UserGroups\Currency\CurrencyRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | use Illuminate\Support\Facades\Log; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 18:50:41 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class AccountEnrichment | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This class "enriches" accounts and adds data from other tables and models to each account model.
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | class AccountEnrichment implements EnrichmentInterface | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     private Collection $collection; | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |     private array      $currencies; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |     private AccountRepositoryInterface  $repository; | 
					
						
							|  |  |  |     private CurrencyRepositoryInterface $currencyRepository; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->repository         = app(AccountRepositoryInterface::class); | 
					
						
							|  |  |  |         $this->currencyRepository = app(CurrencyRepositoryInterface::class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 05:10:16 +02:00
										 |  |  |     #[\Override]
 | 
					
						
							| 
									
										
										
										
											2024-07-26 18:50:41 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Do the actual enrichment. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-05-13 05:10:16 +02:00
										 |  |  |     public function enrich(Collection $collection): Collection | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-07-26 18:50:41 +02:00
										 |  |  |         Log::debug(sprintf('Now doing account enrichment for %d account(s)', $collection->count())); | 
					
						
							|  |  |  |         // prep local fields
 | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |         $this->collection = $collection; | 
					
						
							|  |  |  |         $this->currencies = []; | 
					
						
							| 
									
										
										
										
											2024-07-26 18:50:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  |         // do everything here:
 | 
					
						
							|  |  |  |         $this->getLastActivity(); | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |         $this->collectAccountTypes(); | 
					
						
							|  |  |  |         $this->collectMetaData(); | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |         // $this->getMetaBalances();
 | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 18:50:41 +02:00
										 |  |  | //        $this->collection->transform(function (Account $account) {
 | 
					
						
							|  |  |  | //            $account->user_array = ['id' => 1, 'bla bla' => 'bla'];
 | 
					
						
							|  |  |  | //            $account->balances   = collect([
 | 
					
						
							|  |  |  | //                ['balance_id' => 1, 'balance' => 5],
 | 
					
						
							|  |  |  | //                ['balance_id' => 2, 'balance' => 5],
 | 
					
						
							|  |  |  | //                ['balance_id' => 3, 'balance' => 5],
 | 
					
						
							|  |  |  | //            ]);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //            return $account;
 | 
					
						
							|  |  |  | //        });
 | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $this->collection; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * TODO this method refers to a single-use method inside Steam that could be moved here. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getLastActivity(): void | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |         $lastActivity = $this->repository->getLastActivity($this->collection); | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  |         foreach ($lastActivity as $row) { | 
					
						
							|  |  |  |             $this->collection->where('id', $row['account_id'])->first()->last_activity = Carbon::parse($row['date_max'], config('app.timezone')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * TODO this method refers to a single-use method inside Steam that could be moved here. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getMetaBalances(): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             $array = app('steam')->balancesByAccountsConverted($this->collection, today()); | 
					
						
							|  |  |  |         } catch (FireflyException $e) { | 
					
						
							|  |  |  |             Log::error(sprintf('Could not load balances: %s', $e->getMessage())); | 
					
						
							| 
									
										
										
										
											2024-05-13 05:10:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($array as $accountId => $row) { | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |             $this->collection->where('id', $accountId)->first()->balance        = $row['balance']; | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  |             $this->collection->where('id', $accountId)->first()->native_balance = $row['native_balance']; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * TODO this method refers to a single-use method inside Steam that could be moved here. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function collectAccountTypes(): void | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |         $accountTypes = $this->repository->getAccountTypes($this->collection); | 
					
						
							|  |  |  |         $types        = []; | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var AccountType $row */ | 
					
						
							|  |  |  |         foreach ($accountTypes as $row) { | 
					
						
							|  |  |  |             $types[$row->id] = $row->type; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->collection->transform(function (Account $account) use ($types) { | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |             $account->account_type_string = $types[$account->id]; | 
					
						
							| 
									
										
										
										
											2024-05-13 05:10:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |             return $account; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function collectMetaData(): void | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |         $metaFields  = $this->repository->getMetaValues($this->collection, ['currency_id', 'account_role', 'account_number', 'liability_direction', 'interest', 'interest_period', 'current_debt']); | 
					
						
							|  |  |  |         $currencyIds = $metaFields->where('name', 'currency_id')->pluck('data')->toArray(); | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |         $currencies = []; | 
					
						
							|  |  |  |         foreach ($this->currencyRepository->getByIds($currencyIds) as $currency) { | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |             $id              = $currency->id; | 
					
						
							|  |  |  |             $currencies[$id] = $currency; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->collection->transform(function (Account $account) use ($metaFields, $currencies) { | 
					
						
							|  |  |  |             $set = $metaFields->where('account_id', $account->id); | 
					
						
							|  |  |  |             foreach ($set as $entry) { | 
					
						
							|  |  |  |                 $account->{$entry->name} = $entry->data; | 
					
						
							|  |  |  |                 if ('currency_id' === $entry->name) { | 
					
						
							|  |  |  |                     $id                               = (int) $entry->data; | 
					
						
							| 
									
										
										
										
											2024-07-28 07:47:54 +02:00
										 |  |  |                     $account->currency_name           = $currencies[$id]?->name; | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |                     $account->currency_code           = $currencies[$id]?->code; | 
					
						
							|  |  |  |                     $account->currency_symbol         = $currencies[$id]?->symbol; | 
					
						
							|  |  |  |                     $account->currency_decimal_places = $currencies[$id]?->decimal_places; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-05-13 05:10:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-10 09:17:09 +02:00
										 |  |  |             return $account; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-05-10 06:43:18 +02:00
										 |  |  | } |