1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-08 20:22:42 +01:00
invoiceninja/app/Jobs/PurgeClientData.php

62 lines
1.5 KiB
PHP
Raw Normal View History

2018-03-14 18:51:49 +01:00
<?php
namespace App\Jobs;
use App\Jobs\Job;
use App\Models\Invoice;
use App\Models\LookupAccount;
use DB;
use Exception;
use App\Libraries\HistoryUtils;
2018-04-26 09:28:50 +02:00
use Utils;
2018-03-14 18:51:49 +01:00
class PurgeClientData extends Job
{
public function __construct($client)
{
$this->client = $client;
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
2018-04-26 09:28:50 +02:00
$user = auth()->user();
$client = $this->client;
$contact = $client->getPrimaryContact();
if (! $user->is_admin) {
return;
}
$message = sprintf('%s %s (%s) purged client: %s %s', date('Y-m-d h:i:s'), $user->email, request()->getClientIp(), $client->name, $contact->email);
if (config('app.log') == 'single') {
@file_put_contents(storage_path('logs/purged-clients.log'), $message, FILE_APPEND);
} else {
Utils::logError('[purged client] ' . $message);
}
$invoices = $client->invoices()->withTrashed()->get();
$expenses = $client->expenses()->withTrashed()->get();
2018-03-14 18:51:49 +01:00
foreach ($invoices as $invoice) {
foreach ($invoice->documents as $document) {
$document->delete();
}
}
foreach ($expenses as $expense) {
foreach ($expense->documents as $document) {
$document->delete();
}
}
$this->client->forceDelete();
HistoryUtils::deleteHistory($this->client);
}
}