AdminController.php 3.7 KB

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