mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-08 12:12:48 +01:00
90 lines
2.6 KiB
PHP
90 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace App\Jobs;
|
|
|
|
use App\Jobs\Job;
|
|
use App\Models\Document;
|
|
use App\Models\LookupAccount;
|
|
use Auth;
|
|
use DB;
|
|
use Exception;
|
|
use App\Ninja\Mailers\UserMailer;
|
|
|
|
class PurgeAccountData extends Job
|
|
{
|
|
/**
|
|
* Execute the job.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function handle(UserMailer $userMailer)
|
|
{
|
|
$user = Auth::user();
|
|
$account = $user->account;
|
|
|
|
if (! $user->is_admin) {
|
|
throw new Exception(trans('texts.forbidden'));
|
|
}
|
|
|
|
// delete the documents from cloud storage
|
|
Document::scope()->each(function ($item, $key) {
|
|
$item->delete();
|
|
});
|
|
|
|
$tables = [
|
|
'activities',
|
|
'invitations',
|
|
'account_gateway_tokens',
|
|
'payment_methods',
|
|
'credits',
|
|
'expense_categories',
|
|
'expenses',
|
|
'recurring_expenses',
|
|
'invoice_items',
|
|
'payments',
|
|
'invoices',
|
|
'tasks',
|
|
'projects',
|
|
'products',
|
|
'vendor_contacts',
|
|
'vendors',
|
|
'contacts',
|
|
'clients',
|
|
'proposals',
|
|
'proposal_templates',
|
|
'proposal_snippets',
|
|
'proposal_categories',
|
|
'proposal_invitations',
|
|
'tax_rates',
|
|
];
|
|
|
|
foreach ($tables as $table) {
|
|
DB::table($table)->where('account_id', '=', $user->account_id)->delete();
|
|
}
|
|
|
|
$account->invoice_number_counter = 1;
|
|
$account->quote_number_counter = 1;
|
|
$account->credit_number_counter = $account->credit_number_counter > 0 ? 1 : 0;
|
|
$account->client_number_counter = $account->client_number_counter > 0 ? 1 : 0;
|
|
$account->save();
|
|
|
|
session([RECENTLY_VIEWED => false]);
|
|
|
|
if (env('MULTI_DB_ENABLED')) {
|
|
$current = config('database.default');
|
|
config(['database.default' => DB_NINJA_LOOKUP]);
|
|
|
|
$lookupAccount = LookupAccount::whereAccountKey($account->account_key)->firstOrFail();
|
|
DB::table('lookup_contacts')->where('lookup_account_id', '=', $lookupAccount->id)->delete();
|
|
DB::table('lookup_invitations')->where('lookup_account_id', '=', $lookupAccount->id)->delete();
|
|
DB::table('lookup_proposal_invitations')->where('lookup_account_id', '=', $lookupAccount->id)->delete();
|
|
|
|
config(['database.default' => $current]);
|
|
}
|
|
|
|
$subject = trans('texts.purge_successful');
|
|
$message = trans('texts.purge_details', ['account' => $user->account->getDisplayName()]);
|
|
$userMailer->sendMessage($user, $subject, $message);
|
|
}
|
|
}
|