Server IP : 23.254.227.96 / Your IP : 216.73.216.7 Web Server : Apache/2.4.62 (Unix) OpenSSL/1.1.1k System : Linux hwsrv-1277026.hostwindsdns.com 4.18.0-477.13.1.el8_8.x86_64 #1 SMP Tue May 30 14:53:41 EDT 2023 x86_64 User : viralblo ( 1001) PHP Version : 8.1.31 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/local/cwpsrv/var/services/pma/libraries/classes/ |
Upload File : |
<?php /** * Used to render the console of PMA's pages */ declare(strict_types=1); namespace PhpMyAdmin; use function count; use function sprintf; /** * Class used to output the console */ class Console { /** * Whether to display anything * * @access private * @var bool */ private $isEnabled; /** * Whether we are servicing an ajax request. * * @access private * @var bool */ private $isAjax; /** @var Relation */ private $relation; /** @var Template */ public $template; /** * Creates a new class instance */ public function __construct() { global $dbi; $this->isEnabled = true; $this->relation = new Relation($dbi); $this->template = new Template(); } /** * Set the ajax flag to indicate whether * we are servicing an ajax request * * @param bool $isAjax Whether we are servicing an ajax request */ public function setAjax(bool $isAjax): void { $this->isAjax = $isAjax; } /** * Disables the rendering of the footer */ public function disable(): void { $this->isEnabled = false; } /** * Renders the bookmark content * * @access public */ public static function getBookmarkContent(): string { global $dbi; $template = new Template(); $cfgBookmark = Bookmark::getParams($GLOBALS['cfg']['Server']['user']); if ($cfgBookmark) { $bookmarks = Bookmark::getList( $dbi, $GLOBALS['cfg']['Server']['user'] ); $count_bookmarks = count($bookmarks); if ($count_bookmarks > 0) { $welcomeMessage = sprintf( _ngettext( 'Showing %1$d bookmark (both private and shared)', 'Showing %1$d bookmarks (both private and shared)', $count_bookmarks ), $count_bookmarks ); } else { $welcomeMessage = __('No bookmarks'); } return $template->render('console/bookmark_content', [ 'welcome_message' => $welcomeMessage, 'bookmarks' => $bookmarks, ]); } return ''; } /** * Returns the list of JS scripts required by console * * @return array list of scripts */ public function getScripts(): array { return ['console.js']; } /** * Renders the console * * @access public */ public function getDisplay(): string { if (! $this->isAjax && $this->isEnabled) { $cfgBookmark = Bookmark::getParams( $GLOBALS['cfg']['Server']['user'] ); $image = Html\Generator::getImage('console', __('SQL Query Console')); $_sql_history = $this->relation->getHistory( $GLOBALS['cfg']['Server']['user'] ); $bookmarkContent = static::getBookmarkContent(); return $this->template->render('console/display', [ 'cfg_bookmark' => $cfgBookmark, 'image' => $image, 'sql_history' => $_sql_history, 'bookmark_content' => $bookmarkContent, ]); } return ''; } }