2009-07-03 04:40:48 +00:00
< ? php
2011-05-24 15:16:13 +00:00
// any method change in this file should be transferred to editor/include/adminer.inc.php and plugins/plugin.php
2009-07-27 11:25:37 +00:00
class Adminer {
2010-04-21 12:01:32 +00:00
/** @var array operators used in select, null for all operators */
var $operators ;
2009-07-27 11:25:37 +00:00
/** Name in title and navigation
2011-04-03 15:27:34 +00:00
* @ return string HTML code
2009-07-27 11:25:37 +00:00
*/
function name () {
2011-04-03 15:27:34 +00:00
return " <a href='http://www.adminer.org/' id='h1'>Adminer</a> " ;
2009-07-27 11:25:37 +00:00
}
/** Connection parameters
* @ return array ( $server , $username , $password )
*/
function credentials () {
2010-10-15 08:58:08 +00:00
return array ( SERVER , $_GET [ " username " ], get_session ( " pwds " ));
2009-07-27 11:25:37 +00:00
}
2009-12-18 17:39:48 +00:00
/** Get key used for permanent login
* @ return string cryptic string which gets combined with password
*/
function permanentLogin () {
2010-05-06 13:45:34 +00:00
return password_file ();
2009-12-18 17:39:48 +00:00
}
2009-07-27 11:25:37 +00:00
/** Identifier of selected database
* @ return string
*/
function database () {
2009-08-29 13:54:25 +00:00
// should be used everywhere instead of DB
return DB ;
2009-07-27 11:25:37 +00:00
}
2012-02-24 06:54:48 +00:00
/** Get cached list of databases
* @ param bool
* @ return array
*/
function databases ( $flush = true ) {
return get_databases ( $flush );
}
2012-08-20 00:12:19 +00:00
/** Specify limit for waiting on some slow queries like DB list
* @ return float number of seconds
*/
function queryTimeout () {
return 5 ;
}
2010-10-17 20:13:32 +00:00
/** Headers to send before HTML output
2011-05-31 05:48:10 +00:00
* @ return bool true to send security headers
2010-10-17 20:13:32 +00:00
*/
function headers () {
2011-05-31 05:48:10 +00:00
return true ;
2010-10-17 20:13:32 +00:00
}
2011-03-23 10:57:35 +00:00
/** Print HTML code inside < head >
* @ return bool true to link adminer . css if exists
*/
function head () {
return true ;
}
2009-07-27 11:25:37 +00:00
/** Print login form
* @ return null
*/
2010-04-21 12:01:32 +00:00
function loginForm () {
2010-10-13 15:53:59 +00:00
global $drivers ;
2009-07-21 12:19:25 +00:00
?>
2009-07-21 15:25:05 +00:00
< table cellspacing = " 0 " >
2012-05-14 07:08:32 +00:00
< tr >< th >< ? php echo lang ( 'System' ); ?> <td><?php echo html_select("auth[driver]", $drivers, DRIVER, "loginDriver(this);"); ?>
2013-01-31 05:35:51 +00:00
< tr >< th >< ? php echo lang ( 'Server' ); ?> <td><input name="auth[server]" value="<?php echo h(SERVER); ?>" title="hostname[:port]" autocapitalize="off">
< tr >< th >< ? php echo lang ( 'Username' ); ?> <td><input name="auth[username]" id="username" value="<?php echo h($_GET["username"]); ?>" autocapitalize="off">
2012-05-14 07:08:32 +00:00
< tr >< th >< ? php echo lang ( 'Password' ); ?> <td><input type="password" name="auth[password]">
2013-01-31 05:35:51 +00:00
< tr >< th >< ? php echo lang ( 'Database' ); ?> <td><input name="auth[db]" value="<?php echo h($_GET["db"]); ?>" autocapitalize="off">
2009-07-21 15:25:05 +00:00
</ table >
2010-04-26 16:21:28 +00:00
< script type = " text/javascript " >
2011-01-31 13:48:40 +00:00
var username = document . getElementById ( 'username' );
username . focus ();
2012-05-14 07:08:32 +00:00
username . form [ 'auth[driver]' ] . onchange ();
2010-04-26 16:21:28 +00:00
</ script >
2009-07-21 12:19:25 +00:00
< ? php
2009-12-18 17:49:21 +00:00
echo " <p><input type='submit' value=' " . lang ( 'Login' ) . " '> \n " ;
2012-05-14 07:08:32 +00:00
echo checkbox ( " auth[permanent] " , 1 , $_COOKIE [ " adminer_permanent " ], lang ( 'Permanent login' )) . " \n " ;
2009-07-21 12:19:25 +00:00
}
2009-07-27 11:25:37 +00:00
/** Authorize the user
* @ param string
* @ param string
* @ return bool
*/
function login ( $login , $password ) {
return true ;
2009-07-24 10:14:36 +00:00
}
2009-07-27 11:25:37 +00:00
/** Table caption used in navigation and headings
* @ param array result of SHOW TABLE STATUS
2011-03-24 01:19:21 +00:00
* @ return string HTML code , " " to ignore table
2009-07-27 11:25:37 +00:00
*/
function tableName ( $tableStatus ) {
2009-07-28 16:20:50 +00:00
return h ( $tableStatus [ " Name " ]);
2009-07-27 11:25:37 +00:00
}
/** Field caption used in select and edit
* @ param array single field returned from fields ()
2009-07-27 16:51:40 +00:00
* @ param int order of column in select
2011-03-24 01:19:21 +00:00
* @ return string HTML code , " " to ignore field
2009-07-27 11:25:37 +00:00
*/
2009-07-27 16:51:40 +00:00
function fieldName ( $field , $order = 0 ) {
2009-07-28 16:20:50 +00:00
return '<span title="' . h ( $field [ " full_type " ]) . '">' . h ( $field [ " field " ]) . '</span>' ;
2009-07-27 11:25:37 +00:00
}
2009-09-20 07:31:46 +00:00
/** Print links after select heading
2009-07-27 11:25:37 +00:00
* @ param array result of SHOW TABLE STATUS
2009-11-24 09:44:28 +00:00
* @ param string new item options , NULL for no new item
2009-09-20 07:31:46 +00:00
* @ return null
2009-07-27 11:25:37 +00:00
*/
2009-09-20 07:31:46 +00:00
function selectLinks ( $tableStatus , $set = " " ) {
2009-11-24 09:44:28 +00:00
echo '<p class="tabs">' ;
2009-11-27 13:44:44 +00:00
$links = array ( " select " => lang ( 'Select data' ), " table " => lang ( 'Show structure' ));
2010-05-27 11:31:08 +00:00
if ( is_view ( $tableStatus )) {
2009-11-24 09:44:28 +00:00
$links [ " view " ] = lang ( 'Alter view' );
2010-04-21 12:01:32 +00:00
} else {
$links [ " create " ] = lang ( 'Alter table' );
2009-09-20 07:31:46 +00:00
}
2012-05-14 06:54:07 +00:00
if ( $set !== null ) {
2009-11-24 09:44:28 +00:00
$links [ " edit " ] = lang ( 'New item' );
}
foreach ( $links as $key => $val ) {
2010-11-22 15:08:36 +00:00
echo " <a href=' " . h ( ME ) . " $key = " . urlencode ( $tableStatus [ " Name " ]) . ( $key == " edit " ? $set : " " ) . " ' " . bold ( isset ( $_GET [ $key ])) . " > $val </a> " ;
2009-09-20 07:31:46 +00:00
}
echo " \n " ;
2009-07-27 11:25:37 +00:00
}
2010-10-29 11:58:08 +00:00
/** Get foreign keys for table
* @ param string
* @ return array same format as foreign_keys ()
*/
function foreignKeys ( $table ) {
return foreign_keys ( $table );
}
2009-07-27 11:25:37 +00:00
/** Find backward keys for table
* @ param string
2009-09-23 14:28:06 +00:00
* @ param string
* @ return array $return [ $target_table ][ " keys " ][ $key_name ][ $target_column ] = $source_column ; $return [ $target_table ][ " name " ] = $this -> tableName ( $target_table );
2009-07-27 11:25:37 +00:00
*/
2009-09-23 14:28:06 +00:00
function backwardKeys ( $table , $tableName ) {
2009-07-27 11:25:37 +00:00
return array ();
}
2009-09-23 14:28:06 +00:00
/** Print backward keys for row
* @ param array result of $this -> backwardKeys ()
* @ param array
* @ return null
*/
function backwardKeysPrint ( $backwardKeys , $row ) {
}
2009-07-27 11:25:37 +00:00
/** Query printed in select before execution
* @ param string query to be executed
* @ return string
*/
function selectQuery ( $query ) {
2010-05-07 13:44:22 +00:00
global $jush ;
2011-03-23 13:59:06 +00:00
return " <p><a href=' " . h ( remove_from_uri ( " page " )) . " &page=last' title=' " . lang ( 'Last page' ) . " '>>></a> <code class='jush- $jush '> " . h ( str_replace ( " \n " , " " , $query )) . " </code> <a href=' " . h ( ME ) . " sql= " . urlencode ( $query ) . " '> " . lang ( 'Edit' ) . " </a></p> \n " ; // </p> - required for IE9 inline edit
2009-07-27 11:25:37 +00:00
}
/** Description of a row in a table
* @ param string
* @ return string SQL expression , empty string for no description
*/
function rowDescription ( $table ) {
return " " ;
}
/** Get descriptions of selected data
* @ param array all data to print
* @ param array
* @ return array
*/
function rowDescriptions ( $rows , $foreignKeys ) {
return $rows ;
}
2013-01-11 01:59:43 +00:00
/** Get a link to use in select table
* @ param string raw value of the field
* @ param array single field returned from fields ()
* @ return string or null to create the default link
*/
function selectLink ( $val , $field ) {
}
2009-07-27 11:25:37 +00:00
/** Value printed in select table
2009-07-27 16:32:56 +00:00
* @ param string HTML - escaped value to print
2009-07-27 11:25:37 +00:00
* @ param string link to foreign key
* @ param array single field returned from fields ()
* @ return string
*/
function selectVal ( $val , $link , $field ) {
2012-05-14 06:24:39 +00:00
$return = ( $val === null ? " <i>NULL</i> " : ( ereg ( " char|binary " , $field [ " type " ]) && ! ereg ( " var " , $field [ " type " ]) ? " <code> $val </code> " : $val ));
2010-09-28 08:02:55 +00:00
if ( ereg ( 'blob|bytea|raw|file' , $field [ " type " ]) && ! is_utf8 ( $val )) {
2013-01-23 10:18:02 +00:00
$return = lang ( '%d byte(s)' , strlen ( html_entity_decode ( $val , ENT_QUOTES )));
2009-07-23 11:31:08 +00:00
}
2012-12-05 23:29:57 +00:00
return ( $link ? " <a href=' " . h ( $link ) . " '> $return </a> " : $return );
2009-07-27 11:25:37 +00:00
}
2009-07-27 16:32:56 +00:00
/** Value conversion used in select and edit
* @ param string
* @ param array single field returned from fields ()
2009-07-28 09:27:00 +00:00
* @ return string
2009-07-27 16:32:56 +00:00
*/
function editVal ( $val , $field ) {
2012-09-09 05:56:34 +00:00
return $val ;
2009-07-27 16:32:56 +00:00
}
2009-07-27 14:40:55 +00:00
/** Print columns box in select
2011-05-24 15:03:48 +00:00
* @ param array result of selectColumnsProcess ()[ 0 ]
2009-07-27 14:40:55 +00:00
* @ param array selectable columns
* @ return null
*/
function selectColumnsPrint ( $select , $columns ) {
2010-04-21 12:01:32 +00:00
global $functions , $grouping ;
2009-09-11 19:26:27 +00:00
print_fieldset ( " select " , lang ( 'Select' ), $select );
2009-07-27 14:40:55 +00:00
$i = 0 ;
2010-04-21 12:01:32 +00:00
$fun_group = array ( lang ( 'Functions' ) => $functions , lang ( 'Aggregation' ) => $grouping );
2009-07-27 14:40:55 +00:00
foreach ( $select as $key => $val ) {
$val = $_GET [ " columns " ][ $key ];
2009-10-02 13:21:34 +00:00
echo " <div> " . html_select ( " columns[ $i ][fun] " , array ( - 1 => " " ) + $fun_group , $val [ " fun " ]);
2012-07-29 20:20:03 +00:00
echo " (<select name='columns[ $i ][col]' onchange='selectFieldChange(this.form);'><option> " . optionlist ( $columns , $val [ " col " ], true ) . " </select>)</div> \n " ;
2009-07-27 14:40:55 +00:00
$i ++ ;
}
2010-04-21 12:01:32 +00:00
echo " <div> " . html_select ( " columns[ $i ][fun] " , array ( - 1 => " " ) + $fun_group , " " , " this.nextSibling.nextSibling.onchange(); " );
echo " (<select name='columns[ $i ][col]' onchange='selectAddRow(this);'><option> " . optionlist ( $columns , null , true ) . " </select>)</div> \n " ;
2009-07-27 14:40:55 +00:00
echo " </div></fieldset> \n " ;
}
/** Print search box in select
* @ param array result of selectSearchProcess ()
* @ param array selectable columns
* @ param array
* @ return null
*/
function selectSearchPrint ( $where , $columns , $indexes ) {
2009-09-11 19:26:27 +00:00
print_fieldset ( " search " , lang ( 'Search' ), $where );
2009-07-27 14:40:55 +00:00
foreach ( $indexes as $i => $index ) {
if ( $index [ " type " ] == " FULLTEXT " ) {
2009-07-28 16:20:50 +00:00
echo " (<i> " . implode ( " </i>, <i> " , array_map ( 'h' , $index [ " columns " ])) . " </i>) AGAINST " ;
2012-12-05 21:11:36 +00:00
echo " <input type='search' name='fulltext[ $i ]' value=' " . h ( $_GET [ " fulltext " ][ $i ]) . " ' onchange='selectFieldChange(this.form);'> " ;
2009-09-25 12:03:30 +00:00
echo checkbox ( " boolean[ $i ] " , 1 , isset ( $_GET [ " boolean " ][ $i ]), " BOOL " );
2009-07-27 14:40:55 +00:00
echo " <br> \n " ;
}
}
2012-05-17 06:54:56 +00:00
$_GET [ " where " ] = ( array ) $_GET [ " where " ];
reset ( $_GET [ " where " ]);
$change_next = " this.nextSibling.onchange(); " ;
for ( $i = 0 ; $i <= count ( $_GET [ " where " ]); $i ++ ) {
list (, $val ) = each ( $_GET [ " where " ]);
if ( ! $val || ( " $val[col] $val[val] " != " " && in_array ( $val [ " op " ], $this -> operators ))) {
echo " <div><select name='where[ $i ][col]' onchange=' $change_next '><option value=''>( " . lang ( 'anywhere' ) . " ) " . optionlist ( $columns , $val [ " col " ], true ) . " </select> " ;
echo html_select ( " where[ $i ][op] " , $this -> operators , $val [ " op " ], $change_next );
2012-12-05 21:11:36 +00:00
echo " <input type='search' name='where[ $i ][val]' value=' " . h ( $val [ " val " ]) . " ' onchange=' " . ( $val ? " selectFieldChange(this.form) " : " selectAddRow(this) " ) . " ;'></div> \n " ;
2009-07-27 14:40:55 +00:00
}
}
echo " </div></fieldset> \n " ;
}
/** Print order box in select
* @ param array result of selectOrderProcess ()
* @ param array selectable columns
* @ param array
* @ return null
*/
function selectOrderPrint ( $order , $columns , $indexes ) {
2009-09-11 19:26:27 +00:00
print_fieldset ( " sort " , lang ( 'Sort' ), $order );
2009-07-27 14:40:55 +00:00
$i = 0 ;
foreach (( array ) $_GET [ " order " ] as $key => $val ) {
if ( isset ( $columns [ $val ])) {
2012-05-17 06:54:56 +00:00
echo " <div><select name='order[ $i ]' onchange='selectFieldChange(this.form);'><option> " . optionlist ( $columns , $val , true ) . " </select> " ;
2009-09-25 12:03:30 +00:00
echo checkbox ( " desc[ $i ] " , 1 , isset ( $_GET [ " desc " ][ $key ]), lang ( 'descending' )) . " </div> \n " ;
2009-07-27 14:40:55 +00:00
$i ++ ;
}
}
2009-12-17 13:22:28 +00:00
echo " <div><select name='order[ $i ]' onchange='selectAddRow(this);'><option> " . optionlist ( $columns , null , true ) . " </select> " ;
2011-02-25 15:22:25 +00:00
echo " <label><input type='checkbox' name='desc[ $i ]' value='1'> " . lang ( 'descending' ) . " </label></div> \n " ; // not checkbox() to allow selectAddRow()
2009-07-27 14:40:55 +00:00
echo " </div></fieldset> \n " ;
}
/** Print limit box in select
* @ param string result of selectLimitProcess ()
* @ return null
*/
function selectLimitPrint ( $limit ) {
echo " <fieldset><legend> " . lang ( 'Limit' ) . " </legend><div> " ; // <div> for easy styling
2012-12-05 21:11:36 +00:00
echo " <input type='number' name='limit' class='size' value=' " . h ( $limit ) . " ' onchange='selectFieldChange(this.form);'> " ;
2009-07-27 14:40:55 +00:00
echo " </div></fieldset> \n " ;
}
/** Print text length box in select
* @ param string result of selectLengthProcess ()
* @ return null
*/
function selectLengthPrint ( $text_length ) {
2012-05-14 06:54:07 +00:00
if ( $text_length !== null ) {
2009-07-27 14:40:55 +00:00
echo " <fieldset><legend> " . lang ( 'Text length' ) . " </legend><div> " ;
2012-12-05 21:11:36 +00:00
echo " <input type='number' name='text_length' class='size' value=' " . h ( $text_length ) . " '> " ;
2009-07-27 14:40:55 +00:00
echo " </div></fieldset> \n " ;
}
}
/** Print action box in select
2012-05-17 06:54:56 +00:00
* @ param array
2009-07-27 14:40:55 +00:00
* @ return null
*/
2012-05-17 06:54:56 +00:00
function selectActionPrint ( $indexes ) {
2009-07-27 14:40:55 +00:00
echo " <fieldset><legend> " . lang ( 'Action' ) . " </legend><div> " ;
echo " <input type='submit' value=' " . lang ( 'Select' ) . " '> " ;
2012-05-17 06:54:56 +00:00
echo " <span id='noindex' title=' " . lang ( 'Full table scan' ) . " '></span> " ;
echo " <script type='text/javascript'> \n " ;
echo " var indexColumns = " ;
$columns = array ();
foreach ( $indexes as $index ) {
if ( $index [ " type " ] != " FULLTEXT " ) {
$columns [ reset ( $index [ " columns " ])] = 1 ;
}
}
$columns [ " " ] = 1 ;
foreach ( $columns as $key => $val ) {
json_row ( $key );
}
echo " ; \n " ;
echo " selectFieldChange(document.getElementById('form')); \n " ;
echo " </script> \n " ;
2009-07-27 14:40:55 +00:00
echo " </div></fieldset> \n " ;
}
2011-05-24 15:16:13 +00:00
/** Print command box in select
* @ return bool whether to print default commands
*/
function selectCommandPrint () {
return ! information_schema ( DB );
}
/** Print import box in select
* @ return bool whether to print default import
*/
function selectImportPrint () {
2012-08-29 17:08:18 +00:00
return ! information_schema ( DB );
2011-05-24 15:16:13 +00:00
}
2009-07-28 11:18:08 +00:00
/** Print extra text in the end of a select form
* @ param array fields holding e - mails
2009-09-09 20:47:42 +00:00
* @ param array selectable columns
2009-07-28 11:18:08 +00:00
* @ return null
*/
2009-09-09 20:47:42 +00:00
function selectEmailPrint ( $emailFields , $columns ) {
2009-07-28 11:18:08 +00:00
}
2009-07-27 14:40:55 +00:00
/** Process columns box in select
* @ param array selectable columns
2009-09-09 20:47:42 +00:00
* @ param array
2009-07-27 14:40:55 +00:00
* @ return array ( array ( select_expressions ), array ( group_expressions ))
*/
function selectColumnsProcess ( $columns , $indexes ) {
2010-04-21 12:01:32 +00:00
global $functions , $grouping ;
2009-07-27 14:40:55 +00:00
$select = array (); // select expressions, empty for *
$group = array (); // expressions without aggregation - will be used for GROUP BY if an aggregation function is used
foreach (( array ) $_GET [ " columns " ] as $key => $val ) {
2010-04-21 12:01:32 +00:00
if ( $val [ " fun " ] == " count " || ( isset ( $columns [ $val [ " col " ]]) && ( ! $val [ " fun " ] || in_array ( $val [ " fun " ], $functions ) || in_array ( $val [ " fun " ], $grouping )))) {
2009-07-27 14:40:55 +00:00
$select [ $key ] = apply_sql_function ( $val [ " fun " ], ( isset ( $columns [ $val [ " col " ]]) ? idf_escape ( $val [ " col " ]) : " * " ));
2010-04-21 12:01:32 +00:00
if ( ! in_array ( $val [ " fun " ], $grouping )) {
2009-07-27 14:40:55 +00:00
$group [] = $select [ $key ];
}
}
}
return array ( $select , $group );
}
/** Process search box in select
* @ param array
* @ param array
* @ return array expressions to join by AND
*/
2009-07-28 14:21:05 +00:00
function selectSearchProcess ( $fields , $indexes ) {
2010-10-13 16:04:40 +00:00
global $jush ;
2009-07-27 14:40:55 +00:00
$return = array ();
foreach ( $indexes as $i => $index ) {
2010-01-09 23:33:41 +00:00
if ( $index [ " type " ] == " FULLTEXT " && $_GET [ " fulltext " ][ $i ] != " " ) {
2010-10-13 16:04:40 +00:00
$return [] = " MATCH ( " . implode ( " , " , array_map ( 'idf_escape' , $index [ " columns " ])) . " ) AGAINST ( " . q ( $_GET [ " fulltext " ][ $i ]) . ( isset ( $_GET [ " boolean " ][ $i ]) ? " IN BOOLEAN MODE " : " " ) . " ) " ;
2009-07-27 14:40:55 +00:00
}
}
foreach (( array ) $_GET [ " where " ] as $val ) {
2010-01-09 23:33:41 +00:00
if ( " $val[col] $val[val] " != " " && in_array ( $val [ " op " ], $this -> operators )) {
2010-04-21 12:01:32 +00:00
$cond = " $val[op] " ;
if ( ereg ( 'IN$' , $val [ " op " ])) {
$in = process_length ( $val [ " val " ]);
$cond .= " ( " . ( $in != " " ? $in : " NULL " ) . " ) " ;
2011-01-30 01:07:27 +00:00
} elseif ( ! $val [ " op " ]) {
$cond .= $val [ " val " ]; // SQL injection
2010-04-21 12:01:32 +00:00
} elseif ( $val [ " op " ] == " LIKE %% " ) {
$cond = " LIKE " . $this -> processInput ( $fields [ $val [ " col " ]], " % $val[val] % " );
} elseif ( ! ereg ( 'NULL$' , $val [ " op " ])) {
$cond .= " " . $this -> processInput ( $fields [ $val [ " col " ]], $val [ " val " ]);
}
2010-01-09 23:33:41 +00:00
if ( $val [ " col " ] != " " ) {
2009-07-28 13:43:38 +00:00
$return [] = idf_escape ( $val [ " col " ]) . $cond ;
2009-07-27 14:40:55 +00:00
} else {
2009-07-28 13:43:38 +00:00
// find anywhere
$cols = array ();
foreach ( $fields as $name => $field ) {
2012-09-09 18:03:02 +00:00
$is_text = ereg ( 'char|text|enum|set' , $field [ " type " ]);
if (( is_numeric ( $val [ " val " ]) || ! ereg ( 'int|float|double|decimal|bit' , $field [ " type " ]))
&& ( ! ereg ( " [ \x80 - \xFF ] " , $val [ " val " ]) || $is_text )
) {
2010-01-15 13:58:29 +00:00
$name = idf_escape ( $name );
2012-09-09 18:03:02 +00:00
$cols [] = ( $jush == " sql " && $is_text && ! ereg ( '^utf8' , $field [ " collation " ]) ? " CONVERT( $name USING utf8) " : $name );
2009-07-27 14:40:55 +00:00
}
}
2010-01-15 13:58:29 +00:00
$return [] = ( $cols ? " ( " . implode ( " $cond OR " , $cols ) . " $cond ) " : " 0 " );
2009-07-27 14:40:55 +00:00
}
}
}
return $return ;
}
/** Process order box in select
* @ param array
* @ param array
* @ return array expressions to join by comma
*/
2009-07-28 14:21:05 +00:00
function selectOrderProcess ( $fields , $indexes ) {
2009-07-27 14:40:55 +00:00
$return = array ();
foreach (( array ) $_GET [ " order " ] as $key => $val ) {
2010-04-21 12:01:32 +00:00
if ( isset ( $fields [ $val ]) || preg_match ( '~^((COUNT\\(DISTINCT |[A-Z0-9_]+\\()(`(?:[^`]|``)+`|"(?:[^"]|"")+")\\)|COUNT\\(\\*\\))$~' , $val )) { //! MS SQL uses []
$return [] = ( isset ( $fields [ $val ]) ? idf_escape ( $val ) : $val ) . ( isset ( $_GET [ " desc " ][ $key ]) ? " DESC " : " " );
2009-07-27 14:40:55 +00:00
}
}
return $return ;
}
/** Process limit box in select
* @ return string expression to use in LIMIT , will be escaped
*/
function selectLimitProcess () {
return ( isset ( $_GET [ " limit " ]) ? $_GET [ " limit " ] : " 30 " );
}
/** Process length box in select
* @ return string number of characters to shorten texts , will be escaped
*/
function selectLengthProcess () {
return ( isset ( $_GET [ " text_length " ]) ? $_GET [ " text_length " ] : " 100 " );
}
2009-07-27 11:25:37 +00:00
/** Process extras in select form
* @ param array AND conditions
2009-09-09 20:19:27 +00:00
* @ param array
2009-07-27 11:25:37 +00:00
* @ return bool true if processed , false to process other parts of form
*/
2009-09-09 20:19:27 +00:00
function selectEmailProcess ( $where , $foreignKeys ) {
2009-07-27 11:25:37 +00:00
return false ;
}
2012-08-24 05:17:44 +00:00
/** Build SQL query used in select
* @ param array result of selectColumnsProcess ()[ 0 ]
* @ param array result of selectSearchProcess ()
* @ param array result of selectColumnsProcess ()[ 1 ]
* @ param array result of selectOrderProcess ()
* @ param int result of selectLimitProcess ()
* @ param int index of page starting at zero
* @ return string empty string to use default query
*/
function selectQueryBuild ( $select , $where , $group , $order , $limit , $page ) {
return " " ;
}
2009-07-27 11:25:37 +00:00
/** Query printed after execution in the message
* @ param string executed query
* @ return string
*/
function messageQuery ( $query ) {
2010-05-07 13:44:22 +00:00
global $jush ;
2011-01-30 19:37:22 +00:00
static $count = 0 ;
2009-11-03 10:55:57 +00:00
restart_session ();
2011-01-30 19:37:22 +00:00
$id = " sql- " . ( $count ++ );
2010-10-15 08:58:08 +00:00
$history = & get_session ( " queries " );
2012-03-10 10:28:13 +00:00
if ( strlen ( $query ) > 1e6 ) {
2011-03-22 14:12:38 +00:00
$query = ereg_replace ( '[\x80-\xFF]+$' , '' , substr ( $query , 0 , 1e6 )) . " \n ... " ; // [\x80-\xFF] - valid UTF-8, \n - can end by one-line comment
}
2012-03-10 10:28:13 +00:00
$history [ $_GET [ " db " ]][] = array ( $query , time ()); // not DB - $_GET["db"] is changed in database.inc.php //! respect $_GET["ns"]
return " <span class='time'> " . @ date ( " H:i:s " ) . " </span> <a href='# $id ' onclick= \" return !toggle(' $id '); \" > " . lang ( 'SQL command' ) . " </a><div id=' $id ' class='hidden'><pre><code class='jush- $jush '> " . shorten_utf8 ( $query , 1000 ) . '</code></pre><p><a href="' . h ( str_replace ( " db= " . urlencode ( DB ), " db= " . urlencode ( $_GET [ " db " ]), ME ) . 'sql=&history=' . ( count ( $history [ $_GET [ " db " ]]) - 1 )) . '">' . lang ( 'Edit' ) . '</a></div>' ; // @ - time zone may be not set
2009-07-27 11:25:37 +00:00
}
/** Functions displayed in edit form
* @ param array single field from fields ()
* @ return array
*/
function editFunctions ( $field ) {
2010-04-21 12:01:32 +00:00
global $edit_functions ;
2010-04-22 00:33:46 +00:00
$return = ( $field [ " null " ] ? " NULL/ " : " " );
2010-04-21 12:01:32 +00:00
foreach ( $edit_functions as $key => $functions ) {
if ( ! $key || ( ! isset ( $_GET [ " call " ]) && ( isset ( $_GET [ " select " ]) || where ( $_GET )))) { // relative functions
foreach ( $functions as $pattern => $val ) {
if ( ! $pattern || ereg ( $pattern , $field [ " type " ])) {
$return .= " / $val " ;
}
}
2011-03-22 14:11:42 +00:00
if ( $key && ! ereg ( 'set|blob|bytea|raw|file' , $field [ " type " ])) {
2011-03-15 16:34:25 +00:00
$return .= " /= " ;
}
2009-08-28 14:09:53 +00:00
}
2009-07-23 11:31:08 +00:00
}
2010-04-21 12:01:32 +00:00
return explode ( " / " , $return );
2009-07-23 11:31:08 +00:00
}
2009-07-27 11:25:37 +00:00
/** Get options to display edit field
* @ param string table name
* @ param array single field from fields ()
2009-07-28 10:09:05 +00:00
* @ param string attributes to use inside the tag
* @ param string
* @ return string custom input field or empty string for default
2009-07-27 11:25:37 +00:00
*/
2009-07-28 10:09:05 +00:00
function editInput ( $table , $field , $attrs , $value ) {
2009-11-12 15:25:21 +00:00
if ( $field [ " type " ] == " enum " ) {
2010-10-22 22:28:48 +00:00
return ( isset ( $_GET [ " select " ]) ? " <label><input type='radio' $attrs value='-1' checked><i> " . lang ( 'original' ) . " </i></label> " : " " )
2012-05-14 06:54:07 +00:00
. ( $field [ " null " ] ? " <label><input type='radio' $attrs value='' " . ( $value !== null || isset ( $_GET [ " select " ]) ? " " : " checked " ) . " ><i>NULL</i></label> " : " " )
2011-01-21 16:36:56 +00:00
. enum_input ( " radio " , $attrs , $field , $value , 0 ) // 0 - empty
2009-11-12 15:25:21 +00:00
;
}
return " " ;
2009-07-23 11:31:08 +00:00
}
2009-07-27 11:25:37 +00:00
/** Process sent input
* @ param array single field from fields ()
2009-07-27 16:32:56 +00:00
* @ param string
* @ param string
2009-07-27 11:25:37 +00:00
* @ return string expression to use in a query
*/
2009-07-27 16:32:56 +00:00
function processInput ( $field , $value , $function = " " ) {
2011-03-15 16:34:25 +00:00
if ( $function == " = " ) {
return $value ; // SQL injection
}
2009-07-27 16:32:56 +00:00
$name = $field [ " field " ];
2011-05-16 14:14:11 +00:00
$return = ( $field [ " type " ] == " bit " && ereg ( " ^([0-9]+|b'[0-1]+') \$ " , $value ) ? $value : q ( $value ));
2010-04-21 12:01:32 +00:00
if ( ereg ( '^(now|getdate|uuid)$' , $function )) {
2009-07-27 11:25:37 +00:00
$return = " $function () " ;
2010-05-17 22:49:37 +00:00
} elseif ( ereg ( '^current_(date|timestamp)$' , $function )) {
$return = $function ;
2010-04-21 12:01:32 +00:00
} elseif ( ereg ( '^([+-]|\\|\\|)$' , $function )) {
2009-07-27 11:25:37 +00:00
$return = idf_escape ( $name ) . " $function $return " ;
} elseif ( ereg ( '^[+-] interval$' , $function )) {
2010-10-22 22:02:24 +00:00
$return = idf_escape ( $name ) . " $function " . ( preg_match ( " ~^( \\ d+|'[0-9.: -]') [A-Z_]+ $ ~i " , $value ) ? $value : $return );
2009-08-28 14:09:53 +00:00
} elseif ( ereg ( '^(addtime|subtime|concat)$' , $function )) {
2009-07-27 11:25:37 +00:00
$return = " $function ( " . idf_escape ( $name ) . " , $return ) " ;
2012-09-09 05:39:15 +00:00
} elseif ( ereg ( '^(md5|sha1|password|encrypt)$' , $function )) {
2009-07-27 11:25:37 +00:00
$return = " $function ( $return ) " ;
}
2012-09-09 05:56:34 +00:00
return unconvert_field ( $field , $return );
2009-07-23 16:22:50 +00:00
}
2009-07-27 11:25:37 +00:00
2009-10-02 12:21:55 +00:00
/** Returns export output options
2010-10-29 15:11:00 +00:00
* @ return array
2009-10-02 12:21:55 +00:00
*/
2010-10-29 15:11:00 +00:00
function dumpOutput () {
2009-10-02 12:21:55 +00:00
$return = array ( 'text' => lang ( 'open' ), 'file' => lang ( 'save' ));
if ( function_exists ( 'gzencode' )) {
$return [ 'gz' ] = 'gzip' ;
}
if ( function_exists ( 'bzcompress' )) {
$return [ 'bz2' ] = 'bzip2' ;
}
// ZipArchive requires temporary file, ZIP can be created by gzcompress - see PEAR File_Archive
2010-10-29 15:11:00 +00:00
return $return ;
2009-10-02 12:21:55 +00:00
}
/** Returns export format options
2011-12-22 06:08:18 +00:00
* @ return array empty to disable export
2009-10-02 12:21:55 +00:00
*/
2010-10-29 15:11:00 +00:00
function dumpFormat () {
2010-10-29 16:02:20 +00:00
return array ( 'sql' => 'SQL' , 'csv' => 'CSV,' , 'csv;' => 'CSV;' , 'tsv' => 'TSV' );
2009-10-02 12:21:55 +00:00
}
2010-10-29 15:03:02 +00:00
/** Export table structure
* @ param string
* @ param string
* @ param bool
* @ return null prints data
*/
function dumpTable ( $table , $style , $is_view = false ) {
if ( $_POST [ " format " ] != " sql " ) {
echo " \xef \xbb \xbf " ; // UTF-8 byte order mark
if ( $style ) {
dump_csv ( array_keys ( fields ( $table )));
}
} elseif ( $style ) {
$create = create_sql ( $table , $_POST [ " auto_increment " ]);
if ( $create ) {
if ( $style == " DROP+CREATE " ) {
echo " DROP " . ( $is_view ? " VIEW " : " TABLE " ) . " IF EXISTS " . table ( $table ) . " ; \n " ;
}
if ( $is_view ) {
2012-08-09 16:39:12 +00:00
$create = remove_definer ( $create );
2010-10-29 15:03:02 +00:00
}
echo ( $style != " CREATE+ALTER " ? $create : ( $is_view ? substr_replace ( $create , " OR REPLACE " , 6 , 0 ) : substr_replace ( $create , " IF NOT EXISTS " , 12 , 0 ))) . " ; \n \n " ;
}
if ( $style == " CREATE+ALTER " && ! $is_view ) {
// create procedure which iterates over original columns and adds new and removes old
$query = " SELECT COLUMN_NAME, COLUMN_DEFAULT, IS_NULLABLE, COLLATION_NAME, COLUMN_TYPE, EXTRA, COLUMN_COMMENT FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = DATABASE() AND TABLE_NAME = " . q ( $table ) . " ORDER BY ORDINAL_POSITION " ;
echo " DELIMITER ;;
CREATE PROCEDURE adminer_alter ( INOUT alter_command text ) BEGIN
DECLARE _column_name , _collation_name , after varchar ( 64 ) DEFAULT '' ;
DECLARE _column_type , _column_default text ;
DECLARE _is_nullable char ( 3 );
DECLARE _extra varchar ( 30 );
DECLARE _column_comment varchar ( 255 );
DECLARE done , set_after bool DEFAULT 0 ;
DECLARE add_columns text DEFAULT ' " ;
$fields = array ();
$after = " " ;
foreach ( get_rows ( $query ) as $row ) {
$default = $row [ " COLUMN_DEFAULT " ];
2012-05-14 06:54:07 +00:00
$row [ " default " ] = ( $default !== null ? q ( $default ) : " NULL " );
2010-10-29 15:03:02 +00:00
$row [ " after " ] = q ( $after ); //! rgt AFTER lft, lft AFTER id doesn't work
$row [ " alter " ] = escape_string ( idf_escape ( $row [ " COLUMN_NAME " ])
. " $row[COLUMN_TYPE] "
. ( $row [ " COLLATION_NAME " ] ? " COLLATE $row[COLLATION_NAME] " : " " )
2012-05-14 06:54:07 +00:00
. ( $default !== null ? " DEFAULT " . ( $default == " CURRENT_TIMESTAMP " ? $default : $row [ " default " ]) : " " )
2010-10-29 15:03:02 +00:00
. ( $row [ " IS_NULLABLE " ] == " YES " ? " " : " NOT NULL " )
. ( $row [ " EXTRA " ] ? " $row[EXTRA] " : " " )
. ( $row [ " COLUMN_COMMENT " ] ? " COMMENT " . q ( $row [ " COLUMN_COMMENT " ]) : " " )
. ( $after ? " AFTER " . idf_escape ( $after ) : " FIRST " )
);
echo " , ADD $row[alter] " ;
$fields [] = $row ;
$after = $row [ " COLUMN_NAME " ];
}
echo " ';
DECLARE columns CURSOR FOR $query ;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1 ;
SET @ alter_table = '' ;
OPEN columns ;
REPEAT
FETCH columns INTO _column_name , _column_default , _is_nullable , _collation_name , _column_type , _extra , _column_comment ;
IF NOT done THEN
SET set_after = 1 ;
CASE _column_name " ;
foreach ( $fields as $row ) {
echo "
WHEN " . q( $row["COLUMN_NAME"] ) . " THEN
2011-04-24 12:42:46 +00:00
SET add_columns = REPLACE ( add_columns , ', ADD $row[alter]' , IF (
_column_default <=> $row [ default ] AND _is_nullable = '$row[IS_NULLABLE]' AND _collation_name <=> " . (isset( $row["COLLATION_NAME"] ) ? " '$row[COLLATION_NAME]' " : " NULL " ) . " AND _column_type = " . q( $row["COLUMN_TYPE"] ) . " AND _extra = '$row[EXTRA]' AND _column_comment = " . q( $row["COLUMN_COMMENT"] ) . " AND after = $row [ after ]
, '' , ', MODIFY $row[alter]' )); "
; //! don't replace in comment
2010-10-29 15:03:02 +00:00
}
echo "
ELSE
SET @ alter_table = CONCAT ( @ alter_table , ', DROP ' , _column_name );
SET set_after = 0 ;
END CASE ;
IF set_after THEN
SET after = _column_name ;
END IF ;
END IF ;
UNTIL done END REPEAT ;
CLOSE columns ;
IF @ alter_table != '' OR add_columns != '' THEN
SET alter_command = CONCAT ( alter_command , 'ALTER TABLE " . table($table) . "' , SUBSTR ( CONCAT ( add_columns , @ alter_table ), 2 ), ';\\n' );
END IF ;
END ;;
DELIMITER ;
CALL adminer_alter ( @ adminer_alter );
DROP PROCEDURE adminer_alter ;
" ;
//! indexes
}
}
}
/** Export table data
* @ param string
* @ param string
2010-10-29 15:11:00 +00:00
* @ param string
2010-10-29 15:03:02 +00:00
* @ return null prints data
*/
2010-10-29 15:11:00 +00:00
function dumpData ( $table , $style , $query ) {
2010-10-29 15:03:02 +00:00
global $connection , $jush ;
$max_packet = ( $jush == " sqlite " ? 0 : 1048576 ); // default, minimum is 1024
if ( $style ) {
if ( $_POST [ " format " ] == " sql " && $style == " TRUNCATE+INSERT " ) {
echo truncate_sql ( $table ) . " ; \n " ;
}
2011-02-15 16:22:50 +00:00
if ( $_POST [ " format " ] == " sql " ) {
$fields = fields ( $table );
}
2010-10-29 15:11:00 +00:00
$result = $connection -> query ( $query , 1 ); // 1 - MYSQLI_USE_RESULT //! enum and set as numbers
2010-10-29 15:03:02 +00:00
if ( $result ) {
$insert = " " ;
$buffer = " " ;
2012-08-09 15:57:45 +00:00
$keys = array ();
2012-08-12 05:59:20 +00:00
$suffix = " " ;
2012-08-09 15:57:45 +00:00
while ( $row = $result -> fetch_row ()) {
if ( ! $keys ) {
2012-08-12 05:59:20 +00:00
$values = array ();
2012-08-09 15:57:45 +00:00
foreach ( $row as $val ) {
$field = $result -> fetch_field ();
$keys [] = $field -> name ;
2012-08-12 05:59:20 +00:00
$key = idf_escape ( $field -> name );
$values [] = " $key = VALUES( $key ) " ;
2012-08-09 15:57:45 +00:00
}
2012-08-12 05:59:20 +00:00
$suffix = ( $style == " INSERT+UPDATE " ? " \n ON DUPLICATE KEY UPDATE " . implode ( " , " , $values ) : " " ) . " ; \n " ;
2012-08-09 15:57:45 +00:00
}
2010-10-29 15:03:02 +00:00
if ( $_POST [ " format " ] != " sql " ) {
2011-02-15 16:22:50 +00:00
if ( $style == " table " ) {
2012-08-09 15:57:45 +00:00
dump_csv ( $keys );
2011-02-15 16:22:50 +00:00
$style = " INSERT " ;
}
2010-10-29 15:03:02 +00:00
dump_csv ( $row );
} else {
if ( ! $insert ) {
2012-08-09 15:57:45 +00:00
$insert = " INSERT INTO " . table ( $table ) . " ( " . implode ( " , " , array_map ( 'idf_escape' , $keys )) . " ) VALUES " ;
2010-10-29 15:03:02 +00:00
}
foreach ( $row as $key => $val ) {
2012-08-09 15:57:45 +00:00
$row [ $key ] = ( $val !== null ? ( ereg ( 'int|float|double|decimal|bit' , $fields [ $keys [ $key ]][ " type " ]) ? $val : q ( $val )) : " NULL " ); //! columns looking like functions
2010-10-29 15:03:02 +00:00
}
2012-08-12 05:59:20 +00:00
$s = ( $max_packet ? " \n " : " " ) . " ( " . implode ( " , \t " , $row ) . " ) " ;
if ( ! $buffer ) {
$buffer = $insert . $s ;
} elseif ( strlen ( $buffer ) + 4 + strlen ( $s ) + strlen ( $suffix ) < $max_packet ) { // 4 - length specification
$buffer .= " , $s " ;
2010-10-29 15:03:02 +00:00
} else {
2012-08-12 05:59:20 +00:00
echo $buffer . $suffix ;
$buffer = $insert . $s ;
2010-10-29 15:03:02 +00:00
}
}
}
2012-08-12 05:59:20 +00:00
if ( $buffer ) {
echo $buffer . $suffix ;
2010-10-29 15:03:02 +00:00
}
2010-10-29 15:29:35 +00:00
} elseif ( $_POST [ " format " ] == " sql " ) {
echo " -- " . str_replace ( " \n " , " " , $connection -> error ) . " \n " ;
2010-10-29 15:03:02 +00:00
}
}
}
2012-06-29 21:41:47 +00:00
/** Set export filename
* @ param string
* @ return string filename without extension
*/
function dumpFilename ( $identifier ) {
return friendly_url ( $identifier != " " ? $identifier : ( SERVER != " " ? SERVER : " localhost " ));
}
2010-10-29 15:03:02 +00:00
/** Send headers for export
* @ param string
* @ param bool
* @ return string extension
*/
function dumpHeaders ( $identifier , $multi_table = false ) {
$output = $_POST [ " output " ];
$ext = ( $_POST [ " format " ] == " sql " ? " sql " : ( $multi_table ? " tar " : " csv " )); // multiple CSV packed to TAR
header ( " Content-Type: " .
( $output == " bz2 " ? " application/x-bzip " :
( $output == " gz " ? " application/x-gzip " :
( $ext == " tar " ? " application/x-tar " :
( $ext == " sql " || $output != " file " ? " text/plain " : " text/csv " ) . " ; charset=utf-8 "
))));
2011-02-17 10:43:21 +00:00
if ( $output == " bz2 " ) {
2010-10-29 15:03:02 +00:00
ob_start ( 'bzcompress' , 1e6 );
}
2011-02-17 10:43:21 +00:00
if ( $output == " gz " ) {
2010-10-29 15:03:02 +00:00
ob_start ( 'gzencode' , 1e6 );
}
return $ext ;
2009-10-02 12:21:55 +00:00
}
2011-01-06 08:30:07 +00:00
/** Print homepage
* @ return bool whether to print default homepage
*/
function homepage () {
echo '<p>' . ( $_GET [ " ns " ] == " " ? '<a href="' . h ( ME ) . 'database=">' . lang ( 'Alter database' ) . " </a> \n " : " " );
2011-06-03 11:49:47 +00:00
echo ( support ( " scheme " ) ? " <a href=' " . h ( ME ) . " scheme='> " . ( $_GET [ " ns " ] != " " ? lang ( 'Alter schema' ) : lang ( 'Create schema' )) . " </a> \n " : " " );
2011-07-12 13:45:55 +00:00
echo ( $_GET [ " ns " ] !== " " ? '<a href="' . h ( ME ) . 'schema=">' . lang ( 'Database schema' ) . " </a> \n " : " " );
2011-06-03 11:50:20 +00:00
echo ( support ( " privileges " ) ? " <a href=' " . h ( ME ) . " privileges='> " . lang ( 'Privileges' ) . " </a> \n " : " " );
2011-01-06 08:30:07 +00:00
return true ;
}
2009-07-27 11:25:37 +00:00
/** Prints navigation after Adminer title
2010-10-18 00:15:58 +00:00
* @ param string can be " auth " if there is no database connection , " db " if there is no database selected , " ns " with invalid schema
2009-07-27 11:25:37 +00:00
* @ return null
*/
function navigation ( $missing ) {
2012-08-21 05:03:39 +00:00
global $VERSION , $token , $jush , $drivers ;
2009-09-19 20:16:15 +00:00
?>
< h1 >
2011-04-03 15:27:34 +00:00
< ? php echo $this -> name (); ?> <span class="version"><?php echo $VERSION; ?></span>
2009-09-19 20:16:15 +00:00
< a href = " http://www.adminer.org/#download " id = " version " >< ? php echo ( version_compare ( $VERSION , $_COOKIE [ " adminer_version " ]) < 0 ? h ( $_COOKIE [ " adminer_version " ]) : " " ); ?> </a>
</ h1 >
< ? php
2010-05-06 12:21:22 +00:00
if ( $missing == " auth " ) {
$first = true ;
2010-10-15 08:58:08 +00:00
foreach (( array ) $_SESSION [ " pwds " ] as $driver => $servers ) {
2010-05-06 12:21:22 +00:00
foreach ( $servers as $server => $usernames ) {
foreach ( $usernames as $username => $password ) {
2012-05-14 06:54:07 +00:00
if ( $password !== null ) {
2010-05-06 12:21:22 +00:00
if ( $first ) {
2012-08-21 05:20:22 +00:00
echo " <p id='logins' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'> \n " ;
2010-05-06 12:21:22 +00:00
$first = false ;
}
2012-09-09 04:29:16 +00:00
$dbs = $_SESSION [ " db " ][ $driver ][ $server ][ $username ];
foreach (( $dbs ? array_keys ( $dbs ) : array ( " " )) as $db ) {
echo " <a href=' " . h ( auth_url ( $driver , $server , $username , $db )) . " '>( $drivers[$driver] ) " . h ( $username . ( $server != " " ? " @ $server " : " " ) . ( $db != " " ? " - $db " : " " )) . " </a><br> \n " ;
}
2010-05-06 12:21:22 +00:00
}
}
}
}
} else {
2009-07-27 11:25:37 +00:00
?>
2009-07-03 06:26:01 +00:00
< form action = " " method = " post " >
2009-10-28 12:21:21 +00:00
< p class = " logout " >
2010-10-18 05:38:23 +00:00
< ? php
2010-10-19 15:29:27 +00:00
if ( DB == " " || ! $missing ) {
2010-11-22 15:08:36 +00:00
echo " <a href=' " . h ( ME ) . " sql=' " . bold ( isset ( $_GET [ " sql " ])) . " > " . lang ( 'SQL command' ) . " </a> \n " ;
2010-10-19 15:29:27 +00:00
if ( support ( " dump " )) {
2010-12-29 17:09:04 +00:00
echo " <a href=' " . h ( ME ) . " dump= " . urlencode ( isset ( $_GET [ " table " ]) ? $_GET [ " table " ] : $_GET [ " select " ]) . " ' id='dump' " . bold ( isset ( $_GET [ " dump " ])) . " > " . lang ( 'Dump' ) . " </a> \n " ;
2010-10-19 15:29:27 +00:00
}
}
?>
2012-08-10 14:06:01 +00:00
< input type = " submit " name = " logout " value = " <?php echo lang('Logout'); ?> " id = " logout " >
2011-03-08 12:43:05 +00:00
< input type = " hidden " name = " token " value = " <?php echo $token ; ?> " >
2009-07-14 11:09:39 +00:00
</ p >
2009-07-03 06:26:01 +00:00
</ form >
< ? php
2012-08-21 05:03:39 +00:00
$this -> databasesPrint ( $missing );
2012-08-08 15:41:52 +00:00
if ( $_GET [ " ns " ] !== " " && ! $missing && DB != " " ) {
2012-07-29 23:05:37 +00:00
echo '<p><a href="' . h ( ME ) . 'create="' . bold ( $_GET [ " create " ] === " " ) . " > " . lang ( 'Create new table' ) . " </a> \n " ;
$tables = tables_list ();
if ( ! $tables ) {
echo " <p class='message'> " . lang ( 'No tables.' ) . " \n " ;
} else {
$this -> tablesPrint ( $tables );
$links = array ();
foreach ( $tables as $table => $type ) {
$links [] = preg_quote ( $table , '/' );
}
echo " <script type='text/javascript'> \n " ;
echo " var jushLinks = { $jush : [ ' " . js_escape ( ME ) . " table= \$ &', / \\ b( " . implode ( " | " , $links ) . " ) \\ b/g ] }; \n " ;
foreach ( array ( " bac " , " bra " , " sqlite_quo " , " mssql_bra " ) as $val ) {
echo " jushLinks. $val = jushLinks. $jush ; \n " ;
}
echo " </script> \n " ;
}
}
2009-09-19 20:16:15 +00:00
}
}
2012-08-21 05:03:39 +00:00
/** Prints databases list in menu
* @ param string
* @ return null
*/
function databasesPrint ( $missing ) {
global $connection ;
$databases = $this -> databases ();
?>
< form action = " " >
< p id = " dbs " >
< ? php hidden_fields_get (); ?>
2013-01-31 05:35:51 +00:00
< ? php echo ( $databases ? html_select ( " db " , array ( " " => " ( " . lang ( 'database' ) . " ) " ) + $databases , DB , " this.form.submit(); " ) : '<input name="db" value="' . h ( DB ) . '" autocapitalize="off">' ); ?>
2012-08-21 05:03:39 +00:00
< input type = " submit " value = " <?php echo lang('Use'); ?> " < ? php echo ( $databases ? " class='hidden' " : " " ); ?> >
< ? php
if ( $missing != " db " && DB != " " && $connection -> select_db ( DB )) {
if ( support ( " scheme " )) {
echo " <br> " . html_select ( " ns " , array ( " " => " ( " . lang ( 'schema' ) . " ) " ) + schemas (), $_GET [ " ns " ], " this.form.submit(); " );
if ( $_GET [ " ns " ] != " " ) {
set_schema ( $_GET [ " ns " ]);
}
}
}
echo ( isset ( $_GET [ " sql " ]) ? '<input type="hidden" name="sql" value="">'
: ( isset ( $_GET [ " schema " ]) ? '<input type="hidden" name="schema" value="">'
: ( isset ( $_GET [ " dump " ]) ? '<input type="hidden" name="dump" value="">'
: " " )));
echo " </p></form> \n " ;
}
2009-09-19 20:16:15 +00:00
/** Prints table list in menu
2009-09-23 15:01:17 +00:00
* @ param array
2009-09-19 20:16:15 +00:00
* @ return null
*/
2009-09-23 15:01:17 +00:00
function tablesPrint ( $tables ) {
2012-08-21 05:20:22 +00:00
echo " <p id='tables' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'> \n " ;
2010-04-21 12:01:32 +00:00
foreach ( $tables as $table => $type ) {
2010-11-22 15:08:36 +00:00
echo '<a href="' . h ( ME ) . 'select=' . urlencode ( $table ) . '"' . bold ( $_GET [ " select " ] == $table ) . " > " . lang ( 'select' ) . " </a> " ;
2011-08-09 11:25:20 +00:00
echo '<a href="' . h ( ME ) . 'table=' . urlencode ( $table ) . '"' . bold ( $_GET [ " table " ] == $table ) . " title=' " . lang ( 'Show structure' ) . " '> " . $this -> tableName ( array ( " Name " => $table )) . " </a><br> \n " ; //! Adminer::tableName may work with full table status
2009-07-03 06:26:01 +00:00
}
}
2009-07-27 11:25:37 +00:00
2009-07-03 04:40:48 +00:00
}
2009-09-09 11:03:03 +00:00
$adminer = ( function_exists ( 'adminer_object' ) ? adminer_object () : new Adminer );
2012-05-14 06:54:07 +00:00
if ( $adminer -> operators === null ) {
2010-04-21 12:01:32 +00:00
$adminer -> operators = $operators ;
}