SlowLogController.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. declare(strict_types=1);
  3. namespace PhpMyAdmin\Controllers\Server\Status\Monitor;
  4. use PhpMyAdmin\Controllers\Server\Status\AbstractController;
  5. use PhpMyAdmin\DatabaseInterface;
  6. use PhpMyAdmin\ResponseRenderer;
  7. use PhpMyAdmin\Server\Status\Data;
  8. use PhpMyAdmin\Server\Status\Monitor;
  9. use PhpMyAdmin\Template;
  10. use PhpMyAdmin\Url;
  11. final class SlowLogController extends AbstractController
  12. {
  13. /** @var Monitor */
  14. private $monitor;
  15. /** @var DatabaseInterface */
  16. private $dbi;
  17. public function __construct(
  18. ResponseRenderer $response,
  19. Template $template,
  20. Data $data,
  21. Monitor $monitor,
  22. DatabaseInterface $dbi
  23. ) {
  24. parent::__construct($response, $template, $data);
  25. $this->monitor = $monitor;
  26. $this->dbi = $dbi;
  27. }
  28. public function __invoke(): void
  29. {
  30. global $errorUrl;
  31. $params = [
  32. 'time_start' => $_POST['time_start'] ?? null,
  33. 'time_end' => $_POST['time_end'] ?? null,
  34. ];
  35. $errorUrl = Url::getFromRoute('/');
  36. if ($this->dbi->isSuperUser()) {
  37. $this->dbi->selectDb('mysql');
  38. }
  39. if (! $this->response->isAjax()) {
  40. return;
  41. }
  42. $data = $this->monitor->getJsonForLogDataTypeSlow(
  43. (int) $params['time_start'],
  44. (int) $params['time_end']
  45. );
  46. if ($data === null) {
  47. $this->response->setRequestStatus(false);
  48. return;
  49. }
  50. $this->response->addJSON(['message' => $data]);
  51. }
  52. }