AdminController.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace App\Controllers;
  3. use League\Flysystem\FileNotFoundException;
  4. use Psr\Http\Message\ResponseInterface as Response;
  5. use Psr\Http\Message\ServerRequestInterface as Request;
  6. class AdminController extends Controller
  7. {
  8. /**
  9. * @param Request $request
  10. * @param Response $response
  11. *
  12. * @throws FileNotFoundException
  13. * @throws \Twig\Error\LoaderError
  14. * @throws \Twig\Error\RuntimeError
  15. * @throws \Twig\Error\SyntaxError
  16. *
  17. * @return Response
  18. */
  19. public function system(Request $request, Response $response): Response
  20. {
  21. $usersCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `users`')->fetch()->count;
  22. $mediasCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads`')->fetch()->count;
  23. $orphanFilesCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads` WHERE `user_id` IS NULL')->fetch()->count;
  24. $medias = $this->database->query('SELECT `uploads`.`storage_path` FROM `uploads`')->fetchAll();
  25. $totalSize = 0;
  26. $filesystem = $this->storage;
  27. foreach ($medias as $media) {
  28. $totalSize += $filesystem->getSize($media->storage_path);
  29. }
  30. return view()->render($response, 'dashboard/system.twig', [
  31. 'usersCount' => $usersCount,
  32. 'mediasCount' => $mediasCount,
  33. 'orphanFilesCount' => $orphanFilesCount,
  34. 'totalSize' => humanFileSize($totalSize),
  35. 'post_max_size' => ini_get('post_max_size'),
  36. 'upload_max_filesize' => ini_get('upload_max_filesize'),
  37. 'installed_lang' => $this->lang->getList(),
  38. 'forced_lang' => $request->getAttribute('forced_lang'),
  39. ]);
  40. }
  41. /**
  42. * @param Request $request
  43. * @param Response $response
  44. *
  45. * @return Response
  46. */
  47. public function deleteOrphanFiles(Response $response): Response
  48. {
  49. $orphans = $this->database->query('SELECT * FROM `uploads` WHERE `user_id` IS NULL')->fetchAll();
  50. $filesystem = $this->storage;
  51. $deleted = 0;
  52. foreach ($orphans as $orphan) {
  53. try {
  54. $filesystem->delete($orphan->storage_path);
  55. $deleted++;
  56. } catch (FileNotFoundException $e) {
  57. }
  58. }
  59. $this->database->query('DELETE FROM `uploads` WHERE `user_id` IS NULL');
  60. $this->session->alert(lang('deleted_orphans', [$deleted]));
  61. return redirect($response, route('system'));
  62. }
  63. /**
  64. * @param Request $request
  65. * @param Response $response
  66. *
  67. * @return Response
  68. */
  69. public function applyLang(Request $request, Response $response): Response
  70. {
  71. if (param($request, 'lang') !== 'auto') {
  72. if (!$this->database->query('SELECT `value` FROM `settings` WHERE `key` = \'lang\'')->fetch()) {
  73. $this->database->query('INSERT INTO `settings`(`key`, `value`) VALUES (\'lang\', ?)', param($request, 'lang'));
  74. } else {
  75. $this->database->query('UPDATE `settings` SET `value`=? WHERE `key` = \'lang\'', param($request, 'lang'));
  76. }
  77. } else {
  78. $this->database->query('DELETE FROM `settings` WHERE `key` = \'lang\'');
  79. }
  80. $this->session->alert(lang('lang_set', [param($request, 'lang')]));
  81. return redirect($response, route('system'));
  82. }
  83. /**
  84. * @param Request $request
  85. * @param Response $response
  86. *
  87. * @return Response
  88. */
  89. public function applyCustomHead(Request $request, Response $response): Response
  90. {
  91. if ($request->getAttribute('custom_head_key_present')) {
  92. $this->database->query('UPDATE `settings` SET `value`=? WHERE `key` = \'custom_head\'', param($request, 'custom_head'));
  93. } else {
  94. $this->database->query('INSERT INTO `settings`(`key`, `value`) VALUES (\'custom_head\', ?)', param($request, 'custom_head'));
  95. }
  96. $this->session->alert(lang('custom_head_set'));
  97. return redirect($response, route('system'));
  98. }
  99. }