Viewing file: SqlController.php (1.88 KB) -rwxr-x--- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Controllers\Table;
use PhpMyAdmin\Config\PageSettings; use PhpMyAdmin\DbTableExists; use PhpMyAdmin\ResponseRenderer; use PhpMyAdmin\SqlQueryForm; use PhpMyAdmin\Template; use PhpMyAdmin\Url; use PhpMyAdmin\Util;
use function htmlspecialchars;
/** * Table SQL executor */ final class SqlController extends AbstractController { /** @var SqlQueryForm */ private $sqlQueryForm;
public function __construct( ResponseRenderer $response, Template $template, string $db, string $table, SqlQueryForm $sqlQueryForm ) { parent::__construct($response, $template, $db, $table); $this->sqlQueryForm = $sqlQueryForm; }
public function __invoke(): void { global $errorUrl, $goto, $back, $db, $table, $cfg;
$this->addScriptFiles(['makegrid.js', 'vendor/jquery/jquery.uitablefilter.js', 'sql.js']);
$pageSettings = new PageSettings('Sql'); $this->response->addHTML($pageSettings->getErrorHTML()); $this->response->addHTML($pageSettings->getHTML());
Util::checkParameters(['db', 'table']);
$url_params = ['db' => $db, 'table' => $table]; $errorUrl = Util::getScriptNameForOption($cfg['DefaultTabTable'], 'table'); $errorUrl .= Url::getCommon($url_params, '&');
DbTableExists::check();
/** * After a syntax error, we return to this script * with the typed query in the textarea. */ $goto = Url::getFromRoute('/table/sql'); $back = Url::getFromRoute('/table/sql');
$this->response->addHTML($this->sqlQueryForm->getHtml( $db, $table, $_GET['sql_query'] ?? true, false, isset($_POST['delimiter']) ? htmlspecialchars($_POST['delimiter']) : ';' )); } }
|