2018-05-20 13:16:01 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace BookStack\Console\Commands;
|
|
|
|
|
2018-09-25 07:30:50 -04:00
|
|
|
use BookStack\Uploads\ImageService;
|
2018-05-20 13:16:01 -04:00
|
|
|
use Illuminate\Console\Command;
|
2018-05-27 09:33:50 -04:00
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
2018-05-20 13:16:01 -04:00
|
|
|
|
2023-05-24 08:21:46 -04:00
|
|
|
class CleanupImagesCommand extends Command
|
2018-05-20 13:16:01 -04:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The name and signature of the console command.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $signature = 'bookstack:cleanup-images
|
2020-12-18 17:54:53 -05:00
|
|
|
{--a|all : Also delete images that are only used in old revisions}
|
|
|
|
{--f|force : Actually run the deletions, Defaults to a dry-run}
|
2018-05-20 13:16:01 -04:00
|
|
|
';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The console command description.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $description = 'Cleanup images and drawings';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the console command.
|
|
|
|
*/
|
2023-05-24 07:59:50 -04:00
|
|
|
public function handle(ImageService $imageService): int
|
2018-05-20 13:16:01 -04:00
|
|
|
{
|
2023-05-24 07:59:50 -04:00
|
|
|
$checkRevisions = !$this->option('all');
|
|
|
|
$dryRun = !$this->option('force');
|
2018-05-20 13:16:01 -04:00
|
|
|
|
|
|
|
if (!$dryRun) {
|
2023-05-24 05:34:43 -04:00
|
|
|
$this->warn("This operation is destructive and is not guaranteed to be fully accurate.\nEnsure you have a backup of your images.\n");
|
2023-09-14 09:17:20 -04:00
|
|
|
$proceed = !$this->input->isInteractive() || $this->confirm("Are you sure you want to proceed?");
|
2018-05-20 13:16:01 -04:00
|
|
|
if (!$proceed) {
|
2023-05-24 07:59:50 -04:00
|
|
|
return 0;
|
2018-05-20 13:16:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-24 07:59:50 -04:00
|
|
|
$deleted = $imageService->deleteUnusedImages($checkRevisions, $dryRun);
|
2018-05-27 09:33:50 -04:00
|
|
|
$deleteCount = count($deleted);
|
2018-05-20 13:16:01 -04:00
|
|
|
|
|
|
|
if ($dryRun) {
|
2023-05-24 05:34:43 -04:00
|
|
|
$this->comment('Dry run, no images have been deleted');
|
2023-09-14 09:17:20 -04:00
|
|
|
$this->comment($deleteCount . ' image(s) found that would have been deleted');
|
2018-05-27 09:33:50 -04:00
|
|
|
$this->showDeletedImages($deleted);
|
2018-05-20 13:16:01 -04:00
|
|
|
$this->comment('Run with -f or --force to perform deletions');
|
2021-06-26 11:23:15 -04:00
|
|
|
|
2023-05-24 07:59:50 -04:00
|
|
|
return 0;
|
2018-05-20 13:16:01 -04:00
|
|
|
}
|
|
|
|
|
2018-05-27 09:33:50 -04:00
|
|
|
$this->showDeletedImages($deleted);
|
2023-09-14 09:17:20 -04:00
|
|
|
$this->comment("{$deleteCount} image(s) deleted");
|
|
|
|
|
2023-05-24 07:59:50 -04:00
|
|
|
return 0;
|
2018-05-20 13:16:01 -04:00
|
|
|
}
|
2018-05-27 09:33:50 -04:00
|
|
|
|
2023-05-24 07:59:50 -04:00
|
|
|
protected function showDeletedImages($paths): void
|
2018-05-27 09:33:50 -04:00
|
|
|
{
|
2018-09-21 13:48:47 -04:00
|
|
|
if ($this->getOutput()->getVerbosity() <= OutputInterface::VERBOSITY_NORMAL) {
|
|
|
|
return;
|
|
|
|
}
|
2023-05-24 07:59:50 -04:00
|
|
|
|
2018-05-27 09:33:50 -04:00
|
|
|
if (count($paths) > 0) {
|
2023-09-14 09:17:20 -04:00
|
|
|
$this->line('Image(s) to delete:');
|
2018-05-27 09:33:50 -04:00
|
|
|
}
|
2023-05-24 07:59:50 -04:00
|
|
|
|
2018-05-27 09:33:50 -04:00
|
|
|
foreach ($paths as $path) {
|
|
|
|
$this->line($path);
|
|
|
|
}
|
|
|
|
}
|
2018-05-20 13:16:01 -04:00
|
|
|
}
|