| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * AccountRepository.php | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * Copyright (c) 2019 thegrumpydictator@gmail.com | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02: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 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02: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/>. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2016-05-20 08:57:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | namespace FireflyIII\Repositories\Account; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2018-02-21 21:06:59 +01:00
										 |  |  | use FireflyIII\Factory\AccountFactory; | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  | use FireflyIII\Models\AccountMeta; | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  | use FireflyIII\Models\AccountType; | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:49 +01:00
										 |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							| 
									
										
										
										
											2019-06-16 13:16:04 +02:00
										 |  |  | use FireflyIII\Models\TransactionGroup; | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2018-02-21 18:42:15 +01:00
										 |  |  | use FireflyIII\Services\Internal\Destroy\AccountDestroyService; | 
					
						
							| 
									
										
										
										
											2018-02-21 20:34:24 +01:00
										 |  |  | use FireflyIII\Services\Internal\Update\AccountUpdateService; | 
					
						
							| 
									
										
										
										
											2016-03-20 11:47:10 +01:00
										 |  |  | use FireflyIII\User; | 
					
						
							| 
									
										
										
										
											2018-07-24 20:49:25 +02:00
										 |  |  | use Illuminate\Database\Eloquent\Relations\HasMany; | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class AccountRepository. | 
					
						
							| 
									
										
										
										
											2019-08-17 10:47:29 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | class AccountRepository implements AccountRepositoryInterface | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-20 11:47:10 +01:00
										 |  |  |     /** @var User */ | 
					
						
							|  |  |  |     private $user; | 
					
						
							| 
									
										
										
										
											2016-03-30 17:47:13 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-03 08:41:03 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Constructor. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:49 +01:00
										 |  |  |         if ('testing' === config('app.env')) { | 
					
						
							| 
									
										
										
										
											2019-06-07 18:20:15 +02:00
										 |  |  |             Log::warning(sprintf('%s should not be instantiated in the TEST environment!', get_class($this))); | 
					
						
							| 
									
										
										
										
											2018-09-03 08:41:03 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function count(array $types): int | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->user->accounts()->accountTypeIn($types)->count(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-09 08:20:29 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Moved here from account CRUD. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param Account      $account | 
					
						
							| 
									
										
										
										
											2018-02-23 16:21:28 +01:00
										 |  |  |      * @param Account|null $moveTo | 
					
						
							| 
									
										
										
										
											2016-10-09 08:20:29 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							| 
									
										
										
										
											2017-12-22 18:32:43 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-09 08:20:29 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-23 16:21:28 +01:00
										 |  |  |     public function destroy(Account $account, ?Account $moveTo): bool | 
					
						
							| 
									
										
										
										
											2016-10-09 08:20:29 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-02-21 18:42:15 +01:00
										 |  |  |         /** @var AccountDestroyService $service */ | 
					
						
							|  |  |  |         $service = app(AccountDestroyService::class); | 
					
						
							|  |  |  |         $service->destroy($account, $moveTo); | 
					
						
							| 
									
										
										
										
											2016-10-09 08:20:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Find account with same name OR same IBAN or both, but not the same type or ID. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function expandWithDoubles(Collection $accounts): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = new Collection; | 
					
						
							|  |  |  |         /** @var Account $account */ | 
					
						
							|  |  |  |         foreach ($accounts as $account) { | 
					
						
							|  |  |  |             $byName = $this->user->accounts()->where('name', $account->name) | 
					
						
							|  |  |  |                                  ->where('id', '!=', $account->id)->first(); | 
					
						
							|  |  |  |             if (null !== $byName) { | 
					
						
							|  |  |  |                 $result->push($account); | 
					
						
							|  |  |  |                 $result->push($byName); | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (null !== $account->iban) { | 
					
						
							|  |  |  |                 $byIban = $this->user->accounts()->where('iban', $account->iban) | 
					
						
							|  |  |  |                                      ->where('id', '!=', $account->id)->first(); | 
					
						
							|  |  |  |                 if (null !== $byIban) { | 
					
						
							|  |  |  |                     $result->push($account); | 
					
						
							|  |  |  |                     $result->push($byIban); | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $result->push($account); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $number | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param array  $types | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return Account|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function findByAccountNumber(string $number, array $types): ?Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $query = $this->user->accounts() | 
					
						
							|  |  |  |                             ->leftJoin('account_meta', 'account_meta.account_id', '=', 'accounts.id') | 
					
						
							| 
									
										
										
										
											2019-07-31 16:53:09 +02:00
										 |  |  |                             ->where('account_meta.name', 'account_number') | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |                             ->where('account_meta.data', json_encode($number)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->leftJoin('account_types', 'accounts.account_type_id', '=', 'account_types.id'); | 
					
						
							|  |  |  |             $query->whereIn('account_types.type', $types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var Collection $accounts */ | 
					
						
							|  |  |  |         $accounts = $query->get(['accounts.*']); | 
					
						
							|  |  |  |         if ($accounts->count() > 0) { | 
					
						
							|  |  |  |             return $accounts->first(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $iban | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param array  $types | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return Account|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function findByIbanNull(string $iban, array $types): ?Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $query = $this->user->accounts()->where('iban', '!=', '')->whereNotNull('iban'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->leftJoin('account_types', 'accounts.account_type_id', '=', 'account_types.id'); | 
					
						
							|  |  |  |             $query->whereIn('account_types.type', $types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-06 05:39:05 +02:00
										 |  |  |         // TODO a loop like this is no longer necessary
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |         $accounts = $query->get(['accounts.*']); | 
					
						
							|  |  |  |         /** @var Account $account */ | 
					
						
							|  |  |  |         foreach ($accounts as $account) { | 
					
						
							|  |  |  |             if ($account->iban === $iban) { | 
					
						
							|  |  |  |                 return $account; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $name | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param array  $types | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return Account|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function findByName(string $name, array $types): ?Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $query = $this->user->accounts(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->leftJoin('account_types', 'accounts.account_type_id', '=', 'account_types.id'); | 
					
						
							|  |  |  |             $query->whereIn('account_types.type', $types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Log::debug(sprintf('Searching for account named "%s" (of user #%d) of the following type(s)', $name, $this->user->id), ['types' => $types]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $accounts = $query->get(['accounts.*']); | 
					
						
							| 
									
										
										
										
											2019-08-03 19:17:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // TODO no longer need to loop like this
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |         /** @var Account $account */ | 
					
						
							|  |  |  |         foreach ($accounts as $account) { | 
					
						
							|  |  |  |             if ($account->name === $name) { | 
					
						
							|  |  |  |                 Log::debug(sprintf('Found #%d (%s) with type id %d', $account->id, $account->name, $account->account_type_id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $account; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Log::debug(sprintf('There is no account with name "%s" of types', $name), $types); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-16 15:19:19 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param int $accountId | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Account|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function findNull(int $accountId): ?Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->user->accounts()->find($accountId); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:49 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return TransactionCurrency|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAccountCurrency(Account $account): ?TransactionCurrency | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $currencyId = (int)$this->getMetaValue($account, 'currency_id'); | 
					
						
							|  |  |  |         if ($currencyId > 0) { | 
					
						
							|  |  |  |             return TransactionCurrency::find($currencyId); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAccountType(Account $account): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $account->accountType->type; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:30:47 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Return account type or null if not found. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $type | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return AccountType|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAccountTypeByType(string $type): ?AccountType | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return AccountType::whereType($type)->first(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $accountIds | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAccountsById(array $accountIds): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var Collection $result */ | 
					
						
							|  |  |  |         $query = $this->user->accounts(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-04 20:58:43 +02:00
										 |  |  |         if (count($accountIds) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->whereIn('accounts.id', $accountIds); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-06-23 05:53:01 +02:00
										 |  |  |         $query->orderBy('accounts.active', 'DESC'); | 
					
						
							| 
									
										
										
										
											2019-06-10 20:14:00 +02:00
										 |  |  |         $query->orderBy('accounts.name', 'ASC'); | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $result = $query->get(['accounts.*']); | 
					
						
							| 
									
										
										
										
											2019-06-10 20:14:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAccountsByType(array $types): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var Collection $result */ | 
					
						
							|  |  |  |         $query = $this->user->accounts(); | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->accountTypeIn($types); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-06-23 05:53:01 +02:00
										 |  |  |         $query->orderBy('accounts.active', 'DESC'); | 
					
						
							| 
									
										
										
										
											2019-06-10 20:14:00 +02:00
										 |  |  |         $query->orderBy('accounts.name', 'ASC'); | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |         $result = $query->get(['accounts.*']); | 
					
						
							| 
									
										
										
										
											2019-05-04 20:58:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getActiveAccountsByType(array $types): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var Collection $result */ | 
					
						
							|  |  |  |         $query = $this->user->accounts()->with( | 
					
						
							|  |  |  |             ['accountmeta' => function (HasMany $query) { | 
					
						
							| 
									
										
										
										
											2019-07-05 19:43:16 +02:00
										 |  |  |                 $query->where('name', 'account_role'); | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             }] | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |             $query->accountTypeIn($types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $query->where('active', 1); | 
					
						
							| 
									
										
										
										
											2019-06-10 20:14:00 +02:00
										 |  |  |         $query->orderBy('accounts.account_type_id', 'ASC'); | 
					
						
							|  |  |  |         $query->orderBy('accounts.name', 'ASC'); | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-19 19:17:14 +02:00
										 |  |  |         return $query->get(['accounts.*']); | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return Account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getCashAccount(): Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var AccountType $type */ | 
					
						
							|  |  |  |         $type = AccountType::where('type', AccountType::CASH)->first(); | 
					
						
							|  |  |  |         /** @var AccountFactory $factory */ | 
					
						
							|  |  |  |         $factory = app(AccountFactory::class); | 
					
						
							|  |  |  |         $factory->setUser($this->user); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $factory->findOrCreate('Cash account', $type->type); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 08:17:31 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Return meta value for account. Null if not found. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param string  $field | 
					
						
							| 
									
										
										
										
											2018-03-19 08:17:31 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return null|string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getMetaValue(Account $account, string $field): ?string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |         /** @var AccountMeta $meta */ | 
					
						
							|  |  |  |         $meta = $account->accountMeta()->where('name', $field)->first(); | 
					
						
							|  |  |  |         if (null === $meta) { | 
					
						
							|  |  |  |             return null; | 
					
						
							| 
									
										
										
										
											2018-03-19 08:17:31 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |         return (string)$meta->data; | 
					
						
							| 
									
										
										
										
											2018-03-19 08:17:31 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 19:39:02 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get note text or null. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return null|string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getNoteText(Account $account): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $note = $account->notes()->first(); | 
					
						
							| 
									
										
										
										
											2018-08-05 18:59:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         if (null === $note) { | 
					
						
							| 
									
										
										
										
											2018-03-19 19:39:02 +01:00
										 |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-08-06 19:14:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 19:39:02 +01:00
										 |  |  |         return $note->text; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return TransactionJournal|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getOpeningBalance(Account $account): ?TransactionJournal | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return TransactionJournal | 
					
						
							|  |  |  |             ::leftJoin('transactions', 'transactions.transaction_journal_id', '=', 'transaction_journals.id') | 
					
						
							|  |  |  |             ->where('transactions.account_id', $account->id) | 
					
						
							|  |  |  |             ->transactionTypes([TransactionType::OPENING_BALANCE]) | 
					
						
							|  |  |  |             ->first(['transaction_journals.*']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-16 22:14:53 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns the amount of the opening balance for this account. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-02-28 21:32:59 +01:00
										 |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-02-16 22:14:53 +01:00
										 |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getOpeningBalanceAmount(Account $account): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $journal = TransactionJournal::leftJoin('transactions', 'transactions.transaction_journal_id', '=', 'transaction_journals.id') | 
					
						
							|  |  |  |                                      ->where('transactions.account_id', $account->id) | 
					
						
							|  |  |  |                                      ->transactionTypes([TransactionType::OPENING_BALANCE]) | 
					
						
							|  |  |  |                                      ->first(['transaction_journals.*']); | 
					
						
							|  |  |  |         if (null === $journal) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $transaction = $journal->transactions()->where('account_id', $account->id)->first(); | 
					
						
							|  |  |  |         if (null === $transaction) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         return (string)$transaction->amount; | 
					
						
							| 
									
										
										
										
											2018-02-16 22:14:53 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Return date of opening balance as string or null. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return null|string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getOpeningBalanceDate(Account $account): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $journal = TransactionJournal::leftJoin('transactions', 'transactions.transaction_journal_id', '=', 'transaction_journals.id') | 
					
						
							|  |  |  |                                      ->where('transactions.account_id', $account->id) | 
					
						
							|  |  |  |                                      ->transactionTypes([TransactionType::OPENING_BALANCE]) | 
					
						
							|  |  |  |                                      ->first(['transaction_journals.*']); | 
					
						
							|  |  |  |         if (null === $journal) { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $journal->date->format('Y-m-d'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return TransactionGroup|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getOpeningBalanceGroup(Account $account): ?TransactionGroup | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $journal = $this->getOpeningBalance($account); | 
					
						
							|  |  |  |         $group   = null; | 
					
						
							|  |  |  |         if (null !== $journal) { | 
					
						
							|  |  |  |             $group = $journal->transactionGroup; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $group; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-09 13:09:43 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getPiggyBanks(Account $account): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $account->piggyBanks()->get(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Account|null | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getReconciliation(Account $account): ?Account | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (AccountType::ASSET !== $account->accountType->type) { | 
					
						
							|  |  |  |             throw new FireflyException(sprintf('%s is not an asset account.', $account->name)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $name = $account->name . ' reconciliation'; | 
					
						
							|  |  |  |         /** @var AccountType $type */ | 
					
						
							|  |  |  |         $type     = AccountType::where('type', AccountType::RECONCILIATION)->first(); | 
					
						
							|  |  |  |         $accounts = $this->user->accounts()->where('account_type_id', $type->id)->get(); | 
					
						
							| 
									
										
										
										
											2019-08-03 19:17:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // TODO no longer need to loop like this
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 21:49:15 +02:00
										 |  |  |         /** @var Account $current */ | 
					
						
							|  |  |  |         foreach ($accounts as $current) { | 
					
						
							|  |  |  |             if ($current->name === $name) { | 
					
						
							|  |  |  |                 return $current; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /** @var AccountFactory $factory */ | 
					
						
							|  |  |  |         $factory = app(AccountFactory::class); | 
					
						
							|  |  |  |         $factory->setUser($account->user); | 
					
						
							|  |  |  |         $account = $factory->findOrCreate($name, $type->type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $account; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 21:18:15 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function isLiability(Account $account): bool | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-06-21 19:10:02 +02:00
										 |  |  |         return in_array($account->accountType->type, [AccountType::CREDITCARD, AccountType::LOAN, AccountType::DEBT, AccountType::MORTGAGE], true); | 
					
						
							| 
									
										
										
										
											2018-08-22 21:18:15 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-21 20:23:25 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns the date of the very first transaction in this account. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2018-08-04 17:30:47 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-24 20:30:52 +02:00
										 |  |  |      * @return TransactionJournal|null | 
					
						
							| 
									
										
										
										
											2016-11-21 20:23:25 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-24 20:30:52 +02:00
										 |  |  |     public function oldestJournal(Account $account): ?TransactionJournal | 
					
						
							| 
									
										
										
										
											2016-11-21 20:23:25 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |         $first = $account->transactions() | 
					
						
							| 
									
										
										
										
											2016-11-21 20:23:25 +01:00
										 |  |  |                          ->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | 
					
						
							|  |  |  |                          ->orderBy('transaction_journals.date', 'ASC') | 
					
						
							|  |  |  |                          ->orderBy('transaction_journals.order', 'DESC') | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |                          ->where('transaction_journals.user_id', $this->user->id) | 
					
						
							| 
									
										
										
										
											2016-11-21 20:23:25 +01:00
										 |  |  |                          ->orderBy('transaction_journals.id', 'ASC') | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |                          ->first(['transaction_journals.id']); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (null !== $first) { | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             return TransactionJournal::find((int)$first->id); | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-24 20:30:52 +02:00
										 |  |  |         return null; | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Returns the date of the very first transaction in this account. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:10 +02:00
										 |  |  |      * @return Carbon|null | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:10 +02:00
										 |  |  |     public function oldestJournalDate(Account $account): ?Carbon | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:10 +02:00
										 |  |  |         $result  = null; | 
					
						
							| 
									
										
										
										
											2017-01-19 21:54:27 +01:00
										 |  |  |         $journal = $this->oldestJournal($account); | 
					
						
							| 
									
										
										
										
											2018-07-24 20:30:52 +02:00
										 |  |  |         if (null !== $journal) { | 
					
						
							| 
									
										
										
										
											2018-03-29 19:01:47 +02:00
										 |  |  |             $result = $journal->date; | 
					
						
							| 
									
										
										
										
											2016-04-08 14:50:18 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 19:01:47 +02:00
										 |  |  |         return $result; | 
					
						
							| 
									
										
										
										
											2016-04-08 14:50:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-02 14:12:09 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $query | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param array  $types | 
					
						
							| 
									
										
										
										
											2019-03-02 14:12:09 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function searchAccount(string $query, array $types): Collection | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-08-29 17:53:25 +02:00
										 |  |  |         $dbQuery = $this->user->accounts() | 
					
						
							|  |  |  |                               ->where('active', 1) | 
					
						
							|  |  |  |                               ->with(['accountType']); | 
					
						
							| 
									
										
										
										
											2019-05-04 20:58:43 +02:00
										 |  |  |         if ('' !== $query) { | 
					
						
							|  |  |  |             $search = sprintf('%%%s%%', $query); | 
					
						
							|  |  |  |             $dbQuery->where('name', 'LIKE', $search); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (count($types) > 0) { | 
					
						
							| 
									
										
										
										
											2019-03-02 14:12:09 +01:00
										 |  |  |             $dbQuery->leftJoin('account_types', 'accounts.account_type_id', '=', 'account_types.id'); | 
					
						
							|  |  |  |             $dbQuery->whereIn('account_types.type', $types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $dbQuery->get(['accounts.*']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-30 16:42:58 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param User $user | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-22 18:50:27 +02:00
										 |  |  |     public function setUser(User $user): void | 
					
						
							| 
									
										
										
										
											2017-01-30 16:42:58 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $this->user = $user; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $data | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Account | 
					
						
							| 
									
										
										
										
											2019-07-31 16:53:09 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function store(array $data): Account | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-02-21 21:06:59 +01:00
										 |  |  |         /** @var AccountFactory $factory */ | 
					
						
							|  |  |  |         $factory = app(AccountFactory::class); | 
					
						
							|  |  |  |         $factory->setUser($this->user); | 
					
						
							| 
									
										
										
										
											2017-12-30 21:04:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         return $factory->create($data); | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2019-08-24 07:56:08 +02:00
										 |  |  |      * @param array   $data | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return Account | 
					
						
							| 
									
										
										
										
											2019-07-31 16:53:09 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function update(Account $account, array $data): Account | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-02-21 20:34:24 +01:00
										 |  |  |         /** @var AccountUpdateService $service */ | 
					
						
							|  |  |  |         $service = app(AccountUpdateService::class); | 
					
						
							| 
									
										
										
										
											2018-02-21 21:11:44 +01:00
										 |  |  |         $account = $service->update($account, $data); | 
					
						
							| 
									
										
										
										
											2016-10-10 08:03:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $account; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-10-19 19:17:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getInactiveAccountsByType(array $types): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var Collection $result */ | 
					
						
							|  |  |  |         $query = $this->user->accounts()->with( | 
					
						
							|  |  |  |             ['accountmeta' => function (HasMany $query) { | 
					
						
							|  |  |  |                 $query->where('name', 'account_role'); | 
					
						
							|  |  |  |             }] | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         if (count($types) > 0) { | 
					
						
							|  |  |  |             $query->accountTypeIn($types); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $query->where('active', 0); | 
					
						
							|  |  |  |         $query->orderBy('accounts.account_type_id', 'ASC'); | 
					
						
							|  |  |  |         $query->orderBy('accounts.name', 'ASC'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $query->get(['accounts.*']); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-03-29 08:14:32 +02:00
										 |  |  | } |