DashboardController.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. namespace App\Controllers;
  3. use App\Web\Session;
  4. use League\Flysystem\FileNotFoundException;
  5. use Slim\Http\Request;
  6. use Slim\Http\Response;
  7. class DashboardController extends Controller
  8. {
  9. const PER_PAGE = 21;
  10. const PER_PAGE_ADMIN = 25;
  11. /**
  12. * @param Request $request
  13. * @param Response $response
  14. * @return Response
  15. */
  16. public function redirects(Request $request, Response $response): Response
  17. {
  18. if ($request->getParam('afterInstall') !== null && is_dir('install')) {
  19. Session::alert(lang('installed'), 'success');
  20. removeDirectory('install');
  21. }
  22. return redirect($response, 'home');
  23. }
  24. /**
  25. * @param Request $request
  26. * @param Response $response
  27. * @param $args
  28. * @return Response
  29. */
  30. public function home(Request $request, Response $response, $args): Response
  31. {
  32. $page = isset($args['page']) ? (int)$args['page'] : 0;
  33. $page = max(0, --$page);
  34. if (Session::get('admin', false)) {
  35. $medias = $this->database->query('SELECT `uploads`.*, `users`.`user_code`, `users`.`username` FROM `uploads` LEFT JOIN `users` ON `uploads`.`user_id` = `users`.`id` ORDER BY `timestamp` DESC LIMIT ? OFFSET ?', [self::PER_PAGE_ADMIN, $page * self::PER_PAGE_ADMIN])->fetchAll();
  36. $pages = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads`')->fetch()->count / self::PER_PAGE_ADMIN;
  37. } else {
  38. $medias = $this->database->query('SELECT `uploads`.*,`users`.`user_code`, `users`.`username` FROM `uploads` INNER JOIN `users` ON `uploads`.`user_id` = `users`.`id` WHERE `user_id` = ? ORDER BY `timestamp` DESC LIMIT ? OFFSET ?', [Session::get('user_id'), self::PER_PAGE, $page * self::PER_PAGE])->fetchAll();
  39. $pages = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads` WHERE `user_id` = ?', Session::get('user_id'))->fetch()->count / self::PER_PAGE;
  40. }
  41. $filesystem = $this->getStorage();
  42. foreach ($medias as $media) {
  43. $extension = pathinfo($media->filename, PATHINFO_EXTENSION);
  44. try {
  45. $media->size = humanFileSize($filesystem->getSize($media->storage_path));
  46. $mime = $filesystem->getMimetype($media->storage_path);
  47. } catch (FileNotFoundException $e) {
  48. $mime = null;
  49. }
  50. $media->extension = $extension;
  51. $media->mimetype = $mime;
  52. }
  53. return $this->view->render(
  54. $response,
  55. Session::get('admin', false) ? 'dashboard/admin.twig' : 'dashboard/home.twig',
  56. [
  57. 'medias' => $medias,
  58. 'next' => $page < floor($pages),
  59. 'previous' => $page >= 1,
  60. 'current_page' => ++$page,
  61. ]
  62. );
  63. }
  64. /**
  65. * @param Request $request
  66. * @param Response $response
  67. * @return Response
  68. * @throws FileNotFoundException
  69. */
  70. public function system(Request $request, Response $response): Response
  71. {
  72. $usersCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `users`')->fetch()->count;
  73. $mediasCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads`')->fetch()->count;
  74. $orphanFilesCount = $this->database->query('SELECT COUNT(*) AS `count` FROM `uploads` WHERE `user_id` IS NULL')->fetch()->count;
  75. $medias = $this->database->query('SELECT `users`.`user_code`, `uploads`.`code`, `uploads`.`storage_path` FROM `uploads` LEFT JOIN `users` ON `uploads`.`user_id` = `users`.`id`')->fetchAll();
  76. $totalSize = 0;
  77. $filesystem = $this->getStorage();
  78. foreach ($medias as $media) {
  79. $totalSize += $filesystem->getSize($media->storage_path);
  80. }
  81. return $this->view->render($response, 'dashboard/system.twig', [
  82. 'usersCount' => $usersCount,
  83. 'mediasCount' => $mediasCount,
  84. 'orphanFilesCount' => $orphanFilesCount,
  85. 'totalSize' => humanFileSize($totalSize),
  86. 'post_max_size' => ini_get('post_max_size'),
  87. 'upload_max_filesize' => ini_get('upload_max_filesize'),
  88. ]);
  89. }
  90. /**
  91. * @param Request $request
  92. * @param Response $response
  93. * @return Response
  94. */
  95. public function getThemes(Request $request, Response $response): Response
  96. {
  97. $apiJson = json_decode(file_get_contents('https://bootswatch.com/api/4.json'));
  98. $out = [];
  99. $out['Default - Bootstrap 4 default theme'] = 'https://bootswatch.com/_vendor/bootstrap/dist/css/bootstrap.min.css';
  100. foreach ($apiJson->themes as $theme) {
  101. $out["{$theme->name} - {$theme->description}"] = $theme->cssMin;
  102. }
  103. return $response->withJson($out);
  104. }
  105. public function applyTheme(Request $request, Response $response): Response
  106. {
  107. if (!is_writable('static/bootstrap/css/bootstrap.min.css')) {
  108. Session::alert(lang('cannot_write_file'), 'danger');
  109. return redirect($response, route('system'));
  110. }
  111. file_put_contents('static/bootstrap/css/bootstrap.min.css', file_get_contents($request->getParam('css')));
  112. return redirect($response, 'system')
  113. ->withAddedHeader('Cache-Control', 'no-cache, no-store, must-revalidate')
  114. ->withAddedHeader('Pragma', 'no-cache')
  115. ->withAddedHeader('Expire', '0');
  116. }
  117. }