AdminController.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. namespace App\Controllers;
  3. use League\Flysystem\FileNotFoundException;
  4. use Slim\Http\Request;
  5. use Slim\Http\Response;
  6. class AdminController extends Controller
  7. {
  8. /**
  9. * @param Request $request
  10. * @param Response $response
  11. * @return Response
  12. * @throws FileNotFoundException
  13. */
  14. public function system(Request $request, Response $response): Response
  15. {
  16. $usersCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `users`')->fetch()->count;
  17. $mediasCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads`')->fetch()->count;
  18. $orphanFilesCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads` WHERE `user_id` IS NULL')->fetch()->count;
  19. $medias = $this->database->query('SELECT `uploads`.`storage_path` FROM `uploads`')->fetchAll();
  20. $totalSize = 0;
  21. $filesystem = $this->storage;
  22. foreach ($medias as $media) {
  23. $totalSize += $filesystem->getSize($media->storage_path);
  24. }
  25. return $this->view->render($response, 'dashboard/system.twig', [
  26. 'usersCount' => $usersCount,
  27. 'mediasCount' => $mediasCount,
  28. 'orphanFilesCount' => $orphanFilesCount,
  29. 'totalSize' => humanFileSize($totalSize),
  30. 'post_max_size' => ini_get('post_max_size'),
  31. 'upload_max_filesize' => ini_get('upload_max_filesize'),
  32. 'installed_lang' => $this->lang->getList(),
  33. ]);
  34. }
  35. /**
  36. * @param Request $request
  37. * @param Response $response
  38. * @return Response
  39. */
  40. public function deleteOrphanFiles(Request $request, Response $response): Response
  41. {
  42. $orphans = $this->database->query('SELECT * FROM `uploads` WHERE `user_id` IS NULL')->fetchAll();
  43. $filesystem = $this->storage;
  44. $deleted = 0;
  45. foreach ($orphans as $orphan) {
  46. try {
  47. $filesystem->delete($orphan->storage_path);
  48. $deleted++;
  49. } catch (FileNotFoundException $e) {
  50. }
  51. }
  52. $this->database->query('DELETE FROM `uploads` WHERE `user_id` IS NULL');
  53. $this->session->alert(lang('deleted_orphans', [$deleted]));
  54. return redirect($response, 'system');
  55. }
  56. /**
  57. * @param Request $request
  58. * @param Response $response
  59. * @return Response
  60. */
  61. public function applyLang(Request $request, Response $response): Response
  62. {
  63. $config = require BASE_DIR . 'config.php';
  64. if ($request->getParam('lang') !== 'auto') {
  65. $config['lang'] = $request->getParam('lang');
  66. } else {
  67. unset($config['lang']);
  68. }
  69. file_put_contents(BASE_DIR . 'config.php', '<?php' . PHP_EOL . 'return ' . var_export($config, true) . ';');
  70. $this->session->alert(lang('lang_set', [$request->getParam('lang')]));
  71. return redirect($response, 'system');
  72. }
  73. }