51 lines
2.1 KiB
PHP
51 lines
2.1 KiB
PHP
<?php
|
|
/* $Id$ */
|
|
// vim: expandtab sw=4 ts=4 sts=4:
|
|
|
|
/**
|
|
* Ensure the database and the table exist (else move to the "parent" script)
|
|
* and display headers
|
|
*/
|
|
if (!isset($is_db) || !$is_db) {
|
|
// Not a valid db name -> back to the welcome page
|
|
if (isset($db) && strlen($db)) {
|
|
$is_db = @PMA_DBI_select_db($db);
|
|
}
|
|
if (!isset($db) || !strlen($db) || !$is_db) {
|
|
if (!defined('IS_TRANSFORMATION_WRAPPER')) {
|
|
PMA_sendHeaderLocation($cfg['PmaAbsoluteUri'] . 'main.php?' . PMA_generate_common_url('', '', '&') . (isset($message) ? '&message=' . urlencode($message) : '') . '&reload=1');
|
|
}
|
|
exit;
|
|
}
|
|
} // end if (ensures db exists)
|
|
if (!isset($is_table) || !$is_table) {
|
|
// Not a valid table name -> back to the db_details.php
|
|
if (isset($table) && strlen($table)) {
|
|
$is_table = PMA_DBI_try_query('SHOW TABLES LIKE \'' . PMA_sqlAddslashes($table, TRUE) . '\';', null, PMA_DBI_QUERY_STORE);
|
|
}
|
|
if (! isset($table) && ! strlen($table)
|
|
|| !($is_table && @PMA_DBI_num_rows($is_table))) {
|
|
$redirect = TRUE;
|
|
if (!defined('IS_TRANSFORMATION_WRAPPER')) {
|
|
$redirect = TRUE;
|
|
if (isset($table) && strlen($table)) {
|
|
PMA_DBI_free_result($is_table);
|
|
// SHOW TABLES doesn't show temporary tables, so try select (as it can happen just in case temporary table, it should be fast):
|
|
$is_table2 = PMA_DBI_try_query('SELECT COUNT(*) FROM `' . PMA_sqlAddslashes($table, TRUE) . '`;', null, PMA_DBI_QUERY_STORE);
|
|
$redirect = !($is_table2 && @PMA_DBI_num_rows($is_table2));
|
|
PMA_DBI_free_result($is_table2);
|
|
}
|
|
|
|
if ($redirect) {
|
|
PMA_sendHeaderLocation($cfg['PmaAbsoluteUri'] . 'db_details.php?' . PMA_generate_common_url($db, '', '&') . (isset($message) ? '&message=' . urlencode($message) : '') . '&reload=1');
|
|
}
|
|
}
|
|
if ($redirect) {
|
|
exit;
|
|
}
|
|
} elseif (isset($is_table)) {
|
|
PMA_DBI_free_result($is_table);
|
|
}
|
|
} // end if (ensures table exists)
|
|
?>
|