mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-11-30 12:43:43 +08:00
c7a2d568bf
Tools seems to fit better since the classes were a bit of a mixed bunch and did not always manage. Also simplified the structure of the SlugGenerator class. Also focused EntityContext on shelves and simplified to use session helper.
79 lines
2.6 KiB
PHP
79 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace BookStack\Http\Controllers;
|
|
|
|
use BookStack\Actions\ActivityType;
|
|
use BookStack\Entities\Tools\TrashCan;
|
|
use BookStack\Notifications\TestEmail;
|
|
use BookStack\Uploads\ImageService;
|
|
use Illuminate\Http\Request;
|
|
|
|
class MaintenanceController extends Controller
|
|
{
|
|
/**
|
|
* Show the page for application maintenance.
|
|
*/
|
|
public function index()
|
|
{
|
|
$this->checkPermission('settings-manage');
|
|
$this->setPageTitle(trans('settings.maint'));
|
|
|
|
// Get application version
|
|
$version = trim(file_get_contents(base_path('version')));
|
|
|
|
// Recycle bin details
|
|
$recycleStats = (new TrashCan())->getTrashedCounts();
|
|
|
|
return view('settings.maintenance', [
|
|
'version' => $version,
|
|
'recycleStats' => $recycleStats,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Action to clean-up images in the system.
|
|
*/
|
|
public function cleanupImages(Request $request, ImageService $imageService)
|
|
{
|
|
$this->checkPermission('settings-manage');
|
|
$this->logActivity(ActivityType::MAINTENANCE_ACTION_RUN, 'cleanup-images');
|
|
|
|
$checkRevisions = !($request->get('ignore_revisions', 'false') === 'true');
|
|
$dryRun = !($request->has('confirm'));
|
|
|
|
$imagesToDelete = $imageService->deleteUnusedImages($checkRevisions, $dryRun);
|
|
$deleteCount = count($imagesToDelete);
|
|
if ($deleteCount === 0) {
|
|
$this->showWarningNotification(trans('settings.maint_image_cleanup_nothing_found'));
|
|
return redirect('/settings/maintenance')->withInput();
|
|
}
|
|
|
|
if ($dryRun) {
|
|
session()->flash('cleanup-images-warning', trans('settings.maint_image_cleanup_warning', ['count' => $deleteCount]));
|
|
} else {
|
|
$this->showSuccessNotification(trans('settings.maint_image_cleanup_success', ['count' => $deleteCount]));
|
|
}
|
|
|
|
return redirect('/settings/maintenance#image-cleanup')->withInput();
|
|
}
|
|
|
|
/**
|
|
* Action to send a test e-mail to the current user.
|
|
*/
|
|
public function sendTestEmail()
|
|
{
|
|
$this->checkPermission('settings-manage');
|
|
$this->logActivity(ActivityType::MAINTENANCE_ACTION_RUN, 'send-test-email');
|
|
|
|
try {
|
|
user()->notify(new TestEmail());
|
|
$this->showSuccessNotification(trans('settings.maint_send_test_email_success', ['address' => user()->email]));
|
|
} catch (\Exception $exception) {
|
|
$errorMessage = trans('errors.maintenance_test_email_failure') . "\n" . $exception->getMessage();
|
|
$this->showErrorNotification($errorMessage);
|
|
}
|
|
|
|
return redirect('/settings/maintenance#image-cleanup')->withInput();
|
|
}
|
|
}
|