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 " ]);
2008-09-23 09:57:01 +00:00
$operators = array ( " = " , " < " , " > " , " <= " , " >= " , " != " , " LIKE " , " REGEXP " , " IN " , " IS NULL " , " NOT LIKE " , " NOT REGEXP " , " NOT IN " , " IS NOT NULL " );
2008-10-15 10:39:20 +00:00
if ( eregi ( '^(MyISAM|Maria)$' , $table_status [ " Engine " ])) {
2008-01-08 14:02:55 +00:00
$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-08-07 10:57:28 +00:00
$select = array ();
$group = array ();
foreach (( array ) $_GET [ " columns " ] as $key => $val ) {
if ( $val [ " fun " ] == " count " || ( in_array ( $val [ " col " ], $columns , true ) && ( ! $val [ " fun " ] || in_array ( $val [ " fun " ], $functions ) || in_array ( $val [ " fun " ], $grouping )))) {
$select [ $key ] = ( in_array ( $val [ " col " ], $columns , true ) ? ( ! $val [ " fun " ] ? idf_escape ( $val [ " col " ]) : ( $val [ " fun " ] == " distinct " ? " COUNT(DISTINCT " : strtoupper ( " $val[fun] ( " )) . idf_escape ( $val [ " col " ]) . " ) " ) : " COUNT(*) " );
if ( ! in_array ( $val [ " fun " ], $grouping )) {
$group [] = $select [ $key ];
}
}
}
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 ) {
2008-10-09 12:10:28 +00:00
if ( strlen ( " $val[col] $val[val] " ) && in_array ( $val [ " op " ], $operators )) {
if ( $val [ " op " ] == " AGAINST " ) {
2008-01-08 14:02:55 +00:00
$where [] = " MATCH ( " . idf_escape ( $val [ " col " ]) . " ) AGAINST (' " . $mysql -> escape_string ( $val [ " val " ]) . " ' IN BOOLEAN MODE) " ;
2008-10-09 12:10:28 +00:00
} elseif ( ereg ( 'IN$' , $val [ " op " ]) && ! strlen ( $in = process_length ( $val [ " val " ]))) {
$where [] = " 0 " ;
2008-01-08 14:02:55 +00:00
} else {
2008-12-12 13:35:47 +00:00
$cond = " $val[op] " . ( ereg ( 'NULL$' , $val [ " op " ]) ? " " : ( ereg ( 'IN$' , $val [ " op " ]) ? " ( $in ) " : " ' " . $mysql -> escape_string ( $val [ " val " ]) . " ' " )); //! this searches in numeric values too
2008-10-09 12:10:28 +00:00
if ( strlen ( $val [ " col " ])) {
$where [] = idf_escape ( $val [ " col " ]) . $cond ;
} else {
$cols = array ();
foreach ( $fields as $name => $field ) {
if ( is_numeric ( $val [ " val " ]) || ! ereg ( 'int|float|double|decimal' , $field [ " type " ])) {
$cols [] = $name ;
}
}
$where [] = ( $cols ? " ( " . implode ( " $cond OR " , array_map ( 'idf_escape' , $cols )) . " $cond ) " : " 0 " );
}
2008-01-08 14:02:55 +00:00
}
}
}
$order = array ();
foreach (( array ) $_GET [ " order " ] as $key => $val ) {
2008-09-16 14:49:22 +00:00
if ( in_array ( $val , $columns , true ) || preg_match ( '(^(COUNT\\(\\*\\)|(' . strtoupper ( implode ( '|' , $functions ) . '|' . implode ( '|' , $grouping )) . ')\\((' . implode ( '|' , array_map ( 'preg_quote' , array_map ( 'idf_escape' , $columns ))) . ')\\))$)' , $val )) {
2008-01-08 14:02:55 +00:00
$order [] = idf_escape ( $val ) . ( isset ( $_GET [ " desc " ][ $key ]) ? " DESC " : " " );
}
}
$limit = ( isset ( $_GET [ " limit " ]) ? $_GET [ " limit " ] : " 30 " );
2008-08-07 10:57:28 +00:00
$from = " FROM " . idf_escape ( $_GET [ " select " ]) . ( $where ? " WHERE " . implode ( " AND " , $where ) : " " ) . ( $group && count ( $group ) < count ( $select ) ? " GROUP BY " . implode ( " , " , $group ) : " " ) . ( $order ? " ORDER BY " . implode ( " , " , $order ) : " " ) . ( strlen ( $limit ) ? " LIMIT " . intval ( $limit ) . ( intval ( $_GET [ " page " ]) ? " OFFSET " . ( $limit * $_GET [ " page " ]) : " " ) : " " );
2008-01-08 14:02:55 +00:00
if ( $_POST && ! $error ) {
2008-10-01 11:39:13 +00:00
if ( $_POST [ " export " ]) {
2008-08-18 15:18:16 +00:00
dump_headers ( $_GET [ " select " ]);
2008-08-18 22:40:45 +00:00
dump_table ( $_GET [ " select " ], " " );
2009-04-01 10:57:34 +00:00
if ( is_array ( $_POST [ " check " ])) {
foreach ( $_POST [ " check " ] as $val ) {
2008-10-01 11:39:13 +00:00
parse_str ( $val , $check );
dump_data ( $_GET [ " select " ], " INSERT " , " FROM " . idf_escape ( $_GET [ " select " ]) . " WHERE " . implode ( " AND " , where ( $check )) . " LIMIT 1 " );
2008-01-08 14:02:55 +00:00
}
2009-04-01 10:57:34 +00:00
} else {
dump_data ( $_GET [ " select " ], " INSERT " , ( $where ? " FROM " . idf_escape ( $_GET [ " select " ]) . " WHERE " . implode ( " AND " , $where ) : " " ));
2008-01-08 14:02:55 +00:00
}
2008-10-01 11:39:13 +00:00
exit ;
}
2008-12-30 15:19:35 +00:00
if ( $_POST [ " import " ]) {
$file = preg_replace ( " ~^ \xEF \xBB \xBF ~ " , '' , get_file ( " csv_file " )); //! character set
2009-04-01 10:57:34 +00:00
$cols = " " ;
2008-12-30 15:19:35 +00:00
$rows = array (); //! packet size
preg_match_all ( '~("[^"]*"|[^"\\n]+)+~' , $file , $matches );
2009-04-01 10:57:34 +00:00
foreach ( $matches [ 0 ] as $key => $val ) {
2008-12-30 15:19:35 +00:00
$row = array ();
2009-04-01 10:57:34 +00:00
preg_match_all ( '~(("[^"]*")+|[^,]*),~' , " $val , " , $matches2 );
if ( ! $key && ! array_diff ( $matches2 [ 1 ], array_keys ( $fields ))) { //! doesn't work with column names containing ",\n
$cols = " ( " . implode ( " , " , array_map ( 'idf_escape' , $matches2 [ 1 ])) . " ) " ;
} else {
foreach ( $matches2 [ 1 ] as $col ) {
$row [] = ( ! strlen ( $col ) ? " NULL " : " ' " . $mysql -> escape_string ( str_replace ( '""' , '"' , preg_replace ( '~^".*"$~s' , '' , $col ))) . " ' " );
}
$rows [] = " ( " . implode ( " , " , $row ) . " ) " ;
2008-01-08 14:02:55 +00:00
}
}
2009-04-01 10:57:34 +00:00
$result = queries ( " INSERT INTO " . idf_escape ( $_GET [ " select " ]) . " $cols VALUES " . implode ( " , " , $rows ));
2008-12-30 15:19:35 +00:00
query_redirect ( queries (), remove_from_uri ( " page " ), lang ( '%d row(s) has been imported.' , $mysql -> affected_rows ), $result , false , ! $result );
2008-10-01 11:39:13 +00:00
} else {
2008-12-30 15:19:35 +00:00
$result = true ;
$affected = 0 ;
$command = ( $_POST [ " delete " ] ? ( $_POST [ " all " ] && ! $where ? " TRUNCATE " : " DELETE FROM " ) : ( $_POST [ " clone " ] ? " INSERT INTO " : " UPDATE " )) . idf_escape ( $_GET [ " select " ]);
if ( ! $_POST [ " delete " ]) {
$set = array ();
foreach ( $fields as $name => $field ) {
$val = process_input ( $name , $field );
if ( $_POST [ " clone " ]) {
$set [] = ( $val !== false ? $val : idf_escape ( $name ));
} elseif ( $val !== false ) {
$set [] = idf_escape ( $name ) . " = $val " ;
}
}
$command .= ( $_POST [ " clone " ] ? " SELECT " . implode ( " , " , $set ) . " FROM " . idf_escape ( $_GET [ " select " ]) : " SET " . implode ( " , " , $set ));
}
if ( ! $_POST [ " delete " ] && ! $set ) {
// nothing
} elseif ( $_POST [ " all " ]) {
$result = queries ( $command . ( $where ? " WHERE " . implode ( " AND " , $where ) : " " ));
$affected = $mysql -> affected_rows ;
} else {
foreach (( array ) $_POST [ " check " ] as $val ) {
parse_str ( $val , $check );
$result = queries ( $command . " WHERE " . implode ( " AND " , where ( $check )) . " LIMIT 1 " );
if ( ! $result ) {
break ;
}
$affected += $mysql -> affected_rows ;
2008-10-01 11:39:13 +00:00
}
}
2008-12-30 15:19:35 +00:00
query_redirect ( queries (), remove_from_uri ( " page " ), lang ( '%d item(s) have been affected.' , $affected ), $result , false , ! $result );
//! display edit page in case of an error
2008-08-16 21:15:46 +00:00
}
2008-01-08 14:02:55 +00:00
}
2008-10-09 13:23:54 +00:00
page_header ( lang ( 'Select' ) . " : " . htmlspecialchars ( $_GET [ " select " ]), $error );
2008-01-08 14:02:55 +00:00
2009-01-23 15:50:42 +00:00
echo " <p> " ;
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
2009-01-23 15:50:42 +00:00
echo '<a href="' . htmlspecialchars ( $SELF ) . 'edit=' . urlencode ( $_GET [ 'select' ]) . '">' . lang ( 'New item' ) . '</a> ' ;
2007-07-02 05:51:26 +00:00
}
2009-01-23 15:50:42 +00:00
echo '<a href="' . htmlspecialchars ( $SELF ) . 'table=' . urlencode ( $_GET [ 'select' ]) . '">' . lang ( 'Table structure' ) . '</a>' ;
echo " </p> \n " ;
2007-07-02 05:51:26 +00:00
2007-07-06 13:03:13 +00:00
if ( ! $columns ) {
2008-04-10 14:37:10 +00:00
echo " <p class='error'> " . lang ( 'Unable to select the table' ) . ( $fields ? " " : " : " . htmlspecialchars ( $mysql -> error )) . " .</p> \n " ;
2007-07-06 13:03:13 +00:00
} else {
2008-08-07 10:57:28 +00:00
echo " <form action='' id='form'> \n " ;
?>
2008-09-24 20:46:21 +00:00
< script type = " text/javascript " >// <! [ CDATA [
2008-08-07 10:57:28 +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' );
selects [ i ] . selectedIndex = 0 ;
}
var inputs = row . getElementsByTagName ( 'input' );
if ( inputs . length ) {
inputs [ 0 ] . name = inputs [ 0 ] . name . replace ( / [ a - z ] \ [[ 0 - 9 ] +/ , '$&1' );
inputs [ 0 ] . value = '' ;
}
field . parentNode . parentNode . appendChild ( row );
field . onchange = function () { };
}
2008-09-24 20:46:21 +00:00
// ]]></script>
2008-08-07 10:57:28 +00:00
< ? php
echo " <fieldset><legend> " . lang ( 'Select' ) . " </legend> \n " ;
2007-07-06 13:03:13 +00:00
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 " ;
2008-08-07 10:57:28 +00:00
$i = 0 ;
$fun_group = array ( lang ( 'Functions' ) => $functions , lang ( 'Aggregation' ) => $grouping );
foreach ( $select as $key => $val ) {
$val = $_GET [ " columns " ][ $key ];
echo " <div><select name='columns[ $i ][fun]'><option></option> " . optionlist ( $fun_group , $val [ " fun " ]) . " </select> " ;
echo " <select name='columns[ $i ][col]'><option></option> " . optionlist ( $columns , $val [ " col " ]) . " </select></div> \n " ;
$i ++ ;
}
echo " <div><select name='columns[ $i ][fun]' onchange='this.nextSibling.onchange();'><option></option> " . optionlist ( $fun_group ) . " </select> " ;
echo " <select name='columns[ $i ][col]' onchange='add_row(this);'><option></option> " . optionlist ( $columns ) . " </select></div> \n " ;
echo " </fieldset> \n " ;
2007-07-06 13:03:13 +00:00
2008-08-07 10:57:28 +00:00
echo " <fieldset><legend> " . lang ( 'Search' ) . " </legend> \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 ]) . '" />' ;
2008-10-01 11:39:13 +00:00
echo " <label><input type='checkbox' name='boolean[ $i ]' value='1' " . ( 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 ) {
2008-10-09 12:10:28 +00:00
if ( strlen ( " $val[col] $val[val] " ) && in_array ( $val [ " op " ], $operators )) {
2009-02-21 06:07:00 +00:00
echo " <div><select name='where[ $i ][col]'><option value=''> " . lang ( '(anywhere)' ) . " </option> " . optionlist ( $columns , $val [ " col " ]) . " </select> " ;
2009-01-22 17:29:11 +00:00
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 ) {
2009-01-22 17:29:11 +00:00
for ( var i = 0 ; i < op . form . elements . length ; i ++ ) {
var el = op . form . elements [ i ];
if ( el . name == op . name . substr ( 0 , op . name . length - 4 ) + '[val]' ) {
el . style . display = ( / NULL $ /. test ( op . options [ op . selectedIndex ] . text ) ? '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 } ?>
</ script >
< ? php
2009-02-21 06:07:00 +00:00
echo " <div><select name='where[ $i ][col]' onchange='add_row(this);'><option value=''> " . lang ( '(anywhere)' ) . " </option> " . optionlist ( $columns ) . " </select> " ;
2009-01-22 17:29:11 +00:00
echo " <select name='where[ $i ][op]' onchange='where_change(this);'> " . optionlist ( $operators ) . " </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
}
}
2008-08-04 13:53:54 +00:00
echo " <div><select name='order[ $i ]' onchange='add_row(this);'><option></option> " . optionlist ( $columns ) . " </select> " ;
2007-07-24 15:58:39 +00:00
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
2008-10-13 15:20:14 +00:00
echo " <fieldset><legend> " . lang ( 'Limit' ) . " </legend><div><input name='limit' size='3' value= \" " . htmlspecialchars ( $limit ) . " \" /></div></fieldset> \n " ;
2007-07-06 13:03:13 +00:00
2007-07-11 10:22:59 +00:00
if ( isset ( $text_length )) {
2008-10-13 15:20:14 +00:00
echo " <fieldset><legend> " . lang ( 'Text length' ) . " </legend><div><input name='text_length' size='3' value= \" " . htmlspecialchars ( $text_length ) . " \" /></div></fieldset> \n " ;
2007-07-11 10:22:59 +00:00
}
2008-10-13 15:20:14 +00:00
echo " <fieldset><legend> " . lang ( 'Action' ) . " </legend><div><input type='submit' value=' " . lang ( 'Select' ) . " ' /></div></fieldset> \n " ;
2007-07-06 13:03:13 +00:00
echo " </form> \n " ;
2008-09-01 12:22:26 +00:00
$query = " SELECT " . ( $select ? ( count ( $group ) < count ( $select ) ? " SQL_CALC_FOUND_ROWS " : " " ) . implode ( " , " , $select ) : " * " ) . " $from " ;
2008-09-03 09:35:12 +00:00
echo " <p><code class='jush-sql'> " . htmlspecialchars ( $query ) . " </code> <a href=' " . htmlspecialchars ( $SELF ) . " sql= " . urlencode ( $query ) . " '> " . lang ( 'Edit' ) . " </a></p> \n " ;
2008-09-01 12:22:26 +00:00
$result = $mysql -> query ( $query );
2007-09-03 11:12:38 +00:00
if ( ! $result ) {
2008-04-10 14:37:10 +00:00
echo " <p class='error'> " . htmlspecialchars ( $mysql -> error ) . " </p> \n " ;
2007-07-06 13:03:13 +00:00
} else {
2008-12-30 15:19:35 +00:00
echo " <form action='' method='post' enctype='multipart/form-data'> \n " ;
2007-09-03 11:12:38 +00:00
if ( ! $result -> num_rows ) {
echo " <p class='message'> " . lang ( 'No rows.' ) . " </p> \n " ;
} else {
$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-11-04 09:19:36 +00:00
echo " <table border='1' cellspacing='0' cellpadding='2' class='nowrap'> \n " ;
2007-09-03 11:12:38 +00:00
for ( $j = 0 ; $row = $result -> fetch_assoc (); $j ++ ) {
if ( ! $j ) {
2008-11-04 09:19:36 +00:00
echo '<thead><tr><td><label><input type="checkbox" name="all" value="1" />' . lang ( 'whole result' ) . '</label></td>' ;
2008-05-27 14:31:39 +00:00
foreach ( $row as $key => $val ) {
2008-08-28 12:24:59 +00:00
echo '<th><a href="' . htmlspecialchars ( remove_from_uri ( '(order|desc)[^=]*' )) . '&order%5B0%5D=' . htmlspecialchars ( $key ) . ( $_GET [ " order " ][ 0 ] === $key && ! $_GET [ " desc " ][ 0 ] ? '&desc%5B0%5D=1' : '' ) . '">' . htmlspecialchars ( $key ) . " </a></th> " ;
2008-05-27 14:31:39 +00:00
}
echo " </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 ));
2008-11-04 09:19:36 +00:00
echo '<tr><td><input type="checkbox" name="check[]" value="' . $unique_idf . '" onclick="this.form[\'all\'].checked = false;" />' . ( count ( $select ) == count ( $group ) && $_GET [ " db " ] != " information_schema " ? ' <a href="' . htmlspecialchars ( $SELF ) . 'edit=' . urlencode ( $_GET [ 'select' ]) . '&' . $unique_idf . '">' . lang ( 'edit' ) . '</a> <a href="' . htmlspecialchars ( $SELF ) . 'clone=' . urlencode ( $_GET [ 'select' ]) . '&' . $unique_idf . '">' . lang ( 'clone' ) . '</a></td>' : '' );
2007-09-03 11:12:38 +00:00
foreach ( $row as $key => $val ) {
if ( ! isset ( $val )) {
$val = " <i>NULL</i> " ;
2009-03-04 17:09:24 +00:00
} elseif ( preg_match ( '~blob|binary~' , $fields [ $key ][ " type " ]) && preg_match ( '~[\\0-\\x8\\xb\\xc\\xe-\\x1F\\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-09-01 10:25:29 +00:00
echo " <p> " ;
$found_rows = ( intval ( $limit ) ? $mysql -> result ( $mysql -> query ( count ( $group ) < count ( $select ) ? " SELECT FOUND_ROWS() " : " SELECT COUNT(*) FROM " . idf_escape ( $_GET [ " select " ]) . ( $where ? " WHERE " . implode ( " AND " , $where ) : " " ))) : $result -> num_rows );
if ( intval ( $limit ) && $found_rows > $limit ) {
2007-09-03 11:12:38 +00:00
$max_page = floor (( $found_rows - 1 ) / $limit );
2008-09-01 10:25:29 +00:00
echo lang ( 'Page' ) . " : " ;
2007-09-03 11:12:38 +00:00
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 );
2007-07-25 16:31:47 +00:00
}
2008-09-01 10:25:29 +00:00
echo " ( " . lang ( '%d row(s)' , $found_rows ) . " )</p> \n " ;
2008-09-01 12:22:26 +00:00
2008-11-04 09:19:36 +00:00
echo ( $_GET [ " db " ] != " information_schema " ? " <fieldset><legend> " . lang ( 'Edit' ) . " </legend><div><input type='submit' value=' " . lang ( 'Edit' ) . " ' /> <input type='submit' name='clone' value=' " . lang ( 'Clone' ) . " ' /> <input type='submit' name='delete' value=' " . lang ( 'Delete' ) . " ' $confirm /></div></fieldset> \n " : " " );
2009-04-01 10:57:34 +00:00
echo " <fieldset><legend> " . lang ( 'Export' ) . " </legend><div> $dump_options <input type='submit' name='export' value=' " . lang ( 'Export' ) . " ' /></div></fieldset> \n " ;
2007-07-02 05:51:26 +00:00
}
2007-09-03 11:12:38 +00:00
$result -> free ();
2008-12-30 15:19:35 +00:00
echo " <fieldset><legend> " . lang ( 'CSV Import' ) . " </legend><div><input type='hidden' name='token' value=' $token ' /><input type='file' name='csv_file' /> <input type='submit' name='import' value=' " . lang ( 'Import' ) . " ' /></div></fieldset> \n " ;
echo " </form> \n " ;
2007-07-02 05:51:26 +00:00
}
}