| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * AccountCollection.php | 
					
						
							|  |  |  |  * Copyright (c) 2020 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | namespace FireflyIII\Helpers\Collector\Extensions; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use FireflyIII\Helpers\Collector\GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2024-12-23 08:22:54 +01:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							|  |  |  | use FireflyIII\Support\Facades\Steam; | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Builder as EloquentBuilder; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2024-12-23 08:22:54 +01:00
										 |  |  | use Illuminate\Support\Facades\Log; | 
					
						
							| 
									
										
										
										
											2025-05-27 16:57:36 +02:00
										 |  |  | use Override; | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Trait AccountCollection | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | trait AccountCollection | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2025-05-27 16:57:36 +02:00
										 |  |  |     #[Override]
 | 
					
						
							| 
									
										
										
										
											2025-05-04 17:41:26 +02:00
										 |  |  |     public function accountBalanceIs(string $direction, string $operator, string $value): GroupCollectorInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Log::warning(sprintf('GroupCollector will be SLOW: accountBalanceIs: "%s" "%s" "%s"', $direction, $operator, $value)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * @param array $object | 
					
						
							|  |  |  |          * | 
					
						
							|  |  |  |          * @return bool | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         $filter              = static function (array $object) use ($direction, $operator, $value): bool { | 
					
						
							|  |  |  |             /** @var array $transaction */ | 
					
						
							|  |  |  |             foreach ($object['transactions'] as $transaction) { | 
					
						
							|  |  |  |                 $key       = sprintf('%s_account_id', $direction); | 
					
						
							|  |  |  |                 $accountId = $transaction[$key] ?? 0; | 
					
						
							|  |  |  |                 if (0 === $accountId) { | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // in theory, this could lead to finding other users accounts.
 | 
					
						
							|  |  |  |                 /** @var null|Account $account */ | 
					
						
							|  |  |  |                 $account   = Account::find($accountId); | 
					
						
							|  |  |  |                 if (null === $account) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 // the balance must be found BEFORE the transaction date.
 | 
					
						
							|  |  |  |                 // so sub one second. This is not perfect, but works well enough.
 | 
					
						
							|  |  |  |                 $date      = clone $transaction['date']; | 
					
						
							|  |  |  |                 $date->subSecond(); | 
					
						
							|  |  |  |                 Log::debug(sprintf('accountBalanceIs: Call finalAccountBalance with date/time "%s"', $date->toIso8601String())); | 
					
						
							|  |  |  |                 $balance   = Steam::finalAccountBalance($account, $date); | 
					
						
							|  |  |  |                 $result    = bccomp((string) $balance['balance'], $value); | 
					
						
							|  |  |  |                 Log::debug(sprintf('"%s" vs "%s" is %d', $balance['balance'], $value, $result)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 switch ($operator) { | 
					
						
							|  |  |  |                     default: | 
					
						
							|  |  |  |                         Log::error(sprintf('GroupCollector: accountBalanceIs: unknown operator "%s"', $operator)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '==': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be 0 (equal)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return 0 === $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '!=': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be -1 or 1 (not equal)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return 0 !== $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '>': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be 1 (greater then)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return 1 === $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '>=': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be 0 or 1 (greater then or equal)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return -1 !== $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '<': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be -1 (less than)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return -1 === $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     case '<=': | 
					
						
							|  |  |  |                         Log::debug('Expect result to be -1 or 0 (less than or equal)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         return 1 !== $result; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 // if($balance['balance'] $operator $value) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // }
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         $this->postFilters[] = $filter; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * These accounts must not be included. | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function excludeAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             $this->query->whereNotIn('source.account_id', $accountIds); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |             $this->query->whereNotIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             app('log')->debug(sprintf('GroupCollector: excludeAccounts: %s', implode(', ', $accountIds))); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * These accounts must not be destination accounts. | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function excludeDestinationAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             $this->query->whereNotIn('destination.account_id', $accountIds); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             app('log')->debug(sprintf('GroupCollector: excludeDestinationAccounts: %s', implode(', ', $accountIds))); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * These accounts must not be source accounts. | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function excludeSourceAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |             $this->query->whereNotIn('source.account_id', $accountIds); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             app('log')->debug(sprintf('GroupCollector: excludeSourceAccounts: %s', implode(', ', $accountIds))); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Define which accounts can be part of the source and destination transactions. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |             $this->query->where( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                 static function (EloquentBuilder $query) use ($accountIds): void { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |                     $query->whereIn('source.account_id', $accountIds); | 
					
						
							|  |  |  |                     $query->orWhereIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             // app('log')->debug(sprintf('GroupCollector: setAccounts: %s', implode(', ', $accountIds)));
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * Both source AND destination must be in this list of accounts. | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function setBothAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |             $this->query->where( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                 static function (EloquentBuilder $query) use ($accountIds): void { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |                     $query->whereIn('source.account_id', $accountIds); | 
					
						
							|  |  |  |                     $query->whereIn('destination.account_id', $accountIds); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:07 +02:00
										 |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             app('log')->debug(sprintf('GroupCollector: setBothAccounts: %s', implode(', ', $accountIds))); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * Define which accounts can be part of the source and destination transactions. | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function setDestinationAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             $this->query->whereIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             app('log')->debug(sprintf('GroupCollector: setDestinationAccounts: %s', implode(', ', $accountIds))); | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |      * Define which accounts can NOT be part of the source and destination transactions. | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |     public function setNotAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |             $this->query->where( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                 static function (EloquentBuilder $query) use ($accountIds): void { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2022-09-25 15:31:58 +02:00
										 |  |  |                     $query->whereNotIn('source.account_id', $accountIds); | 
					
						
							|  |  |  |                     $query->whereNotIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             // app('log')->debug(sprintf('GroupCollector: setAccounts: %s', implode(', ', $accountIds)));
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Define which accounts can be part of the source and destination transactions. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setSourceAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |             $this->query->whereIn('source.account_id', $accountIds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             app('log')->debug(sprintf('GroupCollector: setSourceAccounts: %s', implode(', ', $accountIds))); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Either account can be set, but NOT both. This effectively excludes internal transfers. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setXorAccounts(Collection $accounts): GroupCollectorInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             $accountIds = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |             $this->query->where( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                 static function (EloquentBuilder $q1) use ($accountIds): void { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |                     // sourceAccount is in the set, and destination is NOT.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     $q1->where( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                         static function (EloquentBuilder $q2) use ($accountIds): void { | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |                             $q2->whereIn('source.account_id', $accountIds); | 
					
						
							|  |  |  |                             $q2->whereNotIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     ); | 
					
						
							|  |  |  |                     // destination is in the set, and source is NOT
 | 
					
						
							|  |  |  |                     $q1->orWhere( | 
					
						
							| 
									
										
										
										
											2023-12-21 05:07:26 +01:00
										 |  |  |                         static function (EloquentBuilder $q3) use ($accountIds): void { | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |                             $q3->whereNotIn('source.account_id', $accountIds); | 
					
						
							|  |  |  |                             $q3->whereIn('destination.account_id', $accountIds); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             app('log')->debug(sprintf('GroupCollector: setXorAccounts: %s', implode(', ', $accountIds))); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Will include the source and destination account names and types. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withAccountInformation(): GroupCollectorInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (false === $this->hasAccountInfo) { | 
					
						
							|  |  |  |             // join source account table
 | 
					
						
							|  |  |  |             $this->query->leftJoin('accounts as source_account', 'source_account.id', '=', 'source.account_id'); | 
					
						
							|  |  |  |             // join source account type table
 | 
					
						
							|  |  |  |             $this->query->leftJoin('account_types as source_account_type', 'source_account_type.id', '=', 'source_account.account_type_id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // add source account fields:
 | 
					
						
							| 
									
										
										
										
											2024-12-23 08:40:29 +01:00
										 |  |  |             $this->fields[]       = 'source_account.name as source_account_name'; | 
					
						
							|  |  |  |             $this->fields[]       = 'source_account.iban as source_account_iban'; | 
					
						
							|  |  |  |             $this->fields[]       = 'source_account_type.type as source_account_type'; | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // same for dest
 | 
					
						
							|  |  |  |             $this->query->leftJoin('accounts as dest_account', 'dest_account.id', '=', 'destination.account_id'); | 
					
						
							|  |  |  |             $this->query->leftJoin('account_types as dest_account_type', 'dest_account_type.id', '=', 'dest_account.account_type_id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // and add fields:
 | 
					
						
							| 
									
										
										
										
											2022-03-21 06:31:38 +01:00
										 |  |  |             $this->fields[]       = 'dest_account.name as destination_account_name'; | 
					
						
							|  |  |  |             $this->fields[]       = 'dest_account.iban as destination_account_iban'; | 
					
						
							|  |  |  |             $this->fields[]       = 'dest_account_type.type as destination_account_type'; | 
					
						
							| 
									
										
										
										
											2020-03-21 08:54:38 +01:00
										 |  |  |             $this->hasAccountInfo = true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-05-30 07:33:06 +02:00
										 |  |  | } |