2018-04-14 09:18:00 +00:00
|
|
|
<?php
|
|
|
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
|
|
|
/**
|
|
|
|
* Generic AJAX endpoint for getting information about database
|
|
|
|
*
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
|
|
|
|
|
|
|
use PhpMyAdmin\Response;
|
|
|
|
use PhpMyAdmin\Util;
|
|
|
|
use PhpMyAdmin\Core;
|
|
|
|
|
|
|
|
$_GET['ajax_request'] = 'true';
|
|
|
|
|
|
|
|
require_once 'libraries/common.inc.php';
|
|
|
|
|
|
|
|
$response = Response::getInstance();
|
|
|
|
$response->setAJAX(true);
|
|
|
|
|
|
|
|
if (empty($_POST['type'])) {
|
|
|
|
Core::fatalError(__('Bad type!'));
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($_POST['type']) {
|
|
|
|
case 'list-databases':
|
|
|
|
$response->addJSON('databases', $GLOBALS['dblist']->databases);
|
|
|
|
break;
|
|
|
|
case 'list-tables':
|
|
|
|
Util::checkParameters(array('db'), true);
|
2018-12-16 14:31:03 +00:00
|
|
|
$response->addJSON('tables', $GLOBALS['dbi']->getTables($_POST['db']));
|
2018-04-14 09:18:00 +00:00
|
|
|
break;
|
|
|
|
case 'list-columns':
|
|
|
|
Util::checkParameters(array('db', 'table'), true);
|
2018-12-16 14:31:03 +00:00
|
|
|
$response->addJSON('columns', $GLOBALS['dbi']->getColumnNames($_POST['db'], $_POST['table']));
|
2018-04-14 09:18:00 +00:00
|
|
|
break;
|
|
|
|
case 'config-get':
|
|
|
|
Util::checkParameters(array('key'), true);
|
2018-12-16 14:31:03 +00:00
|
|
|
$response->addJSON('value', $GLOBALS['PMA_Config']->get($_POST['key']));
|
2018-04-14 09:18:00 +00:00
|
|
|
break;
|
|
|
|
case 'config-set':
|
|
|
|
Util::checkParameters(array('key', 'value'), true);
|
2018-12-16 14:31:03 +00:00
|
|
|
$result = $GLOBALS['PMA_Config']->setUserValue(null, $_POST['key'], json_decode($_POST['value']));
|
2018-04-14 09:18:00 +00:00
|
|
|
if ($result !== true) {
|
|
|
|
$response = Response::getInstance();
|
|
|
|
$response->setRequestStatus(false);
|
|
|
|
$response->addJSON('message', $result);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
Core::fatalError(__('Bad type!'));
|
|
|
|
}
|