You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
46 lines
1.2 KiB
46 lines
1.2 KiB
2 years ago
|
<?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)]);
|
||
|
}
|
||
|
}
|