2016-10-22 16:57:10 +02:00
|
|
|
<?php
|
|
|
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
|
|
|
/**
|
|
|
|
* searches the entire database
|
|
|
|
*
|
|
|
|
* @todo make use of UNION when searching multiple tables
|
|
|
|
* @todo display executed query, optional?
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
|
|
|
|
2018-04-14 11:18:00 +02:00
|
|
|
use PhpMyAdmin\Database\Search;
|
|
|
|
use PhpMyAdmin\Response;
|
|
|
|
use PhpMyAdmin\Util;
|
|
|
|
|
2016-10-22 16:57:10 +02:00
|
|
|
/**
|
2018-04-14 11:18:00 +02:00
|
|
|
* Gets some core libraries
|
|
|
|
*/
|
2016-10-22 16:57:10 +02:00
|
|
|
require_once 'libraries/common.inc.php';
|
|
|
|
|
2017-04-20 12:55:30 +02:00
|
|
|
$response = Response::getInstance();
|
2016-10-22 16:57:10 +02:00
|
|
|
$header = $response->getHeader();
|
|
|
|
$scripts = $header->getScripts();
|
|
|
|
$scripts->addFile('db_search.js');
|
|
|
|
$scripts->addFile('sql.js');
|
|
|
|
$scripts->addFile('makegrid.js');
|
|
|
|
|
|
|
|
require 'libraries/db_common.inc.php';
|
|
|
|
|
|
|
|
// If config variable $GLOBALS['cfg']['UseDbSearch'] is on false : exit.
|
|
|
|
if (! $GLOBALS['cfg']['UseDbSearch']) {
|
2018-04-14 11:18:00 +02:00
|
|
|
Util::mysqlDie(
|
2016-10-22 16:57:10 +02:00
|
|
|
__('Access denied!'), '', false, $err_url
|
|
|
|
);
|
|
|
|
} // end if
|
|
|
|
$url_query .= '&goto=db_search.php';
|
|
|
|
$url_params['goto'] = 'db_search.php';
|
|
|
|
|
|
|
|
// Create a database search instance
|
2018-04-14 11:18:00 +02:00
|
|
|
$db_search = new Search($GLOBALS['db']);
|
2016-10-22 16:57:10 +02:00
|
|
|
|
|
|
|
// Display top links if we are not in an Ajax request
|
2017-04-20 12:55:30 +02:00
|
|
|
if (! $response->isAjax()) {
|
2016-10-22 16:57:10 +02:00
|
|
|
list(
|
|
|
|
$tables,
|
|
|
|
$num_tables,
|
|
|
|
$total_num_tables,
|
|
|
|
$sub_part,
|
|
|
|
$is_show_stats,
|
|
|
|
$db_is_system_schema,
|
|
|
|
$tooltip_truename,
|
|
|
|
$tooltip_aliasname,
|
|
|
|
$pos
|
2018-04-14 11:18:00 +02:00
|
|
|
) = Util::getDbInfo($db, isset($sub_part) ? $sub_part : '');
|
2016-10-22 16:57:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Main search form has been submitted, get results
|
2018-12-16 15:31:03 +01:00
|
|
|
if (isset($_POST['submit_search'])) {
|
2016-10-22 16:57:10 +02:00
|
|
|
$response->addHTML($db_search->getSearchResults());
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we are in an Ajax request, we need to exit after displaying all the HTML
|
2017-04-20 12:55:30 +02:00
|
|
|
if ($response->isAjax() && empty($_REQUEST['ajax_page_request'])) {
|
2016-10-22 16:57:10 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Display the search form
|
2017-04-20 12:55:30 +02:00
|
|
|
$response->addHTML($db_search->getSelectionForm());
|
|
|
|
$response->addHTML('<div id="searchresults"></div>');
|
2016-10-22 16:57:10 +02:00
|
|
|
$response->addHTML(
|
|
|
|
'<div id="togglesearchresultsdiv"><a id="togglesearchresultlink"></a></div>'
|
|
|
|
);
|
2017-04-20 12:55:30 +02:00
|
|
|
$response->addHTML('<br class="clearfloat" />');
|
2016-10-22 16:57:10 +02:00
|
|
|
$response->addHTML($db_search->getResultDivs());
|