2009-07-03 04:40:48 +00:00
< ? php
2009-07-11 19:45:57 +00:00
/** Name in title and navigation
* @ return string
*/
function adminer_name () {
return call_adminer ( 'name' , lang ( 'Adminer' ));
}
/** Connection parameters
* @ return array ( $server , $username , $password )
*/
function adminer_credentials () {
return call_adminer ( 'credentials' , array ( $_GET [ " server " ], $_SESSION [ " usernames " ][ $_GET [ " server " ]], $_SESSION [ " passwords " ][ $_GET [ " server " ]]));
}
/** Identifier of selected database
* @ return string
*/
function adminer_database () {
// should be used everywhere instead of $_GET["db"]
return call_adminer ( 'database' , $_GET [ " db " ]);
}
2009-07-21 12:19:25 +00:00
/** Print login form
* @ param string
* @ return bool whether to display default login form
*/
function adminer_login_form ( $username ) {
if ( call_adminer ( 'login_form' , true , $username )) {
?>
2009-07-21 15:25:05 +00:00
< table cellspacing = " 0 " >
< tr >< th >< ? php echo lang ( 'Server' ); ?> <td><input name="server" value="<?php echo htmlspecialchars($_GET["server"]); ?>">
< tr >< th >< ? php echo lang ( 'Username' ); ?> <td><input name="username" value="<?php echo htmlspecialchars($username); ?>">
< tr >< th >< ? php echo lang ( 'Password' ); ?> <td><input type="password" name="password">
</ table >
2009-07-21 12:19:25 +00:00
< ? php
}
}
/** Authorize the user
* @ param string
* @ param string
* @ return bool
*/
function adminer_login ( $login , $password ) {
return call_adminer ( 'login' , true , $login , $password );
}
2009-07-11 19:45:57 +00:00
/** Table caption used in navigation and headings
* @ param array result of SHOW TABLE STATUS
* @ return string
*/
2009-07-24 06:05:21 +00:00
function adminer_table_name ( $table_status ) {
return call_adminer ( 'table_name' , htmlspecialchars ( $table_status [ " Name " ]), $table_status );
2009-07-11 19:45:57 +00:00
}
/** Field caption used in select and edit
2009-07-23 15:49:59 +00:00
* @ param array single field returned from fields ()
2009-07-11 19:45:57 +00:00
* @ return string
*/
2009-07-23 15:49:59 +00:00
function adminer_field_name ( $field ) {
2009-07-24 06:33:30 +00:00
return call_adminer ( 'field_name' , '<span title="' . htmlspecialchars ( $field [ " full_type " ]) . '">' . htmlspecialchars ( $field [ " field " ]) . '</span>' , $field );
2009-07-11 19:45:57 +00:00
}
/** Links after select heading
* @ param array result of SHOW TABLE STATUS
* @ return string
*/
function adminer_select_links ( $table_status ) {
global $SELF ;
2009-07-24 06:05:21 +00:00
return call_adminer ( 'select_links' , '<a href="' . htmlspecialchars ( $SELF ) . 'table=' . urlencode ( $_GET [ 'select' ]) . '">' . lang ( 'Table structure' ) . '</a>' , $table_status );
2009-07-11 19:45:57 +00:00
}
2009-07-22 11:04:03 +00:00
/** Find backward keys for table
* @ param string
* @ return array $return [ $target_table ][ $key_name ][ $target_column ] = $source_column ;
*/
function adminer_backward_keys ( $table ) {
return call_adminer ( 'backward_keys' , array (), $table );
}
2009-07-11 19:52:48 +00:00
/** Query printed in select before execution
2009-07-11 19:45:57 +00:00
* @ param string query to be executed
* @ return string
*/
function adminer_select_query ( $query ) {
global $SELF ;
// it would be nice if $query can be passed by reference and printed value would be returned but call_user() doesn't allow reference parameters
2009-07-11 20:30:40 +00:00
return call_adminer ( 'select_query' , " <p><code class='jush-sql'> " . htmlspecialchars ( $query ) . " </code> <a href=' " . htmlspecialchars ( $SELF ) . " sql= " . urlencode ( $query ) . " '> " . lang ( 'Edit' ) . " </a> \n " , $query );
2009-07-11 19:45:57 +00:00
}
2009-07-23 14:42:38 +00:00
/** Description of a row in a table
* @ param string
* @ return string SQL expression , empty string for no description
*/
function adminer_row_description ( $table ) {
return call_adminer ( 'row_description' , " " , $table );
}
/** Get descriptions of selected data
2009-07-20 15:34:05 +00:00
* @ param array all data to print
2009-07-23 14:42:38 +00:00
* @ param array
2009-07-20 15:34:05 +00:00
* @ return array
*/
function adminer_row_descriptions ( $rows , $foreign_keys ) {
return call_adminer ( 'row_descriptions' , $rows , $rows , $foreign_keys );
}
2009-07-14 10:06:35 +00:00
/** Value printed in select table
* @ param string escaped value to print
2009-07-15 11:09:19 +00:00
* @ param string link to foreign key
2009-07-24 09:52:18 +00:00
* @ param array single field returned from fields ()
2009-07-15 11:09:19 +00:00
* @ return string
2009-07-14 10:06:35 +00:00
*/
2009-07-24 09:52:18 +00:00
function adminer_select_val ( $val , $link , $field ) {
$return = ( $field [ " type " ] == " char " ? " <code> $val </code> " : $val );
return call_adminer ( 'select_val' , ( $link ? " <a href= \" $link\ " > $return </ a > " : $return ), $val , $link );
2009-07-14 10:06:35 +00:00
}
2009-07-11 19:45:57 +00:00
/** Query printed after execution in the message
* @ param string executed query
* @ return string
*/
function adminer_message_query ( $query ) {
global $SELF ;
$id = " sql- " . count ( $_SESSION [ " messages " ]);
2009-07-16 09:24:16 +00:00
$_SESSION [ " history " ][ $_GET [ " server " ]][ $_GET [ " db " ]][] = $query ;
return call_adminer ( 'message_query' , " <a href='# $id ' onclick= \" return !toggle(' $id '); \" > " . lang ( 'SQL command' ) . " </a><div id=' $id ' class='hidden'><pre class='jush-sql'> " . htmlspecialchars ( $query ) . '</pre><a href="' . htmlspecialchars ( $SELF . 'sql=&history=' . ( count ( $_SESSION [ " history " ][ $_GET [ " server " ]][ $_GET [ " db " ]]) - 1 )) . '">' . lang ( 'Edit' ) . '</a></div>' , $query );
2009-07-11 19:45:57 +00:00
}
2009-07-23 11:31:08 +00:00
/** Functions displayed in edit form
* @ param array single field from fields ()
* @ return array
*/
function adminer_edit_functions ( $field ) {
$return = array ( " " );
if ( ! isset ( $_GET [ " default " ])) {
if ( ereg ( 'char|date|time' , $field [ " type " ])) {
$return = ( ereg ( 'char' , $field [ " type " ]) ? array ( " " , " md5 " , " sha1 " , " password " , " uuid " ) : array ( " " , " now " )); //! JavaScript for disabling maxlength
}
if ( ! isset ( $_GET [ " call " ]) && ( isset ( $_GET [ " select " ]) || where ( $_GET ))) {
// relative functions
if ( ereg ( 'int|float|double|decimal' , $field [ " type " ])) {
$return = array ( " " , " + " , " - " );
}
if ( ereg ( 'date' , $field [ " type " ])) {
$return [] = " + interval " ;
$return [] = " - interval " ;
}
if ( ereg ( 'time' , $field [ " type " ])) {
$return [] = " addtime " ;
$return [] = " subtime " ;
}
}
}
if ( $field [ " null " ] || isset ( $_GET [ " default " ])) {
array_unshift ( $return , " NULL " );
}
2009-07-23 14:42:38 +00:00
return call_adminer ( 'edit_functions' , ( isset ( $_GET [ " select " ]) ? array ( " orig " => lang ( 'original' )) : array ()) + $return , $field );
}
/** Get options to display edit field
* @ param string table name
* @ param array single field from fields ()
* @ return array options for < select > or empty to display < input >
*/
function adminer_edit_input ( $table , $field ) {
return call_adminer ( 'edit_input' , false , $table , $field );
2009-07-23 11:31:08 +00:00
}
2009-07-23 16:22:50 +00:00
/** Process sent input
* @ param string field name
* @ param array single field from fields ()
* @ return string expression to use in a query
*/
function adminer_process_input ( $name , $field ) {
global $dbh ;
$idf = bracket_escape ( $name );
$function = $_POST [ " function " ][ $idf ];
$value = $_POST [ " fields " ][ $idf ];
$return = $dbh -> quote ( $value );
if ( ereg ( '^(now|uuid)$' , $function )) {
$return = " $function () " ;
} elseif ( ereg ( '^[+-]$' , $function )) {
$return = idf_escape ( $name ) . " $function $return " ;
} elseif ( ereg ( '^[+-] interval$' , $function )) {
$return = idf_escape ( $name ) . " $function " . ( preg_match ( " ~^([0-9]+|'[0-9.: -]') [A-Z_]+ $ ~i " , $value ) ? $value : $return );
} elseif ( ereg ( '^(addtime|subtime)$' , $function )) {
$return = " $function ( " . idf_escape ( $name ) . " , $return ) " ;
} elseif ( ereg ( '^(md5|sha1|password)$' , $function )) {
$return = " $function ( $return ) " ;
} elseif ( ereg ( 'date|time' , $field [ " type " ]) && $value == " CURRENT_TIMESTAMP " ) {
$return = $value ;
}
return call_adminer ( 'process_input' , $return , $name , $field );
}
2009-07-11 19:45:57 +00:00
/** Prints navigation after Adminer title
* @ param string can be " auth " if there is no database connection or " db " if there is no database selected
* @ return bool true if default navigation should be printed
*/
function adminer_navigation ( $missing ) {
2009-07-24 06:05:21 +00:00
global $SELF , $dbh ;
2009-07-11 19:45:57 +00:00
if ( call_adminer ( 'navigation' , true , $missing ) && $missing != " auth " ) {
2009-07-16 17:45:07 +00:00
ob_flush ();
flush ();
2009-07-11 19:45:57 +00:00
$databases = get_databases ();
?>
2009-07-03 06:26:01 +00:00
< form action = " " method = " post " >
< p >
< a href = " <?php echo htmlspecialchars( $SELF ); ?>sql= " >< ? php echo lang ( 'SQL command' ); ?> </a>
< a href = " <?php echo htmlspecialchars( $SELF ); ?>dump=<?php echo urlencode(isset( $_GET["table"] ) ? $_GET["table"] : $_GET["select"] ); ?> " >< ? php echo lang ( 'Dump' ); ?> </a>
2009-07-11 20:30:40 +00:00
< input type = " hidden " name = " token " value = " <?php echo $_SESSION["tokens"] [ $_GET["server"] ]; ?> " >
< input type = " submit " name = " logout " value = " <?php echo lang('Logout'); ?> " >
2009-07-14 11:09:39 +00:00
</ p >
2009-07-03 06:26:01 +00:00
</ form >
< form action = " " >
2009-07-11 20:30:40 +00:00
< p >< ? php if ( strlen ( $_GET [ " server " ])) { ?> <input type="hidden" name="server" value="<?php echo htmlspecialchars($_GET["server"]); ?>"><?php } ?>
2009-07-03 06:26:01 +00:00
< ? php if ( $databases ) { ?>
2009-07-11 20:30:40 +00:00
< select name = " db " onchange = " this.form.submit(); " >< option value = " " > ( < ? php echo lang ( 'database' ); ?> )<?php echo optionlist($databases, $_GET["db"]); ?></select>
2009-07-03 06:26:01 +00:00
< ? php } else { ?>
2009-07-11 20:30:40 +00:00
< input name = " db " value = " <?php echo htmlspecialchars( $_GET["db"] ); ?> " >
2009-07-03 06:26:01 +00:00
< ? php } ?>
2009-07-11 20:30:40 +00:00
< ? php if ( isset ( $_GET [ " sql " ])) { ?> <input type="hidden" name="sql" value=""><?php } ?>
< ? php if ( isset ( $_GET [ " schema " ])) { ?> <input type="hidden" name="schema" value=""><?php } ?>
< ? php if ( isset ( $_GET [ " dump " ])) { ?> <input type="hidden" name="dump" value=""><?php } ?>
< input type = " submit " value = " <?php echo lang('Use'); ?> " < ? php echo ( $databases ? " class='hidden' " : " " ); ?> >
2009-07-14 11:09:39 +00:00
</ p >
2009-07-03 06:26:01 +00:00
</ form >
< ? php
2009-07-11 19:45:57 +00:00
if ( $missing != " db " && strlen ( $_GET [ " db " ])) {
2009-07-24 06:05:21 +00:00
$result = $dbh -> query ( " SHOW TABLES " );
if ( ! $result -> num_rows ) {
2009-07-11 20:30:40 +00:00
echo " <p class='message'> " . lang ( 'No tables.' ) . " \n " ;
2009-07-11 19:45:57 +00:00
} else {
echo " <p> \n " ;
2009-07-24 06:05:21 +00:00
while ( $row = $result -> fetch_row ()) {
echo '<a href="' . htmlspecialchars ( $SELF ) . 'select=' . urlencode ( $row [ 0 ]) . '">' . lang ( 'select' ) . '</a> ' ;
echo '<a href="' . htmlspecialchars ( $SELF ) . 'table=' . urlencode ( $row [ 0 ]) . '">' . adminer_table_name ( array ( " Name " => $row [ 0 ])) . " </a><br> \n " ; //! Adminer::table_name may work with full table status
2009-07-03 06:26:01 +00:00
}
}
2009-07-24 06:05:21 +00:00
$result -> free ();
2009-07-11 20:30:40 +00:00
echo '<p><a href="' . htmlspecialchars ( $SELF ) . 'create=">' . lang ( 'Create new table' ) . " </a> \n " ;
2009-07-03 06:26:01 +00:00
}
}
2009-07-03 04:40:48 +00:00
}