Server IP : 85.214.239.14 / Your IP : 3.141.192.115 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /var/www/wordpress/phpMyAdmin/libraries/classes/Controllers/Server/ |
Upload File : |
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * Holds the PhpMyAdmin\Controllers\Server\BinlogController * * @package PhpMyAdmin\Controllers */ declare(strict_types=1); namespace PhpMyAdmin\Controllers\Server; use PhpMyAdmin\Controllers\AbstractController; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\Message; use PhpMyAdmin\Response; use PhpMyAdmin\Template; use PhpMyAdmin\Util; /** * Handles viewing binary logs * * @package PhpMyAdmin\Controllers */ class BinlogController extends AbstractController { /** * array binary log files */ protected $binaryLogs; /** * Constructs BinlogController * * @param Response $response Response object * @param DatabaseInterface $dbi DatabaseInterface object * @param Template $template Template object */ public function __construct($response, $dbi, Template $template) { parent::__construct($response, $dbi, $template); $this->binaryLogs = $this->dbi->fetchResult( 'SHOW MASTER LOGS', 'Log_name', null, DatabaseInterface::CONNECT_USER, DatabaseInterface::QUERY_STORE ); } /** * Index action * * @param array $params Request params * * @return string */ public function indexAction(array $params): string { global $cfg, $pmaThemeImage; include_once ROOT_PATH . 'libraries/server_common.inc.php'; $position = ! empty($params['pos']) ? (int) $params['pos'] : 0; $urlParams = []; if (isset($params['log']) && array_key_exists($params['log'], $this->binaryLogs) ) { $urlParams['log'] = $params['log']; } $isFullQuery = false; if (! empty($params['is_full_query'])) { $isFullQuery = true; $urlParams['is_full_query'] = 1; } $sqlQuery = $this->getSqlQuery( $params['log'] ?? '', $position, (int) $cfg['MaxRows'] ); $result = $this->dbi->query($sqlQuery); $numRows = 0; if (isset($result) && $result) { $numRows = $this->dbi->numRows($result); } $previousParams = $urlParams; $fullQueriesParams = $urlParams; $nextParams = $urlParams; if ($position > 0) { $fullQueriesParams['pos'] = $position; if ($position > $cfg['MaxRows']) { $previousParams['pos'] = $position - $cfg['MaxRows']; } } $fullQueriesParams['is_full_query'] = 1; if ($isFullQuery) { unset($fullQueriesParams['is_full_query']); } if ($numRows >= $cfg['MaxRows']) { $nextParams['pos'] = $position + $cfg['MaxRows']; } $values = []; while ($value = $this->dbi->fetchAssoc($result)) { $values[] = $value; } return $this->template->render('server/binlog/index', [ 'url_params' => $urlParams, 'binary_logs' => $this->binaryLogs, 'log' => $params['log'], 'sql_message' => Util::getMessage(Message::success(), $sqlQuery), 'values' => $values, 'has_previous' => $position > 0, 'has_next' => $numRows >= $cfg['MaxRows'], 'previous_params' => $previousParams, 'full_queries_params' => $fullQueriesParams, 'next_params' => $nextParams, 'has_icons' => Util::showIcons('TableNavigationLinksMode'), 'is_full_query' => $isFullQuery, 'image_path' => $pmaThemeImage, ]); } /** * @param string $log Binary log file name * @param int $position Position to display * @param int $maxRows Maximum number of rows * * @return string */ private function getSqlQuery( string $log, int $position, int $maxRows ): string { $sqlQuery = 'SHOW BINLOG EVENTS'; if (! empty($log)) { $sqlQuery .= ' IN \'' . $log . '\''; } $sqlQuery .= ' LIMIT ' . $position . ', ' . $maxRows; return $sqlQuery; } }