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.
152 lines
4.7 KiB
152 lines
4.7 KiB
<?php |
|
|
|
declare(strict_types=1); |
|
|
|
namespace PhpMyAdmin\Controllers\Table; |
|
|
|
use PhpMyAdmin\DatabaseInterface; |
|
use PhpMyAdmin\DbTableExists; |
|
use PhpMyAdmin\Index; |
|
use PhpMyAdmin\ResponseRenderer; |
|
use PhpMyAdmin\Table\Indexes; |
|
use PhpMyAdmin\Template; |
|
use PhpMyAdmin\Url; |
|
use PhpMyAdmin\Util; |
|
|
|
use function count; |
|
use function is_array; |
|
use function is_numeric; |
|
use function json_decode; |
|
use function min; |
|
|
|
/** |
|
* Displays index edit/creation form and handles it. |
|
*/ |
|
class IndexesController extends AbstractController |
|
{ |
|
/** @var DatabaseInterface */ |
|
private $dbi; |
|
|
|
/** @var Indexes */ |
|
private $indexes; |
|
|
|
public function __construct( |
|
ResponseRenderer $response, |
|
Template $template, |
|
string $db, |
|
string $table, |
|
DatabaseInterface $dbi, |
|
Indexes $indexes |
|
) { |
|
parent::__construct($response, $template, $db, $table); |
|
$this->dbi = $dbi; |
|
$this->indexes = $indexes; |
|
} |
|
|
|
public function __invoke(): void |
|
{ |
|
global $db, $table, $urlParams, $cfg, $errorUrl; |
|
|
|
if (! isset($_POST['create_edit_table'])) { |
|
Util::checkParameters(['db', 'table']); |
|
|
|
$urlParams = ['db' => $db, 'table' => $table]; |
|
$errorUrl = Util::getScriptNameForOption($cfg['DefaultTabTable'], 'table'); |
|
$errorUrl .= Url::getCommon($urlParams, '&'); |
|
|
|
DbTableExists::check(); |
|
} |
|
|
|
if (isset($_POST['index'])) { |
|
if (is_array($_POST['index'])) { |
|
// coming already from form |
|
$index = new Index($_POST['index']); |
|
} else { |
|
$index = $this->dbi->getTable($this->db, $this->table)->getIndex($_POST['index']); |
|
} |
|
} else { |
|
$index = new Index(); |
|
} |
|
|
|
if (isset($_POST['do_save_data'])) { |
|
$this->indexes->doSaveData($index, false, $this->db, $this->table); |
|
|
|
return; |
|
} |
|
|
|
$this->displayForm($index); |
|
} |
|
|
|
/** |
|
* Display the form to edit/create an index |
|
* |
|
* @param Index $index An Index instance. |
|
*/ |
|
private function displayForm(Index $index): void |
|
{ |
|
$this->dbi->selectDb($GLOBALS['db']); |
|
$add_fields = 0; |
|
if (isset($_POST['index']) && is_array($_POST['index'])) { |
|
// coming already from form |
|
if (isset($_POST['index']['columns']['names'])) { |
|
$add_fields = count($_POST['index']['columns']['names']) |
|
- $index->getColumnCount(); |
|
} |
|
|
|
if (isset($_POST['add_fields'])) { |
|
$add_fields += $_POST['added_fields']; |
|
} |
|
} elseif (isset($_POST['create_index'])) { |
|
/** |
|
* In most cases, an index may consist of up to 16 columns, so add an initial limit. |
|
* More columns could be added later if necessary. |
|
* |
|
* @see https://dev.mysql.com/doc/refman/5.6/en/multiple-column-indexes.html "up to 16 columns" |
|
* @see https://mariadb.com/kb/en/innodb-limitations/#limitations-on-schema "maximum of 16 columns" |
|
* @see https://mariadb.com/kb/en/myisam-overview/#myisam-features "Maximum of 32 columns per index" |
|
*/ |
|
$add_fields = 1; |
|
if (is_numeric($_POST['added_fields']) && $_POST['added_fields'] >= 2) { |
|
$add_fields = min((int) $_POST['added_fields'], 16); |
|
} |
|
} |
|
|
|
// Get fields and stores their name/type |
|
if (isset($_POST['create_edit_table'])) { |
|
$fields = json_decode($_POST['columns'], true); |
|
$index_params = [ |
|
'Non_unique' => $_POST['index']['Index_choice'] === 'UNIQUE' |
|
? '0' : '1', |
|
]; |
|
$index->set($index_params); |
|
$add_fields = count($fields); |
|
} else { |
|
$fields = $this->dbi->getTable($this->db, $this->table) |
|
->getNameAndTypeOfTheColumns(); |
|
} |
|
|
|
$form_params = [ |
|
'db' => $this->db, |
|
'table' => $this->table, |
|
]; |
|
|
|
if (isset($_POST['create_index'])) { |
|
$form_params['create_index'] = 1; |
|
} elseif (isset($_POST['old_index'])) { |
|
$form_params['old_index'] = $_POST['old_index']; |
|
} elseif (isset($_POST['index'])) { |
|
$form_params['old_index'] = $_POST['index']; |
|
} |
|
|
|
$this->addScriptFiles(['indexes.js']); |
|
|
|
$this->render('table/index_form', [ |
|
'fields' => $fields, |
|
'index' => $index, |
|
'form_params' => $form_params, |
|
'add_fields' => $add_fields, |
|
'create_edit_table' => isset($_POST['create_edit_table']), |
|
'default_sliders_state' => $GLOBALS['cfg']['InitialSlidersState'], |
|
]); |
|
} |
|
}
|
|
|