['native_virtual_balance'], 'available_budgets' => ['native_amount'], 'bills' => ['native_amount_min', 'native_amount_max'], ]; 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); // fire laravel command to recalculate them all. if (Amount::convertToPrimary()) { Log::debug('Will now convert to primary currency.'); Artisan::call('correction:recalculate-pc-amounts'); return; } Log::debug('Will NOT convert to primary currency.'); } private function resetPiggyBanks(UserGroup $userGroup): void { $repository = app(PiggyBankRepositoryInterface::class); $repository->setUserGroup($userGroup); $piggyBanks = $repository->getPiggyBanks(); Log::debug(sprintf('Resetting %d piggy bank(s).', $piggyBanks->count())); /** @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); $set = $repository->getBudgets(); Log::debug(sprintf('Resetting %d budget(s).', $set->count())); /** @var Budget $budget */ foreach ($set as $budget) { foreach ($budget->autoBudgets as $autoBudget) { if (null === $autoBudget->native_amount) { continue; } Log::debug(sprintf('Resetting native_amount for budget #%d and auto budget #%d.', $budget->id, $autoBudget->id)); $autoBudget->native_amount = null; $autoBudget->saveQuietly(); } 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. $success = DB::table('transactions') ->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]) ; Log::debug(sprintf('Reset %d transactions.', $success)); } }