| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * UserNavigation.php | 
					
						
							| 
									
										
										
										
											2020-02-16 13:56:52 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +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. | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +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. | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +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/>. | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Support\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  | use FireflyIII\Models\AccountType; | 
					
						
							|  |  |  | use FireflyIII\Models\Transaction; | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  | use FireflyIII\Models\TransactionGroup; | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  | use Illuminate\Http\RedirectResponse; | 
					
						
							|  |  |  | use Illuminate\Routing\Redirector; | 
					
						
							| 
									
										
										
										
											2019-09-14 06:26:25 +02:00
										 |  |  | use Illuminate\Support\Str; | 
					
						
							| 
									
										
										
										
											2018-10-17 06:05:19 +02:00
										 |  |  | use Illuminate\Support\ViewErrorBag; | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Trait UserNavigation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | trait UserNavigation | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Functionality:. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * - If the $identifier contains the word "delete" then a remembered uri with the text "/show/" in it will not be returned but instead the index (/) | 
					
						
							|  |  |  |      *   will be returned. | 
					
						
							|  |  |  |      * - If the remembered uri contains "jscript/" the remembered uri will not be returned but instead the index (/) will be returned. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $identifier | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function getPreviousUri(string $identifier): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Log::debug(sprintf('Trying to retrieve URL stored under "%s"', $identifier)); | 
					
						
							|  |  |  |         $uri = (string)session($identifier); | 
					
						
							|  |  |  |         Log::debug(sprintf('The URI is %s', $uri)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (false !== strpos($uri, 'jscript')) { | 
					
						
							|  |  |  |             $uri = $this->redirectUri; // @codeCoverageIgnore
 | 
					
						
							|  |  |  |             Log::debug(sprintf('URI is now %s (uri contains jscript)', $uri)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Log::debug(sprintf('Return direct link %s', $uri)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $uri; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |      * Will return false if you cant edit this account type. | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |      * @return bool | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |     protected function isEditableAccount(Account $account): bool | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         $editable = [AccountType::EXPENSE, AccountType::REVENUE, AccountType::ASSET, AccountType::LOAN, AccountType::DEBT, AccountType::MORTGAGE]; | 
					
						
							|  |  |  |         $type     = $account->accountType->type; | 
					
						
							| 
									
										
										
										
											2019-08-01 06:22:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         return in_array($type, $editable, true); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionGroup $group | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function isEditableGroup(TransactionGroup $group): bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var TransactionJournal $journal */ | 
					
						
							|  |  |  |         $journal = $group->transactionJournals()->first(); | 
					
						
							|  |  |  |         if (null === $journal) { | 
					
						
							|  |  |  |             return false; | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         $type     = $journal->transactionType->type; | 
					
						
							| 
									
										
										
										
											2019-11-13 06:57:17 +01:00
										 |  |  |         $editable = [TransactionType::WITHDRAWAL, TransactionType::TRANSFER, TransactionType::DEPOSIT, TransactionType::RECONCILIATION]; | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         return in_array($type, $editable, true); | 
					
						
							| 
									
										
										
										
											2018-08-09 16:07:33 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |      * @return RedirectResponse|Redirector | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |     protected function redirectAccountToAccount(Account $account) | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         $type = $account->accountType->type; | 
					
						
							|  |  |  |         if (AccountType::RECONCILIATION === $type || AccountType::INITIAL_BALANCE === $type) { | 
					
						
							|  |  |  |             // reconciliation must be stored somewhere in this account's transactions.
 | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |             /** @var Transaction $transaction */ | 
					
						
							|  |  |  |             $transaction = $account->transactions()->first(); | 
					
						
							|  |  |  |             if (null === $transaction) { | 
					
						
							|  |  |  |                 Log::error(sprintf('Account #%d has no transactions. Dont know where it belongs.', $account->id)); | 
					
						
							|  |  |  |                 session()->flash('error', trans('firefly.cant_find_redirect_account')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return redirect(route('index')); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $journal = $transaction->transactionJournal; | 
					
						
							|  |  |  |             /** @var Transaction $other */ | 
					
						
							|  |  |  |             $other = $journal->transactions()->where('id', '!=', $transaction->id)->first(); | 
					
						
							|  |  |  |             if (null === $other) { | 
					
						
							|  |  |  |                 Log::error(sprintf('Account #%d has no valid journals. Dont know where it belongs.', $account->id)); | 
					
						
							|  |  |  |                 session()->flash('error', trans('firefly.cant_find_redirect_account')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return redirect(route('index')); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return redirect(route('accounts.show', [$other->account_id])); | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |         return redirect(route('index')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |      * @param TransactionGroup $group | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |      * @return RedirectResponse|Redirector | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |     protected function redirectGroupToAccount(TransactionGroup $group) | 
					
						
							| 
									
										
										
										
											2019-08-17 08:29:35 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |         /** @var TransactionJournal $journal */ | 
					
						
							|  |  |  |         $journal = $group->transactionJournals()->first(); | 
					
						
							|  |  |  |         if (null === $journal) { | 
					
						
							|  |  |  |             Log::error(sprintf('No journals in group #%d', $group->id)); | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |             return redirect(route('index')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // prefer redirect to everything but expense and revenue:
 | 
					
						
							|  |  |  |         $transactions = $journal->transactions; | 
					
						
							|  |  |  |         $ignore       = [AccountType::REVENUE, AccountType::EXPENSE, AccountType::RECONCILIATION, AccountType::INITIAL_BALANCE]; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($transactions as $transaction) { | 
					
						
							|  |  |  |             $type = $transaction->account->accountType->type; | 
					
						
							|  |  |  |             if (!in_array($type, $ignore, true)) { | 
					
						
							|  |  |  |                 return redirect(route('accounts.edit', [$transaction->account_id])); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |         return redirect(route('index')); | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $identifier | 
					
						
							| 
									
										
										
										
											2019-08-05 19:45:20 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return string|null | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-08-05 19:45:20 +02:00
										 |  |  |     protected function rememberPreviousUri(string $identifier): ?string | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-12-02 17:32:57 +01:00
										 |  |  |         $return = app('url')->previous(); | 
					
						
							| 
									
										
										
										
											2018-10-17 06:05:19 +02:00
										 |  |  |         /** @var ViewErrorBag $errors */ | 
					
						
							| 
									
										
										
										
											2019-09-14 06:26:25 +02:00
										 |  |  |         $errors    = session()->get('errors'); | 
					
						
							| 
									
										
										
										
											2019-12-22 06:23:13 +01:00
										 |  |  |         $forbidden = ['json', 'debug']; | 
					
						
							| 
									
										
										
										
											2019-09-14 06:26:25 +02:00
										 |  |  |         if ((null === $errors || (null !== $errors && 0 === $errors->count())) && !Str::contains($return, $forbidden)) { | 
					
						
							| 
									
										
										
										
											2019-12-02 17:32:57 +01:00
										 |  |  |             Log::debug(sprintf('Saving URL %s under key %s', $return, $identifier)); | 
					
						
							| 
									
										
										
										
											2019-08-05 19:45:20 +02:00
										 |  |  |             session()->put($identifier, $return); | 
					
						
							| 
									
										
										
										
											2018-10-17 06:05:19 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-05 19:45:20 +02:00
										 |  |  |         return $return; | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-12-31 07:48:23 +01:00
										 |  |  | } |