Update website
This commit is contained in:
parent
a0b0d3dae7
commit
ae7ef6ad45
3151 changed files with 566766 additions and 48 deletions
213
admin/phpMyAdmin/libraries/classes/SqlQueryForm.php
Normal file
213
admin/phpMyAdmin/libraries/classes/SqlQueryForm.php
Normal file
|
@ -0,0 +1,213 @@
|
|||
<?php
|
||||
/**
|
||||
* functions for displaying the sql query form
|
||||
*
|
||||
* @usedby /server/sql
|
||||
* @usedby /database/sql
|
||||
* @usedby /table/sql
|
||||
* @usedby /table/structure
|
||||
* @usedby /table/tracking
|
||||
*/
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace PhpMyAdmin;
|
||||
|
||||
use PhpMyAdmin\Html\MySQLDocumentation;
|
||||
use function htmlspecialchars;
|
||||
use function sprintf;
|
||||
use function strlen;
|
||||
use function strpos;
|
||||
|
||||
/**
|
||||
* PhpMyAdmin\SqlQueryForm class
|
||||
*/
|
||||
class SqlQueryForm
|
||||
{
|
||||
/** @var Template */
|
||||
private $template;
|
||||
|
||||
/**
|
||||
* @param Template $template Template object
|
||||
*/
|
||||
public function __construct(Template $template)
|
||||
{
|
||||
$this->template = $template;
|
||||
}
|
||||
|
||||
/**
|
||||
* return HTML for the sql query boxes
|
||||
*
|
||||
* @param bool|string $query query to display in the textarea
|
||||
* or true to display last executed
|
||||
* @param bool|string $display_tab sql|full|false
|
||||
* what part to display
|
||||
* false if not inside querywindow
|
||||
* @param string $delimiter delimiter
|
||||
*
|
||||
* @return string
|
||||
*
|
||||
* @usedby /server/sql
|
||||
* @usedby /database/sql
|
||||
* @usedby /table/sql
|
||||
* @usedby /table/structure
|
||||
* @usedby /table/tracking
|
||||
*/
|
||||
public function getHtml(
|
||||
$query = true,
|
||||
$display_tab = false,
|
||||
$delimiter = ';'
|
||||
) {
|
||||
global $dbi;
|
||||
|
||||
if (! $display_tab) {
|
||||
$display_tab = 'full';
|
||||
}
|
||||
// query to show
|
||||
if ($query === true) {
|
||||
$query = $GLOBALS['sql_query'];
|
||||
if (empty($query) && (isset($_GET['show_query']) || isset($_POST['show_query']))) {
|
||||
$query = $_GET['sql_query'] ?? $_POST['sql_query'] ?? '';
|
||||
}
|
||||
}
|
||||
|
||||
$table = '';
|
||||
$db = '';
|
||||
if (strlen($GLOBALS['db']) === 0) {
|
||||
// prepare for server related
|
||||
$goto = empty($GLOBALS['goto']) ? Url::getFromRoute('/server/sql') : $GLOBALS['goto'];
|
||||
} elseif (strlen($GLOBALS['table']) === 0) {
|
||||
// prepare for db related
|
||||
$db = $GLOBALS['db'];
|
||||
$goto = empty($GLOBALS['goto']) ? Url::getFromRoute('/database/sql') : $GLOBALS['goto'];
|
||||
} else {
|
||||
$table = $GLOBALS['table'];
|
||||
$db = $GLOBALS['db'];
|
||||
$goto = empty($GLOBALS['goto']) ? Url::getFromRoute('/table/sql') : $GLOBALS['goto'];
|
||||
}
|
||||
|
||||
if ($display_tab === 'full' || $display_tab === 'sql') {
|
||||
[$legend, $query, $columns_list] = $this->init($query);
|
||||
}
|
||||
|
||||
$cfgBookmark = Bookmark::getParams($GLOBALS['cfg']['Server']['user']);
|
||||
|
||||
$bookmarks = [];
|
||||
if ($display_tab === 'full') {
|
||||
if ($cfgBookmark) {
|
||||
$bookmark_list = Bookmark::getList(
|
||||
$dbi,
|
||||
$GLOBALS['cfg']['Server']['user'],
|
||||
$GLOBALS['db']
|
||||
);
|
||||
|
||||
foreach ($bookmark_list as $bookmarkItem) {
|
||||
$bookmarks[] = [
|
||||
'id' => $bookmarkItem->getId(),
|
||||
'variable_count' => $bookmarkItem->getVariableCount(),
|
||||
'label' => $bookmarkItem->getLabel(),
|
||||
'is_shared' => empty($bookmarkItem->getUser()),
|
||||
];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $this->template->render('sql/query', [
|
||||
'legend' => $legend ?? '',
|
||||
'textarea_cols' => $GLOBALS['cfg']['TextareaCols'],
|
||||
'textarea_rows' => $GLOBALS['cfg']['TextareaRows'],
|
||||
'textarea_auto_select' => $GLOBALS['cfg']['TextareaAutoSelect'],
|
||||
'columns_list' => $columns_list ?? [],
|
||||
'codemirror_enable' => $GLOBALS['cfg']['CodemirrorEnable'],
|
||||
'has_bookmark' => $cfgBookmark,
|
||||
'delimiter' => $delimiter,
|
||||
'retain_query_box' => $GLOBALS['cfg']['RetainQueryBox'] !== false,
|
||||
'is_upload' => $GLOBALS['is_upload'],
|
||||
'db' => $db,
|
||||
'table' => $table,
|
||||
'goto' => $goto,
|
||||
'query' => $query,
|
||||
'display_tab' => $display_tab,
|
||||
'bookmarks' => $bookmarks,
|
||||
'can_convert_kanji' => Encoding::canConvertKanji(),
|
||||
'is_foreign_key_check' => Util::isForeignKeyCheck(),
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get initial values for Sql Query Form Insert
|
||||
*
|
||||
* @param string $query query to display in the textarea
|
||||
*
|
||||
* @return array ($legend, $query, $columns_list)
|
||||
*/
|
||||
public function init($query)
|
||||
{
|
||||
global $dbi;
|
||||
|
||||
$columns_list = [];
|
||||
if (strlen($GLOBALS['db']) === 0) {
|
||||
// prepare for server related
|
||||
$legend = sprintf(
|
||||
__('Run SQL query/queries on server “%s”'),
|
||||
htmlspecialchars(
|
||||
! empty($GLOBALS['cfg']['Servers'][$GLOBALS['server']]['verbose'])
|
||||
? $GLOBALS['cfg']['Servers'][$GLOBALS['server']]['verbose']
|
||||
: $GLOBALS['cfg']['Servers'][$GLOBALS['server']]['host']
|
||||
)
|
||||
);
|
||||
} elseif (strlen($GLOBALS['table']) === 0) {
|
||||
// prepare for db related
|
||||
$db = $GLOBALS['db'];
|
||||
// if you want navigation:
|
||||
$scriptName = Util::getScriptNameForOption(
|
||||
$GLOBALS['cfg']['DefaultTabDatabase'],
|
||||
'database'
|
||||
);
|
||||
$tmp_db_link = '<a href="' . $scriptName
|
||||
. Url::getCommon(['db' => $db], strpos($scriptName, '?') === false ? '?' : '&')
|
||||
. '">';
|
||||
$tmp_db_link .= htmlspecialchars($db) . '</a>';
|
||||
$legend = sprintf(__('Run SQL query/queries on database %s'), $tmp_db_link);
|
||||
if (empty($query)) {
|
||||
$query = Util::expandUserString(
|
||||
$GLOBALS['cfg']['DefaultQueryDatabase'],
|
||||
'backquote'
|
||||
);
|
||||
}
|
||||
} else {
|
||||
$db = $GLOBALS['db'];
|
||||
$table = $GLOBALS['table'];
|
||||
// Get the list and number of fields
|
||||
// we do a try_query here, because we could be in the query window,
|
||||
// trying to synchronize and the table has not yet been created
|
||||
$columns_list = $dbi->getColumns(
|
||||
$db,
|
||||
$GLOBALS['table'],
|
||||
null,
|
||||
true
|
||||
);
|
||||
|
||||
$scriptName = Util::getScriptNameForOption(
|
||||
$GLOBALS['cfg']['DefaultTabTable'],
|
||||
'table'
|
||||
);
|
||||
$tmp_tbl_link = '<a href="' . $scriptName . Url::getCommon(['db' => $db, 'table' => $table], '&') . '">';
|
||||
$tmp_tbl_link .= htmlspecialchars($db) . '.' . htmlspecialchars($table) . '</a>';
|
||||
$legend = sprintf(__('Run SQL query/queries on table %s'), $tmp_tbl_link);
|
||||
if (empty($query)) {
|
||||
$query = Util::expandUserString(
|
||||
$GLOBALS['cfg']['DefaultQueryTable'],
|
||||
'backquote'
|
||||
);
|
||||
}
|
||||
}
|
||||
$legend .= ': ' . MySQLDocumentation::show('SELECT');
|
||||
|
||||
return [
|
||||
$legend,
|
||||
$query,
|
||||
$columns_list,
|
||||
];
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue