2007-07-02 05:51:26 +00:00
< ? php
2008-01-08 14:02:55 +00:00
$table_status = table_status ( $_GET [ " select " ]);
$indexes = indexes ( $_GET [ " select " ]);
$operators = array ( " = " , " < " , " > " , " <= " , " >= " , " != " , " LIKE " , " REGEXP " , " IN " , " IS NULL " );
if ( $table_status [ " Engine " ] == " MyISAM " ) {
$operators [] = " AGAINST " ;
}
2007-07-06 13:03:13 +00:00
$fields = fields ( $_GET [ " select " ]);
2007-07-09 06:12:22 +00:00
$rights = array ();
2007-07-06 13:03:13 +00:00
$columns = array ();
2007-08-24 16:00:10 +00:00
unset ( $text_length );
2007-07-06 13:03:13 +00:00
foreach ( $fields as $key => $field ) {
2007-07-09 06:12:22 +00:00
if ( isset ( $field [ " privileges " ][ " select " ])) {
2007-07-06 13:03:13 +00:00
$columns [] = $key ;
2007-08-24 16:00:10 +00:00
if ( preg_match ( '~text|blob~' , $field [ " type " ])) {
$text_length = ( isset ( $_GET [ " text_length " ]) ? $_GET [ " text_length " ] : " 100 " );
}
2007-07-06 13:03:13 +00:00
}
2007-07-09 06:12:22 +00:00
$rights += $field [ " privileges " ];
}
2008-01-08 14:02:55 +00:00
$where = array ();
foreach ( $indexes as $i => $index ) {
if ( $index [ " type " ] == " FULLTEXT " && strlen ( $_GET [ " fulltext " ][ $i ])) {
$where [] = " MATCH ( " . implode ( " , " , array_map ( 'idf_escape' , $index [ " columns " ])) . " ) AGAINST (' " . $mysql -> escape_string ( $_GET [ " fulltext " ][ $i ]) . " ' " . ( isset ( $_GET [ " boolean " ][ $i ]) ? " IN BOOLEAN MODE " : " " ) . " ) " ;
}
}
foreach (( array ) $_GET [ " where " ] as $val ) {
if ( strlen ( $val [ " col " ]) && in_array ( $val [ " op " ], $operators )) {
if ( $val [ " op " ] == " IN " ) {
$in = process_length ( $val [ " val " ]);
$where [] = ( strlen ( $in ) ? idf_escape ( $val [ " col " ]) . " IN ( $in ) " : " 0 " );
} elseif ( $val [ " op " ] == " AGAINST " ) {
$where [] = " MATCH ( " . idf_escape ( $val [ " col " ]) . " ) AGAINST (' " . $mysql -> escape_string ( $val [ " val " ]) . " ' IN BOOLEAN MODE) " ;
} else {
$where [] = idf_escape ( $val [ " col " ]) . " $val[op] " . ( $val [ " op " ] == " IS NULL " ? " " : " ' " . $mysql -> escape_string ( $val [ " val " ]) . " ' " );
}
}
}
$order = array ();
foreach (( array ) $_GET [ " order " ] as $key => $val ) {
if ( in_array ( $val , $columns , true )) {
$order [] = idf_escape ( $val ) . ( isset ( $_GET [ " desc " ][ $key ]) ? " DESC " : " " );
}
}
$limit = ( isset ( $_GET [ " limit " ]) ? $_GET [ " limit " ] : " 30 " );
$from = " FROM " . idf_escape ( $_GET [ " select " ]) . ( $where ? " WHERE " . implode ( " AND " , $where ) : " " ) . ( $order ? " ORDER BY " . implode ( " , " , $order ) : " " ) . ( strlen ( $limit ) ? " LIMIT " . intval ( $limit ) . ( intval ( $_GET [ " page " ]) ? " OFFSET " . ( $limit * $_GET [ " page " ]) : " " ) : " " );
if ( $_POST && ! $error ) {
$result = true ;
$deleted = 0 ;
if ( isset ( $_POST [ " truncate " ])) {
$result = $mysql -> query ( " TRUNCATE " . idf_escape ( $_GET [ " select " ]));
$deleted = $mysql -> affected_rows ;
} elseif ( is_array ( $_POST [ " delete " ])) {
foreach ( $_POST [ " delete " ] as $val ) {
parse_str ( $val , $delete );
$result = $mysql -> query ( " DELETE FROM " . idf_escape ( $_GET [ " select " ]) . " WHERE " . implode ( " AND " , where ( $delete )) . " LIMIT 1 " );
if ( ! $result ) {
break ;
}
$deleted += $mysql -> affected_rows ;
}
} elseif ( $_POST [ " delete_selected " ]) {
if ( ! $_GET [ " page " ]) {
$result = $mysql -> query ( " DELETE $from " );
$deleted = $mysql -> affected_rows ;
} else {
$result1 = $mysql -> query ( " SELECT * $from " );
while ( $row1 = $result1 -> fetch_assoc ()) {
parse_str ( implode ( " & " , unique_idf ( $row1 , $indexes )), $delete );
$result = $mysql -> query ( " DELETE FROM " . idf_escape ( $_GET [ " select " ]) . " WHERE " . implode ( " AND " , where ( $delete )) . " LIMIT 1 " );
if ( ! $result ) {
break ;
}
$deleted += $mysql -> affected_rows ;
}
$result1 -> free ();
}
}
if ( $result ) {
redirect ( remove_from_uri ( " page " ), lang ( '%d item(s) have been deleted.' , $deleted ));
}
$error = $mysql -> error ;
}
page_header ( lang ( 'Select' ) . " : " . htmlspecialchars ( $_GET [ " select " ]));
2008-03-18 10:29:20 +00:00
if ( $error ) {
2008-01-08 14:02:55 +00:00
echo " <p class='error'> " . lang ( 'Error during deleting' ) . " : " . htmlspecialchars ( $error ) . " </p> \n " ;
}
2007-07-09 06:12:22 +00:00
if ( isset ( $rights [ " insert " ])) {
2007-07-15 10:56:40 +00:00
//! pass search values forth and back
2007-07-09 06:12:22 +00:00
echo '<p><a href="' . htmlspecialchars ( $SELF ) . 'edit=' . urlencode ( $_GET [ 'select' ]) . '">' . lang ( 'New item' ) . " </a></p> \n " ;
2007-07-02 05:51:26 +00:00
}
2007-07-06 13:03:13 +00:00
if ( ! $columns ) {
2007-07-10 13:30:42 +00:00
echo " <p class='error'> " . lang ( 'Unable to select the table' ) . ( $fields ? " " : " : " . $mysql -> error ) . " .</p> \n " ;
2007-07-06 13:03:13 +00:00
} else {
echo " <form action='' id='form'> \n <fieldset><legend> " . lang ( 'Search' ) . " </legend> \n " ;
if ( strlen ( $_GET [ " server " ])) {
echo '<input type="hidden" name="server" value="' . htmlspecialchars ( $_GET [ " server " ]) . '" />' ;
2007-07-02 05:51:26 +00:00
}
2007-07-06 13:03:13 +00:00
echo '<input type="hidden" name="db" value="' . htmlspecialchars ( $_GET [ " db " ]) . '" />' ;
echo '<input type="hidden" name="select" value="' . htmlspecialchars ( $_GET [ " select " ]) . '" />' ;
echo " \n " ;
2007-07-09 06:12:22 +00:00
foreach ( $indexes as $i => $index ) {
if ( $index [ " type " ] == " FULLTEXT " ) {
2007-07-14 07:15:05 +00:00
echo " (<i> " . implode ( " </i>, <i> " , array_map ( 'htmlspecialchars' , $index [ " columns " ])) . " </i>) AGAINST " ;
2007-07-09 06:12:22 +00:00
echo ' <input name="fulltext[' . $i . ']" value="' . htmlspecialchars ( $_GET [ " fulltext " ][ $i ]) . '" />' ;
2007-07-09 22:55:50 +00:00
echo " <label for='boolean- $i '><input type='checkbox' name='boolean[ $i ]' value='1' id='boolean- $i ' " . ( isset ( $_GET [ " boolean " ][ $i ]) ? " checked='checked' " : " " ) . " /> " . lang ( 'BOOL' ) . " </label> " ;
2007-07-09 06:12:22 +00:00
echo " <br /> \n " ;
}
}
2007-07-06 13:03:13 +00:00
$i = 0 ;
foreach (( array ) $_GET [ " where " ] as $val ) {
2007-07-06 14:07:13 +00:00
if ( strlen ( $val [ " col " ]) && in_array ( $val [ " op " ], $operators )) {
2007-07-11 22:25:54 +00:00
echo " <div><select name='where[ $i ][col]'><option></option> " . optionlist ( $columns , $val [ " col " ]) . " </select> " ;
echo " <select name='where[ $i ][op]' onchange= \" where_change(this); \" > " . optionlist ( $operators , $val [ " op " ]) . " </select> " ;
2007-07-06 13:03:13 +00:00
echo " <input name='where[ $i ][val]' value= \" " . htmlspecialchars ( $val [ " val " ]) . " \" /></div> \n " ;
$i ++ ;
}
}
?>
2007-07-03 07:00:51 +00:00
< script type = " text/javascript " >
function where_change ( op ) {
op . form [ op . name . substr ( 0 , op . name . length - 4 ) + '[val]' ] . style . display = ( op . value == 'IS NULL' ? 'none' : '' );
2007-07-02 15:52:15 +00:00
}
2007-07-03 07:00:51 +00:00
< ? php if ( $i ) { ?>
2007-07-06 09:03:47 +00:00
for ( var i = 0 ; < ? php echo $i ; ?> > i; i++) {
document . getElementById ( 'form' )[ 'where[' + i + '][op]' ] . onchange ();
}
2007-07-03 07:00:51 +00:00
< ? php } ?>
2007-07-24 15:58:39 +00:00
function add_row ( field ) {
var row = field . parentNode . cloneNode ( true );
var selects = row . getElementsByTagName ( 'select' );
for ( var i = 0 ; i < selects . length ; i ++ ) {
selects [ i ] . name = selects [ i ] . name . replace ( / [ a - z ] \ [[ 0 - 9 ] +/ , '$&1' );
2007-08-23 15:38:00 +00:00
selects [ i ] . selectedIndex = 0 ;
2007-07-24 15:58:39 +00:00
}
var input = row . getElementsByTagName ( 'input' )[ 0 ];
input . name = input . name . replace ( / [ a - z ] \ [[ 0 - 9 ] +/ , '$&1' );
input . value = '' ;
field . parentNode . parentNode . appendChild ( row );
field . onchange = function () { };
}
2007-07-03 07:00:51 +00:00
</ script >
< ? php
2007-07-24 15:58:39 +00:00
echo " <div><select name='where[ $i ][col]' onchange='add_row(this);'><option></option> " . optionlist ( $columns , array ()) . " </select> " ;
2007-07-11 22:25:54 +00:00
echo " <select name='where[ $i ][op]' onchange= \" where_change(this); \" > " . optionlist ( $operators , array ()) . " </select> " ;
2007-07-24 15:58:39 +00:00
echo " <input name='where[ $i ][val]' /></div> \n " ;
2007-07-06 13:03:13 +00:00
echo " </fieldset> \n " ;
echo " <fieldset><legend> " . lang ( 'Sort' ) . " </legend> \n " ;
$i = 0 ;
foreach (( array ) $_GET [ " order " ] as $key => $val ) {
if ( in_array ( $val , $columns , true )) {
2007-07-11 22:25:54 +00:00
echo " <div><select name='order[ $i ]'><option></option> " . optionlist ( $columns , $val ) . " </select> " ;
2007-07-24 15:58:39 +00:00
echo " <label><input type='checkbox' name='desc[ $i ]' value='1' " . ( isset ( $_GET [ " desc " ][ $key ]) ? " checked='checked' " : " " ) . " /> " . lang ( 'DESC' ) . " </label></div> \n " ;
2007-07-06 13:03:13 +00:00
$i ++ ;
2007-07-06 09:49:33 +00:00
}
}
2007-07-24 15:58:39 +00:00
echo " <div><select name='order[ $i ]' onchange='add_row(this);'><option></option> " . optionlist ( $columns , array ()) . " </select> " ;
echo " <label><input type='checkbox' name='desc[ $i ]' value='1' /> " . lang ( 'DESC' ) . " </label></div> \n " ;
2007-07-06 13:03:13 +00:00
echo " </fieldset> \n " ;
2007-07-02 05:51:26 +00:00
2007-07-06 13:03:13 +00:00
echo " <fieldset><legend> " . lang ( 'Limit' ) . " </legend> \n " ;
echo '<div><input name="limit" size="3" value="' . htmlspecialchars ( $limit ) . '" /></div>' ;
echo " </fieldset> \n " ;
2007-07-11 10:22:59 +00:00
if ( isset ( $text_length )) {
echo " <fieldset><legend> " . lang ( 'Text length' ) . " </legend> \n " ;
echo '<div><input name="text_length" size="3" value="' . htmlspecialchars ( $text_length ) . '" /></div>' ;
echo " </fieldset> \n " ;
}
2007-07-06 13:03:13 +00:00
echo " <fieldset><legend> " . lang ( 'Action' ) . " </legend><div><input type='submit' value=' " . lang ( 'Select' ) . " ' /></div></fieldset> \n " ;
echo " </form> \n " ;
2007-07-12 10:07:03 +00:00
echo " <div style='clear: left;'> </div> \n " ;
2007-07-06 13:03:13 +00:00
2008-01-08 14:02:55 +00:00
$result = $mysql -> query ( " SELECT SQL_CALC_FOUND_ROWS * $from " );
2007-09-03 11:12:38 +00:00
if ( ! $result ) {
echo " <p class='error'> " . lang ( 'Error in query' ) . " : " . htmlspecialchars ( $mysql -> error ) . " </p> \n " ;
2007-07-06 13:03:13 +00:00
} else {
2007-09-03 11:12:38 +00:00
if ( ! $result -> num_rows ) {
echo " <p class='message'> " . lang ( 'No rows.' ) . " </p> \n " ;
} else {
$found_rows = $mysql -> result ( $mysql -> query ( " SELECT FOUND_ROWS() " )); // space for mysql.trace_mode
$foreign_keys = array ();
foreach ( foreign_keys ( $_GET [ " select " ]) as $foreign_key ) {
foreach ( $foreign_key [ " source " ] as $val ) {
$foreign_keys [ $val ][] = $foreign_key ;
}
2007-07-06 13:03:13 +00:00
}
2007-09-03 11:12:38 +00:00
2008-01-08 14:02:55 +00:00
echo " <form action='' method='post'> \n " ;
2007-09-03 11:12:38 +00:00
echo " <table border='1' cellspacing='0' cellpadding='2'> \n " ;
for ( $j = 0 ; $row = $result -> fetch_assoc (); $j ++ ) {
if ( ! $j ) {
2008-01-08 14:02:55 +00:00
echo '<thead><tr><td><label><input type="checkbox" name="delete_selected" value="1" onclick="var elems = this.form.elements; for (var i=0; i < elems.length; i++) if (elems[i].name == \'delete[]\') elems[i].checked = this.checked;" />' . lang ( 'all' ) . '</label></td><th>' . implode ( " </th><th> " , array_map ( 'htmlspecialchars' , array_keys ( $row ))) . " </th></tr></thead> \n " ;
2007-09-03 11:12:38 +00:00
}
2008-01-08 14:02:55 +00:00
$unique_idf = implode ( '&' , unique_idf ( $row , $indexes ));
echo '<tr><td><input type="checkbox" name="delete[]" value="' . $unique_idf . '" /> <a href="' . htmlspecialchars ( $SELF ) . 'edit=' . urlencode ( $_GET [ 'select' ]) . '&' . $unique_idf . '">' . lang ( 'edit' ) . " </a></td> " ;
2007-09-03 11:12:38 +00:00
foreach ( $row as $key => $val ) {
if ( ! isset ( $val )) {
$val = " <i>NULL</i> " ;
} elseif ( preg_match ( '~blob|binary~' , $fields [ $key ][ " type " ]) && preg_match ( '~[\\x80-\\xFF]~' , $val )) {
2008-01-08 14:02:55 +00:00
$val = '<a href="' . htmlspecialchars ( $SELF ) . 'download=' . urlencode ( $_GET [ " select " ]) . '&field=' . urlencode ( $key ) . '&' . $unique_idf . '">' . lang ( '%d byte(s)' , strlen ( $val )) . '</a>' ;
2007-08-24 16:00:10 +00:00
} else {
2007-09-03 11:12:38 +00:00
if ( ! strlen ( trim ( $val ))) {
$val = " " ;
} elseif ( intval ( $text_length ) > 0 && preg_match ( '~blob|text~' , $fields [ $key ][ " type " ]) && strlen ( $val ) > intval ( $text_length )) {
$val = ( preg_match ( '~blob~' , $fields [ $key ][ " type " ]) ? nl2br ( htmlspecialchars ( substr ( $val , 0 , intval ( $text_length )))) . " <em>...</em> " : shorten_utf8 ( $val , intval ( $text_length )));
} else {
$val = nl2br ( htmlspecialchars ( $val ));
if ( $fields [ $key ][ " type " ] == " char " ) {
$val = " <code> $val </code> " ;
}
2007-08-24 16:00:10 +00:00
}
2007-09-03 11:12:38 +00:00
foreach (( array ) $foreign_keys [ $key ] as $foreign_key ) {
if ( count ( $foreign_keys [ $key ]) == 1 || count ( $foreign_key [ " source " ]) == 1 ) {
$val = " \" > $val </a> " ;
foreach ( $foreign_key [ " source " ] as $i => $source ) {
$val = " &where%5B $i %5D%5Bcol%5D= " . urlencode ( $foreign_key [ " target " ][ $i ]) . " &where%5B $i %5D%5Bop%5D=%3D&where%5B $i %5D%5Bval%5D= " . urlencode ( $row [ $source ]) . $val ;
}
$val = '<a href="' . htmlspecialchars ( strlen ( $foreign_key [ " db " ]) ? preg_replace ( '~([?&]db=)[^&]+~' , '\\1' . urlencode ( $foreign_key [ " db " ]), $SELF ) : $SELF ) . 'select=' . htmlspecialchars ( $foreign_key [ " table " ]) . $val ; // InnoDB supports non-UNIQUE keys
break ;
2007-07-06 13:03:13 +00:00
}
2007-07-02 15:52:15 +00:00
}
2007-07-02 05:51:26 +00:00
}
2007-09-03 11:12:38 +00:00
echo " <td> $val </td> " ;
2007-07-02 05:51:26 +00:00
}
2007-09-03 11:12:38 +00:00
echo " </tr> \n " ;
2007-07-25 16:31:47 +00:00
}
2007-09-03 11:12:38 +00:00
echo " </table> \n " ;
2008-01-08 14:02:55 +00:00
echo " <p><input type='hidden' name='token' value=' $token ' /><input type='submit' value=' " . lang ( 'Delete selected' ) . " ' /> <input type='submit' name='truncate' value=' " . lang ( 'Truncate table' ) . " ' onclick= \" return confirm(' " . lang ( 'Are you sure?' ) . " '); \" /></p> \n " ;
echo " </form> \n " ;
2007-09-03 11:12:38 +00:00
if ( intval ( $limit ) && $found_rows > $limit ) {
$max_page = floor (( $found_rows - 1 ) / $limit );
function print_page ( $page ) {
echo " " . ( $page == $_GET [ " page " ] ? $page + 1 : '<a href="' . htmlspecialchars ( remove_from_uri ( " page " ) . ( $page ? " &page= $page " : " " )) . '">' . ( $page + 1 ) . " </a> " );
}
echo " <p> " . lang ( 'Page' ) . " : " ;
print_page ( 0 );
if ( $_GET [ " page " ] > 3 ) {
echo " ... " ;
}
for ( $i = max ( 1 , $_GET [ " page " ] - 2 ); $i < min ( $max_page , $_GET [ " page " ] + 3 ); $i ++ ) {
print_page ( $i );
}
if ( $_GET [ " page " ] + 3 < $max_page ) {
echo " ... " ;
}
print_page ( $max_page );
echo " </p> \n " ;
2007-07-25 16:31:47 +00:00
}
2007-07-02 05:51:26 +00:00
}
2007-09-03 11:12:38 +00:00
$result -> free ();
2007-07-02 05:51:26 +00:00
}
}