Server IP : 15.235.198.142 / Your IP : 216.73.216.154 Web Server : Apache/2.4.58 (Ubuntu) System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 8.3.6 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /usr/share/phpmyadmin/libraries/classes/Controllers/Database/ |
Upload File : |
<?php declare(strict_types=1); namespace PhpMyAdmin\Controllers\Database; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\ResponseRenderer; use PhpMyAdmin\Template; use function json_encode; /** * Table/Column autocomplete in SQL editors. */ class SqlAutoCompleteController extends AbstractController { /** @var DatabaseInterface */ private $dbi; public function __construct(ResponseRenderer $response, Template $template, string $db, DatabaseInterface $dbi) { parent::__construct($response, $template, $db); $this->dbi = $dbi; } public function __invoke(): void { global $cfg, $db, $sql_autocomplete; $sql_autocomplete = true; if ($cfg['EnableAutocompleteForTablesAndColumns']) { $db = $_POST['db'] ?? $db; $sql_autocomplete = []; if ($db) { $tableNames = $this->dbi->getTables($db); foreach ($tableNames as $tableName) { $sql_autocomplete[$tableName] = $this->dbi->getColumns($db, $tableName); } } } $this->response->addJSON(['tables' => json_encode($sql_autocomplete)]); } }