|
4 | 4 |
|
5 | 5 | namespace PhpMyAdmin\Controllers\Database; |
6 | 6 |
|
7 | | -use PhpMyAdmin\Column; |
8 | 7 | use PhpMyAdmin\Config; |
9 | 8 | use PhpMyAdmin\Controllers\AbstractController; |
10 | | -use PhpMyAdmin\Current; |
11 | 9 | use PhpMyAdmin\DatabaseInterface; |
12 | 10 | use PhpMyAdmin\Http\ServerRequest; |
| 11 | +use PhpMyAdmin\Identifiers\DatabaseName; |
13 | 12 | use PhpMyAdmin\ResponseRenderer; |
14 | 13 | use PhpMyAdmin\Template; |
15 | 14 |
|
16 | | -use function array_map; |
17 | | -use function array_values; |
| 15 | +use function sprintf; |
18 | 16 |
|
19 | 17 | /** |
20 | 18 | * Table/Column autocomplete in SQL editors. |
21 | 19 | */ |
22 | 20 | class SqlAutoCompleteController extends AbstractController |
23 | 21 | { |
24 | | - public function __construct(ResponseRenderer $response, Template $template, private DatabaseInterface $dbi) |
25 | | - { |
| 22 | + public function __construct( |
| 23 | + ResponseRenderer $response, |
| 24 | + Template $template, |
| 25 | + private readonly DatabaseInterface $dbi, |
| 26 | + private readonly Config $config, |
| 27 | + ) { |
26 | 28 | parent::__construct($response, $template); |
27 | 29 | } |
28 | 30 |
|
29 | 31 | public function __invoke(ServerRequest $request): void |
30 | 32 | { |
31 | 33 | $sqlAutocomplete = []; |
32 | | - if (Config::getInstance()->settings['EnableAutocompleteForTablesAndColumns']) { |
33 | | - $db = $request->getParam('db', Current::$database); |
34 | | - if ($db) { |
35 | | - $tableNames = $this->dbi->getTables($db); |
36 | | - foreach ($tableNames as $tableName) { |
37 | | - $sqlAutocomplete[$tableName] = array_map( |
38 | | - static fn (Column $field): array => [ |
39 | | - 'field' => $field->field, |
40 | | - 'columnHint' => $field->type . match ($field->key) { |
41 | | - 'PRI' => ' | Primary', |
42 | | - 'UNI' => ' | Unique', |
43 | | - default=> '' |
44 | | - }, |
45 | | - ], |
46 | | - array_values($this->dbi->getColumns($db, $tableName)), |
47 | | - ); |
48 | | - } |
| 34 | + if ($this->config->settings['EnableAutocompleteForTablesAndColumns']) { |
| 35 | + $db = DatabaseName::tryFrom($request->getParam('db')); |
| 36 | + if ($db !== null) { |
| 37 | + $sqlAutocomplete = $this->getColumnList($db); |
49 | 38 | } |
50 | 39 | } |
51 | 40 |
|
52 | 41 | $this->response->addJSON(['tables' => $sqlAutocomplete]); |
53 | 42 | } |
| 43 | + |
| 44 | + /** @return string[][][] */ |
| 45 | + private function getColumnList(DatabaseName $db): array |
| 46 | + { |
| 47 | + $columns = $this->dbi->query(sprintf( |
| 48 | + 'SELECT TABLE_NAME, COLUMN_NAME, COLUMN_TYPE, COLUMN_KEY ' . |
| 49 | + 'FROM information_schema.columns WHERE table_schema = %s', |
| 50 | + $this->dbi->quoteString($db->getName()), |
| 51 | + )); |
| 52 | + |
| 53 | + $autocompleteList = []; |
| 54 | + /** @var array{TABLE_NAME:string, COLUMN_NAME:string, COLUMN_TYPE:string, COLUMN_KEY:string} $columnInfo */ |
| 55 | + foreach ($columns as $columnInfo) { |
| 56 | + $autocompleteList[$columnInfo['TABLE_NAME']][] = [ |
| 57 | + 'field' => $columnInfo['COLUMN_NAME'], |
| 58 | + 'columnHint' => $columnInfo['COLUMN_TYPE'] . match ($columnInfo['COLUMN_KEY']) { |
| 59 | + 'PRI' => ' | Primary', |
| 60 | + 'UNI' => ' | Unique', |
| 61 | + default=> '' |
| 62 | + }, |
| 63 | + ]; |
| 64 | + } |
| 65 | + |
| 66 | + return $autocompleteList; |
| 67 | + } |
54 | 68 | } |
0 commit comments