| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2024-12-21 12:27:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  | /* | 
					
						
							|  |  |  |  * PreferencesEventHandler.php | 
					
						
							|  |  |  |  * Copyright (c) 2024 james@firefly-iii.org. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see https://www.gnu.org/licenses/. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Handlers\Events; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use FireflyIII\Events\Preferences\UserGroupChangedDefaultCurrency; | 
					
						
							|  |  |  | use FireflyIII\Models\Budget; | 
					
						
							|  |  |  | use FireflyIII\Models\PiggyBank; | 
					
						
							|  |  |  | use FireflyIII\Models\UserGroup; | 
					
						
							| 
									
										
										
										
											2025-03-08 15:10:24 +01:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\PiggyBank\PiggyBankRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  | use FireflyIII\Support\Facades\Amount; | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  | use Illuminate\Database\Query\Builder; | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  | use Illuminate\Support\Facades\Artisan; | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  | use Illuminate\Support\Facades\DB; | 
					
						
							|  |  |  | use Illuminate\Support\Facades\Log; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class PreferencesEventHandler | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     public function resetNativeAmounts(UserGroupChangedDefaultCurrency $event): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Reset the native amounts for all objects that have it.
 | 
					
						
							|  |  |  |         Log::debug('Resetting native amounts for all objects.'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $tables = [ | 
					
						
							|  |  |  |             // !!! this array is also in the migration
 | 
					
						
							|  |  |  |             'accounts'          => ['native_virtual_balance'], | 
					
						
							|  |  |  |             'available_budgets' => ['native_amount'], | 
					
						
							|  |  |  |             'bills'             => ['native_amount_min', 'native_amount_max'], | 
					
						
							| 
									
										
										
										
											2024-12-21 12:27:07 +01:00
										 |  |  |             // 'transactions' => ['native_amount', 'native_foreign_amount']
 | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         foreach ($tables as $table => $columns) { | 
					
						
							|  |  |  |             foreach ($columns as $column) { | 
					
						
							|  |  |  |                 Log::debug(sprintf('Resetting column %s in table %s.', $column, $table)); | 
					
						
							|  |  |  |                 DB::table($table)->where('user_group_id', $event->userGroup->id)->update([$column => null]); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->resetPiggyBanks($event->userGroup); | 
					
						
							|  |  |  |         $this->resetBudgets($event->userGroup); | 
					
						
							|  |  |  |         $this->resetTransactions($event->userGroup); | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  |         // fire laravel command to recalculate them all.
 | 
					
						
							|  |  |  |         if (Amount::convertToNative()) { | 
					
						
							| 
									
										
										
										
											2025-02-01 13:01:13 +01:00
										 |  |  |             Log::debug('Will now convert to native.'); | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  |             Artisan::call('correction:recalculate-native-amounts'); | 
					
						
							| 
									
										
										
										
											2025-02-01 19:06:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-01 13:01:13 +01:00
										 |  |  |             return; | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-02-01 13:01:13 +01:00
										 |  |  |         Log::debug('Will NOT convert to native.'); | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function resetPiggyBanks(UserGroup $userGroup): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $repository = app(PiggyBankRepositoryInterface::class); | 
					
						
							|  |  |  |         $repository->setUserGroup($userGroup); | 
					
						
							|  |  |  |         $piggyBanks = $repository->getPiggyBanks(); | 
					
						
							| 
									
										
										
										
											2024-12-21 12:27:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |         /** @var PiggyBank $piggyBank */ | 
					
						
							|  |  |  |         foreach ($piggyBanks as $piggyBank) { | 
					
						
							|  |  |  |             if (null !== $piggyBank->native_target_amount) { | 
					
						
							|  |  |  |                 Log::debug(sprintf('Resetting native_target_amount for piggy bank #%d.', $piggyBank->id)); | 
					
						
							|  |  |  |                 $piggyBank->native_target_amount = null; | 
					
						
							|  |  |  |                 $piggyBank->saveQuietly(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             foreach ($piggyBank->accounts as $account) { | 
					
						
							|  |  |  |                 if (null !== $account->pivot->native_current_amount) { | 
					
						
							|  |  |  |                     Log::debug(sprintf('Resetting native_current_amount for piggy bank #%d and account #%d.', $piggyBank->id, $account->id)); | 
					
						
							|  |  |  |                     $account->pivot->native_current_amount = null; | 
					
						
							|  |  |  |                     $account->pivot->save(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             foreach ($piggyBank->piggyBankEvents as $event) { | 
					
						
							|  |  |  |                 if (null !== $event->native_amount) { | 
					
						
							|  |  |  |                     Log::debug(sprintf('Resetting native_amount for piggy bank #%d and event #%d.', $piggyBank->id, $event->id)); | 
					
						
							|  |  |  |                     $event->native_amount = null; | 
					
						
							|  |  |  |                     $event->saveQuietly(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function resetBudgets(UserGroup $userGroup): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $repository = app(BudgetRepositoryInterface::class); | 
					
						
							|  |  |  |         $repository->setUserGroup($userGroup); | 
					
						
							| 
									
										
										
										
											2024-12-30 04:12:18 +01:00
										 |  |  |         $set        = $repository->getBudgets(); | 
					
						
							| 
									
										
										
										
											2024-12-21 12:27:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |         /** @var Budget $budget */ | 
					
						
							|  |  |  |         foreach ($set as $budget) { | 
					
						
							|  |  |  |             foreach ($budget->autoBudgets as $autoBudget) { | 
					
						
							| 
									
										
										
										
											2025-05-27 17:06:15 +02:00
										 |  |  |                 if (null === $autoBudget->native_amount) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2025-05-27 17:06:15 +02:00
										 |  |  |                 Log::debug(sprintf('Resetting native_amount for budget #%d and auto budget #%d.', $budget->id, $autoBudget->id)); | 
					
						
							|  |  |  |                 $autoBudget->native_amount = null; | 
					
						
							|  |  |  |                 $autoBudget->saveQuietly(); | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |             foreach ($budget->budgetlimits as $limit) { | 
					
						
							|  |  |  |                 if (null !== $limit->native_amount) { | 
					
						
							|  |  |  |                     Log::debug(sprintf('Resetting native_amount for budget #%d and budget limit #%d.', $budget->id, $limit->id)); | 
					
						
							|  |  |  |                     $limit->native_amount = null; | 
					
						
							|  |  |  |                     $limit->saveQuietly(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function resetTransactions(UserGroup $userGroup): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // custom query because of the potential size of this update.
 | 
					
						
							| 
									
										
										
										
											2024-12-21 11:33:58 +01:00
										 |  |  |         $success = DB::table('transactions') | 
					
						
							| 
									
										
										
										
											2024-12-30 04:12:18 +01:00
										 |  |  |             ->join('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | 
					
						
							|  |  |  |             ->where('transaction_journals.user_group_id', $userGroup->id) | 
					
						
							|  |  |  |             ->where(static function (Builder $q): void { | 
					
						
							|  |  |  |                 $q->whereNotNull('native_amount') | 
					
						
							|  |  |  |                     ->orWhereNotNull('native_foreign_amount') | 
					
						
							|  |  |  |                 ; | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             ->update(['native_amount' => null, 'native_foreign_amount' => null]) | 
					
						
							|  |  |  |         ; | 
					
						
							| 
									
										
										
										
											2024-12-29 08:16:27 +01:00
										 |  |  |         Log::debug(sprintf('Reset %d transactions.', $success)); | 
					
						
							| 
									
										
										
										
											2024-12-21 07:12:11 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | } |