diff options
Diffstat (limited to 'srcs/phpmyadmin/db_multi_table_query.php')
| -rw-r--r-- | srcs/phpmyadmin/db_multi_table_query.php | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/srcs/phpmyadmin/db_multi_table_query.php b/srcs/phpmyadmin/db_multi_table_query.php new file mode 100644 index 0000000..c624e85 --- /dev/null +++ b/srcs/phpmyadmin/db_multi_table_query.php @@ -0,0 +1,51 @@ +<?php +/* vim: set expandtab sw=4 ts=4 sts=4: */ +/** + * Handles database multi-table querying + * + * @package PhpMyAdmin + */ +declare(strict_types=1); + +use PhpMyAdmin\Controllers\Database\MultiTableQueryController; +use PhpMyAdmin\DatabaseInterface; +use PhpMyAdmin\Response; +use PhpMyAdmin\Template; + +if (! defined('ROOT_PATH')) { + define('ROOT_PATH', __DIR__ . DIRECTORY_SEPARATOR); +} + +require_once ROOT_PATH . 'libraries/common.inc.php'; + +/** @var Response $response */ +$response = $containerBuilder->get(Response::class); + +/** @var DatabaseInterface $dbi */ +$dbi = $containerBuilder->get(DatabaseInterface::class); + +/** @var MultiTableQueryController $controller */ +$controller = $containerBuilder->get(MultiTableQueryController::class); + +/** @var Template $template */ +$template = $containerBuilder->get('template'); + +if (isset($_POST['sql_query'])) { + $controller->displayResults([ + 'sql_query' => $_POST['sql_query'], + 'db' => $_REQUEST['db'] ?? null, + ]); +} elseif (isset($_GET['tables'])) { + $response->addJSON($controller->table([ + 'tables' => $_GET['tables'], + 'db' => $_REQUEST['db'] ?? null, + ])); +} else { + $header = $response->getHeader(); + $scripts = $header->getScripts(); + $scripts->addFile('vendor/jquery/jquery.md5.js'); + $scripts->addFile('database/multi_table_query.js'); + $scripts->addFile('database/query_generator.js'); + + $response->addHTML($controller->index($template)); +} |
