| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-18 00:56:55 +08:00
										 |  |  | namespace BookStack\Settings; | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-18 00:56:55 +08:00
										 |  |  | use BookStack\Activity\ActivityType; | 
					
						
							| 
									
										
										
										
											2025-05-14 03:38:08 +08:00
										 |  |  | use BookStack\App\AppVersion; | 
					
						
							| 
									
										
										
										
											2020-11-22 07:20:54 +08:00
										 |  |  | use BookStack\Entities\Tools\TrashCan; | 
					
						
							| 
									
										
										
										
											2023-05-19 03:53:39 +08:00
										 |  |  | use BookStack\Http\Controller; | 
					
						
							| 
									
										
										
										
											2022-08-30 00:30:26 +08:00
										 |  |  | use BookStack\References\ReferenceStore; | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  | use BookStack\Uploads\ImageService; | 
					
						
							|  |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class MaintenanceController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Show the page for application maintenance. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-02-08 00:37:36 +08:00
										 |  |  |     public function index(TrashCan $trashCan) | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  |     { | 
					
						
							|  |  |  |         $this->checkPermission('settings-manage'); | 
					
						
							|  |  |  |         $this->setPageTitle(trans('settings.maint')); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-04 01:44:12 +08:00
										 |  |  |         // Recycle bin details
 | 
					
						
							| 
									
										
										
										
											2024-02-08 00:37:36 +08:00
										 |  |  |         $recycleStats = $trashCan->getTrashedCounts(); | 
					
						
							| 
									
										
										
										
											2020-10-04 01:44:12 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return view('settings.maintenance', [ | 
					
						
							| 
									
										
										
										
											2025-05-14 03:38:08 +08:00
										 |  |  |             'version'      => AppVersion::get(), | 
					
						
							| 
									
										
										
										
											2020-10-04 01:44:12 +08:00
										 |  |  |             'recycleStats' => $recycleStats, | 
					
						
							|  |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Action to clean-up images in the system. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function cleanupImages(Request $request, ImageService $imageService) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->checkPermission('settings-manage'); | 
					
						
							| 
									
										
										
										
											2020-11-19 07:38:44 +08:00
										 |  |  |         $this->logActivity(ActivityType::MAINTENANCE_ACTION_RUN, 'cleanup-images'); | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $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')); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  |             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'); | 
					
						
							| 
									
										
										
										
											2020-11-19 07:38:44 +08:00
										 |  |  |         $this->logActivity(ActivityType::MAINTENANCE_ACTION_RUN, 'send-test-email'); | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         try { | 
					
						
							| 
									
										
										
										
											2023-09-12 02:26:28 +08:00
										 |  |  |             user()->notifyNow(new TestEmailNotification()); | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  |             $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); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-30 00:30:26 +08:00
										 |  |  |         return redirect('/settings/maintenance#image-cleanup'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Action to regenerate the reference index in the system. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function regenerateReferences(ReferenceStore $referenceStore) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->checkPermission('settings-manage'); | 
					
						
							|  |  |  |         $this->logActivity(ActivityType::MAINTENANCE_ACTION_RUN, 'regenerate-references'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         try { | 
					
						
							| 
									
										
										
										
											2023-12-19 00:23:40 +08:00
										 |  |  |             $referenceStore->updateForAll(); | 
					
						
							| 
									
										
										
										
											2022-08-30 00:30:26 +08:00
										 |  |  |             $this->showSuccessNotification(trans('settings.maint_regen_references_success')); | 
					
						
							|  |  |  |         } catch (\Exception $exception) { | 
					
						
							|  |  |  |             $this->showErrorNotification($exception->getMessage()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return redirect('/settings/maintenance#regenerate-references'); | 
					
						
							| 
									
										
										
										
											2020-09-19 16:24:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | } |