ACC SHELL

Path : /srv/www/vhosts/alfa-com/
File Upload :
Current File : /srv/www/vhosts/alfa-com/adminer.php

<?php
/** Adminer - Compact MySQL management
* @link http://www.adminer.org/
* @author Jakub Vrana, http://php.vrana.cz/
* @copyright 2007 Jakub Vrana
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
*/error_reporting(6135);$gd=(!ereg('^(unsafe_raw)?$',ini_get("filter.default"))||ini_get("filter.default_flags"));if($gd){foreach(array('_GET','_POST','_COOKIE','_SERVER')as$b){$zd=filter_input_array(constant("INPUT$b"),FILTER_UNSAFE_RAW);if($zd){$$b=$zd;}}}if(isset($_GET["file"])){header("Expires: ".gmdate("D, d M Y H:i:s",time()+365*24*60*60)." GMT");if($_GET["file"]=="favicon.ico"){header("Content-Type: image/x-icon");echo
base64_decode("AAABAAEAEBAQAAEABAAoAQAAFgAAACgAAAAQAAAAIAAAAAEABAAAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////AAAA/wBhTgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABEQAAAAAAERExAAAAARERExEAABERMREzMQABExMRERMRAAExMRETMRAAATERERMRAAABExERExAAAAETERExEAAAATERETERERARMRETESESEBMTETESEREQExEzESEREhETMxEREhERIREREAARISIRAAAAAAERERD/4z8A/wM/APgDAADAAwAAgAMAAIAHAACADwAAgB8AAIAfAACAAQAAAAEAAAABAAAAAAAAAAAAAAcAAAD/gQAA");}elseif($_GET["file"]=="default.css"){header("Content-Type: text/css");echo'body{color:#000;background:#fff;font:90%/1.25 Verdana,Arial,Helvetica,sans-serif;margin:0;}a{color:blue;}a:visited{color:navy;}a:hover{color:red;}h1{font-size:150%;margin:0;padding:.8em 1em;border-bottom:1px solid #999;font-weight:normal;color:#777;background:#eee;}h2{font-size:150%;margin:0 0 20px -18px;padding:.8em 1em;border-bottom:1px solid #000;color:#000;font-weight:normal;background:#ddf;}h3{font-weight:normal;font-size:130%;margin:.8em 0;}form{margin:0;}table{margin:0 20px .8em 0;border:0;border-top:1px solid #999;border-left:1px solid #999;font-size:90%;}td,th{margin-bottom:1em;border:0;border-right:1px solid #999;border-bottom:1px solid #999;padding:.2em .3em;}th{background:#eee;text-align:left;}thead th{text-align:center;}thead td,thead th{background:#ddf;}fieldset{display:inline;vertical-align:top;padding:.5em .8em;margin:0 .5em .5em 0;border:1px solid #999;}p{margin:0 20px 1em 0;}img{vertical-align:middle;border:0;}code{background:#eee;}tr:hover td,tr:hover th{background:#ddf;}.version{color:#777;font-size:67%;}.js .hidden{display:none;}.nowrap td,.nowrap th,td.nowrap{white-space:pre;}.wrap td{white-space:normal;}.error{color:red;background:#fee;}.message{color:green;background:#efe;}.error,.message{padding:.5em .8em;margin:0 20px 1em 0;}.char{color:#007F00;}.date{color:#7F007F;}.enum{color:#007F7F;}.binary{color:red;}.odd td{background:#F5F5F5;}.time{color:silver;font-size:70%;float:right;margin-top:-3em;}.function{text-align:right;}.number{text-align:right;}.datetime{text-align:right;}.type{width:15ex;width:auto\\9;}#menu{position:absolute;margin:10px 0 0;padding:0 0 30px 0;top:2em;left:0;width:19em;overflow:auto;overflow-y:hidden;white-space:nowrap;}#menu p{padding:.8em 1em;margin:0;border-bottom:1px solid #ccc;}#content{margin:2em 0 0 21em;padding:10px 20px 20px 0;}#lang{position:absolute;top:0;left:0;line-height:1.8em;padding:.3em 1em;}#breadcrumb{white-space:nowrap;position:absolute;top:0;left:21em;background:#eee;height:2em;line-height:1.8em;padding:0 1em;margin:0 0 0 -18px;}#h1{color:#777;text-decoration:none;font-style:italic;}#version{font-size:67%;color:red;}#schema{margin-left:60px;position:relative;}#schema .table{border:1px solid silver;padding:0 2px;cursor:move;position:absolute;}#schema .references{position:absolute;}@media print{#lang,#menu{display:none;}#content{margin-left:1em;}#breadcrumb{left:1em;}}';}elseif($_GET["file"]=="functions.js"){header("Content-Type: text/javascript");?>
document.body.className='js';function toggle(id){var el=document.getElementById(id);el.className=(el.className=='hidden'?'':'hidden');return true;}
function verify_version(){document.cookie='adminer_version=0';var script=document.createElement('script');script.src='https://adminer.svn.sourceforge.net/svnroot/adminer/trunk/version.js';document.body.appendChild(script);}
function form_check(el,name){var elems=el.form.elements;for(var i=0;i<elems.length;i++){if(name.test(elems[i].name)){elems[i].checked=el.checked;}}}
function form_uncheck(id){document.getElementById(id).checked=false;}
function form_checked(el,name){var checked=0;var elems=el.form.elements;for(var i=0;i<elems.length;i++){if(name.test(elems[i].name)&&elems[i].checked){checked++;}}
return checked;}
function table_click(event){var el=event.target||event.srcElement;while(!/^tr$/i.test(el.tagName)){if(/^(table|a|input)$/i.test(el.tagName)){return;}
el=el.parentNode;}
el=el.firstChild.firstChild;el.click&&el.click();el.onclick&&el.onclick();}
function select_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='';inputs[0].className='';}
field.parentNode.parentNode.appendChild(row);field.onchange=function(){};}
function body_load(){var jush_root='https://jush.svn.sourceforge.net/svnroot/jush/trunk/';var script=document.createElement('script');script.src=jush_root+'jush.js';script.onload=function(){if(window.jush){jush.create_links=' target="_blank"';jush.style(jush_root+'jush.css');jush.highlight_tag('pre',0);jush.highlight_tag('code');}};script.onreadystatechange=function(){if(/^(loaded|complete)$/.test(script.readyState)){script.onload();}};document.body.appendChild(script);}
function select_value(select){return select.options[select.selectedIndex].text;}
function form_field(form,name){for(var i=0;i<form.length;i++){if(form[i].name==name){return form[i];}}}
function type_password(el,disable){try{el.type=(disable?'text':'password');}catch(e){}}
var added='.',row_count;function re_escape(s){return s.replace(/[\[\]\\^$*+?.(){|}]/,'\\$&');}
function idf_escape(s){return'`'+s.replace(/`/,'``')+'`';}
function editing_name_change(field){var name=field.name.substr(0,field.name.length-7);var type=form_field(field.form,name+'[type]');var opts=type.options;var table=re_escape(field.value);var column='';var match;if((match=/(.+)_(.+)/.exec(table))||(match=/(.*[a-z])([A-Z].*)/.exec(table))){table=match[1];column=match[2];}
var plural='(?:e?s)?';var tab_col=table+plural+'_?'+column;var re=new RegExp('(^'+idf_escape(table+plural)+'\\.'+idf_escape(column)+'$'
+'|^'+idf_escape(tab_col)+'\\.'
+'|^'+idf_escape(column+plural)+'\\.'+idf_escape(table)+'$'
+')|\\.'+idf_escape(tab_col)+'$','i');var candidate;for(var i=opts.length;i--;){if(opts[i].value.substr(0,1)!='`'){if(i==opts.length-2&&candidate&&!match[1]&&name=='fields[1]'){return false;}
break;}
if(match=re.exec(opts[i].value)){if(candidate){return false;}
candidate=i;}}
if(candidate){type.selectedIndex=candidate;type.onchange();}}
function editing_add_row(button,allowed,focus){if(allowed&&row_count>=allowed){return false;}
var match=/([0-9]+)(\.[0-9]+)?/.exec(button.name);var x=match[0]+(match[2]?added.substr(match[2].length):added)+'1';var row=button.parentNode.parentNode;var row2=row.cloneNode(true);var tags=row.getElementsByTagName('select');var tags2=row2.getElementsByTagName('select');for(var i=0;i<tags.length;i++){tags2[i].name=tags[i].name.replace(/([0-9.]+)/,x);tags2[i].selectedIndex=tags[i].selectedIndex;}
tags=row.getElementsByTagName('input');tags2=row2.getElementsByTagName('input');var input=tags2[0];for(var i=0;i<tags.length;i++){if(tags[i].name=='auto_increment_col'){tags2[i].value=x;tags2[i].checked=false;}
tags2[i].name=tags[i].name.replace(/([0-9.]+)/,x);if(/\[(orig|field|comment|default)/.test(tags[i].name)){tags2[i].value='';}
if(/\[(has_default)/.test(tags[i].name)){tags2[i].checked=false;}}
tags[0].onchange=function(){editing_name_change(tags[0]);};row.parentNode.insertBefore(row2,row.nextSibling);if(focus){input.onchange=function(){editing_name_change(input);};input.focus();}
added+='0';row_count++;return true;}
function editing_remove_row(button){var field=form_field(button.form,button.name.replace(/drop_col(.+)/,'fields$1[field]'));field.parentNode.removeChild(field);button.parentNode.parentNode.style.display='none';return true;}
function editing_type_change(type){var name=type.name.substr(0,type.name.length-6);var text=select_value(type);for(var i=0;i<type.form.elements.length;i++){var el=type.form.elements[i];if(el.name==name+'[collation]'){el.className=(/(char|text|enum|set)$/.test(text)?'':'hidden');}
if(el.name==name+'[unsigned]'){el.className=(/(int|float|double|decimal)$/.test(text)?'':'hidden');}}}
function editing_length_focus(field){var td=field.parentNode;if(/enum|set/.test(select_value(td.previousSibling.firstChild))){var edit=document.getElementById('enum-edit');var val=field.value;edit.value=(/^'.+','.+'$/.test(val)?val.substr(1,val.length-2).replace(/','/g,"\n").replace(/''/g,"'"):val);td.appendChild(edit);field.style.display='none';edit.style.display='inline';edit.focus();}}
function editing_length_blur(edit){var field=edit.parentNode.firstChild;var val=edit.value;field.value=(/\n/.test(val)?"'"+val.replace(/\n+$/,'').replace(/'/g,"''").replace(/\n/g,"','")+"'":val);field.style.display='inline';edit.style.display='none';}
function column_show(checked,column){var trs=document.getElementById('edit-fields').getElementsByTagName('tr');for(var i=0;i<trs.length;i++){trs[i].getElementsByTagName('td')[column].className=(checked?'nowrap':'hidden');}}
function partition_by_change(el){var partition_table=/RANGE|LIST/.test(select_value(el));el.form['partitions'].className=(partition_table||!el.selectedIndex?'hidden':'');document.getElementById('partition-table').className=(partition_table?'':'hidden');}
function partition_name_change(el){var row=el.parentNode.parentNode.cloneNode(true);row.firstChild.firstChild.value='';el.parentNode.parentNode.parentNode.appendChild(row);el.onchange=function(){};}
function foreign_add_row(field){var row=field.parentNode.parentNode.cloneNode(true);var selects=row.getElementsByTagName('select');for(var i=0;i<selects.length;i++){selects[i].name=selects[i].name.replace(/\]/,'1$&');selects[i].selectedIndex=0;}
field.parentNode.parentNode.parentNode.appendChild(row);field.onchange=function(){};}
function indexes_add_row(field){var row=field.parentNode.parentNode.cloneNode(true);var spans=row.getElementsByTagName('span');for(var i=0;i<spans.length-1;i++){row.removeChild(spans[i]);}
var selects=row.getElementsByTagName('select');for(var i=0;i<selects.length;i++){selects[i].name=selects[i].name.replace(/indexes\[[0-9]+/,'$&1');selects[i].selectedIndex=0;}
var input=row.getElementsByTagName('input')[0];input.name=input.name.replace(/indexes\[[0-9]+/,'$&1');input.value='';field.parentNode.parentNode.parentNode.appendChild(row);field.onchange=function(){};}
function indexes_add_column(field){var column=field.parentNode.cloneNode(true);var select=column.getElementsByTagName('select')[0];select.name=select.name.replace(/\]\[[0-9]+/,'$&1');select.selectedIndex=0;var input=column.getElementsByTagName('input')[0];input.name=input.name.replace(/\]\[[0-9]+/,'$&1');input.value='';field.parentNode.parentNode.appendChild(column);field.onchange=function(){};}
var that,x,y,em,table_pos;function schema_mousedown(el,event){that=el;x=event.clientX-el.offsetLeft;y=event.clientY-el.offsetTop;}
function schema_mousemove(ev){if(that!==undefined){ev=ev||event;var left=(ev.clientX-x)/em;var top=(ev.clientY-y)/em;var divs=that.getElementsByTagName('div');var line_set={};for(var i=0;i<divs.length;i++){if(divs[i].className=='references'){var div2=document.getElementById((divs[i].id.substr(0,4)=='refs'?'refd':'refs')+divs[i].id.substr(4));var ref=(table_pos[divs[i].title]?table_pos[divs[i].title]:[div2.parentNode.offsetTop/em,0]);var left1=-1;var is_top=true;var id=divs[i].id.replace(/^ref.(.+)-.+/,'$1');if(divs[i].parentNode!=div2.parentNode){left1=Math.min(0,ref[1]-left)-1;divs[i].style.left=left1+'em';divs[i].getElementsByTagName('div')[0].style.width=-left1+'em';var left2=Math.min(0,left-ref[1])-1;div2.style.left=left2+'em';div2.getElementsByTagName('div')[0].style.width=-left2+'em';is_top=(div2.offsetTop+ref[0]*em>divs[i].offsetTop+top*em);}
if(!line_set[id]){var line=document.getElementById(divs[i].id.replace(/^....(.+)-[0-9]+$/,'refl$1'));var shift=ev.clientY-y-that.offsetTop;line.style.left=(left+left1)+'em';if(is_top){line.style.top=(line.offsetTop+shift)/em+'em';}
if(divs[i].parentNode!=div2.parentNode){line=line.getElementsByTagName('div')[0];line.style.height=(line.offsetHeight+(is_top?-1:1)*shift)/em+'em';}
line_set[id]=true;}}}
that.style.left=left+'em';that.style.top=top+'em';}}
function schema_mouseup(ev){if(that!==undefined){ev=ev||event;table_pos[that.firstChild.firstChild.firstChild.data]=[(ev.clientY-y)/em,(ev.clientX-x)/em];that=undefined;var date=new Date();date.setMonth(date.getMonth()+1);var s='';for(var key in table_pos){s+='_'+key+':'+Math.round(table_pos[key][0]*10000)/10000+'x'+Math.round(table_pos[key][1]*10000)/10000;}
document.cookie='adminer_schema='+encodeURIComponent(s.substr(1))+'; expires='+date+'; path='+location.pathname+location.search;}}<?php
}else{header("Content-Type: image/gif");switch($_GET["file"]){case"plus.gif":echo
base64_decode("R0lGODdhEgASAKEAAO7u7gAAAJmZmQAAACwAAAAAEgASAAACIYSPqcvtD00I8cwqKb5v+q8pIAhxlRmhZYi17iPE8kzLBQA7");break;case"cross.gif":echo
base64_decode("R0lGODdhEgASAKEAAO7u7gAAAJmZmQAAACwAAAAAEgASAAACI4SPqcvtDyMKYdZGb355wy6BX3dhlOEx57FK7gtHwkzXNl0AADs=");break;case"up.gif":echo
base64_decode("R0lGODdhEgASAKEAAO7u7gAAAJmZmQAAACwAAAAAEgASAAACIISPqcvtD00IUU4K730T9J5hFTiKEXmaYcW2rgDH8hwXADs=");break;case"down.gif":echo
base64_decode("R0lGODdhEgASAKEAAO7u7gAAAJmZmQAAACwAAAAAEgASAAACIISPqcvtD00I8cwqKb5bV/5cosdMJtmcHca2lQDH8hwXADs=");break;case"arrow.gif":echo
base64_decode("R0lGODlhCAAKAIAAAICAgP///yH5BAEAAAEALAAAAAAIAAoAAAIPBIJplrGLnpQRqtOy3rsAADs=");break;}}exit;}if(!isset($_SERVER["REQUEST_URI"])){$_SERVER["REQUEST_URI"]=$_SERVER["ORIG_PATH_INFO"].(strlen($_SERVER["QUERY_STRING"])?"?$_SERVER[QUERY_STRING]":"");}session_write_close();@ini_set("session.use_trans_sid",false);session_name("adminer_sid");$wd=array(0,preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]),"",$_SERVER["HTTPS"]);if(version_compare(PHP_VERSION,'5.2.0')>=0){$wd[]=true;}call_user_func_array('session_set_cookie_params',$wd);session_start();if(get_magic_quotes_gpc()){$xa=array(&$_GET,&$_POST,&$_COOKIE);while(list($e,$b)=each($xa)){foreach($b
as$Ea=>$fa){unset($xa[$e][$Ea]);if(is_array($fa)){$xa[$e][stripslashes($Ea)]=$fa;$xa[]=&$xa[$e][stripslashes($Ea)];}else{$xa[$e][stripslashes($Ea)]=($gd?$fa:stripslashes($fa));}}}unset($xa);}if(function_exists("set_magic_quotes_runtime")){set_magic_quotes_runtime(false);}@set_time_limit(0);define("DB",$_GET["db"]);define("ME",preg_replace('~^[^?]*/([^?]*).*~','\\1',$_SERVER["REQUEST_URI"]).'?'.(SID?SID.'&':'').(strlen($_GET["server"])?'server='.urlencode($_GET["server"]).'&':'').(strlen(DB)?'db='.urlencode(DB).'&':''));$La=array("RESTRICT","CASCADE","SET NULL","NO ACTION");$db="2.2.1";function
connection(){global$d;return$d;}function
idf_escape($ea){return"`".str_replace("`","``",$ea)."`";}function
idf_unescape($ea){return
str_replace("``","`",$ea);}function
escape_string($b){global$d;return
substr($d->quote($b),1,-1);}function
bracket_escape($ea,$Rd=false){static$Jd=array(':'=>':1',']'=>':2','['=>':3');return
strtr($ea,($Rd?array_flip($Jd):$Jd));}function
h($K){return
htmlspecialchars($K,ENT_QUOTES);}function
nbsp($K){return(strlen(trim($K))?h($K):"&nbsp;");}function
checkbox($j,$o,$P,$Hd="",$Gd=""){static$N=0;$N++;$g="<input type='checkbox' name='$j' value='".h($o)."'".($P?" checked":"").($Gd?" onclick=\"$Gd\"":"")." id='checkbox-$N'>";return(strlen($Hd)?"<label for='checkbox-$N'>$g".h($Hd)."</label>":$g);}function
optionlist($Ob,$Sd=null,$vd=false){$g="";foreach($Ob
as$Ea=>$fa){if(is_array($fa)){$g.='<optgroup label="'.h($Ea).'">';}foreach((is_array($fa)?$fa:array($Ea=>$fa))as$e=>$b){$g.='<option'.($vd||is_string($e)?' value="'.h($e).'"':'').(($vd||is_string($e)?(string)$e:$b)===$Sd?' selected':'').'>'.h($b);}if(is_array($fa)){$g.='</optgroup>';}}return$g;}function
html_select($j,$Ob,$o="",$Na=true){if($Na){return"<select name='".h($j)."'".(is_string($Na)?" onchange=\"$Na\"":"").">".optionlist($Ob,$o)."</select>";}$g="";foreach($Ob
as$e=>$b){$g.="<label><input type='radio' name='".h($j)."' value='".h($e)."'".($e==$o?" checked":"").">".h($b)."</label>";}return$g;}function
get_vals($m,$ha=0){global$d;$g=array();$f=$d->query($m);if($f){while($a=$f->fetch_row()){$g[]=$a[$ha];}}return$g;}function
unique_idf($a,$v){foreach($v
as$r){if(ereg("PRIMARY|UNIQUE",$r["type"])){$g=array();foreach($r["columns"]as$e){if(!isset($a[$e])){continue
2;}$g[]=urlencode("where[".bracket_escape($e)."]")."=".urlencode($a[$e]);}return$g;}}$g=array();foreach($a
as$e=>$b){if(!preg_match('~^(COUNT\\((\\*|(DISTINCT )?`(?:[^`]|``)+`)\\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\\(`(?:[^`]|``)+`\\))$~',$e)){$g[]=(isset($b)?urlencode("where[".bracket_escape($e)."]")."=".urlencode($b):"null%5B%5D=".urlencode($e));}}return$g;}function
where($C){$g=array();foreach((array)$C["where"]as$e=>$b){$e=bracket_escape($e,"back");$g[]=(preg_match('~^[A-Z0-9_]+\\(`(?:[^`]|``)+`\\)$~',$e)?$e:idf_escape($e))." LIKE ".exact_value(addcslashes($b,"%_"));}foreach((array)$C["null"]as$e){$e=bracket_escape($e,"back");$g[]=(preg_match('~^[A-Z0-9_]+\\(`(?:[^`]|``)+`\\)$~',$e)?$e:idf_escape($e))." IS NULL";}return
implode(" AND ",$g);}function
where_check($b){parse_str($b,$Qd);return
where($Qd);}function
where_link($h,$ha,$o){return"&where%5B$h%5D%5Bcol%5D=".urlencode($ha)."&where%5B$h%5D%5Bop%5D=%3D&where%5B$h%5D%5Bval%5D=".urlencode($o);}function
cookie($j,$o){return
setcookie($j,$o,time()+2592000,preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]));}function
restart_session(){if(!ini_get("session.use_cookies")){session_start();}}function
redirect($A,$ba=null){if(isset($ba)){restart_session();$_SESSION["messages"][]=$ba;}header("Location: ".(strlen($A)?$A:"."));exit;}function
query_redirect($m,$A,$ba,$Lb=true,$Pd=true,$mb=false){global$d,$n,$q;if($Pd){$mb=!$d->query($m);}$cc="";if($m){$cc=$q->messageQuery($m);}if($mb){$n=h($d->error).$cc;return
false;}if($Lb){redirect($A,$ba.$cc);}return
true;}function
queries($m=null){global$d;static$dd=array();if(!isset($m)){return
implode(";\n",$dd);}$dd[]=$m;return$d->query($m);}function
queries_redirect($A,$ba,$Lb){return
query_redirect(queries(),$A,$ba,$Lb,false,!$Lb);}function
remove_from_uri($ga=""){$ga="($ga|".session_name().")";return
substr(preg_replace("~(?<=[?&])$ga=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
pagination($nb){return" ".($nb==$_GET["page"]?$nb+1:'<a href="'.h(remove_from_uri("page").($nb?"&page=$nb":"")).'">'.($nb+1)."</a>");}function
get_file($e,$ed=false){$L=$_FILES[$e];if(!$L||$L["error"]){return$L["error"];}return
file_get_contents($ed&&ereg('\\.gz$',$L["name"])?"compress.zlib://$L[tmp_name]":($ed&&ereg('\\.bz2$',$L["name"])?"compress.bzip2://$L[tmp_name]":$L["tmp_name"]));}function
upload_error($n){$ld=($n==UPLOAD_ERR_INI_SIZE?ini_get("upload_max_filesize"):null);return($n?lang(0).($ld?" ".lang(1,$ld):""):lang(2));}function
odd($g=' class="odd"'){static$h=0;if(!$g){$h=-1;}return($h++%
2?$g:'');}function
is_utf8($b){return(preg_match('~~u',$b)&&!preg_match('~[\\0-\\x8\\xB\\xC\\xE-\\x1F]~',$b));}function
shorten_utf8($K,$pa=80,$Od=""){if(!preg_match("(^([\t\r\n -\x{FFFF}]{0,$pa})($)?)u",$K,$k)){preg_match("(^([\t\r\n -~]{0,$pa})($)?)",$K,$k);}return
h($k[1]).$Od.(isset($k[2])?"":"<em>...</em>");}function
friendly_url($b){return
preg_replace('~[^a-z0-9_]~i','-',$b);}function
hidden_fields($xa,$Td=array()){while(list($e,$b)=each($xa)){if(is_array($b)){foreach($b
as$Ea=>$fa){$xa[$e."[$Ea]"]=$fa;}}elseif(!in_array($e,$Td)){echo'<input type="hidden" name="'.h($e).'" value="'.h($b).'">';}}}function
column_foreign_keys($p){$g=array();foreach(foreign_keys($p)as$G){foreach($G["source"]as$b){$g[$b][]=$G;}}return$g;}function
input($c,$o,$x){global$oa,$q;$j=h(bracket_escape($c["field"]));echo"<td class='function'>";$Da=(isset($_GET["select"])?array("orig"=>lang(3)):array())+$q->editFunctions($c);if($c["type"]=="enum"){echo
nbsp($Da[""])."<td>".($Da["orig"]?"<label><input type='radio' name='fields[$j]' value='-1' checked><em>$Da[orig]</em></label> ":""),$q->editInput($_GET["edit"],$c," name='fields[$j]'",$o);preg_match_all("~'((?:[^']|'')*)'~",$c["length"],$F);foreach($F[1]as$h=>$b){$b=stripcslashes(str_replace("''","'",$b));$P=(is_int($o)?$o==$h+1:$o===$b);echo" <label><input type='radio' name='fields[$j]' value='".($h+1)."'".($P?' checked':'').'>'.h($b).'</label>';}}else{$Nb=0;foreach($Da
as$e=>$b){if($e===""||!$b){break;}$Nb++;}$Na=($Nb?" onchange=\"var f = this.form['function[".addcslashes($j,"\r\n'\\")."]']; if ($Nb > f.selectedIndex) f.selectedIndex = $Nb;\"":"");$bb=" name='fields[$j]'$Na";echo(count($Da)>1?html_select("function[$j]",$Da,!isset($x)||in_array($x,$Da)?$x:""):nbsp(reset($Da))).'<td>';$rd=$q->editInput($_GET["edit"],$c,$bb,$o);if(strlen($rd)){echo$rd;}elseif($c["type"]=="set"){preg_match_all("~'((?:[^']|'')*)'~",$c["length"],$F);foreach($F[1]as$h=>$b){$b=stripcslashes(str_replace("''","'",$b));$P=(is_int($o)?($o>>$h)&1:in_array($b,explode(",",$o),true));echo" <label><input type='checkbox' name='fields[$j][$h]' value='".(1<<$h)."'".($P?' checked':'')."$Na>".h($b).'</label>';}}elseif(ereg('binary|blob',$c["type"])&&ini_get("file_uploads")){echo"<input type='file' name='fields-$j'$Na>";}elseif(ereg('text|blob',$c["type"])){echo"<textarea cols='50' rows='12'$bb>".h($o).'</textarea>';}else{$sd=(!ereg('int',$c["type"])&&preg_match('~^([0-9]+)(,([0-9]+))?$~',$c["length"],$k)?($k[1]+($k[3]?1:0)+($k[2]&&!$c["unsigned"]?1:0)):($oa[$c["type"]]?$oa[$c["type"]]+($c["unsigned"]?0:1):0));echo"<input value='".h($o)."'".($sd?" maxlength='$sd'":"").(ereg('char',$c["type"])&&$c["length"]>20?" size='40'":"")."$bb>";}}}function
process_input($c){global$d,$q;$ea=bracket_escape($c["field"]);$x=$_POST["function"][$ea];$o=$_POST["fields"][$ea];if($c["type"]=="enum"?$o==-1:$x=="orig"){return
false;}elseif($c["type"]=="enum"||$c["auto_increment"]?!strlen($o):$x=="NULL"){return"NULL";}elseif($c["type"]=="enum"){return
intval($o);}elseif($c["type"]=="set"){return
array_sum((array)$o);}elseif(ereg('binary|blob',$c["type"])&&ini_get("file_uploads")){$L=get_file("fields-$ea");if(!is_string($L)){return
false;}return$d->quote($L);}else{return$q->processInput($c,$o,$x);}}function
dump_csv($a){foreach($a
as$e=>$b){if(preg_match("~[\"\n,]~",$b)||(isset($b)&&!strlen($b))){$a[$e]='"'.str_replace('"','""',$b).'"';}}echo
implode(",",$a)."\n";}function
apply_sql_function($x,$ha){return($x?($x=="count distinct"?"COUNT(DISTINCT ":strtoupper("$x("))."$ha)":$ha);}function
is_email($Ud){$nd='[-a-z0-9!#$%&\'*+/=?^_`{|}~]';$xb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return
preg_match("(^$nd+(\\.$nd+)*@($xb?\\.)+$xb\$)i",$Ud);}function
is_url($K){$xb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return
preg_match("~^https?://($xb?\\.)+$xb(:[0-9]+)?(/.*)?(\\?.*)?(#.*)?\$~i",$K);}function
print_fieldset($N,$Ld,$Nd=false){echo"<fieldset><legend><a href='#fieldset-$N' onclick=\"return !toggle('fieldset-$N');\">$Ld</a></legend><div id='fieldset-$N'".($Nd?"":" class='hidden'").">\n";}function
bold($K,$Md){return($Md?"<b>$K</b>":$K);}$Va=array('en'=>'English','cs'=>'Čeština','sk'=>'Slovenčina','nl'=>'Nederlands','es'=>'Español','de'=>'Deutsch','fr'=>'Français','it'=>'Italiano','et'=>'Eesti','ru'=>'Русский язык','zh'=>'简体中文','zh-tw'=>'繁體中文',);function
lang($ea,$Xb=null){global$ia,$T;$Xa=$T[$ea];if(is_array($Xa)&&$Xa){$qb=($Xb==1?0:((!$Xb||$Xb>=5)&&ereg('cs|sk|ru',$ia)?2:1));$Xa=$Xa[$qb];}$jd=func_get_args();array_shift($jd);return
vsprintf((isset($Xa)?$Xa:$ea),$jd);}function
switch_lang(){global$ia,$Va;echo"<form action=''>\n<div id='lang'>";hidden_fields($_GET,array('lang'));echo
lang(4).": ".html_select("lang",$Va,$ia,"this.form.submit();")," <input type='submit' value='".lang(5)."' class='hidden'>\n","</div>\n</form>\n";}if(isset($_GET["lang"])){$_COOKIE["adminer_lang"]=$_GET["lang"];$_SESSION["lang"]=$_GET["lang"];}$ia="en";if(isset($Va[$_COOKIE["adminer_lang"]])){cookie("adminer_lang",$_COOKIE["adminer_lang"]);$ia=$_COOKIE["adminer_lang"];}elseif(isset($Va[$_SESSION["lang"]])){$ia=$_SESSION["lang"];}else{$Mb=array();preg_match_all('~([-a-z]+)(;q=([0-9.]+))?~',str_replace("_","-",strtolower($_SERVER["HTTP_ACCEPT_LANGUAGE"])),$F,PREG_SET_ORDER);foreach($F
as$k){$Mb[$k[1]]=(isset($k[3])?$k[3]:1);}arsort($Mb);foreach($Mb
as$e=>$za){if(isset($Va[$e])){$ia=$e;break;}$e=preg_replace('~-.*~','',$e);if(!isset($Mb[$e])&&isset($Va[$e])){$ia=$e;break;}}}switch($ia){case"cs":$T=array('Nepodařilo se nahrát soubor.','Maximální povolená velikost souboru je %sB.','Soubor neexistuje.','původní','Jazyk','Vybrat','Server','Uživatel','Heslo','Vypsat tabulku','Struktura tabulky','Pozměnit tabulku','Pozměnit pohled','Nová položka','Upravit',array('%d bajt','%d bajty','%d bajtů'),'Vypsat','Funkce','Agregace','Vyhledat','(kdekoliv)','Seřadit','sestupně','Limit','Délka textů','Akce','SQL příkaz','otevřít','uložit','Export','Odhlásit','databáze','Žádné tabulky.','Vytvořit novou tabulku','vypsat','Žádná MySQL extenze','Není dostupná žádná z podporovaných PHP extenzí (%s).','Čísla','Datum a čas','Řetězce','Binární','Seznamy','Neplatný token CSRF. Odešlete formulář znovu.','Odhlášení proběhlo v pořádku.','Přihlásit se','Neplatné přihlašovací údaje.','Session proměnné musí být povolené.','Session vypršela, přihlašte se prosím znovu.','Databáze','Nesprávná databáze.','Databáze byla odstraněna.','Vybrat databázi','Vytvořit novou databázi','Oprávnění','Seznam procesů','Proměnné','Verze MySQL: %s přes PHP extenzi %s','Přihlášen jako: %s','Porovnávání','Odstranit','Opravdu?','Žádné řádky.','Cizí klíče','porovnávání','Název sloupce','Název parametru','Typ','Délka','Volby','Auto Increment','Výchozí hodnoty','Komentář','Přidat další','Odebrat','Přesunout nahoru','Přesunout dolů','Příliš velká POST data. Zmenšete data nebo zvyšte hodnotu konfigurační direktivy %s.','Pohled','Tabulka','Sloupec','Indexy','Pozměnit indexy','Změnit','Přidat cizí klíč','Triggery','Přidat trigger','Schéma databáze','Export','Výstup','Formát','Procedury a funkce','Události','Tabulky','Data','~ %s','upravit','Vytvořit uživatele','Chyba v dotazu','%.3f s',array('%d řádek','%d řádky','%d řádků'),array('Příkaz proběhl v pořádku, byl změněn %d záznam.','Příkaz proběhl v pořádku, byly změněny %d záznamy.','Příkaz proběhl v pořádku, bylo změněno %d záznamů.'),'Žádné příkazy k vykonání.','Provést','Zastavit při chybě','Nahrávání souborů není povoleno.','Nahrání souboru','Spustit soubor','Soubor %s na webovém serveru','Historie','Vyčistit','Položka byla aktualizována.','Položka byla vložena.','Vložit','Uložit','Uložit a pokračovat v editaci','Uložit a vložit další','Tabulka byla změněna.','Tabulka byla vytvořena.','Vytvořit tabulku','Byl překročen maximální povolený počet polí. Zvyšte prosím %s a %s.','Název tabulky','úložiště','Zobrazit komentáře sloupců','Rozdělit podle','Oddíly','Název oddílu','Hodnoty','Indexy byly změněny.','Typ indexu','Sloupec (délka)','Databáze byla vytvořena.','Databáze byla přejmenována.','Databáze byla změněna.','Pozměnit databázi','Vytvořit databázi','Zavolat',array('Procedura byla zavolána, byl změněn %d záznam.','Procedura byla zavolána, byly změněny %d záznamy.','Procedura byla zavolána, bylo změněno %d záznamů.'),'Cizí klíč byl odstraněn.','Cizí klíč byl změněn.','Cizí klíč byl vytvořen.','Zdrojové a cílové sloupce musí mít stejný datový typ, nad cílovými sloupci musí být definován index a odkazovaná data musí existovat.','Cizí klíč','Cílová tabulka','Změnit','Zdroj','Cíl','Při smazání','Při změně','Přidat sloupec','Pohled byl odstraněn.','Pohled byl změněn.','Pohled byl vytvořen.','Vytvořit pohled','Název','Událost byla odstraněna.','Událost byla změněna.','Událost byla vytvořena.','Pozměnit událost','Vytvořit událost','Začátek','Konec','Každých','Stav','Po dokončení zachovat','Procedura byla odstraněna.','Procedura byla změněna.','Procedura byla vytvořena.','Změnit funkci','Změnit proceduru','Vytvořit funkci','Vytvořit proceduru','Návratový typ','Trigger byl odstraněn.','Trigger byl změněn.','Trigger byl vytvořen.','Změnit trigger','Vytvořit trigger','Čas','Událost','Uživatel byl odstraněn.','Uživatel byl změněn.','Uživatel byl vytvořen.','Zahašované','Procedura','Povolit','Zakázat',array('Byl ukončen %d proces.','Byly ukončeny %d procesy.','Bylo ukončeno %d procesů.'),'Ukončit',array('Byl ovlivněn %d záznam.','Byly ovlivněny %d záznamy.','Bylo ovlivněno %d záznamů.'),array('Byl importován %d záznam.','Byly importovány %d záznamy.','Bylo importováno %d záznamů.'),'Nepodařilo se vypsat tabulku','Vztahy','Stránka','celý výsledek','Klonovat','Smazat','Import CSV','Import','Tabulky byly vyprázdněny.','Tabulky byly přesunuty','Tabulky byly odstraněny.','Tabulky a pohledy','Úložiště','Velikost dat','Velikost indexů','Volné místo','Řádků',' ','Analyzovat','Optimalizovat','Zkontrolovat','Opravit','Vyprázdnit','Přesunout do jiné databáze','Přesunout','Plán','V daný čas','Editor');break;case"de":$T=array('Hochladen von Datei fehlgeschlagen.','Maximal erlaubte Dateigrösse ist %sB.','Datei existiert nicht.','Original','Sprache','Benutzung','Server','Benutzer','Passwort','Tabelle auswählen','Tabellenstruktur','Tabelle ändern','View ändern','Neuer Datensatz','Ändern',array('%d Byte','%d Bytes'),'Daten zeigen von','Funktionen','Agregationen','Suchen','(beliebig)','Ordnen','absteigend','Begrenzung','Textlänge','Aktion','SQL-Query','anzeigen','Datei','Export','Abmelden','Datenbank','Keine Tabellen.','Neue Tabelle','zeigen','Keine MySQL-Erweiterungen installiert','Keine der unterstützten PHP-Erweiterungen (%s) ist vorhanden.','Zahlen','Datum oder Zeit','Zeichenketten','Binär','Listen','CSRF Token ungültig. Bitte die Formulardaten erneut abschicken.','Abmeldung erfolgreich.','Login','Ungültige Anmelde-Informationen.','Sitzungen müssen aktiviert sein.','Sitzungsdauer abgelaufen, bitte erneut anmelden.','Datenbank','Datenbank ungültig.','Datenbank entfernt.','Datenbank auswählen','Neue Datenbank','Rechte','Prozessliste','Variablen','Version MySQL: %s, mit PHP-Erweiterung %s','Angemeldet als: %s','Collation','Entfernen','Sind Sie sicher ?','Keine Daten.','Fremdschlüssel','Kollation','Spaltenname','Name des Parameters','Typ','Länge','Optionen','Auto-Inkrement','Vorgabewerte festlegen','Kommentar','Hinzufügen','Entfernen','Nach oben','Nach unten','POST data zu gross. Reduzieren Sie die Grösse oder vergrössern Sie den Wert %s in der Konfiguration.','View','Tabelle','Spalte','Indizes','Indizes ändern','Ändern','Fremdschlüssel hinzufügen','Trigger','Trigger hinzufügen','Datenbankschema','Exportieren','Ergebnis','Format','Prozeduren','Ereignisse','Tabellen','Daten','~ %s','ändern','Neuer Benutzer','Fehler in der SQL-Abfrage','%.3f s',array('%d Datensatz','%d Datensätze'),array('Abfrage ausgeführt, %d Datensatz betroffen.','Abfrage ausgeführt, %d Datensätze betroffen.'),'Kein Kommando vorhanden.','Ausführen','Bei Fehler anhaltan','Importieren von Dateien abgeschaltet.','Datei importieren','Datei ausführen','Webserver Datei %s','History','Entleeren','Datensatz geändert.','Datensatz hinzugefügt.','Hinzufügen','Speichern','Speichern und weiter bearbeiten','Speichern und nächsten hinzufügen','Tabelle geändert.','Tabelle erstellt.','Neue Tabelle erstellen','Die maximal erlaubte Anzahl der Felder ist überschritten. Bitte %s und %s erhöhen.','Name der Tabelle','Motor','Spaltenkommentare zeigen','Partitionieren um','Partitionen','Name der Partition','Werte','Indizes geändert.','Index-Typ','Spalte (Länge)','Datenbank erstellt.','Datenbank umbenannt.','Datenbank geändert.','Datenbank ändern','Neue Datenbank','Aufrufen',array('Kommando SQL ausgeführt, %d Datensatz betroffen.','Kommando SQL ausgeführt, %d Datensätze betroffen.'),'Fremdschlüssel entfernt.','Fremdschlüssel geändert.','Fremdschlüssel erstellt.','Spalten des Ursprungs und des Zieles müssen vom gleichen Datentyp sein, es muss unter den Zielspalten ein Index existieren und die referenzierten Daten müssen existieren.','Fremdschlüssel','Zieltabelle','Ändern','Ursprung','Ziel','ON DELETE','ON UPDATE','Spalte hinzufügen','View entfernt.','View geändert.','View erstellt.','Neue View erstellen','Name','Ereignis entfernt.','Ereignis geändert.','Ereignis erstellt.','Ereignis ändern','Ereignis erstellen','Start','Ende','Jede','Status','Nach der Ausführung erhalten','Prozedur entfernt.','Prozedur geändert.','Prozedur erstellt.','Funktion ändern','Prozedur ändern','Neue Funktion','Neue Prozedur','Typ des Rückgabewertes','Trigger entfernt.','Trigger geändert.','Trigger erstellt.','Trigger ändern','Trigger hinzufügen','Zeitpunkt','Ereignis','Benutzer entfernt.','Benutzer geändert.','Benutzer erstellt.','Hashed','Rutine','Erlauben','Verbieten',array('%d Prozess gestoppt.','%d Prozesse gestoppt.'),'Anhalten',array('%d Artikel betroffen.','%d Artikel betroffen.'),array('%d Datensatz importiert.','%d Datensätze wurden importiert.'),'Auswahl der Tabelle fehlgeschlagen','Relationen','Seite','Gesamtergebnis','Klonen','Entfernen','Importiere CSV','Importieren','Tabellen sind entleert worden (truncate).','Tabellen verschoben.','Tabellen wurden entfernt (drop).','Tabellen und Views','Motor','Datengrösse','Indexgrösse','Freier Bereich','Datensätze',' ','Analysieren','Optimisieren','Prüfen','Reparieren','Entleeren (truncate)','In andere Datenbank verschieben','Verschieben','Zeitplan','Zur angegebenen Zeit',array('%d e-mail abgeschickt.','%d e-mails abgeschickt.'));break;case"en":$T=array('Unable to upload a file.','Maximum allowed file size is %sB.','File does not exist.','original','Language','Use','Server','Username','Password','Select table','Table structure','Alter table','Alter view','New item','Edit',array('%d byte','%d bytes'),'Select','Functions','Aggregation','Search','(anywhere)','Sort','descending','Limit','Text length','Action','SQL command','open','save','Dump','Logout','database','No tables.','Create new table','select','No MySQL extension','None of the supported PHP extensions (%s) are available.','Numbers','Date and time','Strings','Binary','Lists','Invalid CSRF token. Send the form again.','Logout successful.','Login','Invalid credentials.','Session support must be enabled.','Session expired, please login again.','Database','Invalid database.','Database has been dropped.','Select database','Create new database','Privileges','Process list','Variables','MySQL version: %s through PHP extension %s','Logged as: %s','Collation','Drop','Are you sure?','No rows.','Foreign keys','collation','Column name','Parameter name','Type','Length','Options','Auto Increment','Default values','Comment','Add next','Remove','Move up','Move down','Too big POST data. Reduce the data or increase the %s configuration directive.','View','Table','Column','Indexes','Alter indexes','Alter','Add foreign key','Triggers','Add trigger','Database schema','Export','Output','Format','Routines','Events','Tables','Data','~ %s','edit','Create user','Error in query','%.3f s',array('%d row','%d rows'),array('Query executed OK, %d row affected.','Query executed OK, %d rows affected.'),'No commands to execute.','Execute','Stop on error','File uploads are disabled.','File upload','Run file','Webserver file %s','History','Clear','Item has been updated.','Item has been inserted.','Insert','Save','Save and continue edit','Save and insert next','Table has been altered.','Table has been created.','Create table','Maximum number of allowed fields exceeded. Please increase %s and %s.','Table name','engine','Show column comments','Partition by','Partitions','Partition name','Values','Indexes have been altered.','Index Type','Column (length)','Database has been created.','Database has been renamed.','Database has been altered.','Alter database','Create database','Call',array('Routine has been called, %d row affected.','Routine has been called, %d rows affected.'),'Foreign key has been dropped.','Foreign key has been altered.','Foreign key has been created.','Source and target columns must have the same data type, there must be an index on the target columns and referenced data must exist.','Foreign key','Target table','Change','Source','Target','ON DELETE','ON UPDATE','Add column','View has been dropped.','View has been altered.','View has been created.','Create view','Name','Event has been dropped.','Event has been altered.','Event has been created.','Alter event','Create event','Start','End','Every','Status','On completion preserve','Routine has been dropped.','Routine has been altered.','Routine has been created.','Alter function','Alter procedure','Create function','Create procedure','Return type','Trigger has been dropped.','Trigger has been altered.','Trigger has been created.','Alter trigger','Create trigger','Time','Event','User has been dropped.','User has been altered.','User has been created.','Hashed','Routine','Grant','Revoke',array('%d process has been killed.','%d processes have been killed.'),'Kill',array('%d item has been affected.','%d items have been affected.'),array('%d row has been imported.','%d rows have been imported.'),'Unable to select the table','Relations','Page','whole result','Clone','Delete','CSV Import','Import','Tables have been truncated.','Tables have been moved.','Tables have been dropped.','Tables and views','Engine','Data Length','Index Length','Data Free','Rows',',','Analyze','Optimize','Check','Repair','Truncate','Move to other database','Move','Schedule','At given time',array('%d e-mail has been sent.','%d e-mails have been sent.'));break;case"es":$T=array('No posible importar archivo.','Tamaño máximo de archivo es %sB.','Archivo no existe.','original','Idioma','Usar','Servidor','Usuario','Contraseña','Mostrar datos','Información de la Tabla','Modificar Estructura','Modificar vista','Nuevo Registro','Modificar',array('%d byte','%d bytes'),'Mostrar','Funciones','Agregaciones','Condición','(donde sea)','Ordenar','descendiente','Limit','Longitud de texto','Acción','Comando SQL','mostrar','archivo','Export','Logout','base de datos','No existen tablas.','Nueva tabla','registros','No hay extension MySQL','Ninguna de las extensiones PHP soportadas (%s) está disponible.','Números','Fecha y hora','Cadena','Binario','Listas','Token CSRF inválido. Vuelva a enviar los datos del formulario.','Salida exitosa.','Login','Autenticación fallada.','Deben estar habilitadas las sesiones.','Sesión expirada, favor loguéese de nuevo.','Base de datos','Base de datos inválida.','Base de datos eliminada.','Seleccionar Base de datos','Nueva Base de datos','Privilegios','Lista de procesos','Variables','Versión MySQL: %s a través de extensión PHP %s','Logeado como: %s','Colación','Eliminar','Está seguro?','No existen registros.','Claves foráneas','colación','Nombre de columna','Nombre de Parametro','Tipo','Longitud','Opciones','Auto increment','Valores predeterminados','Comentario','Agregar','Eliminar','Mover arriba','Mover abajo','POST data demasiado grande. Reduzca el tamaño o aumente la directiva de configuración %s.','Vistas','Tabla','Columna','Indices','Modificar indices','Modificar','Agregar clave foránea','Triggers','Agregar trigger','Esquema de base de datos','Exportar','Salida','Formato','Procedimientos','Eventos','Tablas','Datos','~ %s','modificar','Crear Usuario','Error en consulta','%.3f s',array('%d registro','%d registros'),array('Consulta ejecutada, %d registro afectado.','Consulta ejecutada, %d registros afectados.'),'No hay comando para ejecutar.','Ejecutar','Parar en caso de error','Importación de archivos deshablilitado.','Importar archivo','Ejecutar Archivo','Archivo de servidor web %s','History','Vaciar','Registro modificado.','Registro insertado.','Agregar','Guardar','Guardar y continuar editando','Guardar e insertar otro','Tabla modificada.','Tabla creada.','Crear tabla','Cantida máxima de campos permitidos excedidos. Favor aumente %s y %s.','Nombre de tabla','motor','Mostrar comentario de columnas','Particionar por','Particiones','Nombre de Partición','Valores','Indices modificados.','Tipo de índice','Columna (longitud)','Base de datos creada.','Base de datos renombrada.','Base de datos modificada.','Modificar Base de datos','Crear Base de datos','Llamar',array('Consulta ejecutada, %d registro afectado.','Consulta ejecutada, %d registros afectados.'),'Clave foránea eliminada.','Clave foránea modificada.','Clave foránea creada.','Las columnas de origen y destino deben ser del mismo tipo, debe existir un índice entre las columnas del destino y el registro referenciado debe existir.','Clave foránea','Tabla destino','Modificar','Origen','Destino','ON DELETE','ON UPDATE','Agregar columna','Vista eliminada.','Vista modificada.','Vista creada.','Cear vista','Nombre','Evento eliminado.','Evento modificado.','Evento creado.','Modificar Evento','Crear Evento','Inicio','Fin','Cada','Estado','Al completar preservar','Procedimiento eliminado.','Procedimiento modificado.','Procedimiento creado.','Modificar Función','Modificar procedimiento','Crear función','Crear procedimiento','Tipo de valor retornado','Trigger eliminado.','Trigger modificado.','Trigger creado.','Modificar Trigger','Agregar Trigger','Tiempo','Evento','Usuario eliminado.','Usuario modificado.','Usuario creado.','Hash','Rutina','Conceder','Impedir',array('%d proceso detenido.','%d procesos detenidos.'),'Detener',array('%d ítem afectado.','%d itemes afectados.'),array('%d registro importado.','%d registros importados.'),'No posible seleccionar la tabla','Relaciones','Página','resultado completo','Clonar','Eliminar','Importar CSV','Importar','Tablas vaciadas (truncate).','Se movieron las tablas.','Tablas eliminadas.','Tablas y vistas','Motor','Longitud de datos','Longitud de índice','Espacio libre','Registros',' ','Analizar','Optimizar','Comprobar','Reparar','Vaciar','Mover a otra base de datos','Mover','Agendamiento','A hora determinada',array('%d email enviado.','%d emails enviados.'));break;case"et":$T=array('Faili üleslaadimine pole võimalik.','Maksimaalne failisuurus %sB.','Faili ei leitud.','originaal','Keel','Kasuta','Server','Kasutajanimi','Parool','Vali tabel','Tabeli struktuur','Muuda tabeli struktuuri','Muuda vaadet (VIEW)','Lisa kirje','Muuda',array('%d bait','%d baiti'),'Kuva','Funktsioonid','Liitmine','Otsi','(vahet pole)','Sorteeri','kahanevalt','Piira','Teksti pikkus','Tegevus','SQL-Päring','näita brauseris','salvesta failina','Ekspordi','Logi välja','andmebaas','Tabeleid ei leitud.','Loo uus tabel','kuva','Ei leitud MySQL laiendust','Serveris pole ühtegi toetatud PHP laiendustest (%s).','Numbrilised','Kuupäev ja kellaaeg','Tekstid','Binaar','Listid','Sobimatu CSRF, palun postitage vorm uuesti.','Väljalogimine õnnestus.','Logi sisse','Ebakorrektsed andmed.','Sessioonid peavad olema lubatud.','Sessioon on aegunud, palun logige uuesti sisse.','Andmebaas','Tundmatu andmebaas.','Andmebaas on edukalt kustutatud.','Vali andmebaas','Loo uus andmebaas','Õigused','Protsesside nimekiri','Muutujad','MySQL versioon: %s, kasutatud PHP moodul: %s','Sisse logitud: %s','Tähetabel','Kustuta','Kas oled kindel?','Sissekanded puuduvad.','Võõrvõtmed (foreign key)','tähetabel','Veeru nimi','Parameetri nimi','Tüüp','Pikkus','Valikud','Automaatselt suurenev','Vaikimisi väärtused','Kommentaar','Lisa järgmine','Eemalda','Liiguta ülespoole','Liiguta allapoole','POST-andmete maht on liialt suur. Palun vähendage andmeid või suurendage %s php-seadet.','Vaata','Tabel','Veerg','Indeksid','Muuda indekseid','Muuda','Lisa võõrvõti','Päästikud (trigger)','Lisa päästik (TRIGGER)','Andmebaasi skeem','Ekspordi','Väljund','Formaat','Protseduurid','Sündmused (EVENTS)','Tabelid','Andmed','~ %s','muuda','Loo uus kasutaja','Päringus esines viga','%.3f s',array('%d rida','%d rida'),array('Päring õnnestus, mõjutatatud ridu: %d.','Päring õnnestus, mõjutatatud ridu: %d.'),'Käsk puudub.','Käivita','Peatuda vea esinemisel','Failide üleslaadimine on keelatud.','Faili üleslaadimine','Käivita fail','Fail serveris: %s','Ajalugu','Puhasta','Uuendamine õnnestus.','Lisamine õnnestus.','Sisesta','Salvesta','Salvesta ja jätka muutmist','Salvesta ja lisa järgmine','Tabeli andmed on edukalt muudetud.','Tabel on edukalt loodud.','Loo uus tabel','Maksimaalne väljade arv ületatud. Palun suurendage %s ja %s.','Tabeli nimi','andmebaasimootor','Kuva veeru kommentaarid','Partitsiooni','Partitsioonid','Partitsiooni nimi','Väärtused','Indeksite andmed on edukalt uuendatud.','Indeksi tüüp','Veerg (pikkus)','Andmebaas on edukalt loodud.','Andmebaas on edukalt ümber nimetatud.','Andmebaasi struktuuri uuendamine õnnestus.','Muuda andmebaasi','Loo uus andmebaas','Käivita',array('Protseduur täideti edukalt, mõjutatud ridu: %d.','Protseduur täideti edukalt, mõjutatud ridu: %d.'),'Võõrvõti on edukalt kustutatud.','Võõrvõtme andmed on edukalt muudetud.','Võõrvõri on edukalt loodud.','Lähte- ja sihtveerud peavad eksisteerima ja omama sama andmetüüpi, sihtveergudel peab olema määratud indeks ning viidatud andmed peavad eksisteerima.','Võõrvõti','Siht-tabel','Muuda','Allikas','Sihtkoht','ON DELETE','ON UPDATE','Lisa veerg','Vaade (VIEW) on edukalt kustutatud.','Vaade (VIEW) on edukalt muudetud.','Vaade (VIEW) on edukalt loodud.','Loo uus vaade (VIEW)','Nimi','Sündmus on edukalt kustutatud.','Sündmuse andmed on edukalt uuendatud.','Sündmus on edukalt loodud.','Muuda sündmuse andmeid','Loo uus sündmus (EVENT)','Alusta','Lõpeta','Iga','Staatus','Lõpetamisel jäta sündmus alles','Protseduur on edukalt kustutatud.','Protseduuri andmed on edukalt muudetud.','Protseduur on edukalt loodud.','Muuda funktsiooni','Muuda protseduuri','Loo uus funktsioon','Loo uus protseduur','Tagastustüüp','Päästik on edukalt kustutatud.','Päästiku andmed on edukalt uuendatud.','Uus päästik on edukalt loodud.','Muuda päästiku andmeid','Loo uus päästik (TRIGGER)','Aeg','Sündmus','Kasutaja on edukalt kustutatud.','Kasutaja andmed on edukalt muudetud.','Kasutaja on edukalt lisatud.','Häshitud (Hashed)','Protseduur','Anna','Eemalda',array('Protsess on edukalt peatatud (%d).','Valitud protsessid (%d) on edukalt peatatud.'),'Peata',array('Mõjutatud kirjeid: %d.','Mõjutatud kirjeid: %d.'),array('Imporditi %d rida.','Imporditi %d rida.'),'Tabeli valimine ebaõnnestus','Seosed','Lehekülg','Täielikud tulemused','Kloon','Kustuta','Impordi CSV','Impordi','Validud tabelid on edukalt tühjendatud.','Valitud tabelid on edukalt liigutatud.','Valitud tabelid on edukalt kustutatud.','Tabelid ja vaated','Implementatsioon','Andmete pikkus','Indeksi pikkus','Vaba ruumi','Ridu',',','Analüüsi','Optimeeri','Kontrolli','Paranda','Tühjenda','Liiguta teise andmebaasi','Liiguta','Ajakava','Antud ajahetkel',array('Saadetud kirju: %d.','Saadetud kirju: %d.'));break;case"fr":$T=array('Impossible d\'importer le fichier.','Taille maximale des fichiers est de %sB.','Le fichier est introuvable.','original','Langues','Utiliser','Serveur','Utilisateur','Mot de passe','Selectionner la table','Structure de la table','Modifier la table','Modifier une vue','Nouvel élément','Modifier',array('%d octet','%d octets'),'Select','Fonctions','Agrégation','Rechercher','(n\'importe où)','Ordonner','décroissant','Limit','Longueur du texte','Action','Requête SQL','ouvrir','sauvegarder','Exporter','Déconnexion','base de données','Aucunes tables.','Créer une table','select','Extension MySQL introuvable','Aucune des extensions PHP supportées (%s) n\'est disponible.','Nombres','Date et heure','Chaînes','Binaires','Listes','Token CSRF invalide. Veuillez réenvoyer le formulaire.','Aurevoir!','Authentification','Authentification échouée','Veuillez activer les sessions.','Session expirée, veuillez vous authentifier à nouveau.','Base de données','Base de donnée invalide','Base de données effacée.','Selectionner la base de donnée','Créer une base de donnée','Privilège','Liste de processus','Variables','Version de MySQL: %s utilisant l\'extension %s','Authentifié en tant que %s','Collation','Effacer','Êtes-vous certain?','Aucun résultat','Clé éxterne','collation','Nom de la colonne','Nom du Paramêtre','Type','Longeur','Options','Auto increment','Valeurs par défaut','Commentaire','Ajouter le prochain','Effacer','Déplacer vers le haut','Déplacer vers le bas','Donnée POST trop grande . Réduire la taille des données ou modifier le %s dans la configuration de PHP.','Vue','Table','Colonne','Index','Modifier les index','Modifier','Ajouter une clé externe','Triggers','Ajouter un trigger','Schéma de la base de données','Exporter','Sortie','Formatter','Routines','Évènement','Tables','Donnée','~ %s','modifier','Créer un utilisateur','Erreur dans la requête','%.3f s',array('%d ligne','%d lignes'),array('Requête exécutée, %d ligne affectée.','Requête exécutée, %d lignes affectées.'),'Aucune commande à exécuter.','Exécuter','Arrêt sur erreur','Importation de fichier désactivé.','Importer un fichier','Executer le fichier','%s fichier du serveur Web','Historique','Effacer','Élément modifié.','Élément inseré.','Insérer','Sauvegarder','Sauvegarder et continuer l\'édition','Sauvegarder et insérer le prochain','Table modifiée','Table créée.','Créer une table','Le nombre de champs maximum est dépassé. Veuillez augmenter %s et %s','Nom de la table','moteur','Voir les commentaires sur les colonnes','Partitionné par','Partitions','Nom de la partition','Valeurs','Index modifiés.','Type d\'index','Colonne (longueur)','Base de données créée.','Base de données renommée.','Base de données modifiée.','Modifier la base de données','Créer une base de données','Appeler',array('Routine exécutée, %d ligne modifiée.','Routine exécutée, %d lignes modifiées.'),'Clé externe effacée.','Clé externe modifiée.','Clé externe créée.','Les colonnes selectionnées et les colonnes de destination doivent être du même type, il doit y avoir un index sur les colonnes de destination et les données de référence doivent exister.','Clé externe','Table visée','Modifier','Source','Cible','ON DELETE','ON UPDATE','Ajouter une colonne','Vue effacée.','Vue modifiée.','Vue créée.','Créer une vue','Nom','L\'évènement a été supprimé.','L\'évènement a été modifié.','L\'évènement a été créé.','Modifier un évènement','Créer un évènement','Démarrer','Terminer','Chaque','Status','Conserver quand complété','Procédure éliminée.','Procédure modifiée.','Procédure créée.','Modifier la fonction','Modifier la procédure','Créer une fonction','Créer une procédure','Type de retour','Trigger éliminé.','Trigger modifié.','Trigger créé.','Modifier un trigger','Ajouter un trigger','Temps','Évènement','Utilisateur éffacé.','Utilisateur modifié.','Utilisateur créé.','Haché','Routine','Grant','Revoke',array('%d processus arrêté.','%d processus arrêtés.'),'Arrêter',array('%d élément ont été modifié.','%d éléments ont été modifié.'),array('%d ligne a été importé','%d lignes ont été importé'),'Impossible de sélectionner la table','Relations','Page','résultat entier','Cloner','Effacer','Importation CVS','Importer','Les tables ont été tronquées','Les tables ont été déplacées','Les tables ont été effacées','Tables et vues','Moteur','Longeur des données','Longeur de l\'index','Vide','Rangés',',','Analyser','Opitimiser','Vérifier','Réparer','Tronquer','Déplacer dans une autre base de données','Déplacer','Horaire','À un moment précis',array('%d message a été envoyé.','%d messages ont été envoyés.'));break;case"it":$T=array('Caricamento del file non riuscito.','La dimensione massima del file è %sB.','Il file non esiste.','originale','Lingua','Usa','Server','Utente','Password','Scegli tabella','Struttura tabella','Modifica tabella','Modifica vista','Nuovo elemento','Modifica',array('%d byte','%d bytes'),'Seleziona','Funzioni','Aggregazione','Cerca','(ovunque)','Ordina','discendente','Limite','Lunghezza testo','Azione','Comando SQL','apri','salva','Dump','Esci','database','No tabelle.','Crea nuova tabella','seleziona','Estensioni MySQL non presenti','Nessuna delle estensioni PHP supportate (%s) disponibile.','Numeri','Data e ora','Stringhe','Binari','Liste','Token CSRF non valido. Reinvia la richiesta.','Uscita effettuata con successo.','Autenticazione','Credenziali non valide.','Le sessioni devono essere abilitate.','Sessione scaduta, autenticarsi di nuovo.','Database','Database non valido.','Database eliminato.','Seleziona database','Crea nuovo database','Privilegi','Elenco processi','Variabili','Versione MySQL: %s via estensione PHP %s','Autenticato come: %s','Collazione','Elimina','Sicuro?','Nessuna riga.','Chiavi esterne','collazione','Nome colonna','Nome parametro','Tipo','Lunghezza','Opzioni','Auto incremento','Valori predefiniti','Commento','Aggiungi altro','Rimuovi','Sposta su','Sposta giu','Troppi dati via POST. Ridurre i dati o aumentare la direttiva di configurazione %s.','Vedi','Tabella','Colonna','Indici','Modifica indici','Modifica','Aggiungi foreign key','Trigger','Aggiungi trigger','Schema database','Esporta','Risultato','Formato','Routine','Eventi','Tabelle','Dati','~ %s','modifica','Crea utente','Errore nella query','%.3f s',array('%d riga','%d righe'),array('Esecuzione della query OK, %d riga interessata.','Esecuzione della query OK, %d righe interessate.'),'Nessun commando da eseguire.','Esegui','Stop su errore','Caricamento file disabilitato.','Caricamento file','Esegui file','Webserver file %s','Storico','Pulisci','Elemento aggiornato.','Elemento inserito.','Inserisci','Salva','Salva e continua','Salva e inserisci un altro','Tabella modificata.','Tabella creata.','Crea tabella','Troppi campi. Per favore aumentare %s e %s.','Nome tabella','motore','Mostra i commenti delle colonne','Partiziona per','Partizioni','Nome partizione','Valori','Indici modificati.','Tipo indice','Colonna (lunghezza)','Database creato.','Database rinominato.','Database modificato.','Modifica database','Crea database','Chiama',array('Routine chiamata, %d riga interessata.','Routine chiamata, %d righe interessate.'),'Foreign key eliminata.','Foreign key modificata.','Foreign key creata.','Le colonne sorgente e destinazione devono essere dello stesso tipo e ci deve essere un indice sulla colonna di destinazione e sui dati referenziati.','Foreign key','Tabella obiettivo','Cambia','Sorgente','Obiettivo','ON DELETE','ON UPDATE','Aggiungi colonna','Vista eliminata.','Vista modificata.','Vista creata.','Crea vista','Nome','Evento eliminato.','Evento modificato.','Evento creato.','Modifica evento','Crea evento','Inizio','Fine','Ogni','Stato','Al termine preservare','Routine eliminata.','Routine modificata.','Routine creata.','Modifica funzione','Modifica procedura','Crea funzione','Crea procedura','Return type','Trigger eliminato.','Trigger modificato.','Trigger creato.','Modifica trigger','Crea trigger','Orario','Evento','Utente eliminato.','Utente modificato.','Utente creato.','Hashed','Routine','Permetti','Revoca',array('%d processo interrotto.','%d processi interrotti.'),'Interrompi',array('Il risultato consiste in %d elemento','Il risultato consiste in %d elementi'),array('%d riga importata.','%d righe importate.'),'Selezione della tabella non riuscita','Relazioni','Pagina','intero risultato','Clona','Elimina','Importa da CSV','Importa','Le tabelle sono state svuotate.','Le tabelle sono state spostate.','Le tabelle sono state eliminate.','Tabelle e viste','Motore','Lunghezza dato','Lunghezza indice','Dati liberi','Righe','.','Analizza','Ottimizza','Controlla','Ripara','Svuota','Sposta in altro database','Sposta','Pianifica','A tempo prestabilito',array('%d e-mail inviata.','%d e-mail inviate.'));break;case"nl":$T=array('Onmogelijk bestand te uploaden.','Maximum toegelaten bestandsgrootte is %sB.','Bestand niet gevonden.','origineel','Taal','Gebruik','Server','Gebruikersnaam','Wachtwoord','Selecteer tabel','Tabelstructuur','Tabel aanpassen','View aanpassen','Nieuw item','Bewerk',array('%d byte','%d bytes'),'Kies','Functies','Totalen','Zoeken','(overal)','Sorteren','Aflopend','Beperk','Tekst lengte','Acties','SQL opdracht','openen','opslaan','Exporteer','Uitloggen','database','Geen tabellen.','Nieuwe tabel','kies','Geen MySQL extensie','Geen geldige PHP extensies beschikbaar (%s).','Getallen','Datum en tijd','Tekst','Binaire gegevens','Lijsten','Ongeldig CSRF token. Verstuur het formulier opnieuw.','Uitloggen geslaagd.','Inloggen','Ongeldige logingegevens.','Sessies moeten geactiveerd zijn.','Uw sessie is verlopen. Gelieve opnieuw in te loggen.','Database','Ongeldige database.','Database verwijderd.','Database selecteren','Nieuwe database','Rechten','Proceslijst','Variabelen','MySQL versie: %s met PHP extensie %s','Aangemeld als: %s','Collatie','Verwijderen','Weet u het zeker?','Geen rijen.','Foreign keys','collation','Kolomnaam','Parameternaam','Type','Lengte','Opties','Auto nummering','Standaard waarden','Commentaar','Volgende toevoegen','Verwijderen','Omhoog','Omlaag','POST-data is te groot. Verklein de hoeveelheid data of verhoog de %s configuratie.','View','Tabel','Kolom','Indexen','Indexen aanpassen','Aanpassen','Foreign key aanmaken','Triggers','Trigger aanmaken','Database schema','Exporteren','Uitvoer','Formaat','Procedures','Events','Tabellen','Data','~ %s','bewerk','Gebruiker aanmaken','Fout in query','%.3f s',array('%d rij','%d rijen'),array('Query uitgevoerd, %d rij geraakt.','Query uitgevoerd, %d rijen geraakt.'),'Geen opdrachten uit te voeren.','Uitvoeren','Stoppen bij fout','Bestanden uploaden is uitgeschakeld.','Bestand uploaden','Bestand uitvoeren','Webserver bestand %s','Geschiedenis','Wissen','Item aangepast.','Item toegevoegd.','Toevoegen','Opslaan','Opslaan en verder bewerken','Opslaan, daarna toevoegen','Tabel aangepast.','Tabel aangemaakt.','Tabel aanmaken','Maximum aantal velden bereikt. Verhoog %s en %s.','Tabelnaam','engine','Kolomcommentaar weergeven','Partitioneren op','Partities','Partitie naam','Waarden','Index aangepast.','Index type','Kolom (lengte)','Database aangemaakt.','Database hernoemd.','Database aangepast.','Database aanpassen','Database aanmaken','Uitvoeren',array('Procedure uitgevoerd, %d rij geraakt.','Procedure uitgevoerd, %d rijen geraakt.'),'Foreign key verwijderd.','Foreign key aangepast.','Foreign key aangemaakt.','Bron- en doelkolommen moeten van hetzelfde data type zijn, er moet een index bestaan op de gekozen kolommen en er moet gerelateerde data bestaan.','Foreign key','Doeltabel','Veranderen','Bron','Doel','ON DELETE','ON UPDATE','Kolom toevoegen','View verwijderd.','View aangepast.','View aangemaakt.','View aanmaken','Naam','Event werd verwijderd.','Event werd aangepast.','Event werd aangemaakt.','Event aanpassen','Event aanmaken','Start','Stop','Iedere','Status','Bewaren na voltooiing','Procedure verwijderd.','Procedure aangepast.','Procedure aangemaakt.','Functie aanpassen','Procedure aanpassen','Functie aanmaken','Procedure aanmaken','Return type','Trigger verwijderd.','Trigger aangepast.','Trigger aangemaakt.','Trigger aanpassen','Trigger aanmaken','Time','Event','Gebruiker verwijderd.','Gebruiker aangepast.','Gebruiker aangemaakt.','Gehashed','Routine','Toekennen','Intrekken',array('%d proces gestopt.','%d processen gestopt.'),'Stoppen',array('%d item aangepast.','%d items aangepast.'),array('%d rij werd geïmporteerd.','%d rijen werden geïmporteerd.'),'Onmogelijk tabel te selecteren','Relaties','Pagina','volledig resultaat','Dupliceer','Verwijderen','CSV Import','Importeren','Tabellen werden geleegd.','Tabellen werden verplaatst.','Tabellen werden verwijderd.','Tabellen en views','Engine','Data lengte','Index lengte','Data Vrij','Rijen','.','Analyseer','Optimaliseer','Controleer','Herstel','Legen','Verplaats naar andere database','Verplaats','Schedule','Op aangegeven tijd',array('%d e-mail verzonden.','%d e-mails verzonden.'));break;case"ru":$T=array('Не удалось загрузить файл на сервер.','Максимальный разрешенный размер файла - %sB.','Такого файла не существует.','исходный','Язык','Выбрать','Сервер','Имя пользователя','Пароль','Выбрать данные из таблицы','Структура таблицы','Изменить таблицу','Изменить представление','Новая запись','Редактировать',array('%d байт','%d байта','%d байтов'),'Выбрать','Функции','Агрегация','Поиск','(в любом месте)','Сортировать','по убыванию','Лимит','Длина текста','Действие','SQL запрос','открыть','сохранить','Дамп','Выйти','база данных','В базе данных нет таблиц.','Создать новую таблицу','выбрать','Нет MySQL расширений','Не доступно ни одного расширения из поддерживаемых (%s).','Число','Дата и время','Строки','Двоичный тип','Списки','Недействительный CSRF токен. Отправите форму ещё раз.','Вы успешно покинули систему.','Войти','Неправильное имя пользователя или пароль.','Сессии должны быть включены.','Срок действия сесси истек, нужно снова войти в систему.','База данных','Плохая база данных.','База данных была удалена.','Выбрать базу данных','Создать новую базу данных','Полномочия','Список процессов','Переменные','Версия MySQL: %s с PHP-расширением %s','Вы вошли как: %s','Режим сопоставления','Удалить','Вы уверены?','Нет записей.','Внешние ключи','режим сопоставления','Название поля','Название параметра','Тип','Длина','Действие','Автоматическое приращение','Значения по умолчанию','Комментарий','Добавить еще','Удалить','Переместить вверх','Переместить вниз','Слишком большой объем POST-данных. Пошлите меньший объем данных или увеличьте параметр конфигурационной директивы %s.','Представление','Таблица','Колонка','Индексы','Изменить индексы','Изменить','Добавить внешний ключ','Триггеры','Добавить триггер','Схема базы данных','Експорт','Выходные данные','Формат','Хранимые процедуры и функции','События','Таблицы','Данные','~ %s','редактировать','Создать пользователя','Ошибка в запросe','%.3f s',array('%d строка','%d строки','%d строк'),array('Запрос завершен, изменена %d запись.','Запрос завершен, изменены %d записи.','Запрос завершен, изменено %d записей.'),'Нет команд для выполнения.','Выполнить','Остановить при ошибке','Загрузка файлов на сервер запрещена.','Загрузить файл на сервер','Запустить файл','Файл %s на вебсервере','История','Очистить','Запись обновлена.','Запись вставлена.','Вставить','Сохранить','Сохранить и продолжить редактирование','Сохранить и вставить еще','Таблица была изменена.','Таблица была создана.','Создать таблицу','Достигнуто максимальное значение количества доступных полей. Увеличьте %s и %s.','Название таблицы','тип','Показать комментарии к колонке','Разделить по','Разделы','Название раздела','Параметры','Индексы изменены.','Тип индекса','Колонка (длина)','База данных была создана.','База данных была переименована.','База данных была изменена.','Изменить базу данных','Создать базу данных','Вызвать',array('Была вызвана процедура, %d запись была изменена.','Была вызвана процедура, %d записи было изменено.','Была вызвана процедура, %d записей было изменено.'),'Внешний ключ был удален.','Внешний ключ был изменен.','Внешний ключ был создан.','Колонки должны иметь одинаковые типы данных, в результирующей колонке должен быть индекс, данные для импорта должны существовать.','Внешний ключ','Результирующая таблица','Изменить','Источник','Цель','При стирании','При обновлении','Добавить колонку','Представление было удалено.','Представление было изменено.','Представление было создано.','Создать представление','Название','Событие было удалено.','Событие было изменено.','Событие было создано.','Изменить событие','Создать событие','Начало','Конец','Каждые','Состояние','После завершения сохранить','Процедура была удалена.','Процедура была изменена.','Процедура была создана.','Изменить функцию','Изменить процедуру','Создать функцию','Создать процедуру','Возвращаемый тип','Триггер был удален.','Триггер был изменен.','Триггер был создан.','Изменить триггер','Создать триггер','Время','Событие','Пользователь был удален.','Пользователь был изменен.','Пользователь был создан.','Хешировано','Процедура','Позволить','Запретить',array('Был завершен %d процесс.','Было завершено %d процесса.','Было завершёно %d процессов.'),'Завершить',array('Была изменена %d запись.','Были изменены %d записи.','Было изменено %d записей.'),array('Импортирована %d строка.','Импортировано %d строки.','Импортировано %d строк.'),'Не удалось получить данные из таблицы','Реляции','Страница','весь результат','Клонировать','Стереть','Импорт CSV','Импорт','Таблицы были очищены.','Таблицы были перемещены.','Таблицы были удалены.','Таблицы и представления','Тип','Объём данных','Объём индексов','Свободное место','Строк',' ','Анализировать','Оптимизировать','Проверить','Исправить','Очистить','Переместить в другою базу данных','Переместить','Расписание','В данное время',array('Было отправлено %d письмо.','Было отправлено %d письма.','Было отправлено %d писем.'));break;case"sk":$T=array('Súbor sa nepodarilo nahrať.','Maximálna povolená veľkosť súboru je %sB.','Súbor neexistuje.','originál','Jazyk','Vybrať','Server','Používateľ','Heslo','Vypísať tabuľku','Štruktúra tabuľky','Zmeniť tabuľku','Zmeniť pohľad','Nová položka','Upraviť',array('%d bajt','%d bajty','%d bajtov'),'Vypísať','Funkcie','Agregácia','Vyhľadať','(kdekoľvek)','Zotriediť','zostupne','Limit','Dĺžka textov','Akcia','SQL príkaz','otvoriť','uložiť','Export','Odhlásiť','databáza','Žiadne tabuľky.','Vytvoriť novú tabuľku','vypísať','Žiadne MySQL rozšírenie','Nie je dostupné žiadne z podporovaných rozšírení (%s).','Čísla','Dátum a čas','Reťazce','Binárne','Zoznamy','Neplatný token CSRF. Odošlite formulár znova.','Odhlásenie prebehlo v poriadku.','Prihlásiť sa','Neplatné prihlasovacie údaje.','Session premenné musia byť povolené.','Session vypršala, prihláste sa prosím znova.','Databáza','Nesprávna databáza.','Databáza bola odstránená.','Vybrať databázu','Vytvoriť novú databázu','Oprávnenia','Zoznam procesov','Premenné','Verzia MySQL: %s cez PHP rozšírenie %s','Prihlásený ako: %s','Porovnávanie','Odstrániť','Naozaj?','Žiadne riadky.','Cudzie kľúče','porovnávanie','Názov stĺpca','Názov parametra','Typ','Dĺžka','Voľby','Auto Increment','Východzie hodnoty','Komentár','Pridať ďalší','Odobrať','Presunúť hore','Presunúť dolu','Príliš veľké POST dáta. Zmenšite dáta alebo zvýšte hodnotu konfiguračej direktívy %s.','Pohľad','Tabuľka','Stĺpec','Indexy','Zmeniť indexy','Zmeniť','Pridať cudzí kľúč','Triggery','Pridať trigger','Schéma databázy','Export','Výstup','Formát','Procedúry','Udalosti','Tabuľky','Dáta','~ %s','upraviť','Vytvoriť používateľa','Chyba v dotaze','%.3f s',array('%d riadok','%d riadky','%d riadkov'),array('Príkaz prebehol v poriadku, bol zmenený %d záznam.','Príkaz prebehol v poriadku boli zmenené %d záznamy.','Príkaz prebehol v poriadku bolo zmenených %d záznamov.'),'Žiadne príkazy na vykonanie.','Vykonať','Zastaviť pri chybe','Nahrávánie súborov nie je povolené.','Nahranie súboru','Spustiť súbor','Súbor %s na webovom serveri','História','Vyčistiť','Položka bola aktualizovaná.','Položka bola vložená.','Vložiť','Uložiť','Uložiť a pokračovať v úpravách','Uložiť a vložiť ďalší','Tabuľka bola zmenená.','Tabuľka bola vytvorená.','Vytvoriť tabuľku','Bol prekročený maximálny počet povolených polí. Zvýšte prosím %s a %s.','Názov tabuľky','úložisko','Zobraziť komentáre stĺpcov','Rozdeliť podľa','Oddiely','Názov oddielu','Hodnoty','Indexy boli zmenené.','Typ indexu','Stĺpec (dĺžka)','Databáza bola vytvorená.','Databáza bola premenovaná.','Databáza bola zmenená.','Zmeniť databázu','Vytvoriť databázu','Zavolať',array('Procedúra bola zavolaná, bol zmenený %d záznam.','Procedúra bola zavolaná, boli zmenené %d záznamy.','Procedúra bola zavolaná, bolo zmenených %d záznamov.'),'Cudzí kľúč bol odstránený.','Cudzí kľúč bol zmenený.','Cudzí kľúč bol vytvorený.','Zdrojové a cieľové stĺpce musia mať rovnaký datový typ, nad cieľovými stĺpcami musí byť definovaný index a odkazované dáta musia existovať.','Cudzí kľúč','Cieľová tabuľka','Zmeniť','Zdroj','Cieľ','ON DELETE','ON UPDATE','Pridať stĺpec','Pohľad bol odstránený.','Pohľad bol zmenený.','Pohľad bol vytvorený.','Vytvoriť pohľad','Názov','Udalosť bola odstránená.','Udalosť bola zmenená.','Udalosť bola vytvorená.','Upraviť udalosť','Vytvoriť udalosť','Začiatok','Koniec','Každých','Stav','Po dokončení zachovat','Procedúra bola odstránená.','Procedúra bola zmenená.','Procedúra bola vytvorená.','Zmeniť funkciu','Zmeniť procedúru','Vytvoriť funkciu','Vytvoriť procedúru','Návratový typ','Trigger bol odstránený.','Trigger bol zmenený.','Trigger bol vytvorený.','Zmeniť trigger','Vytvoriť trigger','Čas','Udalosť','Používateľ bol odstránený.','Používateľ bol zmenený.','Používateľ bol vytvorený.','Zahašované','Procedúra','Povoliť','Zakázať',array('Bol ukončený %d proces.','Boli ukončené %d procesy.','Bolo ukončených %d procesov.'),'Ukončiť','%d položiek bolo ovplyvnených.',array('Bol importovaný %d záznam.','Boli importované %d záznamy.','Bolo importovaných %d záznamov.'),'Tabuľku sa nepodarilo vypísať','Vzťahy','Stránka','celý výsledok','Klonovať','Zmazať','Import CSV','Import','Tabuľka bola vyprázdnená','Tabuľka bola presunutá','Tabuľka bola odstránená','Tabuľky a pohľady','Typ','Veľkosť dát','Veľkosť indexu','Voľné miesto','Riadky',' ','Analyzovať','Optimalizovať','Skontrolovať','Opraviť','Vyprázdniť','Presunúť do inej databázy','Presunúť','Plán','V stanovený čas','Editor');break;case"zh-tw":$T=array('無法上傳檔案。','允許的檔案上限大小為%sB','檔案不存在','原始','語言','使用','伺服器','帳號','密碼','選擇資料表','資料表結構','更改資料表','更改檢視表','新建項','編輯','%d byte(s)','選擇','函數','集合','搜尋','(任意位置)','排序','降冪','限定','Text 長度','動作','SQL命令','打開','儲存','導入/導出','登出','資料庫','沒有資料表。','建立新資料表','選擇','沒有 MySQL 擴充模組','沒有任何支援的PHP擴充模組(%s)。','數字','日期時間','字符串','二進制','列表','無效的 CSRF token。請重新發送表單。','登出成功。','登入','無效的憑證。','Session 必須被啟用。','Session 已過期,請重新登入。','資料庫','無效的資料庫。','已丟棄資料庫。','選擇資料庫','建立新資料庫','權限','進程列表','變數','MySQL版本:%s 透過PHP擴充模組 %s','登錄為:%s','校對','丟棄','你確定嗎?','沒有行。','外鍵','校對','列名','參數名稱','類型','長度','選項','自動增加','預設值','註解','新增下一個','移除','上移','下移','POST 資料太大。減少資料或者增加 %s 的設定值。','檢視表','資料表','列','索引','更改索引','更改','新增外鍵','觸發器','建立觸發器','資料庫架構','匯出','輸出','格式','程序','事件','資料表','資料','~ %s','編輯','建立使用者','查詢出錯','%.3f秒','%d行','執行查詢OK,%d行受影響','沒有命令可執行。','執行','出錯時停止','檔案上傳被禁用。','檔案上傳','執行檔案','網頁伺服器檔案 %s','歷史','清除','已更新項目。','已插入項目。','插入','儲存','保存並繼續編輯','儲存並插入下一個','資料表已更改。','資料表已更改。','建立資料表表','超過最多允許的字段數量。請增加%s和%s 。','資料表名稱','引擎','顯示列註解','分區類型','分區','分區名','值','已更改索引。','索引類型','列(長度)','已建立資料庫。','已重新命名資料庫。','已更改資料庫。','更改資料庫','建立資料庫','呼叫','程序已被執行,%d行被影響','已刪除外鍵。','已更改外鍵。','已建立外鍵。','源列和目標列必須具有相同的數據類型,在目標列上必須有一個索引並且引用的數據必須存在。','外鍵','目標資料表','更改','來源','目標','ON DELETE','ON UPDATE','新增資料列','已丟棄檢視表。','已更改檢視表。','已建立檢視表。','建立檢視表','名稱','已丟棄事件。','已更改事件。','已建立事件。','更改事件','建立事件','開始','結束','每','狀態','在完成後保存','已丟棄程序。','已更改子程序。','已建立子程序。','更改函數','更改過程','建立函數','建立預存程序','返回類型','已丟棄觸發器。','已更改觸發器。','已建立觸發器。','更改觸發器','建立觸發器','時間','事件','已丟棄使用者。','已更改使用者。','已建立使用者。','Hashed','程序','授權','廢除','%d 個 Process(es) 被終止','終止','%d個項目受到影響。','%d行已導入。','無法選擇該資料表','關聯','頁','所有結果','複製','刪除','匯入 CSV','匯入','已清空資料表。','已轉移資料表。','已丟棄表。','資料表和檢視表','引擎','資料長度','索引長度','資料空閒','行數',',','分析','優化','檢查','修復','清空','轉移到其它資料庫','轉移','調度','在指定時間','已發送 %d 封郵件。');break;case"zh":$T=array('不能上传文件。','最多允许的文件大小为 %sB','文件不存在','原始','语言','使用','服务器','用户名','密码','选择表','表结构','更改表','更改视图','新建项','编辑','%d 字节','选择','函数','集合','搜索','(任意位置)','排序','降序','限定','文本长度','动作','SQL命令','打开','保存','导入/导出','注销','数据库','没有表。','创建新表','选择','没有MySQL扩展','没有支持的 PHP 扩展可用(%s)。','数字','日期时间','字符串','二进制','列表','无效 CSRF 令牌。重新发送表单。','注销成功。','登录','无效凭据。','会话必须被启用。','会话已过期,请重新登录。','数据库','无效数据库。','已丢弃数据库。','选择数据库','创建新数据库','权限','进程列表','变量','MySQL 版本:%s 通过 PHP 扩展 %s','登录为:%s','校对','丢弃','你确定吗?','没有行。','外键','校对','列名','参数名','类型','长度','选项','自动增量','默认值','注释','添加下一个','移除','上移','下移','太大的 POST 数据。减少数据或者增加 %s 配置命令。','视图','表','列','索引','更改索引','更改','添加外键','触发器','创建触发器','数据库概要','导出','输出','格式','子程序','事件','表','数据','~ %s','编辑','创建用户','查询出错','%.3f 秒','%d 行','执行查询OK,%d 行受影响','没有命令执行。','执行','出错时停止','文件上传被禁用。','文件上传','运行文件','Web服务器文件 %s','历史','清除','已更新项目。','已插入项目。','插入','保存','保存并继续编辑','保存并插入下一个','已更改表。','已创建表。','创建表','超过最多允许的字段数量。请增加 %s 和 %s 。','表名','引擎','显示列注释','分区类型','分区','分区名','值','已更改索引。','索引类型','列(长度)','已创建数据库。','已重命名数据库。','已更改数据库。','更改数据库','创建数据库','调用','子程序被调用,%d 行被影响','已删除外键。','已更改外键。','已创建外键。','源列和目标列必须具有相同的数据类型,在目标列上必须有一个索引并且引用的数据必须存在。','外键','目标表','更改','源','目标','ON DELETE','ON UPDATE','增加列','已丢弃视图。','已更改视图。','已创建视图。','创建视图','名称','已丢弃事件。','已更改事件。','已创建事件。','更改事件','创建事件','开始','结束','每','状态','完成后保存','已丢弃子程序。','已更改子程序。','已创建子程序。','更改函数','更改过程','创建函数','创建过程','返回类型','已丢弃触发器。','已更改触发器。','已创建触发器。','更改触发器','创建触发器','时间','事件','已丢弃用户。','已更改用户。','已创建用户。','Hashed','子程序','授权','废除','%d 个进程被终止','终止','%d 个项目受到影响。','%d 行已导入。','不能选择该表','关联信息','页面','所有结果','克隆','删除','CSV 导入','导入','已清空表。','已转移表。','已丢弃表。','表和视图','引擎','数据长度','索引长度','数据空闲','行数',',','分析','优化','检查','修复','清空','转移到其它数据库','转移','调度','在指定时间','%d 封邮件已发送。');break;}class
Adminer{var$functions=array("char_length","from_unixtime","hex","lower","round","sec_to_time","time_to_sec","unix_timestamp","upper");var$grouping=array("avg","count","count distinct","group_concat","max","min","sum");var$operators=array("=","<",">","<=",">=","!=","LIKE","REGEXP","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL");function
name(){return"Adminer";}function
credentials(){return
array($_GET["server"],$_SESSION["usernames"][$_GET["server"]],$_SESSION["passwords"][$_GET["server"]]);}function
database(){return
DB;}function
loginForm($B){echo'<table cellspacing="0">
<tr><th>',lang(6),'<td><input name="server" value="',h($_GET["server"]),'">
<tr><th>',lang(7),'<td><input name="username" value="',h($B),'">
<tr><th>',lang(8),'<td><input type="password" name="password">
</table>
';}function
login($oe,$va){return
true;}function
tableName($Ub){return
h($Ub["Name"]);}function
fieldName($c,$_a=0){return'<span title="'.h($c["full_type"]).'">'.h($c["field"]).'</span>';}function
selectLinks($Ub,$u=""){echo'<p class="tabs">';$ra=array("select"=>lang(9),"table"=>lang(10));if(isset($Ub["Rows"])){$ra["create"]=lang(11);}else{$ra["view"]=lang(12);}if(isset($u)){$ra["edit"]=lang(13);}foreach($ra
as$e=>$b){echo" <a href='".h(ME)."$e=".urlencode($Ub["Name"]).($e=="edit"?$u:"")."'>".bold($b,isset($_GET[$e]))."</a>";}echo"\n";}function
backwardKeys($p,$qe){return
array();}function
backwardKeysPrint($re,$a){}function
selectQuery($m){return"<p><code class='jush-sql'>".h($m)."</code> <a href='".h(ME)."sql=".urlencode($m)."'>".lang(14)."</a></p>\n";}function
rowDescription($p){return"";}function
rowDescriptions($Ba,$je){return$Ba;}function
selectVal($b,$z,$c){$g=($b!="<i>NULL</i>"&&$c["type"]=="char"?"<code>$b</code>":$b);if(ereg('blob|binary',$c["type"])&&!is_utf8($b)){$g=lang(15,strlen($b));}return($z?"<a href='$z'>$g</a>":$g);}function
editVal($b,$c){return$b;}function
selectColumnsPrint($t,$s){print_fieldset("select",lang(16),$t);$h=0;$od=array(lang(17)=>$this->functions,lang(18)=>$this->grouping);foreach($t
as$e=>$b){$b=$_GET["columns"][$e];echo"<div>".html_select("columns[$h][fun]",array(-1=>"")+$od,$b["fun"]),"<select name='columns[$h][col]'><option>".optionlist($s,$b["col"],true)."</select></div>\n";$h++;}echo"<div>".html_select("columns[$h][fun]",array(-1=>"")+$od,"","this.nextSibling.onchange();"),"<select name='columns[$h][col]' onchange='select_add_row(this);'><option>".optionlist($s,null,true)."</select></div>\n","</div></fieldset>\n";}function
selectSearchPrint($C,$s,$v){print_fieldset("search",lang(19),$C);foreach($v
as$h=>$r){if($r["type"]=="FULLTEXT"){echo"(<i>".implode("</i>, <i>",array_map('h',$r["columns"]))."</i>) AGAINST"," <input name='fulltext[$h]' value='".h($_GET["fulltext"][$h])."'>",checkbox("boolean[$h]",1,isset($_GET["boolean"][$h]),"BOOL"),"<br>\n";}}$h=0;foreach((array)$_GET["where"]as$b){if(strlen("$b[col]$b[val]")&&in_array($b["op"],$this->operators)){echo"<div><select name='where[$h][col]'><option value=''>".lang(20).optionlist($s,$b["col"],true)."</select>",html_select("where[$h][op]",$this->operators,$b["op"]),"<input name='where[$h][val]' value='".h($b["val"])."'></div>\n";$h++;}}echo"<div><select name='where[$h][col]' onchange='select_add_row(this);'><option value=''>".lang(20).optionlist($s,null,true)."</select>",html_select("where[$h][op]",$this->operators),"<input name='where[$h][val]'></div>\n","</div></fieldset>\n";}function
selectOrderPrint($_a,$s,$v){print_fieldset("sort",lang(21),$_a);$h=0;foreach((array)$_GET["order"]as$e=>$b){if(isset($s[$b])){echo"<div><select name='order[$h]'><option>".optionlist($s,$b,true)."</select>",checkbox("desc[$h]",1,isset($_GET["desc"][$e]),lang(22))."</div>\n";$h++;}}echo"<div><select name='order[$h]' onchange='select_add_row(this);'><option>".optionlist($s,null,true)."</select>",checkbox("desc[$h]",1,0,lang(22))."</div>\n","</div></fieldset>\n";}function
selectLimitPrint($Z){echo"<fieldset><legend>".lang(23)."</legend><div>";echo"<input name='limit' size='3' value='".h($Z)."'>","</div></fieldset>\n";}function
selectLengthPrint($Ga){if(isset($Ga)){echo"<fieldset><legend>".lang(24)."</legend><div>",'<input name="text_length" size="3" value="'.h($Ga).'">',"</div></fieldset>\n";}}function
selectActionPrint(){echo"<fieldset><legend>".lang(25)."</legend><div>","<input type='submit' value='".lang(16)."'>","</div></fieldset>\n";}function
selectEmailPrint($se,$s){}function
selectColumnsProcess($s,$v){$t=array();$V=array();foreach((array)$_GET["columns"]as$e=>$b){if($b["fun"]=="count"||(isset($s[$b["col"]])&&(!$b["fun"]||in_array($b["fun"],$this->functions)||in_array($b["fun"],$this->grouping)))){$t[$e]=apply_sql_function($b["fun"],(isset($s[$b["col"]])?idf_escape($b["col"]):"*"));if(!in_array($b["fun"],$this->grouping)){$V[]=$t[$e];}}}return
array($t,$V);}function
selectSearchProcess($l,$v){global$d;$g=array();foreach($v
as$h=>$r){if($r["type"]=="FULLTEXT"&&strlen($_GET["fulltext"][$h])){$g[]="MATCH (".implode(", ",array_map('idf_escape',$r["columns"])).") AGAINST (".$d->quote($_GET["fulltext"][$h]).(isset($_GET["boolean"][$h])?" IN BOOLEAN MODE":"").")";}}foreach((array)$_GET["where"]as$b){if(strlen("$b[col]$b[val]")&&in_array($b["op"],$this->operators)){$Ma=process_length($b["val"]);$Ac=" $b[op]".(ereg('NULL$',$b["op"])?"":(ereg('IN$',$b["op"])?" (".(strlen($Ma)?$Ma:"NULL").")":" ".$this->processInput($l[$b["col"]],$b["val"])));if(strlen($b["col"])){$g[]=idf_escape($b["col"]).$Ac;}else{$Ha=array();foreach($l
as$j=>$c){if(is_numeric($b["val"])||!ereg('int|float|double|decimal',$c["type"])){$Ha[]=$j;}}$g[]=($Ha?"(".implode("$Ac OR ",array_map('idf_escape',$Ha))."$Ac)":"0");}}}return$g;}function
selectOrderProcess($l,$v){$g=array();foreach((array)$_GET["order"]as$e=>$b){if(isset($l[$b])||preg_match('~^((COUNT\\(DISTINCT |[A-Z0-9_]+\\()`(?:[^`]|``)+`\\)|COUNT\\(\\*\\))$~',$b)){$g[]=idf_escape($b).(isset($_GET["desc"][$e])?" DESC":"");}}return$g;}function
selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"30");}function
selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
selectEmailProcess($C,$je){return
false;}function
messageQuery($m){restart_session();$N="sql-".count($_SESSION["messages"]);$_SESSION["history"][$_GET["server"]][DB][]=$m;return" <a href='#$N' onclick=\"return !toggle('$N');\">".lang(26)."</a><div id='$N' class='hidden'><pre class='jush-sql'>".shorten_utf8($m,1000).'</pre><a href="'.h(ME.'sql=&history='.(count($_SESSION["history"][$_GET["server"]][DB])-1)).'">'.lang(14).'</a></div>';}function
editFunctions($c){$g=array("");if(ereg('char|date|time',$c["type"])){$g=(ereg('char',$c["type"])?array("","md5","sha1","password","uuid"):array("","now"));}if(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET))){if(ereg('int|float|double|decimal',$c["type"])){$g=array("","+","-");}if(ereg('date',$c["type"])){$g[]="+ interval";$g[]="- interval";}if(ereg('time',$c["type"])){$g[]="addtime";$g[]="subtime";}if(ereg('char|text',$c["type"])){$g[]="concat";}}if($c["null"]){array_unshift($g,"NULL");}return$g;}function
editInput($p,$c,$bb,$o){if($c["type"]=="enum"){return($c["null"]?"<label><input type='radio'$bb value=''".(isset($o)||isset($_GET["select"])?"":" checked")."><em>NULL</em></label> ":"")."<input type='radio'$bb value='0'".($o===0?" checked":"").">";}return"";}function
processInput($c,$o,$x=""){global$d;$j=$c["field"];$g=$d->quote($o);if(ereg('^(now|uuid)$',$x)){$g="$x()";}elseif(ereg('^[+-]$',$x)){$g=idf_escape($j)." $x $g";}elseif(ereg('^[+-] interval$',$x)){$g=idf_escape($j)." $x ".(preg_match("~^([0-9]+|'[0-9.: -]') [A-Z_]+$~i",$o)?$o:$g);}elseif(ereg('^(addtime|subtime|concat)$',$x)){$g="$x(".idf_escape($j).", $g)";}elseif(ereg('^(md5|sha1|password)$',$x)){$g="$x($g)";}return$g;}function
dumpOutput($t){$g=array('text'=>lang(27),'file'=>lang(28));if(function_exists('gzencode')){$g['gz']='gzip';}if(function_exists('bzcompress')){$g['bz2']='bzip2';}return
html_select("output",$g,"text",$t);}function
dumpFormat($t){return
html_select("format",array('sql'=>'SQL','csv'=>'CSV'),"sql",$t);}function
navigation($Qb){global$db,$d;echo'<h1>
<a href="http://www.adminer.org/" id="h1">',$this->name(),'</a>
<span class="version">',$db,'</span>
<a href="http://www.adminer.org/#download" id="version">',(version_compare($db,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
</h1>
';if($Qb!="auth"){$U=get_databases();echo'<form action="" method="post">
<p class="logout">
<a href="',h(ME),'sql=">',bold(lang(26),isset($_GET["sql"])),'</a>
<a href="',h(ME),'dump=',urlencode(isset($_GET["table"])?$_GET["table"]:$_GET["select"]),'">',bold(lang(29),isset($_GET["dump"])),'</a>
<input type="hidden" name="token" value="',$_SESSION["tokens"][$_GET["server"]],'">
<input type="submit" name="logout" value="',lang(30),'">
</p>
</form>
<form action="">
<p>
';if(SID){echo'<input type="hidden" name="',session_name(),'" value="',h(session_id()),'">';}if(strlen($_GET["server"])){echo'<input type="hidden" name="server" value="',h($_GET["server"]),'">';}echo($U?html_select("db",array(""=>"(".lang(31).")")+$U,DB,"this.form.submit();"):'<input name="db" value="'.h(DB).'">');if(isset($_GET["sql"])){echo'<input type="hidden" name="sql" value="">';}if(isset($_GET["schema"])){echo'<input type="hidden" name="schema" value="">';}if(isset($_GET["dump"])){echo'<input type="hidden" name="dump" value="">';}echo' <input type="submit" value="',lang(5),'"',($U?" class='hidden'":""),'>
</p>
</form>
';if($Qb!="db"&&strlen(DB)&&$d->select_db(DB)){$Ib=tables_list();if(!$Ib){echo"<p class='message'>".lang(32)."\n";}else{$this->tablesPrint($Ib);}echo'<p><a href="'.h(ME).'create=">'.bold(lang(33),$_GET["create"]==="")."</a>\n";}}}function
tablesPrint($Ib){echo"<p id='tables'>\n";foreach($Ib
as$p){echo'<a href="'.h(ME).'select='.urlencode($p).'">'.bold(lang(34),$_GET["select"]==$p).'</a> ','<a href="'.h(ME).'table='.urlencode($p).'">'.bold($this->tableName(array("Name"=>$p)),$_GET["table"]==$p)."</a><br>\n";}}}$q=(function_exists('adminer_object')?adminer_object():new
Adminer);function
page_header($md,$n="",$qc=array(),$pd=""){global$ia,$db,$q;header("Content-Type: text/html; charset=utf-8");header("X-Frame-Options: deny");$qd=$md.(strlen($pd)?": ".h($pd):"");echo'<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html lang="',$ia,'">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Script-Type" content="text/javascript">
<meta name="robots" content="noindex">
<title>',$qd.(strlen($_GET["server"])&&$_GET["server"]!="localhost"?h("- $_GET[server]"):"")." - ".$q->name(),'</title>
<link rel="shortcut icon" type="image/x-icon" href="',h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=favicon.ico&amp;version=2.2.1",'">
<link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=default.css&amp;version=2.2.1";echo'">
';if(file_exists("adminer.css")){echo'<link rel="stylesheet" type="text/css" href="adminer.css">
';}echo'
<body onload="body_load();',(isset($_COOKIE["adminer_version"])?"":" verify_version();"),'">
<script type="text/javascript" src="',h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=functions.js&amp;version=2.2.1",'"></script>

<div id="content">
';if(isset($qc)){$z=substr(preg_replace('~db=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.(strlen($z)?h($z):".").'">'.(isset($_GET["server"])?h($_GET["server"]):lang(6)).'</a> &raquo; ';if(is_array($qc)){if(strlen(DB)){echo'<a href="'.h(substr(ME,0,-1)).'">'.h(DB).'</a> &raquo; ';}foreach($qc
as$e=>$b){$ub=(is_array($b)?$b[1]:$b);if(strlen($ub)){echo'<a href="'.h(ME."$e=").urlencode(is_array($b)?$b[0]:$b).'">'.h($ub).'</a> &raquo; ';}}}echo"$md\n";}echo"<h2>$qd</h2>\n";restart_session();if($_SESSION["messages"]){echo"<div class='message'>".implode("</div>\n<div class='message'>",$_SESSION["messages"])."</div>\n";$_SESSION["messages"]=array();}if(!$_POST&&!isset($_SESSION["passwords"])){$_SESSION["passwords"]=array();}$U=&$_SESSION["databases"][$_GET["server"]];if(strlen(DB)&&$U&&!in_array(DB,$U,true)){$U=null;}if($n){echo"<div class='error'>$n</div>\n";}}function
page_footer($Qb=false){global$q;echo'</div>

';switch_lang();echo'<div id="menu">
';$q->navigation($Qb);echo'</div>
';}if(extension_loaded('pdo')){class
Min_PDO
extends
PDO{var$_result,$server_info,$affected_rows,$error;function
__construct(){}function
dsn($ke,$B,$va){set_exception_handler('auth_error');parent::__construct($ke,$B,$va);restore_exception_handler();$this->setAttribute(13,array('Min_PDOStatement'));}function
select_db($tc){return$this->query("USE ".idf_escape($tc));}function
query($m,$ob=false){$f=parent::query($m);if(!$f){$me=$this->errorInfo();$this->error=$me[2];return
false;}$this->_result=$f;if(!$f->columnCount()){$this->affected_rows=$f->rowCount();return
true;}$f->num_rows=$f->rowCount();return$f;}function
multi_query($m){return$this->query($m);}function
store_result(){return($this->_result->columnCount()?$this->_result:true);}function
next_result(){return$this->_result->nextRowset();}function
result($f,$c=0){if(!$f){return
false;}$a=$f->fetch();return$a[$c];}}class
Min_PDOStatement
extends
PDOStatement{var$_offset=0,$num_rows;function
fetch_assoc(){return$this->fetch(2);}function
fetch_row(){return$this->fetch(3);}function
fetch_field(){$a=(object)$this->getColumnMeta($this->_offset++);$a->orgtable=$a->table;$a->orgname=$a->name;$a->charsetnr=(in_array("blob",$a->flags)?63:0);return$a;}}}if(extension_loaded("mysqli")){class
Min_DB
extends
MySQLi{var$extension="MySQLi";function
Min_DB(){parent::init();}function
connect($ka,$B,$va){list($ge,$Pb)=explode(":",$ka,2);return@$this->real_connect((strlen($ka)?$ge:ini_get("mysqli.default_host")),(strlen("$ka$B")?$B:ini_get("mysqli.default_user")),(strlen("$ka$B$va")?$va:ini_get("mysqli.default_pw")),null,(is_numeric($Pb)?$Pb:ini_get("mysqli.default_port")),(!is_numeric($Pb)?$Pb:null));}function
result($f,$c=0){if(!$f){return
false;}$a=$f->fetch_array();return$a[$c];}function
quote($K){return"'".$this->escape_string($K)."'";}}}elseif(extension_loaded("mysql")){class
Min_DB{var$extension="MySQL",$_link,$_result,$server_info,$affected_rows,$error;function
connect($ka,$B,$va){$this->_link=@mysql_connect((strlen($ka)?$ka:ini_get("mysql.default_host")),(strlen("$ka$B")?$B:ini_get("mysql.default_user")),(strlen("$ka$B$va")?$va:ini_get("mysql.default_password")),true,131072);if($this->_link){$this->server_info=mysql_get_server_info($this->_link);}else{$this->error=mysql_error();}return(bool)$this->_link;}function
quote($K){return"'".mysql_real_escape_string($K,$this->_link)."'";}function
select_db($tc){return
mysql_select_db($tc,$this->_link);}function
query($m,$ob=false){$f=@($ob?mysql_unbuffered_query($m,$this->_link):mysql_query($m,$this->_link));if(!$f){$this->error=mysql_error($this->_link);return
false;}elseif($f===true){$this->affected_rows=mysql_affected_rows($this->_link);return
true;}return
new
Min_Result($f);}function
multi_query($m){return$this->_result=$this->query($m);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
result($f,$c=0){if(!$f){return
false;}return
mysql_result($f->_result,0,$c);}}class
Min_Result{var$_result,$_offset=0,$num_rows;function
Min_Result($f){$this->_result=$f;$this->num_rows=mysql_num_rows($f);}function
fetch_assoc(){return
mysql_fetch_assoc($this->_result);}function
fetch_row(){return
mysql_fetch_row($this->_result);}function
fetch_field(){$a=mysql_fetch_field($this->_result,$this->_offset++);$a->orgtable=$a->table;$a->orgname=$a->name;$a->charsetnr=($a->blob?63:0);return$a;}function
__destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
Min_DB
extends
Min_PDO{var$extension="PDO_MySQL";function
connect($ka,$B,$va){$this->dsn("mysql:host=".str_replace(":",";unix_socket=",preg_replace('~:([0-9])~',';port=\\1',$ka)),$B,$va);$this->server_info=$this->result($this->query("SELECT VERSION()"));return
true;}function
query($m,$ob=false){$this->setAttribute(1000,!$ob);return
parent::query($m,$ob);}}}else{page_header(lang(35),lang(36,'MySQLi, MySQL, PDO_MySQL'),null);page_footer("auth");exit;}function
connect(){global$q;$d=new
Min_DB;$wc=$q->credentials();if($d->connect($wc[0],$wc[1],$wc[2])){$d->query("SET SQL_QUOTE_SHOW_CREATE=1");$d->query("SET NAMES utf8");return$d;}return$d->error;}function
get_databases($Zd=true){$g=&$_SESSION["databases"][$_GET["server"]];if(!isset($g)){restart_session();$g=get_vals("SHOW DATABASES");if($Zd){ob_flush();flush();}}return$g;}function
db_collation($w,$H){global$d;$g=null;$f=$d->query("SHOW CREATE DATABASE ".idf_escape($w));if($f){$S=$d->result($f,1);if(preg_match('~ COLLATE ([^ ]+)~',$S,$k)){$g=$k[1];}elseif(preg_match('~ CHARACTER SET ([^ ]+)~',$S,$k)){$g=$H[$k[1]][0];}}return$g;}function
engines(){global$d;$g=array();$f=$d->query("SHOW ENGINES");while($a=$f->fetch_assoc()){if(ereg("YES|DEFAULT",$a["Support"])){$g[]=$a["Engine"];}}return$g;}function
tables_list(){return
get_vals("SHOW TABLES");}function
table_status($j=""){global$d;$g=array();$f=$d->query("SHOW TABLE STATUS".(strlen($j)?" LIKE ".$d->quote(addcslashes($j,"%_")):""));while($a=$f->fetch_assoc()){if($a["Engine"]=="InnoDB"){$a["Comment"]=preg_replace('~(?:(.+); )?InnoDB free: .*~','\\1',$a["Comment"]);}$g[$a["Name"]]=$a;}return(strlen($j)?$g[$j]:$g);}function
table_status_referencable(){$g=array();foreach(table_status()as$j=>$a){if($a["Engine"]=="InnoDB"){$g[$j]=$a;}}return$g;}function
fields($p){global$d;$g=array();$f=$d->query("SHOW FULL COLUMNS FROM ".idf_escape($p));if($f){while($a=$f->fetch_assoc()){preg_match('~^([^( ]+)(?:\\((.+)\\))?( unsigned)?( zerofill)?$~',$a["Type"],$k);$g[$a["Field"]]=array("field"=>$a["Field"],"full_type"=>$a["Type"],"type"=>$k[1],"length"=>$k[2],"unsigned"=>ltrim($k[3].$k[4]),"default"=>(strlen($a["Default"])||ereg("char",$k[1])?$a["Default"]:null),"null"=>($a["Null"]=="YES"),"auto_increment"=>($a["Extra"]=="auto_increment"),"on_update"=>(eregi('^on update (.+)',$a["Extra"],$k)?$k[1]:""),"collation"=>$a["Collation"],"privileges"=>array_flip(explode(",",$a["Privileges"])),"comment"=>$a["Comment"],"primary"=>($a["Key"]=="PRI"),);}}return$g;}function
indexes($p,$ca=null){global$d;if(!is_object($ca)){$ca=$d;}$g=array();$f=$ca->query("SHOW INDEX FROM ".idf_escape($p));if($f){while($a=$f->fetch_assoc()){$g[$a["Key_name"]]["type"]=($a["Key_name"]=="PRIMARY"?"PRIMARY":($a["Index_type"]=="FULLTEXT"?"FULLTEXT":($a["Non_unique"]?"INDEX":"UNIQUE")));$g[$a["Key_name"]]["columns"][$a["Seq_in_index"]]=$a["Column_name"];$g[$a["Key_name"]]["lengths"][$a["Seq_in_index"]]=$a["Sub_part"];}}return$g;}function
foreign_keys($p){global$d,$La;static$ua='(?:[^`]|``)+';$g=array();$f=$d->query("SHOW CREATE TABLE ".idf_escape($p));if($f){$Yd=$d->result($f,1);preg_match_all("~CONSTRAINT `($ua)` FOREIGN KEY \\(((?:`$ua`,? ?)+)\\) REFERENCES `($ua)`(?:\\.`($ua)`)? \\(((?:`$ua`,? ?)+)\\)(?: ON DELETE (".implode("|",$La)."))?(?: ON UPDATE (".implode("|",$La)."))?~",$Yd,$F,PREG_SET_ORDER);foreach($F
as$k){preg_match_all("~`($ua)`~",$k[2],$Q);preg_match_all("~`($ua)`~",$k[5],$Ja);$g[$k[1]]=array("db"=>idf_unescape(strlen($k[4])?$k[3]:$k[4]),"table"=>idf_unescape(strlen($k[4])?$k[4]:$k[3]),"source"=>array_map('idf_unescape',$Q[1]),"target"=>array_map('idf_unescape',$Ja[1]),"on_delete"=>$k[6],"on_update"=>$k[7],);}}return$g;}function
view($j){global$d;return
array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)* AS ~U','',$d->result($d->query("SHOW CREATE VIEW ".idf_escape($j)),1)));}function
collations(){global$d;$g=array();$f=$d->query("SHOW COLLATION");while($a=$f->fetch_assoc()){$g[$a["Charset"]][]=$a["Collation"];}ksort($g);foreach($g
as$e=>$b){sort($g[$e]);}return$g;}function
information_schema($w){global$d;return($d->server_info>=5&&$w=="information_schema");}function
exact_value($b){global$d;return"BINARY ".$d->quote($b);}$oa=array();$_c=array();foreach(array(lang(37)=>array("tinyint"=>3,"smallint"=>5,"mediumint"=>8,"int"=>10,"bigint"=>20,"float"=>12,"double"=>21,"decimal"=>66),lang(38)=>array("date"=>10,"datetime"=>19,"timestamp"=>19,"time"=>10,"year"=>4),lang(39)=>array("char"=>255,"varchar"=>65535,"tinytext"=>255,"text"=>65535,"mediumtext"=>16777215,"longtext"=>4294967295),lang(40)=>array("binary"=>255,"varbinary"=>65535,"tinyblob"=>255,"blob"=>65535,"mediumblob"=>16777215,"longblob"=>4294967295),lang(41)=>array("enum"=>65535,"set"=>64),)as$e=>$b){$oa+=$b;$_c[$e]=array_keys($b);}$pb=array("unsigned","zerofill","unsigned zerofill");if(isset($_POST["server"])){session_regenerate_id();$_SESSION["usernames"][$_POST["server"]]=$_POST["username"];$_SESSION["passwords"][$_POST["server"]]=$_POST["password"];if(count($_POST)==3){$A=((string)$_GET["server"]===$_POST["server"]?remove_from_uri():preg_replace('~^([^?]*).*~','\\1',$_SERVER["REQUEST_URI"]).(strlen($_POST["server"])?'?server='.urlencode($_POST["server"]):''));if(!isset($_COOKIE[session_name()])){$A.=(strpos($A,"?")===false?"?":"&").SID;}redirect($A);}$_GET["server"]=$_POST["server"];}elseif(isset($_POST["logout"])){$_=$_SESSION["tokens"][$_GET["server"]];if($_&&$_POST["token"]!=$_){page_header(lang(30),lang(42));page_footer("db");exit;}else{foreach(array("usernames","passwords","databases","tokens","history")as$b){unset($_SESSION[$b][$_GET["server"]]);}if(!isset($_SESSION["passwords"])){$_SESSION["passwords"]=array();}redirect(substr(ME,0,-1),lang(43));}}function
auth_error($cd=null){global$d,$q;$Rb=session_name();$B=$_SESSION["usernames"][$_GET["server"]];unset($_SESSION["usernames"][$_GET["server"]]);page_header(lang(44),(isset($B)?h($cd?$cd->getMessage():(is_string($d)?$d:lang(45))):(!$_COOKIE[$Rb]&&$_GET[$Rb]&&ini_get("session.use_only_cookies")?lang(46):(($_COOKIE[$Rb]||$_GET[$Rb])&&!isset($_SESSION["passwords"])?lang(47):""))),null);echo"<form action='' method='post'>\n";$q->loginForm($B);echo"<p>\n";hidden_fields($_POST,array("server","username","password"));echo"<input type='submit' value='".lang(44)."'>\n</form>\n";page_footer("auth");}$B=&$_SESSION["usernames"][$_GET["server"]];if(!isset($B)){$B=$_GET["username"];}$d=(isset($B)?connect():'');if(is_string($d)||!$q->login($B,$_SESSION["passwords"][$_GET["server"]])){auth_error();exit;}unset($B);if(!$_SESSION["tokens"][$_GET["server"]]){$_SESSION["tokens"][$_GET["server"]]=rand(1,1e6);}function
connect_error(){global$d,$db,$_,$n;if(strlen(DB)){page_header(lang(48).": ".h(DB),lang(49),false);}else{if($_POST["db"]&&!$n){unset($_SESSION["databases"][$_GET["server"]]);foreach($_POST["db"]as$w){if(!queries("DROP DATABASE ".idf_escape($w))){break;}}queries_redirect(substr(ME,0,-1),lang(50),!$d->error);}page_header(lang(51),"",null);echo"<p>";foreach(array('database'=>lang(52),'privileges'=>lang(53),'processlist'=>lang(54),'variables'=>lang(55),)as$e=>$b){echo"<a href='".h(ME)."$e='>$b</a>\n";}echo"<p>".lang(56,"<b".($d->server_info<4.1?" class='binary'":"").">$d->server_info</b>","<b>$d->extension</b>")."\n","<p>".lang(57,"<b>".h($d->result($d->query("SELECT USER()")))."</b>")."\n";$U=get_databases();if($U){$H=collations();echo"<form action='' method='post'>\n","<table cellspacing='0' onclick='table_click(event);'>\n","<thead><tr><td><input type='hidden' name='token' value='$_'>&nbsp;<th>".lang(48)."<td>".lang(58)."</thead>\n";foreach($U
as$w){$fd=h(ME)."db=".urlencode($w);echo"<tr".odd()."><td>".checkbox("db[]",$w,false),"<th><a href='$fd'>".h($w)."</a>","<td><a href='$fd&amp;database='>".nbsp(db_collation($w,$H))."</a>","\n";}echo"</table>\n","<p><input type='submit' name='drop' value='".lang(59)."' onclick=\"return confirm('".lang(60)." (' + form_checked(this, /db/) + ')');\">\n","</form>\n";}}page_footer("db");}if(!(strlen(DB)?$d->select_db(DB):isset($_GET["sql"])||isset($_GET["dump"])||isset($_GET["database"])||isset($_GET["processlist"])||isset($_GET["privileges"])||isset($_GET["user"])||isset($_GET["variables"]))){if(strlen(DB)){unset($_SESSION["databases"][$_GET["server"]]);}connect_error();exit;}function
select($f,$ca=null){if(!$f->num_rows){echo"<p class='message'>".lang(61)."\n";}else{echo"<table cellspacing='0' class='nowrap'>\n";$ra=array();$v=array();$s=array();$bd=array();$oa=array();odd('');for($h=0;$a=$f->fetch_row();$h++){if(!$h){echo"<thead><tr>";for($I=0;$I<count($a);$I++){$c=$f->fetch_field();if(strlen($c->orgtable)){if(!isset($v[$c->orgtable])){$v[$c->orgtable]=array();foreach(indexes($c->orgtable,$ca)as$r){if($r["type"]=="PRIMARY"){$v[$c->orgtable]=array_flip($r["columns"]);break;}}$s[$c->orgtable]=$v[$c->orgtable];}if(isset($s[$c->orgtable][$c->orgname])){unset($s[$c->orgtable][$c->orgname]);$v[$c->orgtable][$c->orgname]=$I;$ra[$I]=$c->orgtable;}}if($c->charsetnr==63){$bd[$I]=true;}$oa[$I]=$c->type;echo"<th>".h($c->name);}echo"</thead>\n";}echo"<tr".odd().">";foreach($a
as$e=>$b){if(!isset($b)){$b="<i>NULL</i>";}else{if($bd[$e]&&!is_utf8($b)){$b="<i>".lang(15,strlen($b))."</i>";}elseif(!strlen($b)){$b="&nbsp;";}else{$b=h($b);if($oa[$e]==254){$b="<code>$b</code>";}}if(isset($ra[$e])&&!$s[$ra[$e]]){$z="edit=".urlencode($ra[$e]);foreach($v[$ra[$e]]as$Ab=>$I){$z.="&where".urlencode("[".bracket_escape($Ab)."]")."=".urlencode($a[$I]);}$b="<a href='".h(ME.$z)."'>$b</a>";}}echo"<td>$b";}}echo"</table>\n";}}function
referencable_primary($Xd){$g=array();foreach(table_status_referencable()as$O=>$p){if($O!=$Xd){foreach(fields($O)as$c){if($c["primary"]){if($g[$O]){unset($g[$O]);break;}$g[$O]=$c;}}}}return$g;}function
edit_type($e,$c,$H,$D=array()){global$_c,$pb,$Sa;echo'<td><select name="',$e,'[type]" class="type" onchange="editing_type_change(this);">',optionlist($_c+($D?array(lang(62)=>$D):array()),$c["type"]),'</select>
<td><input name="',$e,'[length]" value="',h($c["length"]),'" size="3" onfocus="editing_length_focus(this);">
<td>',"<select name='$e"."[collation]'".(ereg('(char|text|enum|set)$',$c["type"])?"":" class='hidden'").'><option value="">('.lang(63).')'.optionlist($H,$c["collation"]).'</select>',($pb?" <select name='$e"."[unsigned]'".(!$c["type"]||ereg('(int|float|double|decimal)$',$c["type"])?"":" class='hidden'").'><option>'.optionlist($pb,$c["unsigned"]).'</select>':'');}function
process_length($pa){global$Qa;return(preg_match("~^\\s*(?:$Qa)(?:\\s*,\\s*(?:$Qa))*\\s*\$~",$pa)&&preg_match_all("~$Qa~",$pa,$F)?implode(",",$F[0]):preg_replace('~[^0-9,+-]~','',$pa));}function
process_type($c,$jb="COLLATE"){global$d,$pb;return" $c[type]".(strlen($c["length"])&&!ereg('^date|time$',$c["type"])?"(".process_length($c["length"]).")":"").(ereg('int|float|double|decimal',$c["type"])&&in_array($c["unsigned"],$pb)?" $c[unsigned]":"").(ereg('char|text|enum|set',$c["type"])&&$c["collation"]?" $jb ".$d->quote($c["collation"]):"");}function
process_field($c,$ib){global$d;return
idf_escape($c["field"]).process_type($ib).($c["null"]?" NULL":" NOT NULL").(!isset($c["default"])?"":" DEFAULT ".($c["type"]=="timestamp"&&eregi("^CURRENT_TIMESTAMP$",$c["default"])?$c["default"]:$d->quote($c["default"]))).($c["on_update"]?" ON UPDATE $c[on_update]":"")." COMMENT ".$d->quote($c["comment"]);}function
type_class($aa){foreach(array('char'=>'text','date'=>'time|year','binary'=>'blob','enum'=>'set',)as$e=>$b){if(ereg("$e|$b",$aa)){return" class='$e'";}}}function
edit_fields($l,$H,$aa="TABLE",$id=0,$D=array()){global$Sa;$Ta=false;foreach($l
as$c){if(strlen($c["comment"])){$Ta=true;break;}}echo'<thead><tr>
';if($aa=="PROCEDURE"){echo'<td>&nbsp;';}echo'<th>',($aa=="TABLE"?lang(64):lang(65)),'<td>',lang(66),'<textarea id="enum-edit" rows="4" cols="10" style="display: none;" onblur="editing_length_blur(this);"></textarea>
<td>',lang(67),'<td>',lang(68);if($aa=="TABLE"){echo'<td>NULL
<td><input type="radio" name="auto_increment_col" value=""><acronym title="',lang(69),'">A_I</acronym>
<td class="hidden">',lang(70),'<td',($Ta?"":" class='hidden'"),'>',lang(71);}echo'<td>',"<input type='image' name='add[0]' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=plus.gif&amp;version=2.2.1' alt='+' title='".lang(72)."'>",'<script type="text/javascript">row_count = ',count($l),';</script>
</thead>
';foreach($l
as$h=>$c){$h++;$hd=(isset($_POST["add"][$h-1])||(isset($c["field"])&&!$_POST["drop_col"][$h]));echo'<tr',($hd?"":" style='display: none;'"),'>
';if($aa=="PROCEDURE"){echo"<td>".html_select("fields[$h][inout]",$Sa,$c["inout"]);}echo'<th>';if($hd){echo'<input name="fields[',$h,'][field]" value="',h($c["field"]),'" onchange="',(strlen($c["field"])||count($l)>1?"":"editing_add_row(this, $id); "),'editing_name_change(this);" maxlength="64">';}echo'<input type="hidden" name="fields[',$h,'][orig]" value="',h($c[($_POST?"orig":"field")]),'">
';edit_type("fields[$h]",$c,$H,$D);if($aa=="TABLE"){echo'<td>',checkbox("fields[$h][null]",1,$c["null"]),'<td><input type="radio" name="auto_increment_col" value="',$h,'"';if($c["auto_increment"]){echo' checked';}echo'>
<td class="nowrap hidden">',checkbox("fields[$h][has_default]",1,$c["has_default"]),'<input name="fields[',$h,'][default]" value="',h($c["default"]),'" onchange="this.previousSibling.checked = true;">
<td',($Ta?"":" class='hidden'"),'><input name="fields[',$h,'][comment]" value="',h($c["comment"]),'" maxlength="255">
';}echo"<td class='nowrap'><input type='image' name='add[$h]' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=plus.gif&amp;version=2.2.1' alt='+' title='".lang(72)."' onclick='return !editing_add_row(this, $id, 1);'>","&nbsp;<input type='image' name='drop_col[$h]' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=cross.gif&amp;version=2.2.1' alt='x' title='".lang(73)."' onclick='return !editing_remove_row(this);'>","&nbsp;<input type='image' name='up[$h]' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=up.gif&amp;version=2.2.1' alt='^' title='".lang(74)."'>","&nbsp;<input type='image' name='down[$h]' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=down.gif&amp;version=2.2.1' alt='v' title='".lang(75)."'>","\n";}return$Ta;}function
process_fields(&$l){ksort($l);$Y=0;if($_POST["up"]){$wb=0;foreach($l
as$e=>$c){if(key($_POST["up"])==$e){unset($l[$e]);array_splice($l,$wb,0,array($c));break;}if(isset($c["field"])){$wb=$Y;}$Y++;}}if($_POST["down"]){$X=false;foreach($l
as$e=>$c){if(isset($c["field"])&&$X){unset($l[key($_POST["down"])]);array_splice($l,$Y,0,array($X));break;}if(key($_POST["down"])==$e){$X=$c;}$Y++;}}$l=array_values($l);if($_POST["add"]){array_splice($l,key($_POST["add"]),0,array(array()));}}function
normalize_enum($k){return"'".str_replace("'","''",addcslashes(stripcslashes(str_replace($k[0]{0}.$k[0]{0},$k[0]{0},substr($k[0],1,-1))),'\\'))."'";}function
routine($j,$aa){global$d,$Qa,$Sa,$oa;$uc=array("bit"=>"tinyint","bool"=>"tinyint","boolean"=>"tinyint","integer"=>"int","double precision"=>"float","real"=>"float","dec"=>"decimal","numeric"=>"decimal","fixed"=>"decimal","national char"=>"char","national varchar"=>"varchar");$ud="(".implode("|",array_keys($oa+$uc)).")(?:\\s*\\(((?:[^'\")]*|$Qa)+)\\))?\\s*(zerofill\\s*)?(unsigned(?:\\s+zerofill)?)?(?:\\s*(?:CHARSET|CHARACTER\\s+SET)\\s*['\"]?([^'\"\\s]+)['\"]?)?";$ua="\\s*(".($aa=="FUNCTION"?"":implode("|",$Sa)).")?\\s*(?:`((?:[^`]|``)*)`\\s*|\\b(\\S+)\\s+)$ud";$S=$d->result($d->query("SHOW CREATE $aa ".idf_escape($j)),2);preg_match("~\\(((?:$ua\\s*,?)*)\\)".($aa=="FUNCTION"?"\\s*RETURNS\\s+$ud":"")."\\s*(.*)~is",$S,$k);$l=array();preg_match_all("~$ua\\s*,?~is",$k[1],$F,PREG_SET_ORDER);foreach($F
as$ga){$j=str_replace("``","`",$ga[2]).$ga[3];$oc=strtolower($ga[4]);$l[$j]=array("field"=>$j,"type"=>(isset($uc[$oc])?$uc[$oc]:$oc),"length"=>preg_replace_callback("~$Qa~s",'normalize_enum',$ga[5]),"unsigned"=>strtolower(preg_replace('~\\s+~',' ',trim("$ga[7] $ga[6]"))),"inout"=>strtoupper($ga[1]),"collation"=>strtolower($ga[8]),);}if($aa!="FUNCTION"){return
array("fields"=>$l,"definition"=>$k[10]);}$Wd=array("type"=>$k[10],"length"=>$k[11],"unsigned"=>$k[13],"collation"=>$k[14]);return
array("fields"=>$l,"returns"=>$Wd,"definition"=>$k[15]);}function
grant($E,$J,$s,$Eb){if(!$J){return
true;}if($J==array("ALL PRIVILEGES","GRANT OPTION")){return($E=="GRANT"?queries("$E ALL PRIVILEGES$Eb WITH GRANT OPTION"):queries("$E ALL PRIVILEGES$Eb")&&queries("$E GRANT OPTION$Eb"));}return
queries("$E ".preg_replace('~(GRANT OPTION)\\([^)]*\\)~','\\1',implode("$s, ",$J).$s).$Eb);}function
drop_create($Fd,$S,$A,$Ed,$ae,$be,$j){if($_POST["drop"]){return
query_redirect($Fd,$A,$Ed,true,!$_POST["dropped"]);}$ma=strlen($j)&&($_POST["dropped"]||queries($Fd));$fe=queries($S);if(!queries_redirect($A,(strlen($j)?$ae:$be),$fe)&&$ma){restart_session();$_SESSION["messages"][]=$Ed;}return$ma;}function
tar_file($sc,$lc){$g=pack("a100a8a8a8a12a12",$sc,644,0,0,decoct(strlen($lc)),decoct(time()));$Cd=8*32;for($h=0;$h<strlen($g);$h++){$Cd+=ord($g{$h});}$g.=sprintf("%06o",$Cd)."\0 ";return$g.str_repeat("\0",512-strlen($g)).$lc.str_repeat("\0",511-(strlen($lc)+511)%
512);}function
dump_triggers($p,$y){global$d;if($_POST["format"]=="sql"&&$y&&$d->server_info>=5){$f=$d->query("SHOW TRIGGERS LIKE ".$d->quote(addcslashes($p,"%_")));if($f->num_rows){$R="\nDELIMITER ;;\n";while($a=$f->fetch_assoc()){$R.="\n".($y=='CREATE+ALTER'?"DROP TRIGGER IF EXISTS ".idf_escape($a["Trigger"]).";;\n":"")."CREATE TRIGGER ".idf_escape($a["Trigger"])." $a[Timing] $a[Event] ON ".idf_escape($a["Table"])." FOR EACH ROW\n$a[Statement];;\n";}echo"$R\nDELIMITER ;\n";}}}function
dump_table($p,$y,$nc=false){global$d;if($_POST["format"]=="csv"){echo"\xef\xbb\xbf";if($y){dump_csv(array_keys(fields($p)));}}elseif($y){$f=$d->query("SHOW CREATE TABLE ".idf_escape($p));if($f){if($y=="DROP+CREATE"){echo"DROP ".($nc?"VIEW":"TABLE")." IF EXISTS ".idf_escape($p).";\n";}$S=$d->result($f,1);echo($y!="CREATE+ALTER"?$S:($nc?substr_replace($S," OR REPLACE",6,0):substr_replace($S," IF NOT EXISTS",12,0))).";\n\n";}if($y=="CREATE+ALTER"&&!$nc){$m="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 = ".$d->quote($p)." 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 '";$l=array();$f=$d->query($m);$Oa="";while($a=$f->fetch_assoc()){$la=$a["COLUMN_DEFAULT"];$a["default"]=(isset($la)?$d->quote($la):"NULL");$a["after"]=$d->quote($Oa);$a["alter"]=escape_string(idf_escape($a["COLUMN_NAME"])." $a[COLUMN_TYPE]".($a["COLLATION_NAME"]?" COLLATE $a[COLLATION_NAME]":"").(isset($la)?" DEFAULT ".($la=="CURRENT_TIMESTAMP"?$la:$a["default"]):"").($a["IS_NULLABLE"]=="YES"?"":" NOT NULL").($a["EXTRA"]?" $a[EXTRA]":"").($a["COLUMN_COMMENT"]?" COMMENT ".$d->quote($a["COLUMN_COMMENT"]):"").($Oa?" AFTER ".idf_escape($Oa):" FIRST"));echo", ADD $a[alter]";$l[]=$a;$Oa=$a["COLUMN_NAME"];}echo"';
	DECLARE columns CURSOR FOR $m;
	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($l
as$a){echo"
				WHEN ".$d->quote($a["COLUMN_NAME"])." THEN
					SET add_columns = REPLACE(add_columns, ', ADD $a[alter]', '');
					IF NOT (_column_default <=> $a[default]) OR _is_nullable != '$a[IS_NULLABLE]' OR _collation_name != '$a[COLLATION_NAME]' OR _column_type != ".$d->quote($a["COLUMN_TYPE"])." OR _extra != '$a[EXTRA]' OR _column_comment != ".$d->quote($a["COLUMN_COMMENT"])." OR after != $a[after] THEN
						SET @alter_table = CONCAT(@alter_table, ', MODIFY $a[alter]');
					END IF;";}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 ".idf_escape($p)."', SUBSTR(CONCAT(add_columns, @alter_table), 2), ';\\n');
	END IF;
END;;
DELIMITER ;
CALL adminer_alter(@adminer_alter);
DROP PROCEDURE adminer_alter;

";}}}function
dump_data($p,$y,$t=""){global$d;$ee=1048576;if($y){if($_POST["format"]!="csv"&&$y=="TRUNCATE+INSERT"){echo"TRUNCATE ".idf_escape($p).";\n";}$l=fields($p);$f=$d->query(($t?$t:"SELECT * FROM ".idf_escape($p)),1);if($f){$rb="";$wa="";while($a=$f->fetch_assoc()){if($_POST["format"]=="csv"){dump_csv($a);}else{if(!$rb){$rb="INSERT INTO ".idf_escape($p)." (".implode(", ",array_map('idf_escape',array_keys($a))).") VALUES";}foreach($a
as$e=>$b){$a[$e]=(isset($b)?(ereg('int|float|double|decimal',$l[$e]["type"])?$b:$d->quote($b)):"NULL");}$R=implode(",\t",$a);if($y=="INSERT+UPDATE"){$u=array();foreach($a
as$e=>$b){$u[]=idf_escape($e)." = $b";}echo"$rb ($R) ON DUPLICATE KEY UPDATE ".implode(", ",$u).";\n";}else{$R="\n($R)";if(!$wa){$wa=$rb.$R;}elseif(strlen($wa)+2+strlen($R)<$ee){$wa.=",$R";}else{$wa.=";\n";echo$wa;$wa=$rb.$R;}}}}if($_POST["format"]!="csv"&&$y!="INSERT+UPDATE"&&$wa){$wa.=";\n";echo$wa;}}}}function
dump_headers($xd,$de=false){$sc=(strlen($xd)?friendly_url($xd):"dump");$Pa=$_POST["output"];$Ia=($_POST["format"]=="sql"?"sql":($de?"tar":"csv"));header("Content-Type: ".($Pa=="bz2"?"application/x-bzip":($Pa=="gz"?"application/x-gzip":($Ia=="tar"?"application/x-tar":($Ia=="sql"||$Pa!="file"?"text/plain":"text/csv")."; charset=utf-8"))));if($Pa!="text"){header("Content-Disposition: attachment; filename=$sc.$Ia".($Pa!="file"&&!ereg('[^0-9a-z]',$Pa)?".$Pa":""));}session_write_close();if($_POST["output"]=="bz2"){ob_start('bzcompress',1e6);}if($_POST["output"]=="gz"){ob_start('gzencode',1e6);}return$Ia;}session_cache_limiter("");if(!ini_get("session.use_cookies")||@ini_set("session.use_cookies",false)!==false){session_write_close();}$tb=" onclick=\"return confirm('".lang(60)."');\"";$_=$_SESSION["tokens"][$_GET["server"]];$n=($_POST?($_POST["token"]==$_?"":lang(42)):($_SERVER["REQUEST_METHOD"]!="POST"?"":lang(76,'"post_max_size"')));$Qa='\'(?:\'\'|[^\'\\\\]|\\\\.)*\'|"(?:""|[^"\\\\]|\\\\.)*"';$Sa=array("IN","OUT","INOUT");if(isset($_GET["select"])&&($_POST["edit"]||$_POST["clone"])&&!$_POST["save"]){$_GET["edit"]=$_GET["select"];}if(isset($_GET["callf"])){$_GET["call"]=$_GET["callf"];}if(isset($_GET["function"])){$_GET["procedure"]=$_GET["function"];}if(isset($_GET["download"])){$i=$_GET["download"];header("Content-Type: application/octet-stream");header("Content-Disposition: attachment; filename=".friendly_url("$i-".implode("_",$_GET["where"])).".".friendly_url($_GET["field"]));echo$d->result($d->query("SELECT ".idf_escape($_GET["field"])." FROM ".idf_escape($i)." WHERE ".where($_GET)." LIMIT 1"));exit;}elseif(isset($_GET["table"])){$i=$_GET["table"];$l=fields($i);if(!$l){$n=h($d->error);}$na=($l?table_status($i):array());page_header(($l&&!isset($na["Rows"])?lang(77):lang(78)).": ".h($i),$n);$q->selectLinks($na);if($l){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(79)."<td>".lang(66)."<td>".lang(71)."</thead>\n";foreach($l
as$c){echo"<tr".odd()."><th>".h($c["field"]),"<td>".h($c["full_type"]).($c["null"]?" <i>NULL</i>":"").($c["auto_increment"]?" <i>".lang(69)."</i>":""),"<td>".nbsp($c["comment"]),"\n";}echo"</table>\n";if(isset($na["Rows"])){echo"<h3>".lang(80)."</h3>\n";$v=indexes($i);if($v){echo"<table cellspacing='0'>\n";foreach($v
as$r){ksort($r["columns"]);$gb=array();foreach($r["columns"]as$e=>$b){$gb[]="<i>".h($b)."</i>".($r["lengths"][$e]?"(".$r["lengths"][$e].")":"");}echo"<tr><th>$r[type]<td>".implode(", ",$gb)."\n";}echo"</table>\n";}echo'<p><a href="'.h(ME).'indexes='.urlencode($i).'">'.lang(81)."</a>\n";if($na["Engine"]=="InnoDB"){echo"<h3>".lang(62)."</h3>\n";$D=foreign_keys($i);if($D){echo"<table cellspacing='0'>\n";foreach($D
as$j=>$G){$z=(strlen($G["db"])?"<strong>".h($G["db"])."</strong>.":"").h($G["table"]);echo"<tr>","<th><i>".implode("</i>, <i>",array_map('h',$G["source"]))."</i>","<td><a href='".h(strlen($G["db"])?preg_replace('~db=[^&]*~',"db=".urlencode($G["db"]),ME):ME)."table=".urlencode($G["table"])."'>$z</a>","(<em>".implode("</em>, <em>",array_map('h',$G["target"]))."</em>)",'<td><a href="'.h(ME.'foreign='.urlencode($i).'&name='.urlencode($j)).'">'.lang(82).'</a>';}echo"</table>\n";}echo'<p><a href="'.h(ME).'foreign='.urlencode($i).'">'.lang(83)."</a>\n";}if($d->server_info>=5){echo"<h3>".lang(84)."</h3>\n";$f=$d->query("SHOW TRIGGERS LIKE ".$d->quote(addcslashes($i,"%_")));if($f->num_rows){echo"<table cellspacing='0'>\n";while($a=$f->fetch_assoc()){echo"<tr valign='top'><td>$a[Timing]<td>$a[Event]<th>".h($a["Trigger"])."<td><a href='".h(ME.'trigger='.urlencode($i).'&name='.urlencode($a["Trigger"]))."'>".lang(82)."</a>\n";}echo"</table>\n";}echo'<p><a href="'.h(ME).'trigger='.urlencode($i).'">'.lang(85)."</a>\n";}}}}elseif(isset($_GET["schema"])){page_header(lang(86),"",array(),DB);$Ca=array();$Bd=array();preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~',$_COOKIE["adminer_schema"],$F,PREG_SET_ORDER);foreach($F
as$h=>$k){$Ca[$k[1]]=array($k[2],$k[3]);$Bd[]="\n\t'".addcslashes($k[1],"\r\n'\\")."': [ $k[2], $k[3] ]";}$Za=0;$Ad=-1;$Fa=array();$Dd=array();$Id=array();foreach(table_status()as$a){if(!isset($a["Engine"])){continue;}$qb=0;$Fa[$a["Name"]]["fields"]=array();foreach(fields($a["Name"])as$j=>$c){$qb+=1.25;$c["pos"]=$qb;$Fa[$a["Name"]]["fields"][$j]=$c;}$Fa[$a["Name"]]["pos"]=($Ca[$a["Name"]]?$Ca[$a["Name"]]:array($Za,0));if($a["Engine"]=="InnoDB"){foreach(foreign_keys($a["Name"])as$b){if(!$b["db"]){$M=$Ad;if($Ca[$a["Name"]][1]||$Ca[$a["Name"]][1]){$M=min($Ca[$a["Name"]][1],$Ca[$b["table"]][1])-1;}else{$Ad-=.1;}while($Id[(string)$M]){$M-=.0001;}$Fa[$a["Name"]]["references"][$b["table"]][(string)$M]=array($b["source"],$b["target"]);$Dd[$b["table"]][$a["Name"]][(string)$M]=$b["target"];$Id[(string)$M]=true;}}}$Za=max($Za,$Fa[$a["Name"]]["pos"][0]+2.5+$qb);}echo'<div id="schema" style="height: ',$Za,'em;">
<script type="text/javascript">
table_pos = {',implode(",",$Bd)."\n",'};
em = document.getElementById(\'schema\').offsetHeight / ',$Za,';
document.onmousemove = schema_mousemove;
document.onmouseup = schema_mouseup;
</script>
';foreach($Fa
as$j=>$p){echo"<div class='table' style='top: ".$p["pos"][0]."em; left: ".$p["pos"][1]."em;' onmousedown='schema_mousedown(this, event);'>",'<a href="'.h(ME).'table='.urlencode($j).'"><strong>'.h($j)."</strong></a><br>\n";foreach($p["fields"]as$c){$b='<span'.type_class($c["type"]).' title="'.h($c["full_type"].($c["null"]?" NULL":'')).'">'.h($c["field"]).'</span>';echo($c["primary"]?"<em>$b</em>":$b)."<br>\n";}foreach((array)$p["references"]as$cb=>$kb){foreach($kb
as$M=>$Gb){$fb=$M-$Ca[$j][1];$h=0;foreach($Gb[0]as$Q){echo"<div class='references' title='".h($cb)."' id='refs$M-".($h++)."' style='left: $fb"."em; top: ".$p["fields"][$Q]["pos"]."em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: ".(-$fb)."em;'></div></div>\n";}}}foreach((array)$Dd[$j]as$cb=>$kb){foreach($kb
as$M=>$s){$fb=$M-$Ca[$j][1];$h=0;foreach($s
as$Ja){echo"<div class='references' title='".h($cb)."' id='refd$M-".($h++)."' style='left: $fb"."em; top: ".$p["fields"][$Ja]["pos"]."em; height: 1.25em; background: url(".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=arrow.gif) no-repeat right center;&amp;version=2.2.1'><div style='height: .5em; border-bottom: 1px solid Gray; width: ".(-$fb)."em;'></div></div>\n";}}}echo"</div>\n";}foreach($Fa
as$j=>$p){foreach((array)$p["references"]as$cb=>$kb){foreach($kb
as$M=>$Gb){$Hb=$Za;$hc=-10;foreach($Gb[0]as$e=>$Q){$yd=$p["pos"][0]+$p["fields"][$Q]["pos"];$Kd=$Fa[$cb]["pos"][0]+$Fa[$cb]["fields"][$Gb[1][$e]]["pos"];$Hb=min($Hb,$yd,$Kd);$hc=max($hc,$yd,$Kd);}echo"<div class='references' id='refl$M' style='left: $M"."em; top: $Hb"."em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: ".($hc-$Hb)."em;'></div></div>\n";}}}echo'</div>
';}elseif(isset($_GET["dump"])){$i=$_GET["dump"];if($_POST){$Ia=dump_headers((strlen($i)?$i:DB),(!strlen(DB)||count((array)$_POST["tables"]+(array)$_POST["data"])>1));if($_POST["format"]=="sql"){echo"-- Adminer $db dump
SET NAMES utf8;
SET foreign_key_checks = 0;
SET time_zone = ".$d->quote($d->result($d->query("SELECT @@time_zone"))).";
SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';

";}$y=$_POST["db_style"];foreach((strlen(DB)?array(DB):(array)$_POST["databases"])as$w){if($d->select_db($w)){if($_POST["format"]=="sql"&&ereg('CREATE',$y)&&($f=$d->query("SHOW CREATE DATABASE ".idf_escape($w)))){if($y=="DROP+CREATE"){echo"DROP DATABASE IF EXISTS ".idf_escape($w).";\n";}$S=$d->result($f,1);echo($y=="CREATE+ALTER"?preg_replace('~^CREATE DATABASE ~','\\0IF NOT EXISTS ',$S):$S).";\n";}if($_POST["format"]=="sql"){if($y){echo"USE ".idf_escape($w).";\n\n";}if(in_array("CREATE+ALTER",array($y,$_POST["table_style"]))){echo"SET @adminer_alter = '';\n\n";}$sa="";if($_POST["routines"]){foreach(array("FUNCTION","PROCEDURE")as$da){$f=$d->query("SHOW $da STATUS WHERE Db = ".$d->quote($w));while($a=$f->fetch_assoc()){$sa.=($y!='DROP+CREATE'?"DROP $da IF EXISTS ".idf_escape($a["Name"]).";;\n":"").$d->result($d->query("SHOW CREATE $da ".idf_escape($a["Name"])),2).";;\n\n";}}}if($_POST["events"]){$f=$d->query("SHOW EVENTS");while($a=$f->fetch_assoc()){$sa.=($y!='DROP+CREATE'?"DROP EVENT IF EXISTS ".idf_escape($a["Name"]).";;\n":"").$d->result($d->query("SHOW CREATE EVENT ".idf_escape($a["Name"])),3).";;\n\n";}}if($sa){echo"DELIMITER ;;\n\n$sa"."DELIMITER ;\n\n";}}if($_POST["table_style"]||$_POST["data_style"]){$lb=array();foreach(table_status()as$a){$p=(!strlen(DB)||in_array($a["Name"],(array)$_POST["tables"]));$_d=(!strlen(DB)||in_array($a["Name"],(array)$_POST["data"]));if($p||$_d){if(isset($a["Engine"])){if($Ia=="tar"){ob_start();}dump_table($a["Name"],($p?$_POST["table_style"]:""));if($_d){dump_data($a["Name"],$_POST["data_style"]);}if($p){dump_triggers($a["Name"],$_POST["table_style"]);}if($Ia=="tar"){echo
tar_file((strlen(DB)?"":"$w/")."$a[Name].csv",ob_get_clean());}elseif($_POST["format"]=="sql"){echo"\n";}}elseif($_POST["format"]=="sql"){$lb[]=$a["Name"];}}}foreach($lb
as$ie){dump_table($ie,$_POST["table_style"],true);}if($Ia=="tar"){echo
pack("x512");}}if($y=="CREATE+ALTER"&&$_POST["format"]=="sql"){$m="SELECT TABLE_NAME, ENGINE, TABLE_COLLATION, TABLE_COMMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE()";echo"DELIMITER ;;
CREATE PROCEDURE adminer_alter (INOUT alter_command text) BEGIN
	DECLARE _table_name, _engine, _table_collation varchar(64);
	DECLARE _table_comment varchar(64);
	DECLARE done bool DEFAULT 0;
	DECLARE tables CURSOR FOR $m;
	DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
	OPEN tables;
	REPEAT
		FETCH tables INTO _table_name, _engine, _table_collation, _table_comment;
		IF NOT done THEN
			CASE _table_name";$f=$d->query($m);while($a=$f->fetch_assoc()){$zb=$d->quote($a["ENGINE"]=="InnoDB"?preg_replace('~(?:(.+); )?InnoDB free: .*~','\\1',$a["TABLE_COMMENT"]):$a["TABLE_COMMENT"]);echo"
				WHEN ".$d->quote($a["TABLE_NAME"])." THEN
					".(isset($a["ENGINE"])?"IF _engine != '$a[ENGINE]' OR _table_collation != '$a[TABLE_COLLATION]' OR _table_comment != $zb THEN
						ALTER TABLE ".idf_escape($a["TABLE_NAME"])." ENGINE=$a[ENGINE] COLLATE=$a[TABLE_COLLATION] COMMENT=$zb;
					END IF":"BEGIN END").";";}echo"
				ELSE
					SET alter_command = CONCAT(alter_command, 'DROP TABLE `', REPLACE(_table_name, '`', '``'), '`;\\n');
			END CASE;
		END IF;
	UNTIL done END REPEAT;
	CLOSE tables;
END;;
DELIMITER ;
CALL adminer_alter(@adminer_alter);
DROP PROCEDURE adminer_alter;
";}if(in_array("CREATE+ALTER",array($y,$_POST["table_style"]))&&$_POST["format"]=="sql"){echo"SELECT @adminer_alter;\n";}}}exit;}page_header(lang(87),"",(strlen($_GET["export"])?array("table"=>$_GET["export"]):array()),DB);echo'
<form action="" method="post">
<table cellspacing="0">
';$Lc=array('','USE','DROP+CREATE','CREATE');$Dc=array('','DROP+CREATE','CREATE');$ce=array('','TRUNCATE+INSERT','INSERT','INSERT+UPDATE');if($d->server_info>=5){$Lc[]='CREATE+ALTER';$Dc[]='CREATE+ALTER';}echo"<tr><th>".lang(88)."<td><input type='hidden' name='token' value='$_'>".$q->dumpOutput(0)."\n";echo"<tr><th>".lang(89)."<td>".$q->dumpFormat(0)."\n","<tr><th>".lang(48)."<td>".html_select('db_style',$Lc,(strlen(DB)?'':'CREATE'));if($d->server_info>=5){$P=!strlen($_GET["dump"]);echo
checkbox("routines",1,$P,lang(90));if($d->server_info>=5.1){echo
checkbox("events",1,$P,lang(91));}}echo"<tr><th>".lang(92)."<td>".html_select('table_style',$Dc,'DROP+CREATE'),"<tr><th>".lang(93)."<td>".html_select('data_style',$ce,'INSERT'),'</table>
<p><input type="submit" value="',lang(87),'"></p>

<table cellspacing="0">
';if(strlen(DB)){$P=(strlen($i)?"":" checked");echo"<thead><tr>","<th style='text-align: left;'><label><input type='checkbox' id='check-tables'$P onclick='form_check(this, /^tables\\[/);'>".lang(92)."</label>","<th style='text-align: right;'><label>".lang(93)."<input type='checkbox' id='check-data'$P onclick='form_check(this, /^data\\[/);'></label>","</thead>\n";$lb="";foreach(table_status()as$a){$P=!strlen($i)||$a["Name"]==$i;$gb="<tr><td>".checkbox("tables[]",$a["Name"],$P,$a["Name"],"form_uncheck('check-tables');");if(!$a["Engine"]){$lb.="$gb\n";}else{echo"$gb<td align='right'><label>".($a["Engine"]=="InnoDB"&&$a["Rows"]?lang(94,$a["Rows"]):$a["Rows"]).checkbox("data[]",$a["Name"],$P,"","form_uncheck('check-data');")."</label>\n";}}echo$lb;}else{echo"<thead><tr><th style='text-align: left;'><label><input type='checkbox' id='check-databases' checked onclick='form_check(this, /^databases\\[/);'>".lang(48)."</label></thead>\n";foreach(get_databases()as$w){if(!information_schema($w)){echo"<tr><td>".checkbox("databases[]",$w,1,$w,"form_uncheck('check-databases');")."</label>\n";}}}echo'</table>
</form>
';}elseif(isset($_GET["privileges"])){page_header(lang(53));$f=$d->query("SELECT User, Host FROM mysql.user ORDER BY Host, User");if(!$f){echo'<form action=""><p>
';if(SID){echo'<input type="hidden" name="',session_name(),'" value="',h(session_id()),'">';}if(strlen($_GET["server"])){echo'<input type="hidden" name="server" value="',h($_GET["server"]),'">';}echo
lang(7),': <input name="user">
',lang(6),': <input name="host" value="localhost">
<input type="hidden" name="grant" value="">
<input type="submit" value="',lang(14),'">
</form>
';$f=$d->query("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', 1) AS User, SUBSTRING_INDEX(CURRENT_USER, '@', -1) AS Host");}echo"<table cellspacing='0'>\n","<thead><tr><th>&nbsp;<th>".lang(7)."<th>".lang(6)."</thead>\n";while($a=$f->fetch_assoc()){echo'<tr'.odd().'><td><a href="'.h(ME.'user='.urlencode($a["User"]).'&host='.urlencode($a["Host"])).'">'.lang(95).'</a><td>'.h($a["User"])."<td>".h($a["Host"])."\n";}echo"</table>\n",'<p><a href="'.h(ME).'user=">'.lang(96)."</a>";}elseif(isset($_GET["sql"])){restart_session();$Ka=&$_SESSION["history"][$_GET["server"]][DB];if(!$n&&$_POST["clear"]){$Ka=array();redirect(remove_from_uri("history"));}page_header(lang(26),$n);if(!$n&&$_POST){$Aa=false;$m=$_POST["query"];if($_POST["webfile"]){$Aa=@fopen((file_exists("adminer.sql")?"adminer.sql":(file_exists("adminer.sql.gz")?"compress.zlib://adminer.sql.gz":"compress.bzip2://adminer.sql.bz2")),"rb");$m=($Aa?fread($Aa,1e6):false);}elseif($_POST["file"]){$m=get_file("sql_file",true);}if(is_string($m)){@ini_set("memory_limit",2*strlen($m)+memory_get_usage()+8e6);if(strlen($m)&&strlen($m)<1e6&&(!$Ka||end($Ka)!=$m)){$Ka[]=$m;}$_b="(\\s|/\\*.*\\*/|(#|-- )[^\n]*\n|--\n)";$Hc="(CREATE|DROP)$_b+(DATABASE|SCHEMA)\\b~isU";$U=&$_SESSION["databases"][$_GET["server"]];if(!ini_get("session.use_cookies")||(isset($U)&&!preg_match("~\\b$Hc",$m))){session_write_close();}$jc=";";$Y=0;$Uc=true;$ca=(strlen(DB)?connect():null);if(is_object($ca)){$ca->select_db(DB);}$Kc=1;while(strlen($m)){if(!$Y&&preg_match('~^\\s*DELIMITER\\s+(.+)~i',$m,$k)){$jc=$k[1];$m=substr($m,strlen($k[0]));}else{preg_match('('.preg_quote($jc).'|[\'`"]|/\\*|-- |#|$)',$m,$k,PREG_OFFSET_CAPTURE,$Y);$X=$k[0][0];$Y=$k[0][1]+strlen($X);if(!$X&&$Aa&&!feof($Aa)){$m.=fread($Aa,1e5);}else{if(!$X&&!strlen(rtrim($m))){break;}if(!$X||$X==$jc){$Uc=false;$za=substr($m,0,$k[0][1]);echo"<pre class='jush-sql'>".shorten_utf8(trim($za),1000)."</pre>\n";ob_flush();flush();$Sc=explode(" ",microtime());if(!$d->multi_query($za)){echo"<p class='error'>".lang(97).": ".h($d->error)."\n";if($_POST["error_stops"]){break;}}else{$Nc=explode(" ",microtime());echo"<p class='time'>".lang(98,max(0,$Nc[0]-$Sc[0]+$Nc[1]-$Sc[1]))."</p>\n";do{$f=$d->store_result();if(is_object($f)){select($f,$ca);if($ca&&preg_match("~^$_b*SELECT$_b+~isU",$za)){$N="explain-$Kc";echo"<p>".($f->num_rows?lang(99,$f->num_rows).", ":""),"<a href='#$N' onclick=\"return !toggle('$N');\">EXPLAIN</a>\n","<div id='$N' class='hidden'>\n";select($ca->query("EXPLAIN $za"),$ca);echo"</div>\n";$Kc++;}}else{if(preg_match("~^$_b*$Hc",$m)){$U=null;}echo"<p class='message'>".lang(100,$d->affected_rows)."\n";}unset($f);}while($d->next_result());}$m=substr($m,$Y);$Y=0;}else{while(preg_match('~'.($X=='/*'?'\\*/':(ereg('-- |#',$X)?"\n":"$X|\\\\.")).'|$~s',$m,$k,PREG_OFFSET_CAPTURE,$Y)){$R=$k[0][0];$Y=$k[0][1]+strlen($R);if(!$R&&$Aa&&!feof($Aa)){$m.=fread($Aa,1e6);}elseif($R[0]!="\\"){break;}}}}}}if($Uc){echo"<p class='message'>".lang(101)."\n";}}else{echo"<p class='error'>".upload_error($m)."\n";}}echo'
<form action="" method="post" enctype="multipart/form-data">
<p><textarea name="query" rows="20" cols="80" style="width: 98%;">';$za=$_GET["sql"];if($_POST){$za=$_POST["query"];}elseif(strlen($_GET["history"])){$za=$Ka[$_GET["history"]];}echo
h($za),'</textarea>
<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(102),'">
',checkbox("error_stops",1,$_POST["error_stops"],lang(103)),'
<p>
';if(!ini_get("file_uploads")){echo
lang(104);}else{echo
lang(105),': <input type="file" name="sql_file">
<input type="submit" name="file" value="',lang(106),'">
';}echo'
<p>';$ac=array();foreach(array("gz"=>"zlib","bz2"=>"bzip2")as$e=>$b){if(in_array("compress.$b",stream_get_wrappers())){$ac[]=".$e";}}echo
lang(107,"<code>adminer.sql".($ac?"[".implode("|",$ac)."]":"")."</code>"),' <input type="submit" name="webfile" value="',lang(106),'">

';if($Ka){echo"<fieldset><legend>".lang(108)."</legend>\n";foreach($Ka
as$e=>$b){echo'<a href="'.h(ME."sql=&history=$e").'">'.lang(14).'</a> <code class="jush-sql">'.shorten_utf8(ltrim(str_replace("\n"," ",str_replace("\r","",preg_replace('~^(#|-- ).*~m','',$b)))),80,"</code>")."<br>\n";}echo"<input type='submit' name='clear' value='".lang(109)."'>\n","</fieldset>\n";}echo'
</form>
';}elseif(isset($_GET["edit"])){$i=$_GET["edit"];$C=(isset($_GET["select"])?(count($_POST["check"])==1?where_check($_POST["check"][0]):""):where($_GET));$ab=(isset($_GET["select"])?$_POST["edit"]:$C);$l=fields($i);foreach($l
as$j=>$c){if(!isset($c["privileges"][$ab?"update":"insert"])||!strlen($q->fieldName($c))){unset($l[$j]);}}if($_POST&&!$n&&!isset($_GET["select"])){$A=$_SERVER["REQUEST_URI"];if(!$_POST["insert"]){$A=ME."select=".urlencode($i);$h=0;foreach((array)$_GET["set"]as$e=>$b){if($b==$_POST["fields"][$e]){$A.=where_link($h++,bracket_escape($e,"back"),$b);}}}$u=array();foreach($l
as$j=>$c){$b=process_input($c);if(!$ab){$u[idf_escape($j)]=($b!==false?$b:"''");}elseif($b!==false){$u[]="\n".idf_escape($j)." = $b";}}if(!$u){redirect($A);}if($ab){query_redirect("UPDATE ".idf_escape($i)." SET".implode(",",$u)."\nWHERE $C\nLIMIT 1",$A,lang(110));}else{query_redirect("INSERT INTO ".idf_escape($i)." (".implode(", ",array_keys($u)).")\nVALUES (".implode(", ",$u).")",$A,lang(111));}}$O=$q->tableName(table_status($i));page_header(($ab?lang(14):lang(112)),$n,array("select"=>array($i,$O)),$O);unset($a);if($_POST["save"]){$a=(array)$_POST["fields"];}elseif($C){$t=array();foreach($l
as$j=>$c){if(isset($c["privileges"]["select"])){$t[]=($_POST["clone"]&&$c["auto_increment"]?"'' AS ":(ereg("enum|set",$c["type"])?"1*".idf_escape($j)." AS ":"")).idf_escape($j);}}$a=array();if($t){$f=$d->query("SELECT ".implode(", ",$t)." FROM ".idf_escape($i)." WHERE $C ".(isset($_GET["select"])?"HAVING COUNT(*) = 1":"LIMIT 1"));$a=$f->fetch_assoc();}}echo'
<form action="" method="post" enctype="multipart/form-data">
';if($l){unset($S);echo"<table cellspacing='0'>\n";foreach($l
as$j=>$c){echo"<tr><th>".$q->fieldName($c);$la=$_GET["set"][bracket_escape($j)];$o=(isset($a)?(strlen($a[$j])&&ereg("enum|set",$c["type"])?intval($a[$j]):$a[$j]):($_POST["clone"]&&$c["auto_increment"]?"":(isset($_GET["select"])?false:(isset($la)?$la:$c["default"]))));if(!$_POST["save"]&&is_string($o)){$o=$q->editVal($o,$c);}$x=($_POST["save"]?(string)$_POST["function"][$j]:($ab&&$c["on_update"]=="CURRENT_TIMESTAMP"?"now":($o===false?null:(isset($o)?'':'NULL'))));if($c["type"]=="timestamp"&&$o=="CURRENT_TIMESTAMP"){$o="";$x="now";}input($c,$o,$x);echo"\n";}echo"</table>\n";}echo'<p>
<input type="hidden" name="token" value="',$_,'">
<input type="hidden" name="save" value="1">
';if(isset($_GET["select"])){hidden_fields(array("check"=>(array)$_POST["check"],"clone"=>$_POST["clone"],"all"=>$_POST["all"]));}if($l){echo"<input type='submit' value='".lang(113)."'>\n";if(!isset($_GET["select"])){echo"<input type='submit' name='insert' value='".($ab?lang(114):lang(115))."'>\n";}}echo'</form>
';}elseif(isset($_GET["create"])){$i=$_GET["create"];$Rc=array('HASH','LINEAR HASH','KEY','LINEAR KEY','RANGE','LIST');$Oc=referencable_primary($i);$D=array();foreach($Oc
as$O=>$c){$D[idf_escape($O).".".idf_escape($c["field"])]=$O;}$Db=array();$Cb=array();if(strlen($i)){$Db=fields($i);$Cb=table_status($i);}if($_POST&&!$n&&!$_POST["add"]&&!$_POST["drop_col"]&&!$_POST["up"]&&!$_POST["down"]){$xc=" PRIMARY KEY";if(strlen($i)&&$_POST["auto_increment_col"]){foreach(indexes($i)as$r){if(in_array($_POST["fields"][$_POST["auto_increment_col"]]["orig"],$r["columns"],true)){$xc="";break;}if($r["type"]=="PRIMARY"){$xc=" UNIQUE";}}}$l="";ksort($_POST["fields"]);$Fb=reset($Db);$Oa="FIRST";foreach($_POST["fields"]as$e=>$c){$ib=(isset($oa[$c["type"]])?$c:$Oc[$D[$c["type"]]]);if(strlen($c["field"])){if($ib){$la=eregi_replace(" *on update CURRENT_TIMESTAMP","",$c["default"]);if($la!=$c["default"]){$c["on_update"]="CURRENT_TIMESTAMP";$c["default"]=$la;}if(!$c["has_default"]){$c["default"]=null;}$Xc=process_field($c,$ib);$Ec=($e==$_POST["auto_increment_col"]);if($Xc!=process_field($Fb,$Fb)||$Fb["auto_increment"]!=$Ec){$l.="\n".(strlen($i)?(strlen($c["orig"])?"CHANGE ".idf_escape($c["orig"]):"ADD"):" ")." $Xc".($Ec?" AUTO_INCREMENT$xc":"").(strlen($i)?" $Oa":"").",";}if(!isset($oa[$c["type"]])){$l.=(strlen($i)?"\nADD":"")." FOREIGN KEY (".idf_escape($c["field"]).") REFERENCES ".idf_escape($D[$c["type"]])." (".idf_escape($ib["field"])."),";}}$Oa="AFTER ".idf_escape($c["field"]);}elseif(strlen($c["orig"])){$l.="\nDROP ".idf_escape($c["orig"]).",";}if(strlen($c["orig"])){$Fb=next($Db);}}$Bb="COMMENT=".$d->quote($_POST["Comment"]).($_POST["Engine"]&&$_POST["Engine"]!=$Cb["Engine"]?" ENGINE=".$d->quote($_POST["Engine"]):"").($_POST["Collation"]&&$_POST["Collation"]!=$Cb["Collation"]?" COLLATE ".$d->quote($_POST["Collation"]):"").(strlen($_POST["auto_increment"])?" AUTO_INCREMENT=".preg_replace('~[^0-9]+~','',$_POST["auto_increment"]):"");if(in_array($_POST["partition_by"],$Rc)){$yc=array();if($_POST["partition_by"]=='RANGE'||$_POST["partition_by"]=='LIST'){foreach(array_filter($_POST["partition_names"])as$e=>$b){$o=$_POST["partition_values"][$e];$yc[]="\nPARTITION ".idf_escape($b)." VALUES ".($_POST["partition_by"]=='RANGE'?"LESS THAN":"IN").(strlen($o)?" ($o)":" MAXVALUE");}}$Bb.="\nPARTITION BY $_POST[partition_by]($_POST[partition])".($yc?" (".implode(",",$yc)."\n)":($_POST["partitions"]?" PARTITIONS ".intval($_POST["partitions"]):""));}elseif($d->server_info>=5.1&&strlen($i)){$Bb.="\nREMOVE PARTITIONING";}$A=ME."table=".urlencode($_POST["name"]);if(strlen($i)){query_redirect("ALTER TABLE ".idf_escape($i)."$l\nRENAME TO ".idf_escape($_POST["name"]).",\n$Bb",$A,lang(116));}else{cookie("adminer_engine",$_POST["Engine"]);query_redirect("CREATE TABLE ".idf_escape($_POST["name"])." (".substr($l,0,-1)."\n) $Bb",$A,lang(117));}}page_header((strlen($i)?lang(11):lang(118)),$n,array("table"=>$i),$i);$a=array("Engine"=>$_COOKIE["adminer_engine"],"fields"=>array(array("field"=>"")),"partition_names"=>array(""),);if($_POST){$a=$_POST;if($a["auto_increment_col"]){$a["fields"][$a["auto_increment_col"]]["auto_increment"]=true;}process_fields($a["fields"]);}elseif(strlen($i)){$a=$Cb;$a["name"]=$i;$a["fields"]=array();foreach($Db
as$c){$c["has_default"]=isset($c["default"]);if($c["on_update"]){$c["default"].=" ON UPDATE $c[on_update]";}$a["fields"][]=$c;}if($d->server_info>=5.1){$Wa="FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA = ".$d->quote(DB)." AND TABLE_NAME = ".$d->quote($i);$f=$d->query("SELECT PARTITION_METHOD, PARTITION_ORDINAL_POSITION, PARTITION_EXPRESSION $Wa ORDER BY PARTITION_ORDINAL_POSITION DESC LIMIT 1");list($a["partition_by"],$a["partitions"],$a["partition"])=$f->fetch_row();$a["partition_names"]=array();$a["partition_values"]=array();$f=$d->query("SELECT PARTITION_NAME, PARTITION_DESCRIPTION $Wa AND PARTITION_NAME != '' ORDER BY PARTITION_ORDINAL_POSITION");while($Pc=$f->fetch_assoc()){$a["partition_names"][]=$Pc["PARTITION_NAME"];$a["partition_values"][]=$Pc["PARTITION_DESCRIPTION"];}$a["partition_names"][]="";}}$H=collations();$zc=floor(extension_loaded("suhosin")?(min(ini_get("suhosin.request.max_vars"),ini_get("suhosin.post.max_vars"))-13)/10:0);if($zc&&count($a["fields"])>$zc){echo"<p class='error'>".h(lang(119,'suhosin.post.max_vars','suhosin.request.max_vars'))."\n";}$vc=engines();foreach($vc
as$Gc){if(!strcasecmp($Gc,$a["Engine"])){$a["Engine"]=$Gc;break;}}echo'
<form action="" method="post" id="form">
<p>
',lang(120),': <input name="name" maxlength="64" value="',h($a["name"]),'">
',($vc?html_select("Engine",array(""=>"(".lang(121).")")+$vc,$a["Engine"]):""),' ',html_select("Collation",array(""=>"(".lang(63).")")+$H,$a["Collation"]),' <input type="submit" value="',lang(113),'">
</p>
<table cellspacing="0" id="edit-fields">
';$Ta=edit_fields($a["fields"],$H,"TABLE",$zc,$D);echo'</table>
<p>
',lang(69),': <input name="auto_increment" size="6" value="',h($a["auto_increment"]);echo'">
',lang(71),': <input name="Comment" value="',h($a["Comment"]),'" maxlength="60">
<script type="text/javascript">
document.write(\'<label><input type="checkbox" onclick="column_show(this.checked, 5);">',lang(70);?><\/label>');
document.write('<label><input type="checkbox"<?php if($Ta){echo' checked';}echo' onclick="column_show(this.checked, 6);">',lang(122),'<\\/label>\');
</script>
<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(113),'">
';if($d->server_info>=5.1){$Ic=ereg('RANGE|LIST',$a["partition_by"]);echo'<fieldset><legend>',lang(123),'</legend>
<p>
',html_select("partition_by",array(-1=>"")+$Rc,$a["partition_by"],"partition_by_change(this);"),'(<input name="partition" value="',h($a["partition"]),'">)
',lang(124),': <input name="partitions" size="2" value="',h($a["partitions"]),'"',($Ic||!$a["partition_by"]?" class='hidden'":""),'>
<table cellspacing="0" id="partition-table"',($Ic?"":" class='hidden'"),'>
<thead><tr><th>',lang(125),'<th>',lang(126),'</thead>
';foreach($a["partition_names"]as$e=>$b){echo'<tr>','<td><input name="partition_names[]" value="'.h($b).'"'.($e==count($a["partition_names"])-1?' onchange="partition_name_change(this);"':'').'>','<td><input name="partition_values[]" value="'.h($a["partition_values"][$e]).'">';}echo'</table>
</fieldset>
';}echo'</form>
';}elseif(isset($_GET["indexes"])){$i=$_GET["indexes"];$Fc=array("PRIMARY","UNIQUE","INDEX","FULLTEXT");$v=indexes($i);if($_POST&&!$n&&!$_POST["add"]){$Jb=array();foreach($_POST["indexes"]as$r){if(in_array($r["type"],$Fc)){$s=array();$rc=array();$u=array();ksort($r["columns"]);foreach($r["columns"]as$e=>$ha){if(strlen($ha)){$pa=$r["lengths"][$e];$u[]=idf_escape($ha).($pa?"(".intval($pa).")":"");$s[count($s)+1]=$ha;$rc[count($rc)+1]=($pa?$pa:null);}}if($s){foreach($v
as$j=>$Ra){ksort($Ra["columns"]);ksort($Ra["lengths"]);if($r["type"]==$Ra["type"]&&$Ra["columns"]===$s&&$Ra["lengths"]===$rc){unset($v[$j]);continue
2;}}$Jb[]="\nADD $r[type]".($r["type"]=="PRIMARY"?" KEY":"")." (".implode(", ",$u).")";}}}foreach($v
as$j=>$Ra){$Jb[]="\nDROP INDEX ".idf_escape($j);}if(!$Jb){redirect(ME."table=".urlencode($i));}query_redirect("ALTER TABLE ".idf_escape($i).implode(",",$Jb),ME."table=".urlencode($i),lang(127));}page_header(lang(80),$n,array("table"=>$i),$i);$l=array_keys(fields($i));$a=array("indexes"=>$v);if($_POST){$a=$_POST;if($_POST["add"]){foreach($a["indexes"]as$e=>$r){if(strlen($r["columns"][count($r["columns"])])){$a["indexes"][$e]["columns"][]="";}}$r=end($a["indexes"]);if($r["type"]||array_filter($r["columns"],'strlen')||array_filter($r["lengths"],'strlen')){$a["indexes"][]=array("columns"=>array(1=>""));}}}else{foreach($a["indexes"]as$e=>$r){$a["indexes"][$e]["columns"][]="";}$a["indexes"][]=array("columns"=>array(1=>""));}echo'
<form action="" method="post">
<table cellspacing="0">
<thead><tr><th>',lang(128),'<th>',lang(129),'</thead>
';$I=0;foreach($a["indexes"]as$r){echo"<tr><td>".html_select("indexes[$I][type]",array(-1=>"")+$Fc,$r["type"],($I==count($a["indexes"])-1?"indexes_add_row(this);":1))."<td>\n";ksort($r["columns"]);foreach($r["columns"]as$h=>$ha){echo"<span>".html_select("indexes[$I][columns][$h]",array(-1=>"")+$l,$ha,($h==count($r["columns"])?"indexes_add_column(this);":1)),"<input name='indexes[$I][lengths][$h]' size='2' value='".h($r["lengths"][$h])."'> </span>\n";}echo"\n";$I++;}echo'</table>
<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(113),'">
<noscript><p><input type="submit" name="add" value="',lang(72),'"></noscript>
</form>
';}elseif(isset($_GET["database"])){if($_POST&&!$n&&!isset($_POST["add_x"])){if(DB!==$_POST["name"]){restart_session();unset($_SESSION["databases"][$_GET["server"]]);$Ua=explode("\n",str_replace("\r","",$_POST["name"]));$mb=false;$wb="";foreach($Ua
as$w){if(count($Ua)==1||strlen($w)){if(!queries("CREATE DATABASE ".idf_escape($w).($_POST["collation"]?" COLLATE ".$d->quote($_POST["collation"]):""))){$mb=true;}$wb=$w;}}if(query_redirect(queries(),ME."db=".urlencode($wb),lang(130),!strlen(DB),false,$mb)){$f=$d->query("SHOW TABLES");while($a=$f->fetch_row()){if(!queries("RENAME TABLE ".idf_escape($a[0])." TO ".idf_escape($_POST["name"]).".".idf_escape($a[0]))){break;}}if(!$a){queries("DROP DATABASE ".idf_escape(DB));}queries_redirect(preg_replace('~db=[^&]*&~','',ME)."db=".urlencode($_POST["name"]),lang(131),!$a);}}else{if(!$_POST["collation"]){redirect(substr(ME,0,-1));}query_redirect("ALTER DATABASE ".idf_escape($_POST["name"])." COLLATE ".$d->quote($_POST["collation"]),substr(ME,0,-1),lang(132));}}page_header(strlen(DB)?lang(133):lang(134),$n,array(),DB);$H=collations();$j=DB;$jb=null;if($_POST){$j=$_POST["name"];$jb=$_POST["collation"];}elseif(!strlen(DB)){$f=$d->query("SHOW GRANTS");while($a=$f->fetch_row()){if(preg_match('~ ON (`(([^\\\\`]|``|\\\\.)*)%`\\.\\*)?~',$a[0],$k)&&$k[1]){$j=stripcslashes(idf_unescape($k[2]));break;}}}else{$jb=db_collation(DB,$H);}echo'
<form action="" method="post">
<p>
',($_POST["add_x"]||strpos($j,"\n")?'<textarea name="name" rows="10" cols="40">'.h($j).'</textarea><br>':'<input name="name" value="'.h($j).'" maxlength="64">')."\n",html_select("collation",array(""=>"(".lang(63).")")+$H,$jb),'<input type="hidden" name="token" value="',$_,'">
 <input type="submit" value="',lang(113),'">
';if(!$_POST["add_x"]){echo"<input type='image' name='add' src='".h(preg_replace("~\\?.*~","",$_SERVER["REQUEST_URI"]))."?file=plus.gif&amp;version=2.2.1' alt='+' title='".lang(72)."'>\n";}echo'</form>
';}elseif(isset($_GET["call"])){$W=$_GET["call"];page_header(lang(135).": ".h($W),$n);$da=routine($W,(isset($_GET["callf"])?"FUNCTION":"PROCEDURE"));$Ma=array();$sa=array();foreach($da["fields"]as$h=>$c){if(substr($c["inout"],-3)=="OUT"){$sa[$h]="@".idf_escape($c["field"])." AS ".idf_escape($c["field"]);}if(!$c["inout"]||substr($c["inout"],0,2)=="IN"){$Ma[]=$h;}}if(!$n&&$_POST){$Bc=array();foreach($da["fields"]as$e=>$c){if(in_array($e,$Ma)){$b=process_input($c);if($b===false){$b="''";}if(isset($sa[$e])){$d->query("SET @".idf_escape($c["field"])." = $b");}}$Bc[]=(isset($sa[$e])?"@".idf_escape($c["field"]):$b);}$f=$d->multi_query((isset($_GET["callf"])?"SELECT":"CALL")." ".idf_escape($W)."(".implode(", ",$Bc).")");if(!$f){echo"<p class='error'>".h($d->error)."\n";}else{do{$f=$d->store_result();if(is_object($f)){select($f);}else{echo"<p class='message'>".lang(136,$d->affected_rows)."\n";}}while($d->next_result());if($sa){select($d->query("SELECT ".implode(", ",$sa)));}}}echo'
<form action="" method="post">
';if($Ma){echo"<table cellspacing='0'>\n";foreach($Ma
as$e){$c=$da["fields"][$e];echo"<tr><th>".h($c["field"]);$o=$_POST["fields"][$e];if(strlen($o)&&ereg("enum|set",$c["type"])){$o=intval($o);}input($c,$o,(string)$_POST["function"][$j]);echo"\n";}echo"</table>\n";}echo'<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(135),'">
</form>
';}elseif(isset($_GET["foreign"])){$i=$_GET["foreign"];if($_POST&&!$n&&!$_POST["add"]&&!$_POST["change"]&&!$_POST["change-js"]){if($_POST["drop"]){query_redirect("ALTER TABLE ".idf_escape($i)."\nDROP FOREIGN KEY ".idf_escape($_GET["name"]),ME."table=".urlencode($i),lang(137));}else{$Q=array_filter($_POST["source"],'strlen');ksort($Q);$Ja=array();foreach($Q
as$e=>$b){$Ja[$e]=$_POST["target"][$e];}query_redirect("ALTER TABLE ".idf_escape($i).(strlen($_GET["name"])?"\nDROP FOREIGN KEY ".idf_escape($_GET["name"]).",":"")."\nADD FOREIGN KEY (".implode(", ",array_map('idf_escape',$Q)).") REFERENCES ".idf_escape($_POST["table"])." (".implode(", ",array_map('idf_escape',$Ja)).")".(in_array($_POST["on_delete"],$La)?" ON DELETE $_POST[on_delete]":"").(in_array($_POST["on_update"],$La)?" ON UPDATE $_POST[on_update]":""),ME."table=".urlencode($i),(strlen($_GET["name"])?lang(138):lang(139)));$n=lang(140)."<br>$n";}}page_header(lang(141),$n,array("table"=>$i),$i);$a=array("table"=>$i,"source"=>array(""));if($_POST){$a=$_POST;ksort($a["source"]);if($_POST["add"]){$a["source"][]="";}elseif($_POST["change"]||$_POST["change-js"]){$a["target"]=array();}}elseif(strlen($_GET["name"])){$D=foreign_keys($i);$a=$D[$_GET["name"]];$a["source"][]="";}$Q=array_keys(fields($i));$Ja=($i===$a["table"]?$Q:array_keys(fields($a["table"])));echo'
<form action="" method="post">
<p>
';if(!strlen($a["db"])){echo
lang(142),':
',html_select("table",array_keys(table_status_referencable()),$a["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
</p>
<noscript><p><input type="submit" name="change" value="',lang(143),'"></noscript>
<table cellspacing="0">
<thead><tr><th>',lang(144),'<th>',lang(145),'</thead>
';$I=0;foreach($a["source"]as$e=>$b){echo"<tr>","<td>".html_select("source[".intval($e)."]",array(-1=>"")+$Q,$b,($I==count($a["source"])-1?"foreign_add_row(this);":1)),"<td>".html_select("target[".intval($e)."]",$Ja,$a["target"][$e]);$I++;}echo'</table>
<p>
',lang(146),': ',html_select("on_delete",array(-1=>"")+$La,$a["on_delete"]),' ',lang(147),': ',html_select("on_update",array(-1=>"")+$La,$a["on_update"]),'<p>
<input type="submit" value="',lang(113),'">
<noscript><p><input type="submit" name="add" value="',lang(148),'"></noscript>
';}if(strlen($_GET["name"])){echo'<input type="submit" name="drop" value="',lang(59),'"',$tb,'>';}echo'<input type="hidden" name="token" value="',$_,'">
</form>
';}elseif(isset($_GET["view"])){$i=$_GET["view"];$ma=false;if($_POST&&!$n){$ma=drop_create("DROP VIEW ".idf_escape($i),"CREATE VIEW ".idf_escape($_POST["name"])." AS\n$_POST[select]",substr(ME,0,-1),lang(149),lang(150),lang(151),$i);}page_header((strlen($i)?lang(12):lang(152)),$n,array("table"=>$i),$i);$a=array();if($_POST){$a=$_POST;}elseif(strlen($i)){$a=view($i);$a["name"]=$i;}echo'
<form action="" method="post">
<p><textarea name="select" rows="10" cols="80" style="width: 98%;">',h($a["select"]),'</textarea>
<p>
<input type="hidden" name="token" value="',$_,'">
';if($ma){echo'<input type="hidden" name="dropped" value="1">';}echo
lang(153),': <input name="name" value="',h($a["name"]),'" maxlength="64">
<input type="submit" value="',lang(113),'">
</form>
';}elseif(isset($_GET["event"])){$ya=$_GET["event"];$ad=array("YEAR","QUARTER","MONTH","DAY","HOUR","MINUTE","WEEK","SECOND","YEAR_MONTH","DAY_HOUR","DAY_MINUTE","DAY_SECOND","HOUR_MINUTE","HOUR_SECOND","MINUTE_SECOND");$pc=array("ENABLED"=>"ENABLE","DISABLED"=>"DISABLE","SLAVESIDE_DISABLED"=>"DISABLE ON SLAVE");if($_POST&&!$n){if($_POST["drop"]){query_redirect("DROP EVENT ".idf_escape($ya),substr(ME,0,-1),lang(154));}elseif(in_array($_POST["INTERVAL_FIELD"],$ad)&&isset($pc[$_POST["STATUS"]])){$Tc="\nON SCHEDULE ".($_POST["INTERVAL_VALUE"]?"EVERY ".$d->quote($_POST["INTERVAL_VALUE"])." $_POST[INTERVAL_FIELD]".($_POST["STARTS"]?" STARTS ".$d->quote($_POST["STARTS"]):"").($_POST["ENDS"]?" ENDS ".$d->quote($_POST["ENDS"]):""):"AT ".$d->quote($_POST["STARTS"]))." ON COMPLETION".($_POST["ON_COMPLETION"]?"":" NOT")." PRESERVE";query_redirect((strlen($ya)?"ALTER EVENT ".idf_escape($ya).$Tc.($ya!=$_POST["EVENT_NAME"]?"\nRENAME TO ".idf_escape($_POST["EVENT_NAME"]):""):"CREATE EVENT ".idf_escape($_POST["EVENT_NAME"]).$Tc)."\n".$pc[$_POST["STATUS"]]." COMMENT ".$d->quote($_POST["EVENT_COMMENT"])." DO\n$_POST[EVENT_DEFINITION]",substr(ME,0,-1),(strlen($ya)?lang(155):lang(156)));}}page_header((strlen($ya)?lang(157).": ".h($ya):lang(158)),$n);$a=array();if($_POST){$a=$_POST;}elseif(strlen($ya)){$f=$d->query("SELECT * FROM information_schema.EVENTS WHERE EVENT_SCHEMA = ".$d->quote(DB)." AND EVENT_NAME = ".$d->quote($ya));$a=$f->fetch_assoc();}echo'
<form action="" method="post">
<table cellspacing="0">
<tr><th>',lang(153),'<td><input name="EVENT_NAME" value="',h($a["EVENT_NAME"]),'" maxlength="64">
<tr><th>',lang(159),'<td><input name="STARTS" value="',h("$a[EXECUTE_AT]$a[STARTS]"),'">
<tr><th>',lang(160),'<td><input name="ENDS" value="',h($a["ENDS"]),'">
<tr><th>',lang(161),'<td><input name="INTERVAL_VALUE" value="',h($a["INTERVAL_VALUE"]),'" size="6"> ',html_select("INTERVAL_FIELD",$ad,$a["INTERVAL_FIELD"]),'<tr><th>',lang(162),'<td>',html_select("STATUS",$pc,$a["STATUS"]),'<tr><th>',lang(71),'<td><input name="EVENT_COMMENT" value="',h($a["EVENT_COMMENT"]),'" maxlength="64">
<tr><th>&nbsp;<td>',checkbox("ON_COMPLETION","PRESERVE",$a["ON_COMPLETION"]=="PRESERVE",lang(163)),'</table>
<p><textarea name="EVENT_DEFINITION" rows="10" cols="80" style="width: 98%;">',h($a["EVENT_DEFINITION"]),'</textarea>
<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(113),'">
';if(strlen($ya)){echo'<input type="submit" name="drop" value="',lang(59),'"',$tb,'>';}echo'</form>
';}elseif(isset($_GET["procedure"])){$W=$_GET["procedure"];$da=(isset($_GET["function"])?"FUNCTION":"PROCEDURE");$ma=false;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["drop_col"]&&!$_POST["up"]&&!$_POST["down"]){$u=array();$l=(array)$_POST["fields"];ksort($l);foreach($l
as$c){if(strlen($c["field"])){$u[]=(in_array($c["inout"],$Sa)?"$c[inout] ":"").idf_escape($c["field"]).process_type($c,"CHARACTER SET");}}$ma=drop_create("DROP $da ".idf_escape($W),"CREATE $da ".idf_escape($_POST["name"])." (".implode(", ",$u).")".(isset($_GET["function"])?" RETURNS".process_type($_POST["returns"],"CHARACTER SET"):"")."\n$_POST[definition]",substr(ME,0,-1),lang(164),lang(165),lang(166),$W);}page_header((strlen($W)?(isset($_GET["function"])?lang(167):lang(168)).": ".h($W):(isset($_GET["function"])?lang(169):lang(170))),$n);$H=get_vals("SHOW CHARACTER SET");sort($H);$a=array("fields"=>array());if($_POST){$a=$_POST;$a["fields"]=(array)$a["fields"];process_fields($a["fields"]);}elseif(strlen($W)){$a=routine($W,$da);$a["name"]=$W;}echo'
<form action="" method="post" id="form">
<table cellspacing="0">
';edit_fields($a["fields"],$H,$da);if(isset($_GET["function"])){echo'<tr><td>',lang(171);edit_type("returns",$a["returns"],$H);}echo'</table>
<p><textarea name="definition" rows="10" cols="80" style="width: 98%;">',h($a["definition"]),'</textarea>
<p>
<input type="hidden" name="token" value="',$_,'">
';if($ma){echo'<input type="hidden" name="dropped" value="1">';}echo
lang(153),': <input name="name" value="',h($a["name"]),'" maxlength="64">
<input type="submit" value="',lang(113),'">
';if(strlen($W)){echo'<input type="submit" name="drop" value="',lang(59),'"',$tb,'>';}echo'</form>
';}elseif(isset($_GET["trigger"])){$i=$_GET["trigger"];$Mc=array("BEFORE","AFTER");$Qc=array("INSERT","UPDATE","DELETE");$ma=false;if($_POST&&!$n&&in_array($_POST["Timing"],$Mc)&&in_array($_POST["Event"],$Qc)){$ma=drop_create("DROP TRIGGER ".idf_escape($_GET["name"]),"CREATE TRIGGER ".idf_escape($_POST["Trigger"])." $_POST[Timing] $_POST[Event] ON ".idf_escape($i)." FOR EACH ROW\n$_POST[Statement]",ME."table=".urlencode($i),lang(172),lang(173),lang(174),$_GET["name"]);}page_header((strlen($_GET["name"])?lang(175).": ".h($_GET["name"]):lang(176)),$n,array("table"=>$i));$a=array("Trigger"=>$i."_bi");if($_POST){$a=$_POST;}elseif(strlen($_GET["name"])){$f=$d->query("SHOW TRIGGERS WHERE `Trigger` = ".$d->quote($_GET["name"]));$a=$f->fetch_assoc();}echo'
<form action="" method="post" id="form">
<table cellspacing="0">
<tr><th>',lang(177),'<td>',html_select("Timing",$Mc,$a["Timing"],"if (/^".h(preg_quote($i,"/"))."_[ba][iud]$/.test(this.form['Trigger'].value)) this.form['Trigger'].value = '".h(addcslashes($i,"\r\n'\\"))."_' + select_value(this).charAt(0).toLowerCase() + select_value(this.form['Event']).charAt(0).toLowerCase();"),'<tr><th>',lang(178),'<td>',html_select("Event",$Qc,$a["Event"],"this.form['Timing'].onchange();"),'<tr><th>',lang(153),'<td><input name="Trigger" value="',h($a["Trigger"]),'" maxlength="64">
</table>
<p><textarea name="Statement" rows="10" cols="80" style="width: 98%;">',h($a["Statement"]),'</textarea>
<p>
<input type="hidden" name="token" value="',$_,'">
';if($ma){echo'<input type="hidden" name="dropped" value="1">';}echo'<input type="submit" value="',lang(113),'">
';if(strlen($_GET["name"])){echo'<input type="submit" name="drop" value="',lang(59),'"',$tb,'>';}echo'</form>
';}elseif(isset($_GET["user"])){$Yb=$_GET["user"];$J=array(""=>array("All privileges"=>""));$f=$d->query("SHOW PRIVILEGES");while($a=$f->fetch_assoc()){foreach(explode(",",($a["Privilege"]=="Grant option"?"":$a["Context"]))as$Tb){$J[$Tb][$a["Privilege"]]=$a["Comment"];}}$J["Server Admin"]+=$J["File access on server"];$J["Databases"]["Create routine"]=$J["Procedures"]["Create routine"];unset($J["Procedures"]["Create routine"]);$J["Columns"]=array();foreach(array("Select","Insert","Update","References")as$b){$J["Columns"][$b]=$J["Tables"][$b];}unset($J["Server Admin"]["Usage"]);foreach($J["Tables"]as$e=>$b){unset($J["Databases"][$e]);}$sb=array();if($_POST){foreach($_POST["objects"]as$e=>$b){$sb[$b]=((array)$sb[$b])+((array)$_POST["grants"][$e]);}}$ta=array();$Wb="";if(isset($_GET["host"])&&($f=$d->query("SHOW GRANTS FOR ".$d->quote($Yb)."@".$d->quote($_GET["host"])))){while($a=$f->fetch_row()){if(preg_match('~GRANT (.*) ON (.*) TO ~',$a[0],$k)&&preg_match_all('~ *([^(,]*[^ ,(])( *\\([^)]+\\))?~',$k[1],$F,PREG_SET_ORDER)){foreach($F
as$b){$ta["$k[2]$b[2]"][$b[1]]=true;if(ereg(' WITH GRANT OPTION',$a[0])){$ta["$k[2]$b[2]"]["GRANT OPTION"]=true;}}}if(preg_match("~ IDENTIFIED BY PASSWORD '([^']+)~",$a[0],$k)){$Wb=$k[1];}}}if($_POST&&!$n){$eb=(isset($_GET["host"])?$d->quote($Yb)."@".$d->quote($_GET["host"]):"''");$qa=$d->quote($_POST["user"])."@".$d->quote($_POST["host"]);$bc=$d->quote($_POST["pass"]);if($_POST["drop"]){query_redirect("DROP USER $eb",ME."privileges=",lang(179));}else{if($eb==$qa){queries("SET PASSWORD FOR $qa = ".($_POST["hashed"]?$bc:"PASSWORD($bc)"));}else{$n=!queries(($d->server_info<5?"GRANT USAGE ON *.* TO":"CREATE USER")." $qa IDENTIFIED BY".($_POST["hashed"]?" PASSWORD":"")." $bc");}if(!$n){$yb=array();foreach($sb
as$ja=>$E){if(isset($_GET["grant"])){$E=array_filter($E);}$E=array_keys($E);if(isset($_GET["grant"])){$yb=array_diff(array_keys(array_filter($sb[$ja],'strlen')),$E);}elseif($eb==$qa){$Yc=array_keys((array)$ta[$ja]);$yb=array_diff($Yc,$E);$E=array_diff($E,$Yc);unset($ta[$ja]);}if(preg_match('~^(.+)\\s*(\\(.*\\))?$~U',$ja,$k)&&(!grant("REVOKE",$yb,$k[2]," ON $k[1] FROM $qa")||!grant("GRANT",$E,$k[2]," ON $k[1] TO $qa"))){$n=true;break;}}}if(!$n&&isset($_GET["host"])){if($eb!=$qa){queries("DROP USER $eb");}elseif(!isset($_GET["grant"])){foreach($ta
as$ja=>$yb){if(preg_match('~^(.+)(\\(.*\\))?$~U',$ja,$k)){queries("REVOKE ".grant(array_keys($yb),$k[2])." ON $k[1] FROM $qa");}}}}queries_redirect(ME."privileges=",(isset($_GET["host"])?lang(180):lang(181)),!$n);if($eb!=$qa){$d->query("DROP USER $qa");}}}page_header((isset($_GET["host"])?lang(7).": ".h("$Yb@$_GET[host]"):lang(96)),$n,array("privileges"=>array('',lang(53))));if($_POST){$a=$_POST;$ta=$sb;}else{$a=$_GET+array("host"=>$d->result($d->query("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', -1)")));$a["pass"]=$Wb;if(strlen($Wb)){$a["hashed"]=true;}$ta[""]=true;}echo'<form action="" method="post">
<table cellspacing="0">
<tr><th>',lang(7),'<td><input name="user" maxlength="16" value="',h($a["user"]),'">
<tr><th>',lang(6),'<td><input name="host" maxlength="60" value="',h($a["host"]),'">
<tr><th>',lang(8),'<td><input id="pass" name="pass" value="',h($a["pass"]),'">
';if(!$a["hashed"]){echo'<script type="text/javascript">type_password(document.getElementById(\'pass\'));</script>';}echo
checkbox("hashed",1,$a["hashed"],lang(182),"type_password(this.form['pass'], this.checked);"),'</table>

';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".lang(53);$h=0;foreach($ta
as$ja=>$E){echo'<th>'.($ja!="*.*"?"<input name='objects[$h]' value='".h($ja)."' size='10'>":"<input type='hidden' name='objects[$h]' value='*.*' size='10'>*.*");$h++;}echo"</thead>\n";foreach(array(""=>"","Server Admin"=>lang(6),"Databases"=>lang(48),"Tables"=>lang(78),"Columns"=>lang(79),"Procedures"=>lang(183),)as$Tb=>$ub){foreach((array)$J[$Tb]as$vb=>$zb){echo"<tr".odd()."><td".($ub?">$ub<td":" colspan='2'").' lang="en" title="'.h($zb).'">'.h($vb);$h=0;foreach($ta
as$ja=>$E){$j="'grants[$h][".h(strtoupper($vb))."]'";$o=$E[strtoupper($vb)];if($Tb=="Server Admin"&&$ja!=(isset($ta["*.*"])?"*.*":"")){echo"<td>&nbsp;";}elseif(isset($_GET["grant"])){echo"<td><select name=$j><option><option value='1'".($o?" selected":"").">".lang(184)."<option value='0'".($o=="0"?" selected":"").">".lang(185)."</select>";}else{echo"<td align='center'><input type='checkbox' name=$j value='1'".($o?" checked":"").($vb=="All privileges"?" id='grants-$h-all'":($vb=="Grant option"?"":" onclick=\"if (this.checked) form_uncheck('grants-$h-all');\"")).">";}$h++;}}}echo"</table>\n",'<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(113),'">
';if(isset($_GET["host"])){echo'<input type="submit" name="drop" value="',lang(59),'"',$tb,'>';}echo'</form>
';}elseif(isset($_GET["processlist"])){if($_POST&&!$n){$Vb=0;foreach((array)$_POST["kill"]as$b){if(queries("KILL ".ereg_replace("[^0-9]+","",$b))){$Vb++;}}queries_redirect(ME."processlist=",lang(186,$Vb),$Vb||!$_POST["kill"]);}page_header(lang(54),$n);echo'
<form action="" method="post">
<table cellspacing="0" onclick="table_click(event);">
';$f=$d->query("SHOW PROCESSLIST");for($h=0;$a=$f->fetch_assoc();$h++){if(!$h){echo"<thead><tr lang='en'><th>&nbsp;<th>".implode("<th>",array_keys($a))."</thead>\n";}echo"<tr".odd()."><td>".checkbox("kill[]",$a["Id"],0)."<td>".implode("<td>",array_map('nbsp',$a))."\n";}echo'</table>
<p>
<input type="hidden" name="token" value="',$_,'">
<input type="submit" value="',lang(187),'">
</form>
';}elseif(isset($_GET["select"])){$i=$_GET["select"];$na=table_status($i);$v=indexes($i);$l=fields($i);$D=column_foreign_keys($i);$Zc=array();$s=array();unset($Ga);foreach($l
as$e=>$c){$j=$q->fieldName($c);if(isset($c["privileges"]["select"])&&strlen($j)){$s[$e]=html_entity_decode(strip_tags($j));if(ereg('text|blob',$c["type"])){$Ga=$q->selectLengthProcess();}}$Zc+=$c["privileges"];}list($t,$V)=$q->selectColumnsProcess($s,$v);$C=$q->selectSearchProcess($l,$v);$_a=$q->selectOrderProcess($l,$v);$Z=$q->selectLimitProcess();$Wa=($t?implode(", ",$t):"*")." FROM ".idf_escape($i).($C?" WHERE ".implode(" AND ",$C):"");$Zb=($V&&count($V)<count($t)?" GROUP BY ".implode(", ",$V):"").($_a?" ORDER BY ".implode(", ",$_a):"");if($_POST&&!$n){$Wc="(".implode(") OR (",array_map('where_check',(array)$_POST["check"])).")";$mc=($v["PRIMARY"]?($t?array_flip($v["PRIMARY"]["columns"]):array()):null);foreach($t
as$e=>$b){$b=$_GET["columns"][$e];if(!$b["fun"]){unset($mc[$b["col"]]);}}if($_POST["export"]){dump_headers($i);dump_table($i,"");if($_POST["format"]!="sql"){dump_csv($t?$t:array_keys($l));}if(!is_array($_POST["check"])||$mc===array()){dump_data($i,"INSERT","SELECT $Wa".(is_array($_POST["check"])?($C?" AND ":" WHERE ")."($Wc)":"").$Zb);}else{$Vc=array();foreach($_POST["check"]as$b){$Vc[]="(SELECT $Wa ".($C?"AND ":"WHERE ").where_check($b).$Zb." LIMIT 1)";}dump_data($i,"INSERT",implode(" UNION ALL ",$Vc));}exit;}if(!$q->selectEmailProcess($C,$D)){if(!$_POST["import"]){$f=true;$Ya=0;$kc=($_POST["delete"]?"DELETE FROM ":($_POST["clone"]?"INSERT INTO ":"UPDATE ")).idf_escape($i);$u=array();if(!$_POST["delete"]){foreach($s
as$j=>$b){$b=process_input($l[$j]);if($_POST["clone"]){$u[idf_escape($j)]=($b!==false?$b:idf_escape($j));}elseif($b!==false){$u[]=idf_escape($j)." = $b";}}$kc.=($_POST["clone"]?" (".implode(", ",array_keys($u)).")\nSELECT ".implode(", ",$u)."\nFROM ".idf_escape($i):" SET\n".implode(",\n",$u));}if($_POST["delete"]||$u){if($_POST["all"]||($mc===array()&&$_POST["check"])){$f=queries($kc.($_POST["all"]?($C?"\nWHERE ".implode(" AND ",$C):""):"\nWHERE $Wc"));$Ya=$d->affected_rows;}else{foreach((array)$_POST["check"]as$b){$f=queries($kc."\nWHERE ".where_check($b).(count($V)<count($t)?"":"\nLIMIT 1"));if(!$f){break;}$Ya+=$d->affected_rows;}}}queries_redirect(remove_from_uri("page"),lang(188,$Ya),$f);}elseif(is_string($L=get_file("csv_file",true))){$L=preg_replace("~^\xEF\xBB\xBF~",'',$L);$f=true;$Ha=array_keys($l);preg_match_all('~("[^"]*"|[^"\\r\\n])+~',$L,$F);$Ya=count($F[0]);queries("START TRANSACTION");foreach($F[0]as$e=>$b){preg_match_all('~(("[^"]*")+|[^,]*),~',"$b,",$ic);if(!$e&&!array_diff($ic[1],$Ha)){$Ha=$ic[1];$Ya--;}else{$u="";foreach($ic[1]as$h=>$Ab){$u.=", ".idf_escape($Ha[$h])." = ".(!strlen($Ab)&&$l[$Ha[$h]]["null"]?"NULL":$d->quote(str_replace('""','"',preg_replace('~^"|"$~','',$Ab))));}$u=substr($u,1);$f=queries("INSERT INTO ".idf_escape($_GET["select"])." SET$u ON DUPLICATE KEY UPDATE$u");if(!$f){break;}}}queries("COMMIT");queries_redirect(remove_from_uri("page"),lang(189,$Ya),$f);}else{$n=upload_error($L);}}}$O=$q->tableName($na);page_header(lang(16).": $O",$n);$u=null;if(isset($Zc["insert"])){$u="";foreach((array)$_GET["where"]as$b){if(count($D[$b["col"]])==1&&($b["op"]=="="||(!$b["op"]&&!ereg('[_%]',$b["val"])))){$u.="&set".urlencode("[".bracket_escape($b["col"])."]")."=".urlencode($b["val"]);}}}$q->selectLinks($na,$u);if(!$s){echo"<p class='error'>".lang(190).($l?"":": ".h($d->error)).".\n";}else{echo"<form action='' id='form'>\n","<div style='display: none;'>",(strlen($_GET["server"])?'<input type="hidden" name="server" value="'.h($_GET["server"]).'">':""),(strlen(DB)?'<input type="hidden" name="db" value="'.h(DB).'">':"");echo'<input type="hidden" name="select" value="'.h($i).'">',"</div>\n";$q->selectColumnsPrint($t,$s);$q->selectSearchPrint($C,$s,$v);$q->selectOrderPrint($_a,$s,$v);$q->selectLimitPrint($Z);$q->selectLengthPrint($Ga);$q->selectActionPrint($Ga);echo"</form>\n";$m="SELECT ".(intval($Z)&&$V&&count($V)<count($t)?"SQL_CALC_FOUND_ROWS ":"").$Wa.$Zb.(strlen($Z)?" LIMIT ".intval($Z).($_GET["page"]?" OFFSET ".($Z*$_GET["page"]):""):"");echo$q->selectQuery($m);$f=$d->query($m);if(!$f){echo"<p class='error'>".h($d->error)."\n";}else{$Kb=array();echo"<form action='' method='post' enctype='multipart/form-data'>\n";if(!$f->num_rows){echo"<p class='message'>".lang(61)."\n";}else{$Ba=array();while($a=$f->fetch_assoc()){$Ba[]=$a;}$hb=(intval($Z)&&$V&&count($V)<count($t)?$d->result($d->query(" SELECT FOUND_ROWS()")):count($Ba));$Jc=$q->backwardKeys($i,$O);echo"<table cellspacing='0' class='nowrap' onclick='table_click(event);'>\n","<thead><tr><td><input type='checkbox' id='all-page' onclick='form_check(this, /check/);'>";$dc=array();reset($t);$_a=1;foreach($Ba[0]as$e=>$b){$b=$_GET["columns"][key($t)];$c=$l[$t?$b["col"]:$e];$j=($c?$q->fieldName($c,$_a):"*");if(strlen($j)){$_a++;$dc[$e]=$j;echo'<th><a href="'.h(remove_from_uri('(order|desc)[^=]*').'&order%5B0%5D='.urlencode($e).($_GET["order"][0]==$e&&!$_GET["desc"][0]?'&desc%5B0%5D=1':'')).'">'.apply_sql_function($b["fun"],$j)."</a>";}next($t);}echo($Jc?"<th>".lang(191):"")."</thead>\n";foreach($q->rowDescriptions($Ba,$D)as$ec=>$a){$Sb=implode('&',unique_idf($Ba[$ec],$v));echo"<tr".odd()."><td>".checkbox("check[]",$Sb,in_array($Sb,(array)$_POST["check"]),"","this.form['all'].checked = false; form_uncheck('all-page');").(count($t)!=count($V)||information_schema(DB)?'':" <a href='".h(ME."edit=".urlencode($i)."&$Sb")."'>".lang(95)."</a>");foreach($a
as$e=>$b){if(isset($dc[$e])){$c=$l[$e];if(strlen($b)&&(!isset($Kb[$e])||strlen($Kb[$e]))){$Kb[$e]=(is_email($b)?$dc[$e]:"");}$z="";$b=$q->editVal($b,$c);if(!isset($b)){$b="<i>NULL</i>";}else{if(ereg('blob|binary',$c["type"])&&strlen($b)){$z=h(ME.'download='.urlencode($i).'&field='.urlencode($e)."&$Sb");}if(!strlen($b)){$b="&nbsp;";}elseif(strlen($Ga)&&ereg('text|blob',$c["type"])&&is_utf8($b)){$b=shorten_utf8($b,max(0,intval($Ga)));}else{$b=h($b);}if(!$z){foreach((array)$D[$e]as$G){if(count($D[$e])==1||count($G["source"])==1){foreach($G["source"]as$h=>$Q){$z.=where_link($h,$G["target"][$h],$Ba[$ec][$Q]);}$z=h((strlen($G["db"])?preg_replace('~([?&]db=)[^&]+~','\\1'.urlencode($G["db"]),ME):ME).'select='.urlencode($G["table"]).$z);break;}}}}if(!$z&&is_email($b)){$z="mailto:$b";}if(!$z&&is_url($a[$e])){$z="http://www.adminer.org/redirect/?url=".urlencode($a[$e]);}$b=$q->selectVal($b,$z,$c);echo"<td>$b";}}$q->backwardKeysPrint($Jc,$Ba[$ec]);echo"</tr>\n";}echo"</table>\n";if(intval($Z)&&count($V)>=count($t)){ob_flush();flush();$hb=$d->result($d->query("SELECT COUNT(*) FROM ".idf_escape($i).($C?" WHERE ".implode(" AND ",$C):"")));}echo"<p class='pages'>";if(intval($Z)&&$hb>$Z){$fc=floor(($hb-1)/$Z);echo
lang(192).":".pagination(0).($_GET["page"]>3?" ...":"");for($h=max(1,$_GET["page"]-2);$h<min($fc,$_GET["page"]+3);$h++){echo
pagination($h);}echo($_GET["page"]+3<$fc?" ...":"").pagination($fc);}echo" (".lang(99,$hb).") ".checkbox("all",1,0,lang(193))."\n",(information_schema(DB)?"":"<fieldset><legend>".lang(14)."</legend><div><input type='submit' name='edit' value='".lang(14)."'> <input type='submit' name='clone' value='".lang(194)."'> <input type='submit' name='delete' value='".lang(195)."' onclick=\"return confirm('".lang(60)." (' + (this.form['all'].checked ? $hb : form_checked(this, /check/)) + ')');\"></div></fieldset>\n");print_fieldset("export",lang(87));echo$q->dumpOutput(1)." ".$q->dumpFormat(1);echo" <input type='submit' name='export' value='".lang(87)."'>\n","</div></fieldset>\n";}print_fieldset("import",lang(196),!$f->num_rows);echo"<input type='hidden' name='token' value='$_'><input type='file' name='csv_file'> <input type='submit' name='import' value='".lang(197)."'>\n","</div></fieldset>\n";$q->selectEmailPrint(array_filter($Kb,'strlen'),$s);echo"</form>\n";}}}elseif(isset($_GET["variables"])){page_header(lang(55));echo"<table cellspacing='0'>\n";$f=$d->query("SHOW VARIABLES");while($a=$f->fetch_assoc()){echo"<tr>","<th><code class='jush-sqlset'>".h($a["Variable_name"])."</code>","<td>".nbsp($a["Value"]);}echo"</table>\n";}else{$gc=array_merge((array)$_POST["tables"],(array)$_POST["views"]);if($gc&&!$n){$f=true;$ba="";if(count($_POST["tables"])>1&&($_POST["drop"]||$_POST["truncate"])){queries("SET foreign_key_checks = 0");}if(isset($_POST["truncate"])){foreach((array)$_POST["tables"]as$p){if(!queries("TRUNCATE ".idf_escape($p))){$f=false;break;}}$ba=lang(198);}elseif(isset($_POST["move"])){$Cc=array();foreach($gc
as$p){$Cc[]=idf_escape($p)." TO ".idf_escape($_POST["target"]).".".idf_escape($p);}$f=queries("RENAME TABLE ".implode(", ",$Cc));$ba=lang(199);}elseif((!isset($_POST["drop"])||!$_POST["views"]||queries("DROP VIEW ".implode(", ",array_map('idf_escape',$_POST["views"]))))&&(!$_POST["tables"]||($f=queries((isset($_POST["optimize"])?"OPTIMIZE":(isset($_POST["check"])?"CHECK":(isset($_POST["repair"])?"REPAIR":(isset($_POST["drop"])?"DROP":"ANALYZE"))))." TABLE ".implode(", ",array_map('idf_escape',$_POST["tables"])))))){if(isset($_POST["drop"])){$ba=lang(200);}else{while($a=$f->fetch_assoc()){$ba.=h("$a[Table]: $a[Msg_text]")."<br>";}}}queries_redirect(substr(ME,0,-1),$ba,$f);}page_header(lang(48).": ".h(DB),$n,false);echo'<p><a href="'.h(ME).'database=">'.lang(133)."</a>\n",'<a href="'.h(ME).'schema=">'.lang(86)."</a>\n","<h3>".lang(201)."</h3>\n";$na=table_status();if(!$na){echo"<p class='message'>".lang(32)."\n";}else{echo"<form action='' method='post'>\n","<table cellspacing='0' class='nowrap' onclick='table_click(event);'>\n",'<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="form_check(this, /^(tables|views)\[/);" title="'.count($na).'"><th>'.lang(78).'<td>'.lang(202).'<td>'.lang(58).'<td>'.lang(203).'<td>'.lang(204).'<td>'.lang(205).'<td>'.lang(69).'<td>'.lang(206).'<td>'.lang(71)."</thead>\n";foreach($na
as$a){$j=$a["Name"];echo'<tr'.odd().'><td>'.checkbox((isset($a["Rows"])?"tables[]":"views[]"),$j,in_array($j,$gc,true),"","form_uncheck('check-all');"),'<th><a href="'.h(ME).'table='.urlencode($j).'">'.h($j).'</a>';if(isset($a["Rows"])){echo"<td>$a[Engine]<td>$a[Collation]";foreach(array("Data_length"=>"create","Index_length"=>"indexes","Data_free"=>"edit","Auto_increment"=>"create","Rows"=>"select")as$e=>$z){$b=number_format($a[$e],0,'.',lang(207));echo'<td align="right">'.(strlen($a[$e])?'<a href="'.h(ME."$z=").urlencode($j).'">'.str_replace(" ","&nbsp;",($e=="Rows"&&$a["Engine"]=="InnoDB"&&$b?lang(94,$b):$b)).'</a>':'&nbsp;');}echo"<td>".nbsp($a["Comment"]);}else{echo'<td colspan="6"><a href="'.h(ME)."view=".urlencode($j).'">'.lang(77).'</a>','<td align="right"><a href="'.h(ME)."select=".urlencode($j).'">?</a>','<td>&nbsp;';}}echo"</table>\n","<p><input type='hidden' name='token' value='$_'><input type='submit' value='".lang(208)."'> <input type='submit' name='optimize' value='".lang(209)."'> <input type='submit' name='check' value='".lang(210)."'> <input type='submit' name='repair' value='".lang(211)."'> <input type='submit' name='truncate' value='".lang(212)."' onclick=\"return confirm('".lang(60)." (' + form_checked(this, /tables/) + ')');\"> <input type='submit' name='drop' value='".lang(59)."' onclick=\"return confirm('".lang(60)." (' + form_checked(this, /tables|views/) + ')');\">\n";$Ua=get_databases();if(count($Ua)!=1){$w=(isset($_POST["target"])?$_POST["target"]:DB);echo"<p>".lang(213).($Ua?": ".html_select("target",$Ua,$w):': <input name="target" value="'.h($w).'">')." <input type='submit' name='move' value='".lang(214)."'>\n";}echo"</form>\n";}if($d->server_info>=5){echo'<p><a href="'.h(ME).'view=">'.lang(152)."</a>\n","<h3>".lang(90)."</h3>\n";$f=$d->query("SELECT * FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".$d->quote(DB));if($f->num_rows){echo"<table cellspacing='0'>\n";while($a=$f->fetch_assoc()){echo"<tr>","<td>".h($a["ROUTINE_TYPE"]),'<th><a href="'.h(ME).($a["ROUTINE_TYPE"]=="FUNCTION"?'callf=':'call=').urlencode($a["ROUTINE_NAME"]).'">'.h($a["ROUTINE_NAME"]).'</a>','<td><a href="'.h(ME).($a["ROUTINE_TYPE"]=="FUNCTION"?'function=':'procedure=').urlencode($a["ROUTINE_NAME"]).'">'.lang(82)."</a>";}echo"</table>\n";}echo'<p><a href="'.h(ME).'procedure=">'.lang(170).'</a> <a href="'.h(ME).'function=">'.lang(169)."</a>\n";}if($d->server_info>=5.1&&($f=$d->query("SHOW EVENTS"))){echo"<h3>".lang(91)."</h3>\n";if($f->num_rows){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(153)."<td>".lang(215)."<td>".lang(159)."<td>".lang(160)."</thead>\n";while($a=$f->fetch_assoc()){echo"<tr>",'<th><a href="'.h(ME).'event='.urlencode($a["Name"]).'">'.h($a["Name"])."</a>","<td>".($a["Execute at"]?lang(216)."<td>".$a["Execute at"]:lang(161)." ".$a["Interval value"]." ".$a["Interval field"]."<td>$a[Starts]"),"<td>$a[Ends]";}echo"</table>\n";}echo'<p><a href="'.h(ME).'event=">'.lang(158)."</a>\n";}}page_footer();

ACC SHELL 2018