2021-06-13 11:44:33 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
|
|
|
use App\Models\Company;
|
2021-11-24 22:04:25 +01:00
|
|
|
use App\Utils\Ninja;
|
2021-06-13 11:44:33 +02:00
|
|
|
use Illuminate\Console\Command;
|
|
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
|
|
|
|
class S3Cleanup extends Command
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The name and signature of the console command.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $signature = 'ninja:s3-cleanup';
|
|
|
|
|
2021-09-09 07:14:05 +02:00
|
|
|
protected $log = '';
|
|
|
|
|
2021-06-13 11:44:33 +02:00
|
|
|
/**
|
|
|
|
* The console command description.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2021-09-08 06:14:46 +02:00
|
|
|
protected $description = 'Remove orphan folders/files';
|
2021-06-13 11:44:33 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new command instance.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the console command.
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
2022-11-23 09:32:03 +01:00
|
|
|
if (!Ninja::isHosted()) {
|
2021-11-24 22:04:25 +01:00
|
|
|
return;
|
2022-06-21 11:57:17 +02:00
|
|
|
}
|
|
|
|
|
2021-06-13 11:44:33 +02:00
|
|
|
$c1 = Company::on('db-ninja-01')->pluck('company_key');
|
|
|
|
$c2 = Company::on('db-ninja-02')->pluck('company_key');
|
|
|
|
|
2021-06-13 12:09:52 +02:00
|
|
|
$merged = $c1->merge($c2)->toArray();
|
2021-06-13 11:44:33 +02:00
|
|
|
|
2021-06-13 12:09:52 +02:00
|
|
|
$directories = Storage::disk(config('filesystems.default'))->directories();
|
2021-06-13 11:44:33 +02:00
|
|
|
|
2022-06-21 11:57:17 +02:00
|
|
|
$this->LogMessage('Disk Cleanup');
|
2021-06-13 11:44:33 +02:00
|
|
|
|
2022-06-21 11:57:17 +02:00
|
|
|
foreach ($directories as $dir) {
|
|
|
|
if (! in_array($dir, $merged)) {
|
|
|
|
$this->logMessage("Deleting $dir");
|
2021-09-08 06:14:46 +02:00
|
|
|
|
2022-06-21 11:57:17 +02:00
|
|
|
/* Ensure we are not deleting the root folder */
|
|
|
|
if (strlen($dir) > 1) {
|
|
|
|
Storage::disk(config('filesystems.default'))->deleteDirectory($dir);
|
2021-06-13 12:09:52 +02:00
|
|
|
}
|
2022-06-21 11:57:17 +02:00
|
|
|
}
|
|
|
|
}
|
2021-06-13 11:44:33 +02:00
|
|
|
|
2022-06-21 11:57:17 +02:00
|
|
|
$this->logMessage('exiting');
|
2021-06-13 11:44:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private function logMessage($str)
|
|
|
|
{
|
|
|
|
$str = date('Y-m-d h:i:s').' '.$str;
|
|
|
|
$this->info($str);
|
|
|
|
$this->log .= $str."\n";
|
|
|
|
}
|
|
|
|
}
|