Guest User

Untitled

a guest
Aug 16th, 2018
1,254
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 342.18 KB | None | 0 0
  1. <?php
  2. /** Adminer - Compact database management
  3. * @link https://www.adminer.org/
  4. * @author Jakub Vrana, https://www.vrana.cz/
  5. * @copyright 2007 Jakub Vrana
  6. * @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
  7. * @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
  8. * @version 4.6.3
  9. */error_reporting(6135);$Uc=!preg_match('~^(unsafe_raw)?$~',ini_get("filter.default"));if($Uc||ini_get("filter.default_flags")){foreach(array('_GET','_POST','_COOKIE','_SERVER')as$X){$Ai=filter_input_array(constant("INPUT$X"),FILTER_UNSAFE_RAW);if($Ai)$$X=$Ai;}}if(function_exists("mb_internal_encoding"))mb_internal_encoding("8bit");function
  10. connection(){global$g;return$g;}function
  11. adminer(){global$b;return$b;}function
  12. version(){global$ia;return$ia;}function
  13. idf_unescape($u){$ke=substr($u,-1);return
  14. str_replace($ke.$ke,$ke,substr($u,1,-1));}function
  15. escape_string($X){return
  16. substr(q($X),1,-1);}function
  17. number($X){return
  18. preg_replace('~[^0-9]+~','',$X);}function
  19. number_type(){return'((?<!o)int(?!er)|numeric|real|float|double|decimal|money)';}function
  20. remove_slashes($kg,$Uc=false){if(get_magic_quotes_gpc()){while(list($y,$X)=each($kg)){foreach($X
  21. as$ae=>$W){unset($kg[$y][$ae]);if(is_array($W)){$kg[$y][stripslashes($ae)]=$W;$kg[]=&$kg[$y][stripslashes($ae)];}else$kg[$y][stripslashes($ae)]=($Uc?$W:stripslashes($W));}}}}function
  22. bracket_escape($u,$Na=false){static$li=array(':'=>':1',']'=>':2','['=>':3','"'=>':4');return
  23. strtr($u,($Na?array_flip($li):$li));}function
  24. min_version($Ri,$ye="",$h=null){global$g;if(!$h)$h=$g;$fh=$h->server_info;if($ye&&preg_match('~([\d.]+)-MariaDB~',$fh,$B)){$fh=$B[1];$Ri=$ye;}return(version_compare($fh,$Ri)>=0);}function
  25. charset($g){return(min_version("5.5.3",0,$g)?"utf8mb4":"utf8");}function
  26. script($ph,$ki="\n"){return"<script".nonce().">$ph</script>$ki";}function
  27. script_src($Fi){return"<script src='".h($Fi)."'".nonce()."></script>\n";}function
  28. nonce(){return' nonce="'.get_nonce().'"';}function
  29. target_blank(){return' target="_blank" rel="noreferrer noopener"';}function
  30. h($Q){return
  31. str_replace("\0","&#0;",htmlspecialchars($Q,ENT_QUOTES,'utf-8'));}function
  32. nl_br($Q){return
  33. str_replace("\n","<br>",$Q);}function
  34. checkbox($C,$Y,$eb,$he="",$mf="",$jb="",$ie=""){$I="<input type='checkbox' name='$C' value='".h($Y)."'".($eb?" checked":"").($ie?" aria-labelledby='$ie'":"").">".($mf?script("qsl('input').onclick = function () { $mf };",""):"");return($he!=""||$jb?"<label".($jb?" class='$jb'":"").">$I".h($he)."</label>":$I);}function
  35. optionlist($sf,$Zg=null,$Ji=false){$I="";foreach($sf
  36. as$ae=>$W){$tf=array($ae=>$W);if(is_array($W)){$I.='<optgroup label="'.h($ae).'">';$tf=$W;}foreach($tf
  37. as$y=>$X)$I.='<option'.($Ji||is_string($y)?' value="'.h($y).'"':'').(($Ji||is_string($y)?(string)$y:$X)===$Zg?' selected':'').'>'.h($X);if(is_array($W))$I.='</optgroup>';}return$I;}function
  38. html_select($C,$sf,$Y="",$lf=true,$ie=""){if($lf)return"<select name='".h($C)."'".($ie?" aria-labelledby='$ie'":"").">".optionlist($sf,$Y)."</select>".(is_string($lf)?script("qsl('select').onchange = function () { $lf };",""):"");$I="";foreach($sf
  39. as$y=>$X)$I.="<label><input type='radio' name='".h($C)."' value='".h($y)."'".($y==$Y?" checked":"").">".h($X)."</label>";return$I;}function
  40. select_input($Ja,$sf,$Y="",$lf="",$Wf=""){$Ph=($sf?"select":"input");return"<$Ph$Ja".($sf?"><option value=''>$Wf".optionlist($sf,$Y,true)."</select>":" size='10' value='".h($Y)."' placeholder='$Wf'>").($lf?script("qsl('$Ph').onchange = $lf;",""):"");}function
  41. confirm($He="",$ah="qsl('input')"){return
  42. script("$ah.onclick = function () { return confirm('".($He?js_escape($He):'Are you sure?')."'); };","");}function
  43. print_fieldset($t,$pe,$Ui=false){echo"<fieldset><legend>","<a href='#fieldset-$t'>$pe</a>",script("qsl('a').onclick = partial(toggle, 'fieldset-$t');",""),"</legend>","<div id='fieldset-$t'".($Ui?"":" class='hidden'").">\n";}function
  44. bold($Va,$jb=""){return($Va?" class='active $jb'":($jb?" class='$jb'":""));}function
  45. odd($I=' class="odd"'){static$s=0;if(!$I)$s=-1;return($s++%2?$I:'');}function
  46. js_escape($Q){return
  47. addcslashes($Q,"\r\n'\\/");}function
  48. json_row($y,$X=null){static$Vc=true;if($Vc)echo"{";if($y!=""){echo($Vc?"":",")."\n\t\"".addcslashes($y,"\r\n\t\"\\/").'": '.($X!==null?'"'.addcslashes($X,"\r\n\"\\/").'"':'null');$Vc=false;}else{echo"\n}\n";$Vc=true;}}function
  49. ini_bool($Nd){$X=ini_get($Nd);return(preg_match('~^(on|true|yes)$~i',$X)||(int)$X);}function
  50. sid(){static$I;if($I===null)$I=(SID&&!($_COOKIE&&ini_bool("session.use_cookies")));return$I;}function
  51. set_password($Qi,$N,$V,$F){$_SESSION["pwds"][$Qi][$N][$V]=($_COOKIE["adminer_key"]&&is_string($F)?array(encrypt_string($F,$_COOKIE["adminer_key"])):$F);}function
  52. get_password(){$I=get_session("pwds");if(is_array($I))$I=($_COOKIE["adminer_key"]?decrypt_string($I[0],$_COOKIE["adminer_key"]):false);return$I;}function
  53. q($Q){global$g;return$g->quote($Q);}function
  54. get_vals($G,$e=0){global$g;$I=array();$H=$g->query($G);if(is_object($H)){while($J=$H->fetch_row())$I[]=$J[$e];}return$I;}function
  55. get_key_vals($G,$h=null,$ih=true){global$g;if(!is_object($h))$h=$g;$I=array();$H=$h->query($G);if(is_object($H)){while($J=$H->fetch_row()){if($ih)$I[$J[0]]=$J[1];else$I[]=$J[0];}}return$I;}function
  56. get_rows($G,$h=null,$n="<p class='error'>"){global$g;$wb=(is_object($h)?$h:$g);$I=array();$H=$wb->query($G);if(is_object($H)){while($J=$H->fetch_assoc())$I[]=$J;}elseif(!$H&&!is_object($h)&&$n&&defined("PAGE_HEADER"))echo$n.error()."\n";return$I;}function
  57. unique_array($J,$w){foreach($w
  58. as$v){if(preg_match("~PRIMARY|UNIQUE~",$v["type"])){$I=array();foreach($v["columns"]as$y){if(!isset($J[$y]))continue
  59. 2;$I[$y]=$J[$y];}return$I;}}}function
  60. escape_key($y){if(preg_match('(^([\w(]+)('.str_replace("_",".*",preg_quote(idf_escape("_"))).')([ \w)]+)$)',$y,$B))return$B[1].idf_escape(idf_unescape($B[2])).$B[3];return
  61. idf_escape($y);}function
  62. where($Z,$p=array()){global$g,$x;$I=array();foreach((array)$Z["where"]as$y=>$X){$y=bracket_escape($y,1);$e=escape_key($y);$I[]=$e.($x=="sql"&&preg_match('~^[0-9]*\.[0-9]*$~',$X)?" LIKE ".q(addcslashes($X,"%_\\")):($x=="mssql"?" LIKE ".q(preg_replace('~[_%[]~','[\0]',$X)):" = ".unconvert_field($p[$y],q($X))));if($x=="sql"&&preg_match('~char|text~',$p[$y]["type"])&&preg_match("~[^ -@]~",$X))$I[]="$e = ".q($X)." COLLATE ".charset($g)."_bin";}foreach((array)$Z["null"]as$y)$I[]=escape_key($y)." IS NULL";return
  63. implode(" AND ",$I);}function
  64. where_check($X,$p=array()){parse_str($X,$cb);remove_slashes(array(&$cb));return
  65. where($cb,$p);}function
  66. where_link($s,$e,$Y,$of="="){return"&where%5B$s%5D%5Bcol%5D=".urlencode($e)."&where%5B$s%5D%5Bop%5D=".urlencode(($Y!==null?$of:"IS NULL"))."&where%5B$s%5D%5Bval%5D=".urlencode($Y);}function
  67. convert_fields($f,$p,$L=array()){$I="";foreach($f
  68. as$y=>$X){if($L&&!in_array(idf_escape($y),$L))continue;$Ga=convert_field($p[$y]);if($Ga)$I.=", $Ga AS ".idf_escape($y);}return$I;}function
  69. cookie($C,$Y,$se=2592000){global$ba;return
  70. header("Set-Cookie: $C=".urlencode($Y).($se?"; expires=".gmdate("D, d M Y H:i:s",time()+$se)." GMT":"")."; path=".preg_replace('~\?.*~','',$_SERVER["REQUEST_URI"]).($ba?"; secure":"")."; HttpOnly; SameSite=lax",false);}function
  71. restart_session(){if(!ini_bool("session.use_cookies"))session_start();}function
  72. stop_session($ad=false){if(!ini_bool("session.use_cookies")||($ad&&@ini_set("session.use_cookies",false)!==false))session_write_close();}function&get_session($y){return$_SESSION[$y][DRIVER][SERVER][$_GET["username"]];}function
  73. set_session($y,$X){$_SESSION[$y][DRIVER][SERVER][$_GET["username"]]=$X;}function
  74. auth_url($Qi,$N,$V,$l=null){global$dc;preg_match('~([^?]*)\??(.*)~',remove_from_uri(implode("|",array_keys($dc))."|username|".($l!==null?"db|":"").session_name()),$B);return"$B[1]?".(sid()?SID."&":"").($Qi!="server"||$N!=""?urlencode($Qi)."=".urlencode($N)."&":"")."username=".urlencode($V).($l!=""?"&db=".urlencode($l):"").($B[2]?"&$B[2]":"");}function
  75. is_ajax(){return($_SERVER["HTTP_X_REQUESTED_WITH"]=="XMLHttpRequest");}function
  76. redirect($A,$He=null){if($He!==null){restart_session();$_SESSION["messages"][preg_replace('~^[^?]*~','',($A!==null?$A:$_SERVER["REQUEST_URI"]))][]=$He;}if($A!==null){if($A=="")$A=".";header("Location: $A");exit;}}function
  77. query_redirect($G,$A,$He,$wg=true,$Bc=true,$Mc=false,$Xh=""){global$g,$n,$b;if($Bc){$xh=microtime(true);$Mc=!$g->query($G);$Xh=format_time($xh);}$sh="";if($G)$sh=$b->messageQuery($G,$Xh,$Mc);if($Mc){$n=error().$sh.script("messagesPrint();");return
  78. false;}if($wg)redirect($A,$He.$sh);return
  79. true;}function
  80. queries($G){global$g;static$pg=array();static$xh;if(!$xh)$xh=microtime(true);if($G===null)return
  81. array(implode("\n",$pg),format_time($xh));$pg[]=(preg_match('~;$~',$G)?"DELIMITER ;;\n$G;\nDELIMITER ":$G).";";return$g->query($G);}function
  82. apply_queries($G,$T,$yc='table'){foreach($T
  83. as$R){if(!queries("$G ".$yc($R)))return
  84. false;}return
  85. true;}function
  86. queries_redirect($A,$He,$wg){list($pg,$Xh)=queries(null);return
  87. query_redirect($pg,$A,$He,$wg,false,!$wg,$Xh);}function
  88. format_time($xh){return
  89. sprintf('%.3f s',max(0,microtime(true)-$xh));}function
  90. remove_from_uri($Hf=""){return
  91. substr(preg_replace("~(?<=[?&])($Hf".(SID?"":"|".session_name()).")=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
  92. pagination($E,$Ib){return" ".($E==$Ib?$E+1:'<a href="'.h(remove_from_uri("page").($E?"&page=$E".($_GET["next"]?"&next=".urlencode($_GET["next"]):""):"")).'">'.($E+1)."</a>");}function
  93. get_file($y,$Qb=false){$Sc=$_FILES[$y];if(!$Sc)return
  94. null;foreach($Sc
  95. as$y=>$X)$Sc[$y]=(array)$X;$I='';foreach($Sc["error"]as$y=>$n){if($n)return$n;$C=$Sc["name"][$y];$fi=$Sc["tmp_name"][$y];$yb=file_get_contents($Qb&&preg_match('~\.gz$~',$C)?"compress.zlib://$fi":$fi);if($Qb){$xh=substr($yb,0,3);if(function_exists("iconv")&&preg_match("~^\xFE\xFF|^\xFF\xFE~",$xh,$Bg))$yb=iconv("utf-16","utf-8",$yb);elseif($xh=="\xEF\xBB\xBF")$yb=substr($yb,3);$I.=$yb."\n\n";}else$I.=$yb;}return$I;}function
  96. upload_error($n){$Ee=($n==UPLOAD_ERR_INI_SIZE?ini_get("upload_max_filesize"):0);return($n?'Unable to upload a file.'.($Ee?" ".sprintf('Maximum allowed file size is %sB.',$Ee):""):'File does not exist.');}function
  97. repeat_pattern($Uf,$qe){return
  98. str_repeat("$Uf{0,65535}",$qe/65535)."$Uf{0,".($qe%65535)."}";}function
  99. is_utf8($X){return(preg_match('~~u',$X)&&!preg_match('~[\0-\x8\xB\xC\xE-\x1F]~',$X));}function
  100. shorten_utf8($Q,$qe=80,$Dh=""){if(!preg_match("(^(".repeat_pattern("[\t\r\n -\x{10FFFF}]",$qe).")($)?)u",$Q,$B))preg_match("(^(".repeat_pattern("[\t\r\n -~]",$qe).")($)?)",$Q,$B);return
  101. h($B[1]).$Dh.(isset($B[2])?"":"<i>...</i>");}function
  102. format_number($X){return
  103. strtr(number_format($X,0,".",','),preg_split('~~u','0123456789',-1,PREG_SPLIT_NO_EMPTY));}function
  104. friendly_url($X){return
  105. preg_replace('~[^a-z0-9_]~i','-',$X);}function
  106. hidden_fields($kg,$Dd=array()){$I=false;while(list($y,$X)=each($kg)){if(!in_array($y,$Dd)){if(is_array($X)){foreach($X
  107. as$ae=>$W)$kg[$y."[$ae]"]=$W;}else{$I=true;echo'<input type="hidden" name="'.h($y).'" value="'.h($X).'">';}}}return$I;}function
  108. hidden_fields_get(){echo(sid()?'<input type="hidden" name="'.session_name().'" value="'.h(session_id()).'">':''),(SERVER!==null?'<input type="hidden" name="'.DRIVER.'" value="'.h(SERVER).'">':""),'<input type="hidden" name="username" value="'.h($_GET["username"]).'">';}function
  109. table_status1($R,$Nc=false){$I=table_status($R,$Nc);return($I?$I:array("Name"=>$R));}function
  110. column_foreign_keys($R){global$b;$I=array();foreach($b->foreignKeys($R)as$q){foreach($q["source"]as$X)$I[$X][]=$q;}return$I;}function
  111. enum_input($U,$Ja,$o,$Y,$sc=null){global$b;preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$_e);$I=($sc!==null?"<label><input type='$U'$Ja value='$sc'".((is_array($Y)?in_array($sc,$Y):$Y===0)?" checked":"")."><i>".'empty'."</i></label>":"");foreach($_e[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$eb=(is_int($Y)?$Y==$s+1:(is_array($Y)?in_array($s+1,$Y):$Y===$X));$I.=" <label><input type='$U'$Ja value='".($s+1)."'".($eb?' checked':'').'>'.h($b->editVal($X,$o)).'</label>';}return$I;}function
  112. input($o,$Y,$r){global$wi,$b,$x;$C=h(bracket_escape($o["field"]));echo"<td class='function'>";if(is_array($Y)&&!$r){$Ea=array($Y);if(version_compare(PHP_VERSION,5.4)>=0)$Ea[]=JSON_PRETTY_PRINT;$Y=call_user_func_array('json_encode',$Ea);$r="json";}$Fg=($x=="mssql"&&$o["auto_increment"]);if($Fg&&!$_POST["save"])$r=null;$jd=(isset($_GET["select"])||$Fg?array("orig"=>'original'):array())+$b->editFunctions($o);$Ja=" name='fields[$C]'";if($o["type"]=="enum")echo
  113. h($jd[""])."<td>".$b->editInput($_GET["edit"],$o,$Ja,$Y);else{$td=(in_array($r,$jd)||isset($jd[$r]));echo(count($jd)>1?"<select name='function[$C]'>".optionlist($jd,$r===null||$td?$r:"")."</select>".on_help("getTarget(event).value.replace(/^SQL\$/, '')",1).script("qsl('select').onchange = functionChange;",""):h(reset($jd))).'<td>';$Pd=$b->editInput($_GET["edit"],$o,$Ja,$Y);if($Pd!="")echo$Pd;elseif(preg_match('~bool~',$o["type"]))echo"<input type='hidden'$Ja value='0'>"."<input type='checkbox'".(preg_match('~^(1|t|true|y|yes|on)$~i',$Y)?" checked='checked'":"")."$Ja value='1'>";elseif($o["type"]=="set"){preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$_e);foreach($_e[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$eb=(is_int($Y)?($Y>>$s)&1:in_array($X,explode(",",$Y),true));echo" <label><input type='checkbox' name='fields[$C][$s]' value='".(1<<$s)."'".($eb?' checked':'').">".h($b->editVal($X,$o)).'</label>';}}elseif(preg_match('~blob|bytea|raw|file~',$o["type"])&&ini_bool("file_uploads"))echo"<input type='file' name='fields-$C'>";elseif(($Vh=preg_match('~text|lob~',$o["type"]))||preg_match("~\n~",$Y)){if($Vh&&$x!="sqlite")$Ja.=" cols='50' rows='12'";else{$K=min(12,substr_count($Y,"\n")+1);$Ja.=" cols='30' rows='$K'".($K==1?" style='height: 1.2em;'":"");}echo"<textarea$Ja>".h($Y).'</textarea>';}elseif($r=="json"||preg_match('~^jsonb?$~',$o["type"]))echo"<textarea$Ja cols='50' rows='12' class='jush-js'>".h($Y).'</textarea>';else{$Ge=(!preg_match('~int~',$o["type"])&&preg_match('~^(\d+)(,(\d+))?$~',$o["length"],$B)?((preg_match("~binary~",$o["type"])?2:1)*$B[1]+($B[3]?1:0)+($B[2]&&!$o["unsigned"]?1:0)):($wi[$o["type"]]?$wi[$o["type"]]+($o["unsigned"]?0:1):0));if($x=='sql'&&min_version(5.6)&&preg_match('~time~',$o["type"]))$Ge+=7;echo"<input".((!$td||$r==="")&&preg_match('~(?<!o)int(?!er)~',$o["type"])&&!preg_match('~\[\]~',$o["full_type"])?" type='number'":"")." value='".h($Y)."'".($Ge?" data-maxlength='$Ge'":"").(preg_match('~char|binary~',$o["type"])&&$Ge>20?" size='40'":"")."$Ja>";}echo$b->editHint($_GET["edit"],$o,$Y);$Vc=0;foreach($jd
  114. as$y=>$X){if($y===""||!$X)break;$Vc++;}if($Vc)echo
  115. script("mixin(qsl('td'), {onchange: partial(skipOriginal, $Vc), oninput: function () { this.onchange(); }});");}}function
  116. process_input($o){global$b,$m;$u=bracket_escape($o["field"]);$r=$_POST["function"][$u];$Y=$_POST["fields"][$u];if($o["type"]=="enum"){if($Y==-1)return
  117. false;if($Y=="")return"NULL";return+$Y;}if($o["auto_increment"]&&$Y=="")return
  118. null;if($r=="orig")return($o["on_update"]=="CURRENT_TIMESTAMP"?idf_escape($o["field"]):false);if($r=="NULL")return"NULL";if($o["type"]=="set")return
  119. array_sum((array)$Y);if($r=="json"){$r="";$Y=json_decode($Y,true);if(!is_array($Y))return
  120. false;return$Y;}if(preg_match('~blob|bytea|raw|file~',$o["type"])&&ini_bool("file_uploads")){$Sc=get_file("fields-$u");if(!is_string($Sc))return
  121. false;return$m->quoteBinary($Sc);}return$b->processInput($o,$Y,$r);}function
  122. fields_from_edit(){global$m;$I=array();foreach((array)$_POST["field_keys"]as$y=>$X){if($X!=""){$X=bracket_escape($X);$_POST["function"][$X]=$_POST["field_funs"][$y];$_POST["fields"][$X]=$_POST["field_vals"][$y];}}foreach((array)$_POST["fields"]as$y=>$X){$C=bracket_escape($y,1);$I[$C]=array("field"=>$C,"privileges"=>array("insert"=>1,"update"=>1),"null"=>1,"auto_increment"=>($y==$m->primary),);}return$I;}function
  123. search_tables(){global$b,$g;$_GET["where"][0]["val"]=$_POST["query"];$ch="<ul>\n";foreach(table_status('',true)as$R=>$S){$C=$b->tableName($S);if(isset($S["Engine"])&&$C!=""&&(!$_POST["tables"]||in_array($R,$_POST["tables"]))){$H=$g->query("SELECT".limit("1 FROM ".table($R)," WHERE ".implode(" AND ",$b->selectSearchProcess(fields($R),array())),1));if(!$H||$H->fetch_row()){$gg="<a href='".h(ME."select=".urlencode($R)."&where[0][op]=".urlencode($_GET["where"][0]["op"])."&where[0][val]=".urlencode($_GET["where"][0]["val"]))."'>$C</a>";echo"$ch<li>".($H?$gg:"<p class='error'>$gg: ".error())."\n";$ch="";}}}echo($ch?"<p class='message'>".'No tables.':"</ul>")."\n";}function
  124. dump_headers($Bd,$Qe=false){global$b;$I=$b->dumpHeaders($Bd,$Qe);$Ef=$_POST["output"];if($Ef!="text")header("Content-Disposition: attachment; filename=".$b->dumpFilename($Bd).".$I".($Ef!="file"&&!preg_match('~[^0-9a-z]~',$Ef)?".$Ef":""));session_write_close();ob_flush();flush();return$I;}function
  125. dump_csv($J){foreach($J
  126. as$y=>$X){if(preg_match("~[\"\n,;\t]~",$X)||$X==="")$J[$y]='"'.str_replace('"','""',$X).'"';}echo
  127. implode(($_POST["format"]=="csv"?",":($_POST["format"]=="tsv"?"\t":";")),$J)."\r\n";}function
  128. apply_sql_function($r,$e){return($r?($r=="unixepoch"?"DATETIME($e, '$r')":($r=="count distinct"?"COUNT(DISTINCT ":strtoupper("$r("))."$e)"):$e);}function
  129. get_temp_dir(){$I=ini_get("upload_tmp_dir");if(!$I){if(function_exists('sys_get_temp_dir'))$I=sys_get_temp_dir();else{$Tc=@tempnam("","");if(!$Tc)return
  130. false;$I=dirname($Tc);unlink($Tc);}}return$I;}function
  131. file_open_lock($Tc){$hd=@fopen($Tc,"r+");if(!$hd){$hd=@fopen($Tc,"w");if(!$hd)return;chmod($Tc,0660);}flock($hd,LOCK_EX);return$hd;}function
  132. file_write_unlock($hd,$Kb){rewind($hd);fwrite($hd,$Kb);ftruncate($hd,strlen($Kb));flock($hd,LOCK_UN);fclose($hd);}function
  133. password_file($i){$Tc=get_temp_dir()."/adminer.key";$I=@file_get_contents($Tc);if($I||!$i)return$I;$hd=@fopen($Tc,"w");if($hd){chmod($Tc,0660);$I=rand_string();fwrite($hd,$I);fclose($hd);}return$I;}function
  134. rand_string(){return
  135. md5(uniqid(mt_rand(),true));}function
  136. select_value($X,$_,$o,$Wh){global$b;if(is_array($X)){$I="";foreach($X
  137. as$ae=>$W)$I.="<tr>".($X!=array_values($X)?"<th>".h($ae):"")."<td>".select_value($W,$_,$o,$Wh);return"<table cellspacing='0'>$I</table>";}if(!$_)$_=$b->selectLink($X,$o);if($_===null){if(is_mail($X))$_="mailto:$X";if(is_url($X))$_=$X;}$I=$b->editVal($X,$o);if($I!==null){if(!is_utf8($I))$I="\0";elseif($Wh!=""&&is_shortable($o))$I=shorten_utf8($I,max(0,+$Wh));else$I=h($I);}return$b->selectVal($I,$_,$o,$X);}function
  138. is_mail($pc){$Ha='[-a-z0-9!#$%&\'*+/=?^_`{|}~]';$cc='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';$Uf="$Ha+(\\.$Ha+)*@($cc?\\.)+$cc";return
  139. is_string($pc)&&preg_match("(^$Uf(,\\s*$Uf)*\$)i",$pc);}function
  140. is_url($Q){$cc='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return
  141. preg_match("~^(https?)://($cc?\\.)+$cc(:\\d+)?(/.*)?(\\?.*)?(#.*)?\$~i",$Q);}function
  142. is_shortable($o){return
  143. preg_match('~char|text|json|lob|geometry|point|linestring|polygon|string|bytea~',$o["type"]);}function
  144. count_rows($R,$Z,$Vd,$md){global$x;$G=" FROM ".table($R).($Z?" WHERE ".implode(" AND ",$Z):"");return($Vd&&($x=="sql"||count($md)==1)?"SELECT COUNT(DISTINCT ".implode(", ",$md).")$G":"SELECT COUNT(*)".($Vd?" FROM (SELECT 1$G GROUP BY ".implode(", ",$md).") x":$G));}function
  145. slow_query($G){global$b,$hi,$m;$l=$b->database();$Yh=$b->queryTimeout();$mh=$m->slowQuery($G,$Yh);if(!$mh&&support("kill")&&is_object($h=connect())&&($l==""||$h->select_db($l))){$fe=$h->result(connection_id());echo'<script',nonce(),'>
  146. var timeout = setTimeout(function () {
  147. ajax(\'',js_escape(ME),'script=kill\', function () {
  148. }, \'kill=',$fe,'&token=',$hi,'\');
  149. }, ',1000*$Yh,');
  150. </script>
  151. ';}else$h=null;ob_flush();flush();$I=@get_key_vals(($mh?$mh:$G),$h,false);if($h){echo
  152. script("clearTimeout(timeout);");ob_flush();flush();}return$I;}function
  153. get_token(){$sg=rand(1,1e6);return($sg^$_SESSION["token"]).":$sg";}function
  154. verify_token(){list($hi,$sg)=explode(":",$_POST["token"]);return($sg^$_SESSION["token"])==$hi;}function
  155. lzw_decompress($Ra){$Yb=256;$Sa=8;$lb=array();$Hg=0;$Ig=0;for($s=0;$s<strlen($Ra);$s++){$Hg=($Hg<<8)+ord($Ra[$s]);$Ig+=8;if($Ig>=$Sa){$Ig-=$Sa;$lb[]=$Hg>>$Ig;$Hg&=(1<<$Ig)-1;$Yb++;if($Yb>>$Sa)$Sa++;}}$Xb=range("\0","\xFF");$I="";foreach($lb
  156. as$s=>$kb){$oc=$Xb[$kb];if(!isset($oc))$oc=$fj.$fj[0];$I.=$oc;if($s)$Xb[]=$fj.$oc[0];$fj=$oc;}return$I;}function
  157. on_help($rb,$jh=0){return
  158. script("mixin(qsl('select, input'), {onmouseover: function (event) { helpMouseover.call(this, event, $rb, $jh) }, onmouseout: helpMouseout});","");}function
  159. edit_form($a,$p,$J,$Di){global$b,$x,$hi,$n;$Ih=$b->tableName(table_status1($a,true));page_header(($Di?'Edit':'Insert'),$n,array("select"=>array($a,$Ih)),$Ih);if($J===false)echo"<p class='error'>".'No rows.'."\n";echo'<form action="" method="post" enctype="multipart/form-data" id="form">
  160. ';if(!$p)echo"<p class='error'>".'You have no privileges to update this table.'."\n";else{echo"<table cellspacing='0'>".script("qsl('table').onkeydown = editingKeydown;");foreach($p
  161. as$C=>$o){echo"<tr><th>".$b->fieldName($o);$Rb=$_GET["set"][bracket_escape($C)];if($Rb===null){$Rb=$o["default"];if($o["type"]=="bit"&&preg_match("~^b'([01]*)'\$~",$Rb,$Bg))$Rb=$Bg[1];}$Y=($J!==null?($J[$C]!=""&&$x=="sql"&&preg_match("~enum|set~",$o["type"])?(is_array($J[$C])?array_sum($J[$C]):+$J[$C]):$J[$C]):(!$Di&&$o["auto_increment"]?"":(isset($_GET["select"])?false:$Rb)));if(!$_POST["save"]&&is_string($Y))$Y=$b->editVal($Y,$o);$r=($_POST["save"]?(string)$_POST["function"][$C]:($Di&&$o["on_update"]=="CURRENT_TIMESTAMP"?"now":($Y===false?null:($Y!==null?'':'NULL'))));if(preg_match("~time~",$o["type"])&&$Y=="CURRENT_TIMESTAMP"){$Y="";$r="now";}input($o,$Y,$r);echo"\n";}if(!support("table"))echo"<tr>"."<th><input name='field_keys[]'>".script("qsl('input').oninput = fieldChange;")."<td class='function'>".html_select("field_funs[]",$b->editFunctions(array("null"=>isset($_GET["select"]))))."<td><input name='field_vals[]'>"."\n";echo"</table>\n";}echo"<p>\n";if($p){echo"<input type='submit' value='".'Save'."'>\n";if(!isset($_GET["select"])){echo"<input type='submit' name='insert' value='".($Di?'Save and continue edit':'Save and insert next')."' title='Ctrl+Shift+Enter'>\n",($Di?script("qsl('input').onclick = function () { return !ajaxForm(this.form, '".'Saving'."...', this); };"):"");}}echo($Di?"<input type='submit' name='delete' value='".'Delete'."'>".confirm()."\n":($_POST||!$p?"":script("focus(qsa('td', qs('#form'))[1].firstChild);")));if(isset($_GET["select"]))hidden_fields(array("check"=>(array)$_POST["check"],"clone"=>$_POST["clone"],"all"=>$_POST["all"]));echo'<input type="hidden" name="referer" value="',h(isset($_POST["referer"])?$_POST["referer"]:$_SERVER["HTTP_REFERER"]),'">
  162. <input type="hidden" name="save" value="1">
  163. <input type="hidden" name="token" value="',$hi,'">
  164. </form>
  165. ';}if(isset($_GET["file"])){if($_SERVER["HTTP_IF_MODIFIED_SINCE"]){header("HTTP/1.1 304 Not Modified");exit;}header("Expires: ".gmdate("D, d M Y H:i:s",time()+365*24*60*60)." GMT");header("Last-Modified: ".gmdate("D, d M Y H:i:s")." GMT");header("Cache-Control: immutable");if($_GET["file"]=="favicon.ico"){header("Content-Type: image/x-icon");echo
  166. lzw_decompress("\0\0\0` \0„\0\n @\0ґC„и\"\0`EгQёая‡?АtvM'”JdБd\\Њb0\0Д\"™АfУ€¤оs5›ПзСAќXPaJ“0„Ґ‘8„#RЉT©‘z`€#.©ЗcнXГюИЂ?А-\0ЎIm? .«M¶Ђ\0ИЇ(М‰эА/(%Њ\0");}elseif($_GET["file"]=="default.css"){header("Content-Type: text/css; charset=utf-8");echo
  167. lzw_decompress("\n1М‡“ЩЊЮl7њ‡B1„4vb0˜Нfs‘јкn2BМѱ٘Юn:‡#(јb.\rDc)ИИa7E„‘¤Вl ¦Г±”иi1МЋs˜ґз-4™‡fУ ИОi7†ій† „ЋЊFГ©”vt2ћ‚У!– r0ПггЈt~ЅUЌ'3MЂЙW„B¦'cНPВ:6T\rcЈAѕzr_оWK¶\r-јVNFS%~ГcІЩн&›\\^КrА›­жu‚ЕЋГћфЩ‹4'7k¶иЇВгQФжhљ'g\rFB\ryT7SSҐPР1=З¤cIиК:Ќd”єm>ЈS8L†JЃњt.MўЏЉ П‹`'CЎјЫР889¤И ЋQШэЊо2Ќ#8Рђ­Ј’˜6mъІ†рj€ўh«<…Њ°«Њ9/л˜з:ђJк)К‚¤\0d>!\0Z‡€vм»nлѕрјo(ЪуҐЙkФ7ЅЏsащ>Њ о†!РR\"*nSэ\0@P\"Би’(‹#[¶ҐЈ@g №oь­’znю9k¤8†nљ™Є1ґI*€ф =НnІ¤ЄЏёи0«c(ц;ѕГ Ри!°ьл*cмч>ОЋ¬E7DсLJ© 1Ид·г`В8(бХ3MЁу\"З39й?E Ѓe=Т¬ь~щѕІфЕоУё7;ЙCДБ›НE\rd!)Вa*Ї5ajo\0Є#`К38¶\0Кн]“eЊк€Ж2¤ mkЧшe]…Б­AZsХStZ•Z!)BRЁG+О#Jv2(г цоc…4<ё#sBЇ0йъ‚6YL\rІ=Ј…ї[Ч73Жр<Ф:ЈЉbx”ЯJ= m_ ѕПЕfЄlЩЧt‹еIЄѓHЪ3Џx*Ђ›б6`t6ѕГ%ќUФLтeЩ‚˜<ґ\0ЙAQ<P<:љ#u/¤:T\\> Л-…xJ€НЌ QH\njЎL+jЭzру°7Ј•«`ЭрЋі\nkѓѓ'“NУvX>оC-TЛ©¶њёђ†4*L”%Cj>7ЯЁЉЮЁ­х™`щ®њ;yШыЖqБrК3 #ЁЩ} :#nн\rгЅ^Е=CеAЬёЭЖЋЃs&8ЋЈK&»ф*0СТtЭSЙФЕ=ѕ[Чу:ќ\\]ГEЭЊќ/Oа>^]ШГёВ<ЌиШчgZФV†йqєіЉЊщ сЛx\\­Ќи•ц№ЯЮєґ„\"J \\Г®€ы##БЎЅD†Оx6књЪ5xКЬЂё¶†Ё\rHшl ‹сш°bъ rј7бФ6†ацj|Б‰фўЫ–*фF AquvyO’ЅWeM‹Цч‰D.Fбц:RР\$ -ЎЮ¶µT!мDS`°8D˜~џаA`(Зemѓ¦тэўT@O1@є†X¦в“\nLpр–‘PдюБУВm«yfё Ј) ‰«В€ЪGSEI‰ЃҐxC(s(aќ?\$`tEЁn„с±­,чХ \$aђ‹U>,иР’\$ZсkDm,G\0е \\ђђiъЈ%К№ў n¬ҐҐ±·мЭЬgђЙ„b y`’тФ†ЛWм· д——Ў_CАДT\niђПH%Хda АЦiН7нAt°,Б®J†X4n€‘”€0oН№»9g\nzm‹M%`Й'IьЂЌРћ-ит©Р7:pр3pЗЌQ—rEDљ¤Чм аb2 ]…PF эҐЙ>eЙъ†3j\nЂЯ°t!Б?4fђtK;ЈК\rОћРё­!аoЉuќ?УъЃPhћђТ0uIC}'~ЕИ2‡vюQЁТО8)мА†7мDIщ=§йy&•ўeaаs*hЙ•jlAД(к›\"Д\\Укm^i‘®M)‚°^ѓ |~ХlЁ¶#!YНf81RSЋ Бµ!‡†и62PЖC‘фl&ныдxd!Њ| и9°`Ц_OYн=рСGа[EЙ-eLсCvT¬ )Д@ђj -5Ё¶њpSg».’G=Ѓ”РZEТц\$\0ўС†KjнU§µ\$ ‚АG'IдP©В~ыЪЃр ;ЃЪhNЫЋG%*бRjс‰X[њXPf^Б±|жиT!µ*NррР†ё\rUўЊ^q1V!ГщUz,ГI|7°7†r,ѕЎ¬7”иЮДѕBЦщИ;й+чЁ©Я• €AЪpНОЅЗ^ЃЂЎ~ШјW!3PЉI8]“ЅvУJ’БfсqЈ|,ќки9Wшf`\0бq”ZОp}[Jdhy­•NкµY|п™C y,Є<s AЃ{eНQФџтhd„ЃмЗ‡ МB4;ks&ђѓ¬сДЭЗaЮшЕый”Ш;Л№}зSЊЛJ…пН)ч=dмФ|ОМ® NdТ ·Iз*8µЌўdlГС“ЃE6~ПЁђF¦•Ж±X`˜M\rКћ/Ф%B/VАIеN&;кщг0ЕUC cT&.E+з•уѓА°Љ›йЬ@І0`;ЕаЛGи5д±БЮ¦j'™Ѓ›˜цаЖђ»Yв+¶‰QZ-iЃфњyvѓ–I™5Ъу,O|­PЦ]FЫЏбтУщс\0ђьЛ2™49Нў™ўЃn/П‡]Ші&¦ЄI^®=УlЋ©qfIЖК= Ц]x1GRь&¦e·7©є)Љу'ЄЖ:BІB±>a¦z‡-Ґ‰С2.Їц¬ёbzшґЬ#„Ґјс“ДUб“ЌЖL7-јwїtз3Йµс’фe§ЉцDд§\$І#ч±¤jХ@ХG—8О “7pъЬрR YCБР~БИ:А@ЖЦEU‰JЬЩ;67v]–J'ШЬдq1ПійElфQР†iѕНГОс„/ня{k<ђаЦЎMЬpoм}РиrБўqЊШћ мcХГ¤™_mТwпѕЌ^єu–ґЕщЪьщЅ«ђ¶Зlnю”™ Ћэ_‘~·Gшnиж‹Ц{kЬћЯwгЮщ\rj~—K“\0ПЭь¦ѕ-оъПўBЂ;ња›цb`}БCC,Ѓ”№-¶‹LЃР8\r,‡їklэЗЊтn}-5ЃЉЌЌ3u›gmётЕёА *Я/дф КщПоЧЏф`Л`Ѕ#xд+B?#цЫЏN;OR\rЁишЇ\$чОъцЙkтяП™\01\0kу\0Р8фНaий/t ъы#(&Мl&­щҐpёПм‚…ювОiђMђ{Їzp*Ц-gЁВиv‰Е6њkл е€рњd¬Ш‹¬ЬЧДA`6ѓlX) +d љрѕ7 и\r ѕ АЪЃcj6кН\rpЅ\rРХ\r\"oPв7Э\rђК\0Р\0ѕy ЗPЭђэ\rQ7 руаZЃС4Q ззЪЌ p/Ёy\r±±##Dс; ѕџЁ<–gА\0fi2®)fС\\ m ‘Gh\rс#±n Ярн@[ КG‘\"SqmЉ¤\rЂї‘#и»(Aj¦ сqСЈ%фђЙМ‘3qE‰„\0r–МС ѕВ›0эчСЏвљЭНО.­УQ7С€W‘Й‘uЫ‘р„х э@тЁHъЊq'vsд0к\nд+0®„РВSGлpЬO`П\r)cЩ#€ВТ‘ҐR=\$ЂЖђR\rТGС‹\$R?%2C І[\0ШЌД~І!±\\А‹pЛ#@ѕЃТO(rg%’?ra\$‰±)r](І›&’?&С#&RЌ',\rqV3Т\"Hйm+аЌИl’Q\"\0Ы4Ќч\$rЛ,с’=’ НЫ&2;.ІH@`иЇКОa…§ ’с\$І_*RIS&ИРq д_И1 °1+1’ЕАЦ  у3)2ТV7• і2lтЪ„!1g-‘2f`ђТЧ,Qу7сщ0qgУ]!q»уm6Љ¦‹і_ІM7 ї‚Б7іo6Qо аа уkpэ3іg9”Єs‰ 3Ќ6ь\r©:SЃ9УЏ;— “\r9‘-\0ЖYУ§0QХ<b#<УЃТw/ GА…>rЃ\rЕЯ=3пЌ^&Q;СЈ?q 0\"Б0HР™‘|ЎбУК–Sа˜i‹а@*УT­2ЩT#Ћ€ «\0°C°’07]?‘Э&Є›ФE і…DС;:/Ѕ3эE±5УЛEQЊeУЛT\"©mћ©ЛЙ5‘E;уџґ#=4Ѓ8ст*Ит©€шLSТ5HrсJE TO\rФ…JґЌJ“УJуУАeG) 8Bђ8© ,&тђGКІзЂи Рк›+MЂ¦КЙІ¬л^*±ЇлGЛЪ14т6Л\$.\"ж‹ўпI4w!\$L Ь8bкA2ыLГ'M?MFъ\$Ь,ґа“рNr ґк/4пBJЪВЁ");}elseif($_GET["file"]=="functions.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  168. lzw_decompress("f:›ЊgCIјЬ\n8њЕ3)°Л7њ…†81РКx:\nOg#)Ркr7\n\"†иґ`ш|2МgSi–H)N¦S‘д§\r‡ќ\"0№Д@д)џ`(\$s6O!УињV/=ќЊ' T4ж=„˜iS˜Ќ6IO“КerЩxо9ђ*Еє°єn3ќ\rС‰vѓCЃБ`хљЭ2G%ЁYгжбюџ1™Нfф№СИ‚l¤Г1‘\nyЈ*pC\r\$МnЌTЄ•3=\\‚r9O\"г Ааl<Љ\rЗ\\ЂіI,—s\nA¤Жe h+Mв‹!Ќq0™эf»`(№N{c–—+wЛсБYЈ–pЩ§3Љ3ъ˜+I¦Фj№єэЋПk·ІnёqЬѓЌzi#^rШАєґ‹3ивЌП[ћиєo;®Л(‹Р6Ќ#АТђЋЌ\":cz>ЯЈC2vСCXК<ЃP˜ Гc*5\nєЁи·/ьP97с|F»°c0ѓіЁ°д!Ќѓж…!Ёњѓ!‰Г\nZ%ГД‡#CHМ!ЁТ r8з\$ҐЎмЇ,ИRЬ”2…Иг^0·б@¤2Њв(р88P/‚аёЭ„б\\Б\$La\\е;cаH„бHX„Ѓ•\nКѓtњ‡б8A<ПsZф*ѓ;IРО3ЎБ@Т2<Љў¬!A8G<Фjї-Kѓ({*\r’Еa1‡ЎиN4Tc\"\\Т!=1^ •рЭM9Oі:†;jЊЉ\rгXТаL#HО7ѓ#TЭЄ/-ґ‹ЈpК;ЃB В‹\nї2!ѓҐНt]apОЋЭо\0RЫCЛv¬MВI,\rцЌ§\0Hv°Э?kTЮ4ЈЉјуuЩ±Ш;&’ђт+&ѓ›р•µ\rИXЏЌЃbu4ЭЎi88В2Bд/вѓ–4ѓЎЂN8AЬA)52нъшЛеО2€Ёsг8з“5¤ҐЎpзWC@и:˜t…гѕґЦeђљh\"#8_˜жcp^г€вI]OHюФ:zdИ3gЈ(„€ЧГ–kёо“\\6ґђ˜ђ2ЪЪ–ч№iГд7І˜П]\rГxOѕnєpи<ЎБpпQ®UРn‹т|@зЛу#G3рБ8bAЁК6ф2џ67%#ё\\8\rэљ2Иc\rжЭџk® ‚.(’ Ћ’-—J;о›Су ИйLгП ѓ јћWвш㧓ѥɤв–ч·ћnы Т§»жэMОА9ZРќs]кz®Ї¬лy^[Їм4-єU\0t a ¶62^•˜.`¤‚в.CЯjя[б„ % Q\0`dлM8ї¦јЛЫ\$O0`4ІкО\n\0a\rA„<†@џѓ›Љ\r!А:ШBAџ9Щ?h>¤Зє  љ~МЊ—6И€hЬ= Л-њA7XдАЦ‡\\ј\rЃ‘Q<иљ§q’'!XО“2ъT °!ЊD\r§Т,Kґ\"з%˜HЦqR\r„М ўоC =Ћн‚ ждЋИ<c”\n#<Ђ5ЌMш кEѓњyЊЎ”“‡°ъo\"°cJKL2щ&ЈШeRњАWРAОђTwКС‘;еJ€вб\\`)5¦ФЮњBтqhT3§аR ё'\r+\":‚8 ¤АtV“AЯ+]ЊЙS72Ир¤Y€FѓјZ85аc,жф¶JБ±/+SёnBpoWЕdђЦ\"§Qы¦ a­ZKpиЮ§y\$›’РПх4ЏIў@L'@‰xCСdfй~}Q*”ТєAµаQ’\"BЫ*2\0њ.СХkF©\"\r”‘° Шoѓ\\лФўђ™ЪVijY¦ ҐMКфO‚\$Љ€2ТThHЃґ¤Є0XHЄ5~kL©‰…T*:~P©”2¦tТ ВаB\0эY…АИБњџj †vDРs .Р9“sё№М¤ЖPҐ*xћЄ•b¤o“хяўPЬ\$№W/“*ГЙz';¦С\$ћ*щЫЩйdвm нГѓД'b\rСn%ЕД47Wм-џ’ацХ ¶Kґµі@<ЕgжГЁbBСя[7§\\’|ЂVdRЈї6leQМ`(Фў,Сd˜е№8\rҐ]S:?љ1№`оНYА`ЬAеТ“%ѕТZkQ”sMљ*СЧИ{` ЇJ*ќw¶ЧУЉ>оХѕфDПы›>пeУѕ·\"еt+poьь–ц¶ЕW\$гЃЬНыQб”@Иѓ3 t`¶†˜¶-k7gжд ]УКlо ґEА№^dW>nv АtцlzPHЁ—FvWхV\nХh;ў”BбD°Ші/ц:JіЭ\\К+ %Ґс–чоб]ъъСЉЅЈwaЧЭ«ё‡с=ќјX®т†›Nы/ЊРw“Jс_[бt)5фЅщQR2lћ-:›Y9У&l R; Їu#S э ht kПE!lШъФ>SHЂАX<,рЃOёYyРѓ%L–]\0ћ ‚У^ЯdwР3н,ScЎQt˜e=‘M:4ьяФ2]”кPоTГsЋХn:©єu>о/џdњј Юнґa‹'%и“нЭБqТЁ&@ЦђЛ•БоЊ–H·Gв@w8pсАњБОЃ¤Z\n«Ш{¶[Іt2 „Гаa–ґ> ґwЊJо^+u~ГoшеВµXkХ¦BZkЛ±ГX=ИЛ0>ЄtЇўlЕѓ)WbЂЬ¦шх'ГAТ,бнm†Y—,‹A’БсЉeќп#V№с+ђn1I©ОКБEЃ+[вьпШ[ Їы-RљmK9З №~Ќг‹чLЂ-3O˜КБ`_0sъЃЛL;›°ёВа]ђ6хҐ|¤‡hяVЗT:Љ‚ЮћerMОЙaх\$~e‘9Ґ>ббг€БР”Б\rХК\\”БфJ1Гљј БР%ў=0{ц ђџМз|Ю—tЪј“=ѕВуЂQз|\0?хг[g@u?Йќ|Дц4Э*‚µc-7С4\ri'^ЩСеїn;њъ»щ‰Љ¦(»б¦П{KЗhсnfµ пЪZПќ}lіикзЕ]\rд”юpJ>С,gp{џ;О\0µЅu)ЪХsиN‘'эКзгHЩшC9 M5рк*шЏ`кk’г¬Ћ  цю©A hYВ©*–©ЄЉjJ˜З…PN+^ђ D°*ё«ГЂоР ЂD ЄЪPдмЂLQ`O&–Ј\0Ш}ђ\$ќ…В6ђZn>ІЛ0Ы ЬeАђ\nЂљ …trp!ђhV¤'PyР^‰*|r%|\nr\r#Ћ°„@w®»нРT.Rvв8мjв\nmBҐпДpЁП ъY0ЁПўлm\0и@P\r8 АY\rGШЭd’ АQGЃP%EО/@]\rАК А{\0МQђФаАbR M\rFЩз| ўи%0SDr§ВИ ћf/ –аВЬ\":ЬmoІЮѓВ %Я@ж3H¦x\0Вl\0М ЕЪ ‘ЂW ЯеЪ\nз8\r\0}®@ћDЙс`#±t ‚д.ЂjEoDrЗўlb АШЩеtмf4ё0ЂА¤%С0’еТkЄz2\rсџ оW@В’з%\r\n~1Ђ‚X ¤ЩсєD 2!°фO‚*‡¤І{ 0<E¦‹k*mл0Д±юЦО|\r\nж^iЌАЌ Ёі!.§r т §€ьЌМциоfстД¬Ащ+:ЋпћЕ‹JъB5\$LЬитPЅмТLД‚«а¶ Z@ємкМ`^PрL%5%jp‘HвWАрonшцkA#&ђц’8Щт<K6М/–щІЋМЏўМндътXW e+&›%ДСІc&rjн с'%Тx‚І°ѕЕnKҐ2ы2Ц¶‹lак*б.ьrЋНОў‰‚‚*Р\r+jpЏBgк{ ІћЃ0л%1(ЄЉоZ‹`Q#±ФЋвn*hт тvўBвПрА\\F\n‚WЕr f\$у93дG4%d b”:JZ!“,Ђ‰_ ыf%2ЂЛ6s*FЂСЁТєіEQЅq~ІЋ`tsЦТЂ‘’‰(Џ`Ъ\rАљ®#ЂR©¬°±R®rђу¶XкЮ:R›)тA*3ї\$lЛ*ОЅ:\"XlМФtbKЭ-„ВљТO>Rх-ҐdЎЗ=¤т\$Sф\$е2АЉ}7Sf№в[Њ}\"@И] [6S|SE_>Ґq-д@z`н;ґ0±уЖ»ЛБCС*Ї¦[АТА{D°ЮjC\nfеs–Pт6'ЂЋиИ• QE“’жN\\%rсoч7oъG+dW4A*ЂР#TqEОf•ѕ%щDґZж3–§2.м‰ЕR kвЂz@¶Џ@»EіDў`CВV!CждЕ•\0±ФЫIю)38ЋЋM3В@Щ3L‡вZBі1F@Lдh~Gі1MДСС6с‚У4дXС”т}Жћ fЉЛўIN Ђу34рАXФBtdі8\nbtNгаQb;НЬ‘D‚ХLЏ\0ФЇ\"\n‚ћЯдVСН6СА]UхcVf„сЕD`‡Mс6УO4Ѓ4sJ•‹55Џ5“\\x О<5[FЬЯµy7mч)@SV­ИДћ#кx‚Х8 ХёС‹¬Ј`·\\`Э-Љv2ІэХpҐњ·+v§ЂыU«­LкxY.¤ћ‰›\0005(ћ@трґв°µ[U@#µVJuX4нu_п\"JO(Dtэ_ 5sЅ^ђ хЎѓ СЕД5·^»^VаѕIкж\rg&] Ё\r\"ZCIҐ6µК#µО\r©ЁЬ“‡і]7ґђ qХ0Щу6}oѕ’—`uљЂab(сXУD fэMЦN)эVХ UUFЏРѕш“=jSWiЕ\"\\B1 ДћШE0¶ µamPА н&<ҐO_ЋL–т‘В. cЌ1Z* АR\$еhќ¶щmvэ[v>Э­нp•€ќЉ(еЛ0ђр˜ °њcPЈom\0R ґэpч&‹w+KQЃs6†}5[sцJЈХф2µщ/ЂъаO тV*)ЛRµ.Du33–F\rВ;­гv4Щ µюHщ _!ф­2ЊµkЄ¦Џ»+Є»%р: Й_,Фe oиПFЁМAJ¶OИ\"%¬\n‹k5`z %|Г%ДО«g|АП} l¶v2n7К~\0О ЁYRHъЛ@Цнr’­xN-Jp\0рј‚е‹f#ЂЫ@ЛЂmvФx…˜\r–ь–2WMO/°\nDЇЫ7П}2р’тдVWгWикwЙЂ7еЂсЛHЖk„Ёр]ё\$ФMz\\тeЃ.fшRZШa†Bд№ µ QdНKZ“аvtАШЂw4Ї\0жZ@а чфBc;Оb–г>ЪBю 3mНn\nлo ПJ3”жkЊ(ЬЌЈђ‚\"аyG\$:\rШЕ†иЭЋ“ќG6ЂЙІJҐзyСсQц\\Qъчifч­Юш©(пm)/r“\$щJЕ/ќHМ]*ттЅу‡g№ZODчС¬Љѓ]1Оg22˜ї±—€п«fЙ=HT…€]NВ&¦АДM\0Ц[8x‡И®Eж–в8&LЦVmњvА±Є”j„טЗFеД\\™– ™љћ&sб@Q™ \\\"тbЂ° аД\rBsљIwњ њYЙњВN љ7ЗC/&Щ«`Ё\n\nГ™[k˜№ґ*A– сTПV*UZtz{Љ.‚зy˜S‰ љ #Й3ўipzW@yC\nKT»˜1@|„z#дьЂ_CJz(Bє,VФ(Kє_ЎєdO—©ЂPа@X…ЌtѓР…¦єc;ъWZzWҐ_Щ Џ\0ЮЉВCFшxR   а¦\n…„аЋє°PЖAЎи&ЋљљЌ й›,ЦpfV|@NЁ\"ѕ\$Ђ[…i’Љ­•ў ар¦ґаZҐ\0Zd\\\"…|ўW` єЖ]єМtzРo\$в \0[°иЮ±uЃeћзл±Й™¬b hU-Ў‚,Ђr гLk8§  Ц«†V&Ъal§ШлаdнЊЧ2;  '-Ў¶J yu—›a©µЭ\0 чЁ•aЌЈ{s¶[9V\0ґ‡F«‘R ВVB0S;Dє>L4є&‡ZHO1… \0КwgК єSҐtK¤ЁR…z ¦ЁЪiјЪ+Ѕ3хw­§z’Xў]Ё(G\$°ЁЇЄD+°tХ№б(#Є”©™oc”: АаY6ј\0–и&№ј @¦ ањь)ВТ!›‡ґ¦wЂ »њ# tРxєNDуА•Дљ)кхCЈКF ZВpАДa—Д*FДb№ ЇѓНјАЊЈгДЈщЃ¤езSi/Sј!‡ЂzйUH*О4єл¤ЛЩ0щKА-ё/“­А-k`°nЬLiКJл~ВwаJnѕГ\"н`У=мШV¶3OДЇ8tд>µыvoлвE.®ѓRz`Ю‹p·P њФE\\ЩНЙ§О3LзlпСҐs]T‘‡‡oVЇсЂ\n ¤ *‚\rј@7)¦КDьmќ0WЭ5УЂЯУЗ°ЁwЭФb”ИЭ| ЗјJVјиАњ\"‚ur\rд&N0NцBЁd¦ЛdР8оDрЁЂ_Н«Ч^Tц®H#]„dб+ъv Ђ~АU,РPR%с‡…щЙТЯxФХБfAБ»CБьmАђѓ»Нё·№’ЫcГЗyЕњD)ъ›ХuHачЯpюpЄ^u\0и й€ °ІЊ}Ў{СЎЕ\rgдsЗQM¤Y‡2jЃ\r—|0\0XЧв@qНЊ•I`ц»5FЌ6±NЦюV@У”sEпp’х¬#\rюPѕTч–DeW†Шјс›­ЃгЫz!Г»зћ:ьDMV(ў©~XёќЌ9Ј\0еЈ@˜ї­40N¬ЬЅ~”QР[TЏЬДeюqSv\"Х\"hг\0R-ьhZіd—с…АЬF5ґPиУ`і9ВD&xs9WЦ—5Er@oМwkb“1рЭPO-OюOxlHцD 6/Цї­mйЮ ѕІ3Ґ7TђЁKИ~54¬ сp#µI”>YIN\\5ЂШ‚NУѓ­‡—хMытpr&њGнxMИsqЊЂ—ш.Fя–Н8§Cs±Ћ hЂe5ДьТЭр°±т*аbш)SЪЄѕ †М­Щeъ0Й-Xъ {ъ5|±i–Цўa‚гИ•6z‚ЮЅЏѓ/Y‰іяЫЋM¦ Жѓм К\nR*8r oш @7Ў8BfеzщKГr‚№шA\$Л° p‘\0?…я dЁkГ|45}АAяГЂШЙ¶уWїсJА2k Gi\0\"ЎЂћАdЂин8‘\0 >mуВуЃ `8ЇwЩ7Йo4вcGhњ±QР(нЂЁЦ8@\$<\0p¤Т0іч˜L¦eX+„JaЂ{лќBТаґh¶Ш8иCy„ткP2єќУ®џ*УEHк2ЅЕЭDqS‡Ы˜пpЊ0ЩI‚ІѓkЅ`ЮыSн\nв В›:йщBњ7Ыаир{-™ВфР`оЂх р…6ёA WЎЬ–\rюp†W#фдЎ?№юў{\0РЯфјШ ОcD њ[<ђЃ„Рfа--љpФЊґ*B„]„nW°І^Ћ R70\rг+NЁGNі\$(\0±#+yу@Ю@iD(8@\rАhКХH€HeўҐРМzzА{ 1й…А°h„ЩW1F°Who&aЙњЮd6ЎЅЭjw˜иЙь»ҐВ`hќ{v`REЭ\nj †Је`кЬ·ѕФЗЖ*Ь€°Кё}ЄYЎс \rY‡H¶6Ґ#\0рҐе»†кЮaјБ QЁHEl4эd¤ЬнpлЪ#™†ЁЃѓЎЁoУbr+_)\r`‚Р!Р|dQ•>Є№=QКЎЂвО¶ЧEOB'‘>фPм®фУ¶Ш A\rnK‚iµд ЉБф„ќ €%< Гo;‚S„@г! Іx’а:€†ЭA‘+\\ 1d\$щjOњЙ7љ%Ж е/Љњ¶’gu„z*°G‚Hк5\"8–‚,џ]raqЁ«о/ h‹ш#ЌГх­\$ /tnНц8yєЭ-®O‚э˜H±bЏФ­<вZЧ!©њ…1Ўм`Й.(uo›А…­|`GЛђSиФBaM Ъ‚9ЖћоD@Јќх1‰BЂtDРшКЎ@?o©(H–‚qCЇ¶8EјTcncRГ‚6©N%јrHjѕа2G\0‰aґ¤q ™rБЗz9b>(PђгџxиЗ<Ќч)фx#Е8уиЄ№tі€Хh„2vЗсWo2UлООtі˜+=Аl#куПjюDҐ 0¤е‹›&RЈcи\$•*М‘-Z`аА\rЉк;Л|Aщpа=1Ф 1н•ЃнЖ€ЁbEv(^ЂXҐP2=\0}‚W‘€чGѕ<°љКGЎ№‘шшRќ#PѓHЬ®r9 ЈѓYыґ!’LB¤‘‘4ЂNC„Z€оICґ‘ФMLmўВ,Бf@eY x›BS(У+ШЏ<4YЊ)-Ш\rђz?\$аЂЬ\"\"єЌ 6ЄEщ\r)z‘’Д@И‘ў’r„ђђ ¤*еѓжJИмњ‹А€%\$щeэJы ˜‹\0Aе\$Ъ°/5ХСB0Sф¤њxє“IєQ)у•<¦¬4YS‘&‘{Љјbг+IG=>Ў\rђPY`ZёD•`¦”UІўЌЄF1ЂЉш4d8X(ГА°ъC%Ћ`Џгњ­0ЛI\$ѓ7WВpЗЃ,™ њAcА–й&ФЊйp\$ђ:е>]Ф.†VYІЙ\$pр ўТ]фй`Ќ;ъЂeъ\0Ц0г\nЄШK+ Ы@DLбSЂ€r(on°M\0@9§Й%ѓ\"”WSИ\"ёНЯГ 䥙КЩЌ©Ш»j¬_J-АцrКњаЙЮ5Р\\э2Ђ5>Ze\"0 °Њ%9yЃ¦^®WMax&a)D«LАѕі2Q›’јэt? =,А/oёf…3IўJћ\$\r;рЂё7с}Д\r“W @ёТ°•M|\rіYљШ В]5фњђ\\*s:ЊОFV!ЂґаkЩ†МRуэ…L3LВ Љч52°MЂ sb›\$ТВДф7Ћ\0lВy˜¬а&ѕ 9Н|m!№њ0JЂз4АМTSd—№дG’цСnKйV:lїD'/щђ:Zsтя\n ї…yи%ј–iьрНЦ,@ТІL ±j1<ЌН3ДЁ“D2/;љж'PЭ»м±њ‚`п“жУqKИ°¬fќIдLХ DЭ¬„4¦3 і’OHуJЪ qЏ&”ч€’‰XмЎ!Ёфr)FАXx№аЃ^QwOP”Кh•ДХћ-_…>ДaЈ°±ђ( „гx%Ј™K‚bр<ЙEѓj7‘„ЮМц¬†hHt“`Ћ.r‰P‡€Шx п\"{\0006CVQE‹&ЂЕ>йЮ…Ћwйђі–e'?BФ9x§>:\"ѓ73 ¤ЉxT\0eђ”уељj Е…[tиТњ\"д(\\ KђeўzЖrёЂх–e> “Є«\0002ЃhК‡ў­ X¬a<”JtUўz`µйЃ”?лл#’ыЏмє2-ј®4hFY|Cюњ\"MЙyЖ”Kd Ѕ–“EХ7¦ј“+(UІК–XцФ /DєсЮ)е\"Њ¶І‘ШЁЮ‰johЎFz4ЃtаЛмDЧЊлG‡хRZЊД‡¤Иї\0ЕFV4QС6vЈbыi=Gў;П¬‹kМd+\n>ЖEњК\0г2f{‰‚вЯ!J”ўQмљJќ ؘ9ЏН(2 у#\\Zйь,–СQЬҐЋ3?8`в  bwR6аЩ\n*ђ г‹Ђ©Ж’щ(tю§L*фSЎd¤\0x’) (Њ*„wH]7O±N‚v(Р“dgЂq \nLp„РL„ N‰ЪH@р1‘њудM ± nФъz‘Ћџe4!! Ђє'ж§ќ-tЈ л°КAQPє‰щL,„“ўг7»„\\Ыiн™еА^А\$Ѓ, |ђZ¶Ђ(S9©л…а\n* +Є˜TКD„z?(TН>„ЧL¬¦Г¦љтRьВЁ°\$дzРґiМјWќНЁЂDsТ{)Ф@ … ДБ vщPдАgбqIVТЁЂЂ·б\n )Ж! 8|\$pZг*ъ!7A°˜фОNЉЙjпNWЈ€ЂЏU¬§ЫQъ –¤)ьeFљUA“SҐx\0[N€рЈ2є·рX :SПT„~ЖS*T4 Ґ3ЄО]9ХFҐЊ©]:–KUg;Ёь *AyЭaАб1j|8О«ЛА­ЌIДMR“ВVh7uU¦єм„r,‘h…%<qёR@N9д Ю§Аk­ АB|¤™ѕ„Ѓ8 ’–r •»‘ШфDР @\"„Й‹¤z\rІ¦д”ф„OА_ИЄ§QС\0\0®їА|¬]Ђfб\nzЈ¦є„ UeHЏД„/k+М TF ?‘°*03†!­\0·’I™Ј t f\0(SеЎUР лZAёF°Є1\0 ЭkЋ]щоWZNЖQ¬„Ь‚‡‚Ў%Й°x1 „ЏЩ'ЄМ!-,ЧЗ¶vzg’Е#ЋGhЮ;fЫPHЈ9Bj uш\nЩAСVRќЉ“Є1K+њMN!ІеSОјдНY€ЅvdZ\\,Оя“gЩЁџ±Іэњ\"}WЎЖYЙµцt±Pљбїg‹,ёЭЛЫа \0bµ-·hB/@®МЋЂ/€MмсґJШАђY\0”РлЫ)\nЬжI±?vТ ЁСИ”1¦”\$К(‘w\r+фn б®дsµs¬QfQЗO‘Pц.DъЎ¬bV\0-ЗJ<‡i;[ў¬—=#ЏСЙn,j?)а\" ј”lYL.±ҐҐ„A::Ќъ€¤яЄBxOF7ж Ђґр`Ьъ’ dШў}в}=Уi)@Рє‹й\$ qЛ·(y%ЉЊhuzb2б3Ж§–†.а-hЙoOаЂў¬\0`ё‘кVZ„Ь&yоt9C–“Ўй‹­Z№ёТ‘ЂZ!аXгUњёєУ.kґмЃV#8ЎGЂ}»Q¤ђбu8cО«t¤bE>¤v§В{@{QP]<§aryџЙj\\АО\$jєxжnc6k©;qsзT˜јМKѕ …“ЂjJ±џХn\\CЃ©{Ц®Р`gр°„6›5рЇђRkйtкбФтЅ·s•|@л_0О…5:BШ3ъшПБrСЎИ&‚гґёё\0Т»џ‘&¤Ч€°ЉншњФЎћт‡SXК•чG«mћК¶Wr,j‹ q\0\$ЮєsWЅPо.A\n4А9(uрЈ.ђРЏl’VгJuнФЊ‰+ЭAњuC“>hl6уЮ2•‘рGМeЏФЙNв›ДnЇ=»'ќЕУ~щґГћ у©в«PТЂЙ%0zћuшЪrЯ\0А 9uEТs\"ІюЯ\\Нטє­з¶^ыъа(3ВќХ‘S%<+м9есФѕЫЧ«Ђ\0ю…Ъ~'МћчЦ“<+у,iб:ґИ@˜›NЏы  \$ШoхЃІы™Ош Ё]э§ћ’Хк»Zв!эї]ыn,Лшxмх>_Фf‘йW\0006‡Д%т}IЃ\nhЯЂwвАгъќЗѓ -ЎґH@_¶Viќ„њ“‰{ЄЖьRУч^†Ы”} 5ћb,!5аЃРHЃ€p/љЙk<­ў<¬jh|i еk‚бhLvЭ„\nѕ`ў[аЂ¬WC6Внz\nўg•вrЧцu=Ў˜!zCЕЈКФоџe#ЂЫnj…О\0 `^;=Eо*@ЛyЁ% €фLQeУАиЊ2­Aђ1,µтC¤ixрtѓТ ђG­]qмO(Д™±Џ\nіV9drбD'5@x\$‹r6‰’;\"ЗЈЈзЁ7Г\0M0Е†H_#дcаpn>­¤<aa­q@gЦ2±ѓlm-ПЈ¶Жъ¤±В8вш?8Д †7pј№Фд>˜‹jiµксNъ\$#E/Ґ0˜µs\nн»B\r *Ырz·бљoyn[О™¦Э 6·a¦©фЈg8ЭqCШ ·вјњЄIб№rNF›И«•1Аџ70ТЕсрШ/i(ЙBв0§а˜ёZБє(пМ+SцJТ,–дј91/Y+jxУ±F„±РAЙгkтfВJee\r№CНіrzп…m”КЦh@9й°OИЧ Шќм‚ЩGK™AdЖРЗOH’Щк=· Т<&`р‡K¦PAИ!WO;-СXЊL…зmе’Kzб7-e[uј”pЁqИэџo/њ`ђCЏ’‚„KXЎfоiрЇАY7=…Mж/ЄFЦRЕЫ”TшdщпY\"=`В1Ўk’1ХЏh‘\rн˜Фрf@N˜“zи(@у‘„ьЃі hь\0ЖздЭХI»}PJKrм’€pR`xё¦чѓьЁfoўбЛ(AЂї[—ы19Ґ(&jo<·¬I@p @Руі„ьдјп,yМ nIsќ^РЋС«:Y¤Ћvc•љђШЏ9q.C¤Ќ8ьbWЎ–V?гЧТ…І9  \$uй@5#S(4Y‘ЙЖK…“ §6ї!лбN6<хЌ|v1­е§3КЉ:іщ!˜ФбЭ`ИхM‚Юl›”¬¦f`љZ§НJ= ±±GXуY)_lКРђжT¶)P•™`ж%мЪ:И!Z\"lYSцUШ¤(ЯЕY1ZЎл‹€rv)F`жK~=Y>№»љSСфљc®д Кй!lД•ДDиА‰ЬBrF\$ДмRA:Н\\ЉPЎ4ФVХR 6<ЋOєSТ_BCS+”„†з'V€ю2T#LcмF»N BD%яGьWсnRйSИк„·IњЉ\n'k‰0­В€€ўOЃЁРЋбкц…8rЭЇASн?ЉжxmЗдyvлРїaџbы¶Н°б,ЁнР…A”ё€¶†О]pJ\\\\ЦXiШ­л‰Eu‰ыB)рЄ ИхZ@ОЏ \"њИgg0{©•nка'APR «‰ЩЁvУ~є0RэwмЂ±\"‡Ѕх·‰ґЂHџJш®ТО–Щ\\›\r}i?г‘Т’:«†2ёЭПgЂј{Iь3)ЭбB©СН™ZчsЈа`.м#2АvtгњXіIGU>`)М%аАє(|лf<Ољ_ПЮЇЂП‘_GЮ<‘»_ Лџ€†ЋОш‚[:¦6G8°ИlЬ#J (шЎJC—Ґо`†ЪОwFАw\"b !,Џґ!Ъrк@ЬK(§Ђј\n@AsVАщS«Ц№Ц4ы_\nsЩ eЪ‹j¶ю)&К3Ю{Є‡kАбвQ—ќіGіcыЫX^ЌL{сC\nпmщЏЫиA¶жDЬы1O?(кЬ(°¶я·и2\"UL‹Е+#o”ё@бЩзXЙ\0ЬЩ­І¦ј^n_pлeQЛ™X}%Ії*ТАe’mх{€GN‡ЕXlГqй]R\\Z‹v!№) ц°›xdОЂ,ИcK¶П鮇ЗmНфНI~Њп†ШЭK‘{+¬ОGЭҐк=@QУЦ,1!aEOc›А#6<uЏЪrBї\n¦ИІ†ФdH ‰t›Єхх ¶{Cо<x3€ЩиHЄЈ1№ЋKњwB€\0ґ„u‘ЁІЃ'У†Qѓ^Ќ‚јт•Ґ‚…iзrRvфVЙ·№lSЯ.O)ќХц™[±ЄxSЭtцџЕc)Ў…їkҐB‡Х+ЇАv“зъB¤‘w™.шwCБ˜‚2ЎЄЭ2d¬.HБЮp+a\\ H§·[Б\$}nNN7џ•H’.ЯS\rЁИ’T БВ Іw† *HЖg\\ЃЮ\$Щ,©:KBOx»†>рОюј5ђдѓроУ¶˜…‰Аu2ЏЗnлЅј`њЉYqЖDґВгxwMBЋn•2>ЌЗЃGЪЪ„…ЊЖ‘YaKвw(2`˜…†ЪwЇ©Њ‹1mє-:™&LD8оU”њ8lч Б\\<ЊЕг °«zщaЃ‡•”:,ЄЌK'ё%7:п’ъ˜MэЗ€кU[ћьш*;K¶’НjЄ;/wGь“€\nщ†§^…eV'ЋЗ,«Й;ЎјB6џG¤1ГЛOKW”ТХш(iСX\npн±CЪ©c6’^с˜г·Ђ=Ў^Г»cQ±АRp`\$ АD(\0DЈ>{с¦ETпcЌВI\r{ю„з†\$o‘R ДZZИ4*•Г??ё+jхјрn›јQ `НоуЕXє3‹ \$вСёM’\nЧ‰w¦\"dбWёю–~@’'ЎIОб­«ъ0+-Є±wЏ–ЭдЉyЕ6§vИЅ'ШФ†:Y)Y0\0±*)?'ъ«Зћvќ§¦ЙfIЪ\nйћВzР9с.сb¦Ч!Їc•E°[¤ТFйє™ksЮ}єщBv¦gс5ЭV‡”В,)J\$«ВjЗZЉJҐ\$€Y„ДЧ—9ю\0њ\n‹ъ™ј.^J•’Ъ‹±bЦмmI0:gъэ§я—ќ’†Л—ATPЗIщ]~!э‚;D­єВие °zЅ¶<P»Q>ѓm»‚Ю`щК?%Y•ЃT\n\0D\0Љ\0'Ѓ†”H@0`А<Ч­И10а(®mк-¬‚Йћ7A\0А~љ~кЃЎД¤?t’hС”.wђ%)0 #c «ЄЃп\"МcЦпґаjfWйю\0\0pҐЃCыњќkCДж8Вз85+i:ѕт[„8тbіпlА[\"№іµд5S§y\0иђдпБ*¤Qо”6VсsА9»Ѓ7!­;\"ЅЕcж)„OмQ,уЫФ±©†\rЁ7н,*†0ЃaQ©u?з_C|еЭў‚чЉґR(o(ђ¦<j(їаTv° \rо‚›|_\"і3ъжm“вS7DД!Чётhо|ћЎџ(Г&Ќ@:тј \"-ЮЋщш&Mu;к,АbРє=pђ>A6Й­®®д7Ђ»а- WW9вO,Ѕo'сv2Ч<Ђ3\0хч hыЇ@`п 3TXѕПљ|Щ\"FC_МВ~xдьШМ`Её'f¤Q-4љыЎОъ/Т`'фЄ©=Aъ\$>‡ф` PЯА_G(–ћђEџ¤Џ&/JБIаvЃ'¦m餧zpЮћFoЁ к/[ъеiрШ‹…G*ѓѕЌyЎ(сђѕ<Ўгџ7qлY .цзњЄБзBµҐ™\rаlґr\nUnЖ§щќT>ЦуН ыдФя љQ©рч_џ|БпЧВKЪе8уЪ‰эeзб_ЇЮxzхxЌLФр·p14хшdэ‚ЎјU#4tРKф№э\$н!ы§ааp”wІ‚ѓрЇZx фиі_Ј…спђi5T?}рЛCЎо‘‘{ПИюҐцh/Gzj\$.BзТЁ™=#иПЏ|н†я*Ё‡єэIл©фw/ѕАaоx`*©Є*Џіи]э¤е©>a?'} FJSЬпЦФ–A0яб'АЅпрђлКџц0:63БЇ ·Р»эхn'го…’ќU/Цr’|=slb0р¦\0WкљrB—К¤‡™¦@TљР~\$Ѓџ€ьHџЋчя‹ ”ЁD\\ь©к-шДю(яЊб©–Bй—MБЌХz+т%№(‘кiУиг№ѓЇI”ї…5/и.y/цєѕ\$А{Q}p‹Ь»dI†\\яХЋЂBш\0V0јBј9ц{T\$nР8\$ZшeоPДінфЦ%9г&ґЧАV µЛb­x}g\"%hчџ†*ЩёvOwіЛѕП/џoйL,“†э=Б—VЇж5Bgў П¶Ћ3мУ>И~ў`\nxiЧ\"І’v@рІМю‚ЈnЧЈЬПіyacкGА'%[•є4`nец47!5™ЮЂrщџЪЖЙ‰пи>zЎ(Y—tЩы0®щЂVаЌ…PЂZXT`2Ђ~ClОф‚[oеnАt8jB\0dФ\0000 –VЩщgжАщ† @V!‹h\0006d<њо‰=[ WААЉУыfа@pb‰ДaЂиЩјҐs;РЪйG<Ћ~aвџ?®NІLҐ‚їт\"(»пш?¦%Лx#ѓ7В|S…дO¤Ж“)–B4Аж+ьж*м!йщ)6#±+?'џ¶ф(XЗПя·ЩJO\0 Ђ");}elseif($_GET["file"]=="jush.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  169. lzw_decompress("v0њЃFЈ©МР==˜ОFS РК_6MЖі˜ииr:™E‡CIґКo:ќC„”Xc‚ќ\rжШ„J(:=џE†Ѓ¦a28Ўxрё?Д'ѓi°SANN‘щрxs…NBбМVl0›ЊзS њЛUlЃ(D|Т„зКP¦А>љE†г©¶yH chдВ-3Eb“е ёbЅЯpEБpя9.ЉЏ˜М~\nЋ?Kb±iw|И`Зчd.јx8EN¦г!”Н2™‡3©€б\r‡ЌСYЋМиy6GFmYЋ8o7\n\rі0¤ч\0ЃDbcУ!ѕQ7РЁd8‹Бм~‘¬N)щEРі`фNsЯр`ЖS)РOй— ·з/є<ЃxЖ9Ћo»ФеµБм3n«®2»!rј:;г+В9€CИЁ®‰Г\n<сЌ`ИуЇbи\\љ?Ќ`†4\r#`И<ЇBe гB#¤N Ьг\r.D`¬«jк4яЋЋpйar°ш гўєч>т8У\$Йc ѕ1Йcњ Ўc кЭк{n7АГЎѓAрNКRLi\r1Аѕш!Ј(ж jВґ®+Вк62АXК8+Квад.\rНОфѓО!xјеѓhщ' гв€6Sр\0RпФфсOТ\nј…1(W0…гњЗ7qњл:NГE:68n+ЋдХґ5_(®s \rг”к‰ /mђ6PФ@ГEQЃаД9\nЁV-‹Бу\"¦.:еJЌП8weОqЅ|Ш‡іXР]µЭY XБeеzWвь Ћ7выZ1ЌнhQfЩгuЈjС4Z{p\\AUЛJ<х†kбБ@јЙЌГа@„}&„Ѓ€L7 U°wuYhђФ2ёИ@ыu  Pа7ЛA†hиМт°Ю3 Г›кзXEН…Z€]­lб@MplvВ)ж ББHW‘‘Фy>ђYЌ-шYџи/«ќ›ЄБо hC [*‹ыFг­#~†!Р`ф\r#0PпCЛќ—f ·¶ ЎоГ\\‡ЙЃ^Г%B<Џ\\Ѕf€Ю±ЕбРЭг&/¦O‚рL\\jFќЁjZЈ1«\\:Жґ>ЃN№ЇXaFГAАіІрГШНf…h{\"s\nЧ64‡ЬшТ…ј?Д8Ь^pЌ\"лќ°сИё\\Ъe(ёPѓNµмq[gёБrя&В}PhКаЎАWЩн*Юнr_sЛP‡hајаР\nЫЛГomхїҐГк—У#Џ§Ў.Б\0@йpdW І \$Тє°QЫЅTl0† ѕГHdHл)љ‡ЫЏЩ А)PУЬШHђgаэUю„ЏЄBиe\r†t:‡Х\0)\"Еtф,ґњ’ЫЗ[Џ(DшO\nR8!†Ж¬ЦљрЬlAьV…Ё4 hаЈSq<ћа@}ГлКgK±]®аи]в=90°Ѓ'ЂевшwA<‚ѓРСaБ~ЂтWљжѓD|Aґ††2УXЩU2айyЕЉђЉ=Ўp)«\0P ˜sЂµn…3оЃr„f\0ўF…·єvТМG ®БI@й%¤”џ+Ац_I`¶ МфЕ\r.ѓ NІєЛKI…[”К–SJт©ѕaUf›Szыѓ«M§ф„ %¬·\"Q|9ЂЁBc§aБq\0©8џ#Т<a„і:z1UfЄ·>оZ№l‰‰№ќУАe5#U@iUGВ‚™©nЁ%Т°s¦„Л;gxLґpPљ?BзЊКQЌ\\—b „яйѕ’Q„=7Ѓ:ёЇЭЎQє\r:ѓtмҐ:y(Е Ч\nЫd)№РТ\nБX; ‹мЋкCaA¬\rбЭсџPЁGHщ!Ў ў@И9\n\nAl~H ъЄV\nsЄЙХ«ЌЖЇХbBrЈЄц„’­ІЯы3ѓ\rћPї% ўС„\r}b/‰О‘\$“5§PлCд\"wМB_зЋЙUХgAtл¤ф…е¤…й^QДеUЙДЦj™Бн BvhмЎ„4‡)№г +Є)<–j^ђ<Lуа4U* хЃBg лРжи*nЃК–и-яЬхУ 9 O\$ґ‰Ш·zyM™3„\\9Ьи˜.oЉ¶љМлёE(iеаћ њДУ7 tЯљйќ-&ў\nj!\rЃАyњyаD1gрТц]«ЬyRФ7\"рж§·ѓ€~АнаЬ)TZ0E9MеYZt Xe!Эf†@з{И¬yl 8‡;ђ¦ѓR{„л8‡Д®БeШ+ULс'‚FІ1эшж8PE5- Р_!Ф7…у [2‰JЛБ;‡HRІйЗ№Ђ8pз—ІЭ‡@™Ј0,Х®psK0\rї4”ў\$sJѕЃГ4ЙDZ©ХIў™'\$cL”RЃ–MpY&ьЅЏНiзz3GНzТљJ%БМPЬ-„ђ[Й/xзіTѕ{p¶§z‹CЦvµҐУ:ѓV'ќ\\–’KJaЁГMѓ&є°ЈУѕ\"аІeќo^Q+h^вРiTЃр1ЄORдl«,5[ݘ\$№·)¬фjLЖЃU`ЈSЛ`Z ^р|Ђ‡rЅ=Рчnз™»–˜TU 1Hyk›Зt+\0vбDї\r <њаЖ™мсjG”ћ­tЖ*3%k›Y ЬІT*Э|\"CЉьlhE§(И\rГ8r‡Ч{Ьс0еІЧюЩDЬ_Њ‡.6Рёи;гь‡„rBjѓO'ЫњҐҐП>\$¤Ф`^6™М9‘#ёЁ§ж4XюҐmh8:кыc‹ю0шЧ;Ш/Ф‰·ї№Ш;д\\'( о„tъ'+ ќ™тэЇМ·°^ Ѓ]­±NСv№з#З,лvрЧГOПiќП–©>·Ю<SпA\\Ђ\\оµь!Ш3*tl`чuЃ\0p'и7…Pа9·bsњ{Аv®{·ь7€\"{ЫЖrоaЦ(ї^жјЭEчъял№gТЬ/ЎшћUД9g¶оч/ИФ`Д\nL\nЃ)А†‚(Aъaр\" ћзШ Б&„PшВ@O\nеё«0†(M&©FJ'Ъ! …0Љ<пHлоВзЖщҐ*М|мЖ*зOZнm*n/bо/ђц®ђФ €№.мв©o\0ОКdnО)ЏщЏЋiђ:RЋОлP2кmµ\0/vмOXчршFКіП€оЊи®\"с®кцоёч0х0ц‚¬©н0bЛРgjрр\$сnй0}° о@ш =MЖ‚ 0nоPџ/pжotмЂч°Ёр.ММЅ Џg\0Р)o—\n0Ич‰\rF¶й Ђ bѕi¶Гo}\n°МЇ… NQ °' рxтFaРJоОфЏLхйрРаЖ\rАН\rЂЦц‘0Ес' р¬Йd oepЭ°4DРЬКђ¦q(~АМ к\r‚E°ЫprщQVFHњlЈ‚Kj¦їдN&­j!НH`‚_bh\r1Ћ  є n!НЙЋ­ z™°ЎрҐ Н\\«¬\rЉнЉГ`V_kЪГ\"\\Ч‚'V€«\0Кѕ`ACъА±П…¦VЖ`\r%ў’ВЕм¦\rсвѓ‚k@NА°ьЃBснљ™Ї ·!И\n’\0Z™ 6°\$d Њ,%а%laнHЧ\n‹#ўS\$ !\$@¶Э2±Ќ„I\$rЂ{!±°J‡2HаZM\\ЙЗhb,‡ '||cj~gРr…`јДјє\$єДВ +кA1рњEЂЗАЩ <КLЁС\$вY%-FDЄЉdЂLз„і Є\n@’bVfиѕ;2_(лфLДРїВ І<%@Ъњ,\"кdДАN‚erф\0жѓ`Д¤Z Ђѕ4Е'ld9-т#`дуЕ–…а¶Цгj6лЖЈгv ¶аNХНђf Ц@Ь†“&’B\$ е¶ (рZ&„Яу278I аїаP\rk\\Џ§—2`¶\rdLb@Eцѓ2`P( B'г Ђ¶Ђє0І& ф{Вђ•“§:®ЄdBе1т^Ш‰*\r\0c<Kђ|Э5sZѕ`єААO3к5=@е5АC>@ВW* =\0N<gї6s67Sm7u? {<&LВ.3~DДк\rЕљ Їx№н),rоinЕ/ еO\0o{0kО]3>m‹”1\0”I@Ф9T34+Ф™@e”GFMCЙ\rE3ЛEtm!Ы#1БD @‚H(‘Уn ГЖ<g,V`R]@ъВЗЙ3Cr7s~ЕGIуi@\0vВУ5\rVЯ'¬ ¤  ОЈPАФ\rв\$<bР%(‡Ddѓ‹PWДоРМbШ fO жx\0и} Ь в”lb &‰vj4µLSјЁЦґФ¶5&dsF Mу4МУ\".HЛM0у1uLі\"ВВ/J`т{Зю§ЂКxЗђYu*\"U.I53Q­3Qф»J„”g ’5…sаъЋ&jСЊ’Хu‚Щ­РЄGQ MTmGBѓt l-cщ*±ю\rЉ«Z7Фху*hs/RUV·рфЄBџNЛ€ёГугкФЉаiЁLkч.©ґДtм йѕ©…rYi”Хй-Sµѓ3Н\\љTлOM^­G>‘ZQjФ‡™\"¤Ћ¬i”ЦMsSгS\$Ib fІвСu榴™е:кSB|iў YВ¦ѓа8 vК#й”DЄ4`‡†.ЂЛ^уHЕM‰_ХјЉuА™UКz`ZЌJ eзєЭ@Ceнлa‰\"mуb„6ФЇJRВЦ ‘Tќ?ФЈXMZЬНР†НтpиТ¶ЄQvЇjяjV¶{¶јЕCњ\rµХ7‰TКћЄ ън5{Pцї]’\rУ?QаAAАиЋ‹’Н2сѕ “V)JiЈЬ-N 99f–l JmНт;uЁ@‚<FюС ѕe†j ЂТД¦ЏI‰<+CW@рЃзАїZ‘lС1Й<2ЕiFэ7`KG˜~L&+NЏаYtWHйЈ‘w Ц•ѓтlЂТs'gЙгq+Lйzbiz«ЖКЕўР.РЉЗzWІЗ щzd•W¦Ыч№(Џy)vЭE4,\0Ф \"dў¤\$Bг{ІЋ!)1U†5b p#Е}m=ЧИ@€wД P\0д\rм ў·‘Ђ`O|лЖц њЙЌьЕхыYфжJХ‚цEЧЩOuћ_§\n`F`И}MВ.#1Ⴌfм*ґХЎµ§ їzаucыЂ—і xfУ8kZRЇs2К‚-†’§Z2­+ЋК·Ї(еsUхcDтС·К м˜ЭX!аНuш&-vPРШ±\0'LпЊX шLГ№Њ€o Э ф>ёХЋУ\r@ЩPх\rxFЧьEЂМИ­ п%А гм®ь=5NЦњѓё?„7щNЛГ…©wЉ`ШhX«98 МЃЌшЇq¬ЈzгПd%6М‚tН/…•˜д ¬лЏLъНlѕК,ЬKa•N~П АЫмъ ,я'нЗЂM\rf9Јwђ˜!xђчx[€П‘ШG’8;„xA˜щ-IМ&5\$–D\$цјі%…ШxС¬Б”ИВґАВ Њ]›¤х‡&o‰-3ќ9ЦLщЅzЌь§y6 №;u№zZ иС8я_•Йђx\0D?љX7†™«’y±OY.#3џ8 ™ЗЂ˜e”QЁ=ШЂ*˜™GЊwm іЪ„Y‘щ  АЪ]YOYЁFЁнљЩ)„z#\$eЉљ)†/Њz?Јz;™—Щ¬^ЫъFТZg¤щ• МчҐ™§ѓљ`^ЪeЎ­¦є#§“Шс” ©Ћъ?њёeЈЂMЈЪ3uМеЃѓ0№>К\"?џц@Ч—Xv•\"з”Њ№¬¦*Фў\r6v~‡ГOV~Ќ&ЧЁЃ^gь љД‘Щћ‡'ОЂf6:-Z~ №љO6;zxЃІ;&!Ы+{9MіЩіd¬ \r,9Цн°д·WВ ЖЭ­:к\rъЩњщгќ@зќ‚+ў·]њМ-ћ[gћ™Ы‡[s¶[iћЩiИq››y›йxй+“|7Н{7Л|wі}„ў›ЈE– ыW°ЂWkё|JШЃ¶е‰xm€ёq xwyjџ»˜#і˜eјш(І©‰ёЌќАЯћГѕ™†ті {иЯЪЏ y“ »M»ёґ@«жЙ‚“°Yќ(gНљ-я©є©днЎљЎШJ(ҐьЃ@у… ;…yВ#Sј‡µY„Иp@П%иsћъoџ9;°кїфх¤№+ЇЪ Ґ;«Бъ€ZNЩЇВє§„љ kјV§·u‰[сјxќ…|q’¤ON?ЂЙХ …`uњЎ6Ќ|­|X №¤­—Ші|Oмx!л:ЏЁњП—Y]–¬№Ћ™c•¬А\r№hН9nО Б¬¬лЌЂП8'—щ‚к а Ж\rS.1їўUSИё…јX‰Й+ЛЙz]ЙµК¤?њ©КАCЛ\rЧЛ\\ є­№ш\$П`щМ)UМ|Л¤|СЁx'ХњШМдК<аМ™eО|кНіз— в’Мй—LпПЭMОyЂ(Ы§РlЏРє¤O]{СѕЧFD®ХЩ}Ўyu‹СД’Я,XL\\ЖxЖИ;UЧЙWtЂvџД\\OxWJ9И’ЧR5·WiMi[‡K€Ђf(\0жѕdДљТиї©ґ\rмMДбИЩ7ї;ИГЖуТсзУ6‰KК¦IЄ\rДЬГxv\rІV3ХЫЯЙ±.МаRщВюЙЌб|џбѕ^2‰^0Яѕ\$ QНд[гїDчбЬЈе>1'^X ~tЃ1\"6Lќю›+юѕAаћeб“жЮеI‘з~џевіві@ЯХ­х pM>Уm<ґТSKКз-HЙАјT76ЩSMfgЁ=»ЕGPК°›PЦ\rёй>НцѕЎҐ2Sb\$•C[ШЧп(Д)ћЮ%Q#G`uр°ЗGwp\rkЮKe—zhjУ“zi(фиrO«уДЮУюШT=·7іто~ я4\"ef›~ нd™фнVяZ‰љчU•-лb'VµJ№Z7ЫцВ)T‘Ј8.<їRMя\$‰ћфЫШ'Яbyп\n5шѓЭх_Ћ аwсО°нUр’`eiЮїJ”b©gрuЌSНл?Не`цбћм+ѕПп Mпgи7`щпн\0ў_Ф-ыџх _ч–?хF°\0“хЌёX‚еґ’[ІЇJњ8&~D#Бц{P•Шф4Ь—Ѕщ\"›\0МАЂ‹э§Ѓэ@Т“–Ґ\0F ?*Џ ^спЌ№еЇwлРћ:рЃѕuаП3xKН^уw“јЁЯЇ‰y[Фћ(ћж–µ#¦/zr_”g·ж?ѕ\0?Ђ1wMR&Mї†щ?¬StЂT]ЭґGх:I·аўч€)‡©B vф§’Ѕ1з<фtИв6Ѕ:ЏW{АЉфx:=Ио‘ѓЊЮљуш:В!!\0x›Х˜Јчq&би0}z\"]ДЮo•zҐ™ТjГwЧЯКЪБ6ёТJўPЫћ[\\ }ыЄ`S™\0а¤qHMл/7B’ЂP°ВД]FTг•8S5± /IС\rЊ\n ЃоOЇ0aQ\n >Г2­j…;=Ъ¬ЫdA=­pЈVL)Xх\nВ¦`e\$˜TЖ¦QJќНу®жlJпЉФоСy„IЮ д:ѓС ДДBщbPА†ыZНёn«Є°ХU;>_С\n ѕхлРМ `–ФuMтЊ‚‚ВЦЌmіХуВLwъB\0\\b8ўMЬђ[z‘ќ&©1э\0ф Ў\r˜TЦЧ›Ѓ Ђ+\\»3АPlb4-)%Wd#\nИеr ЮеMX\"ПЎд(Ei11(b`@fТґ­ѓSТу€jеD†ќbfЈ}Ђrпѕ‘эD‘R1…ќґbУ˜AЫпIy\"µWvаБgCёIДJ8z\"P\\iҐ\\m~ZR№ўvо1ZB5IЉГi@x”†·°-‰uM\njKХU°h\$o—€JП¤!ИL\"#p7\0ґ PЂ\0ЉDч\$  GK4eФР\$Ѓ\nGд?щ3ЈEAJ F4аIp\0«ЧFЋ4±І<f@ћ %qё<kгwЂЃ аLOp\0‰xУЗ( ЂG>р@ЎШзЖЖ9\0TА€˜мGB7 - ЂћшвG:<Q™ #ГЁУЗґы1П&tzЈб0*J=а'‹J>ШЯЗ8qЎЌРҐЄаЃ ЂOАўXфFґаQЌ,ЃАКР\"9‘®pд*р6 6A'э,yЂќIFЂR€іT€Пэ\"”чHАR‚!ґj#kyFА™аe‘¬zЈлйИрG\0ЋpЈ‰aJ` Cчiщ@њTч|\nЂIxЈK\"­ґ*ЁЌTk\$cітЖ”aAhЂ“! \"ъE\0OђdДSxт \0T ц\0‚ћа!FЬ\n’U“|™#S& IvL\"”“…д\$hРИЮEAпN\$—%%щ/\nP†1љ“І{¤п) <‡р LЌ е-R1¤в6‘¶’<Ѓ@O*\0J@q№‘ФЄ#Й@Зµ0\$tѓ|’]г`»ЎДЉA]иНмPб‘Ђ˜CАp\\pТ¤\0™ТЕ7°ДЦ@9©bђm€r¶oЫC+Щ]ҐJrФfь¶\rм)d¤ ’Сњ­^hЯI\\О. g–К>ҐНЧ8ЊЮА'–HАf™rJТ[rзo㥯.№v„Ѕп#„#yR·+©yЛЦ^тщ›†F\0б±Ѓ™]!Й•ТЮ”++Щ_Л,©\0<@ЂM-¤2WтвЩR ,c•Њњe2Д*@\0кP ЂВc°a0З\\PБЉ€OЃ  ш`I_2Qs\$ґwЈї=:Оz\0)М` М hЉВ–Бѓ€зў\nJ@@К«–\0љш 6qTЇе‡4J%•N-єm¤Дег.Й‹%*cnдЛNз6\"\rН‘ёти—ыЉfТAµБ„ pхM ЫЂI7\0™MИ>lO›4ЕS 7™cНм Ђ\"мЯ§\0е“6оps…–ДЭеy.ґг т¦сRKр•PAo1FВtIДb*ЙБ<‡©э@ѕ7РЛ‚p,пќ0NЕч: ЁNІm ,ќxO%и!‚ЪvіЁ˜ gz(РMґуАIГа аЃ~yЛц›h\0U:йШOZyA8ќ<2§ІрёКusЮ~lтЖОEр˜O”0±џ0]'…>ЎЭЙЌЊ:ЬкЕ;°/ЂВwТфќдм'~3GО–~У­ќдю§c. ю„тvT\0cШt'У;PІ\$А\$ шЂ‚Р-‚sітe|є!•@dРObwУжcўх'У@`P\"xф µиА0O™5ґ/|гU{:b©R\"ы0…С€k˜Рв`BDЃ\nkЂPќгc©б4д^ p6S`ЏЬ\$лђf;О7µ?lsЕАЯ†gDК'4Xja A‡…E%™ 86bЎ:qr \r±]C8КcАF\n'СЊf_9Г%(¦љ*”~ЉгiSиЫ ђЙ@(85 T”Л[ю†JЪЌ4ЃI…l=°ЋQЬ\$dА®hд@D -ЃЩ!ь_]ЙЪH–ЖЉ”k6:·Ът\\M-МШртЈ\r‘FJ>\n.‘ ”qђeGъ5QZЌґ†‹' ЙўћЅђЫЃ0џоЃzP–а#Е¤шцЦйrаТнtЅ’ТПЛЋюЉ<Q€ЏTёЈ3ЏD\\№„ДУpOE¦%)77–Wtќ[єф@ј›Ћљ\$F)Ѕ5qG0«-СWґvў`и°*)RrХЁ=9qE*K\$g ‚нA!еPjBT:—Kы§Ќ!ЧчH“ R0?„6¤yA)B@:Q„8B+JЌ5U]`„Т¬ќЂ:Јре*%Ip9ЊМЂя` KcQъQ.B”±LtbЄ–yJсќEк›TйҐх7•ОцAmУдў•Ku:ЋрSji— 5.q%LiFєљTr¦Аi©ХK€ТЁz—55T%U•‰UЪIХ‚¦µХY\"\nSХm†СДxЁЅChчNZ¶UZќ”Д( Bкф\$YЛVІгЂu@и”»’Ї ўЄ| ‚\$\0я\0 oZw2ТЂx2‘ќыk\$Б*I6IТn• •ЎѓI,ЂЖQU4ь\n„ў). шQђфЦaIб]™А иLвh\"шfўУЉ>˜:ZҐ>LЎ`n˜Ш¶Хм7”VLZu”…eЁлXъи†єBї¬ҐB‰є’ЎђZ`;®ш•J‡]тСЂћдS8ј«f \nЪ¶€#\$щjM(№‘ЮЎ”„¬ќa­Gн§М+Aэ!иxL/\0) Cц\nсW@й4ђЂє ЏбЫ©• ЉФRZѓ®в =˜Зо8“`І8~в†hАмP Ѓ°\r– °ћмD-FyX°+Кf°QSj+Xу|•И9-’шs¬xђШь†к+‰VЙcbpмї”o6HРq °іЄИ@.Ђ˜l 8gЅYMџЦWMPАЄUЎ·YLЯ3PaиH2Р9©„:¶aІ` ¬Жd\0а&кІYмЮY0٘Ў¶SЊ-—’%;/‡TЭBSіPФ%fђШЪэ• @ЯFн¬(ґЦЌ*Сq +[ѓZ:ТQY\0ЮґлJUYЦ“/э¦†pkzИ€тЂ,ґрЄ‡ѓjЪкЂҐW°Чґe©JµFиЌэVBIµ\rЈЖpF›NЩ‚Ц¶™*ХЁН3kЪ0§DЂ{™ЃФш`q™•ТІBqµeҐD‰ cЪЪФVГE©‚¬nЃсЧдFG E›>jоиРъЃ0gґa|ЎShм7uВЭ„Ќ\$•†м;aф—7&Ўл°R[WX„КШ(qЦ#ќЊ¬P№ЖдЧ–Эc8!°HёаШVX§ДЋ­jшКZЋф‘ЎҐ°Q,DUaQ±X0‘ХХЁАЭЛGbБЬlЉBЉt9-oZь”ЌLчЈҐВ­еpЛ‡‘x6&ЇЇMyФПsТђї–ир\"ХНЂиR‚IWU`cч°а}l<|В~Дw\"·рvI%r+Ѓ‹Rа¶\n\\ШщГС][‹С6Џ&БёЭИ­Гa”УємЕj№(Ъ“рTС“А·C'Љ…ґ '%de,И\n–FCЕСЌe9C№NдРЌ‚-6”UeИµЊэCX¶РV±ѓќ№эЬ+ФR+єШ”Л•3BЬЃЪЊJрўи™њ±жT2 ]м\0PиaЗt29ПЧ(i‹#ЂaЖ®1\"S…:ц· €ЦoF)kЩ fфтДРЄ\0ОУїюХ,ЛХwкѓJ@мЦVт„Ћµйq.e}KmZъЫпе№XnZ{G-»чХZQєЇЗ}‘ЕЧ¶ы6ЙёрµД_ћШЃХ‰а\nЦ@7Я` ХC\0]_ Ќ©Кµщ¬«п»}ыGБWW: fCYk+йЪbЫ¶·¦µ2S, Ъ‹Ю9™\0пЇЃ+юWДZ!Їeю°2ыфа›—нІk.OcѓЦ(vМ®8њDeG`Ы‡ВЊцL±х“,ѓdЛ\"CКИЦB-”Д°(ю„ „„pчнУp±=аЩь¶!эk’ШТДјп}(эСКB–krЌ_Rо—Ьј0Њ8a%ۘL \0й†Ас‰bҐІљсЕю@Ч\"СПr,µ0TЫrV>€…ЪИQџР\"•rЮчP‰&3bбPІж- x‚Т±uW~Ќ\"я*и€ћЊNвh—%7ІµюKЎYЂЂ^Aч®ъКC‚ию»pЈбо€\0р ..`cЕж+ПЉвGJЈ¤ёHїА®E‚…¤ѕl@|I#AcвяDђ…|+<[c2Ь+*WS<€rагgёЫЕ}‰Љ>iЃЭЂЃ!`f8сЂ(c¦ЃиЙQэ=fс\nз2СcЈh4–+qќЏЃ8\na·RгBЬ|°R“ЧкїЭm µЉ\\qЪхgXА –ЌПЋ0дXд«`nоFЂомЊO pИоHтCѓ”jdЎfµЯEuDV˜ђbJЙ¦їе:±пЂ\\¤!mЙ±?,TIa˜†ШaT.LЂ]“,JЏЊ?™?П”FMct!aЩ§RкF„Gр!№Aх“»rrЊ-pЋXџ·\r»тC^А7Ѓбр&гRй\0ОСfІ *аA\nхХ›Hбг¤yоY=Зъи…lЂ<‡№AД_№и +‘ОtAъ\0B•<Ay…(fy‹1Оc§O;pќ иЕб¦ќ`з’4РЎMма*њоf†к 5fvy {?©аЛ:yшС^cвНuњ'‡™Ђ8\0±јУ±?«ЉgљУ‡ 8BЌО&p9ЦO\"zЗхћrs–0єжB‘!uН3™f{Ч\0Ј:Б\n@\0ЬАЈЃpђЩЖ6юv.;аъ©„Кb«Ж«:J>Л‚‰й-ГBПhkR`-ЬсОрawжxEj©…чБrћ8ё\0\\БпфЂ\\ёUhm› э(mХH3Мґн§S™“Бжq\0щџNVhіHyЌ —»5гMНЋe\\gЅ\nзIP:Sj¦ЫЎЩ¶и<ЋЇСxу&ЊLЪї;nfН¶cуq›¦\$fр&lпНюiі…њаз0%yОћѕtм/№чgUМі¬dп\0e:ГМhпZ Р^ѓ@з э1ЂПm#СNЏуw@ЊЯOррzGО\$тЁ¦m6й6}ЩТТ‹љX'ҐIЧi\\QєYќЂё4k-.и:yzСИЭHї¦] жжxеGПЦ3ьїM\0ЂЈ@z7ў„і6¦-DO34ќЮ‹\0ОљДщО° t\"О\"vC\"JfПRКћФъku3™MОж~ъ¤УЋ5V а„j/3ъѓУ@gG›}DйѕєBУNqґЩ=]\$йїI‡хУћ”3Ёx=_j‹XЩЁќfk(C]^jЩMБНF«ХХЎЊаПЈCzИТVњБ=]&ћ\rґA< жµВАЬгз6ЩФ®¶ЧґЭ`jk7:gНо‘4Х®бл“YZqЦftuќ|ЌhИZТТ6µ­iгЂ°0 ?йхйЄ­{-7_:°ЧЮђtСЇнck‹`YНШ&“ґйќIхlP `:нф j­{hм=Рf а Г[byћўКЂoР‹B°RS—ЂјB6°А^@'Ѓ4жш1UЫDq}мГNЪ(Xф6j}¬cа{@8 гтр,А ПPFCар‰Bа\$m v˜ќЁPж\"єЫLцХCSі]›ЏЭаEЩЮПlU†Сfнwh{oЌ(—д)и\0@*a1GД ( ЃD4-cШуP8ќЈN|R›†вVMё°Чn8G`e}„!}ҐЂЗp»‡Ьтэ@_ёНСnCtВ9ЋС\0]»u±оЇs»ЉЭ~иr§»#Cn p;·%‹>wuёЌЮnГwы¤Эћк.ќва[ЗЭhTч{ёЭеЂј зЁЛЃ‡·JрЌФЖ—iJК6жЂOѕ=ЎЂ‡ыжЯE”чЩґђ‘ImЫпЪV'Йї@в&‚{Є‘›тцЇµђ;нop;^–Ш6Е¶@2зЇlыФЮNп·єMЙїrЂ_Ь°ЛГЌґ` м( yЯ6з7‘№элоЗ‚“Џ7/Бpрe>|Яа ш=Ѕ]РocЃы‘б&еxNmЌЈ‰зѓ»¬аo ·GГN p—‚»˜xЁ•ГЅЭрѓy\\3аЏш‡ВЂ'ЦI`rвGч]Дѕс7€\\7Ъ49Ў]Е^p‡{<Zб·ёq4™uО|ХЫQЫ™ахp™эљi\$¶@oxс_<ЃАж9p BU\"\0005Ќ— iдЧ‚»ёCыpґ\nфi@‚[гњЖ4јjРЃ„6bжP„\0џ&F2~ЋАщЈјпU&љ}ѕЅЌїЙ˜ ™МDa<Ђжzx¶kЈ€‹=щс°r3йЛ(l_”Ѓ…FeF›ќћ4д1“K \\УЋldо д1ЃH\rЅЂщp!†%bGжXfМА'\0ИњШ '6Аћps_›б\$?0\0’~p(ЃH\nЂ1…W:9ХНўЇ˜`‹ж:hЗB–иg›BЉk©ЖpДЖЃуtјм€EBI@<т%ГёАщ` кЉyЃd\\Y@D–P?Љ|+!„бWАш.:џLeЂv,Р>qуAИзє:ћ–оbYй€@8џd>r/)ВBз4АРО(Ѓ·Љ`|йё:t±!«‹БЁ?<Ї@ш«’/Ґ S’ЇP\0Ва>\\жв |й3п:VСuwҐлзx°(®Іџњ4ЂЗZjD^ґҐ¦Lэ'јмДC[Ч'ъ°§®йjВє[ Eёу uг°{KZ[s„ћЂ6€‚S1ќМz%1хc™ЈB4€B\n3M`0§;зтМВ3Р.”&?Ўк!YAАI,)ре•l†W['ЖКIВ‡TjѓЃи>F©јчS§‡ BР±Pб»caюЗЊuпўNЭПАшHФ LSфЌо0”ХY`ВЖИ\"il‘\rзBІлг/Њфгш%PЂПЭN”Gф ќ0JЖX\n?aл!П3@MжF&ГіЦюїђ,°\"оЂиlbф:KJ\rп`k_кbчьAбЩДЇМь1С I,ЕЭоь€;B,Ч:уѕмY%јJ ЋЉ#v”Ђ'†{ЯСАг „ћ wx:\ni°¶і’} cА°eN®Сп`!wќЖ\0ДBRU#ШSэ!а<`–ђ&v¬<ѕ&нqOТ+ОЈҐsfL9ЏQТBК‡„ЙудЏbУа_+п«*ЂSu>%0ЂЋ™©…8@l±?’L1po.ДC&ЅнЙ BАКqh˜¦у­’Бћz\0±`1б_ 9р\"–Ђи!ђ\$шЊ¶~~-±.ј*3r?шГІАd™s\0МхЃИ>z\nИ\0Љ0 1Д~‘ф˜Jріръ”|SЮњф k7gй\0ЊъKФ d¶ЩaЙоPgє%гw“DфкzmТыИх·)ї‘сЉњj‹ЫЧВя`k»ТЃQа^ГО1ьЊє+Оењ>/wbьGwOkГЮУ_Щ'ѓ¬-CJёе7&ЁўєрEс\0L\r>™!ПqМЃођТ7ЭБ­хoЉ™`9O`€аѓ”ц+!}чP~EеNИc”цQџ)мб#ып#ет‡Ђм‡МСшА‘ЎЇиJсДz_u{іЫK%‘\0=убOЋX«Я¶Cщ>\nІЂ…|wб?ЖFЂЕк„Хa–П©UђЩеЦb NҐYпЙhЉЅ»й‘/ъы)ЮGОЊ2ь™ўK|г±y/џ\0йдїZ”{йЯPчYG¤;х?Z}T!Ю0џХ=mNЇ«ъГfШ\"%4™aц\"!–ЮџЃъєµ\0зхп©}»о[тзЬѕілbU}»Ъ•mхЦ2±• …ц/tюо‘%#Џ.СШ–ДяseЂBяp&}[ЛџЋЗ7г<aщKэпс8жъP\0™уЎgјт?љщ,Ц\0ЯЯ€r, >їЊэWУюпщ/Цю[™qэђk~®CУ‹4ЫыGЉЇ:„ЂXч˜Gъr\0ЙйџвЇчџL%VFLUcЇЮд‘ўюЋHяybP‚Ъ'#яЧ \0РїэПм№`9Ш9ї~пт—_ј¬0qд5K-ЩE0аbфП­ьљЎЋњt`lmкнЛяbЊаƘ; ,=˜  'S‚.bКзS„ѕшCc—ѓклКЌAR,„ѓнЖXЉ@а'…њ8Z0„&мXnc<<ИЈр3\0(ь+*А3·ђ@&\rё+Р@h, цт\$O’ё„\0Е’ѓиt+>¬ў‹њbЄЂК°Ђ\rЈ><]#х%ѓ;Nмsу®ЕЋЂўКр*»пcы0-@®ЄLм >ЅYЃp#Р-†f0оГК±aЄ,>»Ь`ЏЖЕаPа:9ЊЊo·р °ov№R)e\0Ъў\\І°Бµ\nr{Г®X™ТшО:A*ЫЗ.ђDхє7ЃЋ»јт#,ыNё\rЋE™ФчhQK2»Э©ҐЅzА>P@°° ¦ T<ТК=Ў:тА °XБGJ<°GAfх &ЧA^pг`©АР{ыФ0`ј:ырЂ);U !Рe\0оЈЅПc†p\r‹і ‹ѕ:(ш•@…%2 SЇ\$Y«Э3йЇhCЦм™:O˜#ПБLуп/ќљй‚з¬k,†ЇKеoo7ҐBD0{ѓђЎjу мj &X2Ъ«{Ї}„RПx¤ВvБдчШЈА9Aлё ¶ѕ 0‰;0Ѓхб‘а-Ђ5„€/”<Ьз° ѕNЬ8EЇ‘—З +гР…ВPdЎ‚;ЄГА*nџј&І8/jX°\rђљ> PПђW>Kа•O’ўVД/”¬U\n<°Ґ\0Щ\nIЃk@Љєг¦ѓ[аИП¦ВІњ#Ћ?ЂЩг%сѓ‚иЛ.\0001\0шЎkи`1T · ©„ѕл‚ЙђlјђљАЈоЕp®ў°Б¤і¬і…< .Ј>нШ5ЋР\0д» O¬>k@BnѕЉ<\"i%•>њєzД– з“сб єЗ3ЩPѓ! р\rА\"¬г¬\r ‰>љadацуўU?ЪЗ”3PЧБj3Јд°‘>; УдЎ ї>ћt6Л2д[ВрЮѕM\r >°є\0дмP®‚·Bи«Oe*RЃ n¬§њy;« 8\0ИЛХoжЅ0эУшiВшю3КЂ2@КэаЈоЇ?xф[чЂЫГLяaЋЇЃѓw\nsч€‡ЊAІїx\r[СaЄ6Вclc=¶КјX0§z/> +љЄ‰ шW[ґo2ВшЊ)eо2юHQPйDY“zG4#YD…ц…єp) єHъpђЋ˜&в4*@†/:˜ б‰T˜ ­џ¦aH5‘ѓлh.ѓA>њп`;.џ­оY“Бa Втъt/ =3…°BnhD?(\nЂ!ДBъsљ\0ШМDС&D“JЏ‘)\0‡jЕQДyђЋhDh(фK‘/!Р>®h,=Ых±†гtJЂ+ЎSх±,\"MёДїґNС1ї[;шРўЉј+х±#<мЊI¤ZДџЊP‘)ДбLJсDймP1\$ДохјQ‘>dO‘јvй#˜/mh8881N:ќшZ0ZЉБиT •BуCЗq3%°¤@Ў\0Шп\"сXD а3\0•!\\м8#ЃhјvмibП‚TЂ!dЄ—€ОьV\\2уАSлЕЕ’\nA+НЅpљxИiD(мє(а<* цЪ+ЕХE·МT®ѕ BиS·CИїT ґжЩД e„Aп’\"б|©uјv8ДT\0002‘@8D^ooѓ‚шч‘|”Nщ˜фҐђКJ8[¬П3ДВхоJЌzЧіWL\0¶\0ћЂИ†8Ч:y,П6&@”А ђEЈКЇЭ‘h;ј!f˜ј.Bю;:ГКО[Z3Ґ™В«‚рn»млИ‘­йAЁ’УqP4,„уєXc8^»Д`Чѓ‚фl.®ьєўS±hЮ”°ќ‚O+Є%P#ОЎ\n?ЫЬIBЅКeЛ‘ЃO\\]ОВ6ц#ы¦ЫЅШЃ(!c) NхёєС?EШ”B##D нDdoЅеPЏAЄ\0Ђ:ЬnВЖџЂ` Ъи Q„і>!\r6Ё\0Ђ‰V%cbЃHFЧ)¤m&\0B Ё2Iн5’Щ#]ъ˜ШD>¬м3<\n:MLрђЙ9CсЏК˜0гл\0ђ“Ё(бЏ©H\nюЂ¦єMЂ\"GR\n@йЏш`[ГуЂЉ˜\ni*\0њр)€ьЂ‚ђмu©)¤«Hp\0ЂN€ А\"Ђ®N:9qЫ.\r!ЌЌґJЦФ{,Ы'жЩЃЉ4… B†ъЗ lqЕЁџXc«В4Я‹N1ЙЁ5«WmЃЗ3\nЃБFЂ„`­'‘€ТЉxаѓ&>z>N¬\$4?у›ГпЏВ(\nмЂЁ>а лПµPФ!CqНЊјЊp­qGLqqцGІyНH.«^аћ\0zХ\$ЂAT9Fs†Р…ўD{нa§шcc_ЂGИz†)уі‡ Ь}QЖЕhуМHBЦёЌ<‚y!L­“ЂЫ!\\‚І€о ш'’H(‚д-µ\"ѓin]Дћ€і­\\Ё!Ъ`M˜H,gИЋн»*ТKfл*\0т>ВЂ6¶€а6ИЦ2уhJж7Щ{nqВ8аЯфЌЙHХ#cЏHг#˜\r’:¶–7К8аЬЂZІ˜ZrDЈюЯІ`rG\0дl\n®IЌ€i\0<±дгф\0Lg…~ђЁГE¬Ы\$№ТP“\$Љ@ТPЖјT03ЙHGH±lЙQ%*\"N?л%њ– ЂО\nсCrWЙC\$¬–pс%‰uR`АЛ%ітR\$–<‘`ЦIfxЄЇч\$/\$„”ЃҐЃ\$њљ’O…(‹ЏЛ\0жЛ\0ЏRY‚ *Щ/ к\rЬњC9Ђп&hhб=IУ'\$–RRIЗ'\\•a=EФ„ќтuВ·'М™wIе'T’ЂЂ‘ья©ѕгK9%˜dўґ·‚!ь”ЃАККАТj…мЎнУК&Рж„vМџІ\\=<,њEщЊ`ЫYБт\\џІ‚¤*b0>Іr®а,d–pdЊЊМ0DD М–`в,T ­1Э% P‘ћ¤/ш\rтb№(ЊЈхJСиНоT0т``ЖѕЮи нуJ”t©’©Кџ((dЗКЄбh+ <Й€+H%i ‡Иф‹І•#ґ`­ ЪКС'фЈB>t˜ЇJЂZ\\‘`<Jз+h R·КФ8 о‰Ђаh R±,J]gтЁIд•и0\n%J№*РYІЇЈJwDњ°&К–D±®•ЙРњЄR§K\"Я1QтЁЛ ”ІAJKC,дґmV’»ЋІ›КЩ-±тПKI*±rЁѓ\0ЗLі\"ЖKb(ьЄЌуJ:qKr·dщКџ-)БћЛ†#ФёІЮё[єA»@•.[–ТЁКјЯ4єЎЇ.™1т®JЅ.М®¦u#J“‡Бg\0Жгт‘§Ј<Л&”’рK¤+Ѕ M?Н/dЈК%'/›ї2YИд>­\$Н¬lє\0†©+ш—Б‰}-tє’Н…*к‰Rд\$Я” тМK».ґБ­уJHыК‰ ‡2\r„їBЏ‚Ѕ(PНУМ6\"ь–nf†\0#Р‡ ®Н%\$ДК[Ђ\nРnoќLJ°ЊЕУВe'<Їу…‡1KнБyМY1¤ЗsҐ0А&zLf#ьЖі/%y-ІЛЈ3-„В’НKђЈL¶ОЃЙЧ0њі’лё[,¤ЛМµ,њ±’«„§0”±У(‹.DАЎ @ПБ2пL+.|Ј’ч¤Й2и(іLҐ*ґ№S:\0Щ3ґМнуG3lМБaЛђlі@Lі3z4­ЗЅ%М’НLЭ3»…іј!0Љ33=Lщ4|И—Ўа+\"°Кй4ґЛе7Л,\$¬SPM‘\\±О?JЉY“МЎ№Ѕ+(Вa=KЁм4њ¤іCМ¤<РЃ…=\$Ќ,»іUJ]5hіW &tЦI%Ђй5¬Ті\\M38gўНЃ5HЉN?W1Hљ±^КЩФё“YН—Ш ЏНЏ.‚N3Mџ4Г…і`„Ћi/P‰7 ЦdM>љdЇ/ќLRОЬв=K‘60>ЇI\0[рх\0ЯН\r2фФтZ@П1„Ы2я°7И9дFG+дЇТњЕ\r)аhQtL}8\$КBeC#Б“r*HИЫ«Ћ-›Hэ/ШЛТ6ИЯ\$шRC9ВШЁ!‚ЂЕ7ьk/PЛ0Xr5ѓЎ3Dђ„ј<TБФ’qЇKф©іnОH§<µFя:1SLОrА%(яЌu)ёXr—1СЂnJГIМґSЈ \$\$й.О‡9ФйІIОџТ3 ЁL Гl”“ЇО™9дЕC•N #ФЎу\$µ/ФйsќЙ9«@6Кt“І®Nс9јґ·NЙ: №’ВЎ7у У¬Н:DбУБM)<#–УГM}+с2ОNю сІ›O&„рўJNy*ЊттЩё[;суОO\"mЪДуЕMх<c Вґ‚°±8¬KІ,ґУЗNЈ=07sЧJE=TбіЖO<ФфіЈJй=D“У:ПC<М“аЛ‰=диу®KђК»МіИL3¬ч­Џ„LTРЂ3КS,њ.ЁяПq-Њсsз7Н>‚?уј7O;Ь `щOA9ґусП»\$њьБ OС;мэ`9ОnЗIЃAЊxpЬцE=O№<ьІ5ПО„э2ёOЌ?dґЋ„ґЊ`NтiOя>Њю3ЅP ?¤тФOћmњъSрMфЛ¬·†=№(гdг¤AИ­9Џ“‘\0н#ьдІ@ѓ­9DЋЌБЙ&ЬэтЉ‚ ?њ “Р i9»\nа/ЂсAЭутИ­A¤эSЛPo?kuN5Ё~4ЬгЖ6††Ш=т–Њ“*@(®N\0\\Ы”d Gеьp#и¤> 0А«\$2“4z )А `ВW˜р +\0Љ‘80ЈиЏ¦•  ¤Є”дz\"TРд0Ф:\0Љ\ne \$ЂЋrM”=Ўr\nІN‰PчCm t80ръ #¤ШJ= &РЖ 3\0*ЂќBъ6Ђ\"Ђ€йиъЂ#ЏМ>˜  (Q\nЊркґ8С1C\rt2ѓEC€\n`(Зx?j8N№\0ЁИ[А¤QN>Ј©а'\0¬x cкЄр\nЙ3ЏЧChь`&\0ІРґ8С\0ш\n䵦ъO`/Ђ„ЌўA`#РмђXcиРПD яtR\n>јЃФdСBтDґLРДМх ‰дРНDt4РЦ j”pµGAoQoG8,-sСЦрФK#‡);§E5ґTQСGР4Ao\0 >рtMУD8yRG@'PхC° ф<PхCе\"”K\0’ђxьФ~\0Єe i9Рмњv))СµGb6‰ Ђ±H\r48С@‚M‰:ЂіFШtQТ!H•”{R } фURpЏНФO\0ҐI…t8¤ШрыОЗ[D4FСDЌ#КС+DЅ'фMЏК•А>RgIХґЉQпJЁ””UТ)EmаЏьTZ­Eµ'гкЈiEЭґЈТqF zAЄє>э)T‹Q3HЕ#TLТqIjNTЅј…&CшТhЌX\nT›СЩK\0000ґ5Ђ€ўJHС\0“FE@'С™FpґhS5Fќ\"ОoС®ђe%aoS E)  Ђ“DU «Q—FmОСЈMґССІe(tnТ “U1ЬЈ~>Ќ\$сЯЗ‚’­(hХЗ‘Gьy`«\0’к  ѓнG„т3Ф5Sp (эхPгGн\$”њ#¤Ё ©†©NЁ\nфV\$цЌ]ФњPЦ=\"RУЁ?Lzt·ѓ1L\$\0ФшG~е ,‰KNэ=”лТGMЕ”…¤NSЂ)СбO]:ФЉS}Э81аRGe@Cн\0«OPрSхNН1фЭT!P•@СЭSЂряХS‰G`\nЙ:Ђ“P°j”7RЂ @3ьС\n‘ ьгчЏв Ј”DУ жъLИПјЋ  ил\0щQ5фµ©CPъµSMPґv4†є?h hлT‡D0ъСЦЏах>&ТITxфOј?•@U¤чR8@%Ф–ЊхK‰Ђ§NеKгуRyE­E#эщ @эГшд %Lа«Q«QЁµЈЄ?N5\0ҐR\0ъФЃTлFеФ”RџSн!oTEВC(П¶ђИэДµ\0„?3iоSS@UчQeMµѓ KШ\n4PХCeS”‘\0ќNC«P‚­Oх! \"RTђыхЂЏSҐNХЏБU5OU>UiIХPU#UnKPфЈUYTи*ХCЏ«UҐ/\0+єёЕ)ИЪ:ReAа\$\0шЋ¤xтЗWDє3ГкЏа`ьЪьзU5ТIHUY”ф:°P хe\0–MJiЂѓµ ГэQш>х@«T±C{›ХuСм?Х^µv\0WRЌ]U}Cцк1-5+Uд?н\rхW<ё?5•JU-SXьХLФЯ \\tХ?ТsMХb„ХѓVЬЃt§TЊ>ВMU+Ц EЕc€ПФ9Nm\rRЗѓCэ8ЋSЗX•'RТйXjCI#G|Ґ!QЩGh•tрQЌёэ )<№YР*ФРRmX0ьфцЅMЈ›хOQЯYэhА«ЯduХ¤ХZ(эAo#ҐNlyN¬VЂZ9IХЌєM•¦V«ZuOХ…TХTЕEХ‡Ц·SНeµµЦК\nµXµЄSЫQERµіФЩ[MF±VзO=/х­ЏЁ>хgХ№TнVЌoUЏTіZ’NЂ*T\\*ГпРЧS-pµSХГVХqЂТM(ПQ=\\Ќ-UUUV­C•ДЧZШ\nu’V\$?M@UОWJ\r\rUРФ\\е'UЧW]…W”ЈW8єN '#h=oCуРэF(ьй:9ХYu•†¤чV-UУ9џ]ТC©:Uї\\ђ\nµqW—™а(TT?5PбЄ\$ R3ХвєџC}`>\0®E]€#Rка ѓя#RҐ)ІW–’ќ:`#уGх)4ЉRАэ;хбViD%8А)З“^ҐQхй#”h ґHВЋX ѓю\$Nэxґљ#i xыФ’XRхЂ'Ф9`m\\©†Ё\nEА¦Q±`Ґbu@ЧсNҐdTЧ#YYэ„µ®GVЌ]j5#?L¤xt/#¬”е#й…ЅO­PХлQжў6•ЈЈП^н† ЂљЋрьЦШM\\R5tґУљpа*ЂѓX€V\"WЕDЂ oRALm\rdGЏN ХЦАъ6”p\$ќPеєџE5Фэ†©Tx\nЂ+Ђ‹C[ЁфVЋЊэЌЦ8U•Du}Ш»F\$.ЄЛQ-;4ИЂ±NX\nЏ.XсbНђ•\0ЇbҐ)–#­NэG4KШРZS”^ЧґM¶8Шуd­\"C‚¬>ЕХdHe\nцY8ҐЏС.к ъ°€ТЏFъD”ЅW1cZ6”›QвKHь@*\0ї^ёъЦ\\QЯF‚4U3Y|‘=˜У¤йE ›ФЫ¤¦?-™47YѓPm™hYw_\rљVeЧ±M˜±ЯЩЏe(0¶ФFХ\r !ТPUI•uС7Qе•CиСЋ?0яµЏЭgu\rqधY-Qиу°иъ=g\0…\0M#чUЧS5Zt®Цџae^•\$>ІArVЇ_\r;tоЏ¬’Ё”HW©Zн@HХШhzDиЪ\0«S2Jµ HIеO 'ЗЃeнgЙ6№[µR”<ё?И /ЏТKM¤ц–Ш\n>Ѕ¤HбZ!i€ ц¤џTX6–ТЧiєC !У›gЅ а ТG }Q6ћС4>дwа!Ъ™C}§VBЦ>еЄUQЪ‘jЄ8cпUЌTаы–'<‚>ИэхфHC]ЁVљС7jj3vҐ¤е`0ГиИ23ц°Ртxы@U—k \nЂ:Si5ћХ#Yм-wо”ХайM?cйТMQЕGQХСѓb`•т\0Ћ@ хЛТ§\0MҐа)ZrKXыЦџЩWl­ІцќЏНlеіTMЧD\r4—QsSҐ40СsQМЃхmYгh•d¶ВC`{›VЂgEИ\n–»XkХЃа'Уи,4ъј№^нў6Ж#<4ЃйNX nM):№·OM_6dЂ–жхёГх[\"KUІnћЦ?lґx\0&\0їR56џT~>  ф†Хё?”JnћЂ’ €ПZ/iТ6фОЪglН¦ЦUЫбF}ґ.ћЈјЌJLцCTbMЋ4НУcLхTjSD’}JtЊЂЌZ›ЄµЗ:±L­Ђґd:‰Ez”К¤Є>ЌЦV\$2>­µЋў[гpв6цФRЋ9uкW.?•1®ЈRHuћиЫRё?58Ф®¤нDЭЖuѓЈзpыcмZа?њrЧ» Eaf°ђ}5wYґле‚П’ТкЕW‚wT[Sp7'Ф_aEk \"[/iҐї#я\$;m…fШЈWOьф”ФFт\r%\$Нju-t#<Е!·\n:«KEAЈнТС]А\nUжQ­KEА #ЂїXеЁч5[К>€`/ЈНDµКЦ­VEp а)ЏеI%ПqЯЬыnнx):¤§leўґХ[eХ\\•eV[j…–ЈйС7 -+ЦЯGЌWEwtЇWkEЕ~uмQ/mх#ФђW—`эyu“ЗЈDЭAц'Ч±\r±•Х™OќD )ZM^Ђіu-|v8]‹gЅ‘hцЧЕLа–W\0шИы6ЛX†‘=YФdЅQ­7 П“”П9ЈзНІr <ГЦЏкDієB`c 9ї ’И`ЏD ¬=wx©I%д,ᄬ†иІакѓj[СљќЦнЯOя‹ґ ``ЋЕ|ёттЖЮш¤Њ˜јн.М AOЉАД ·‰@е@ 0h2н\\вРЂM{eгЂ9^>ф•в@7\0тфЛ‚W’Ђт\$,нЙЕљЎ@ШЂТв•еЧw^fmе‰,\0ПyD,Чќ^XЂ.ЇЦ†©7г·›ГЧ2ЭЕf;ҐЂ6«\n”¤Ћ…^џzC©Ч§mz…йn–^€ф”&LFFк ,°ц[ЂҐeИ хaXy9hЂ!:zН9cтQ9bЕ !Ђ¦µGw_WЙgҐ9©ЏУS+t®ЪбpЭtЙѓ\nm+–њЮЩ_р ЎЄ\\ј’ќk5ЈТЬ]Ж4€_h•9 ЩчN…ђ—Е]%|Ґ€7ЛЦњЋ];”п |ќсµ ЯXэН9Х|есЧМGў“Ё[ЧФ\0‘}Uс”зЯMCЌI:ТqOЁVФѓa\0\rсRН6ПЂГ\0ш@H ўЕP+rмS¤WгиЂшp7дI~ђp/ш HП^ЭкІь¤¬E§-%ыҐМ»Н&.ОД+ёJС’;:і¶«!“эРNр Ж~цЄ‰Ђ/“WДВ !„BиL+В\$рнq§=ьї+С`/Ж„e„\\±ТПxАpE‘lpSВJ SЌЭўЅц6а‡_№(ЕЇ©Дйb\\OЖК&мј\\Р59ќ\0ыВЂ9nсЏшDё{Ў\$бё‹Kђ‘v2 d]иv…CЃХюЕХ?Ѓtf|WЬ:ЈФЁ p&їаLn„Оиіћо{;€зЪGЃR9шђT.y№ьпI8Ђ№ґ\rl° ъ Tи  n”3јцрT.ѓ9ґи3› љјZиsЎЇСТGсюЋ€: 0Ј¦Јzи­Э.Њ]АзДЈQ›?аgT»%с™ХxЊХЊ.„љФЗn<мЈ-в8BЛі,Bтм˜rgQюўнЯу„ЙЋ`Ъб2й„:оµЅ{…gлДs„шgуZї•… ЧЊ<жЧw{¦˜ѓbU9€ `5`4„\0BxMpр‘8qnahй†@Шјн†-в(—>S|0®…ѕҐ…3б8h\0С«µCФzLQћ@¶\n?†ё`AА >2љВ,чб˜сNЃ&Њ«x€l8sah1и|˜B‡Й‡DЌxBЮ#V—‹V–ЧЉ`Wвa'@›‡¬ X_?\nмѕ •_вЃ. ШPјr2®bUarАIё~бс…S“аъ\0Ч…\" 2ЂЦюА>b;…vPh{[ °7a`Л\0кЛІj—oЊ~·ыюvНЩ|fv†4[Ѕ\$¶« {уЇP\rvжBKGbpлИЕш™–OЉ5Э 2\0jчЩ„LЋЂо)ЗmбИVЎejBB.'R{C¤пV'`Ш‚ ‰Ћ%­ЗЂР\$ Oеќ\0˜`‚Џ’«4 МNт>;4Јіў/МПЂґА*Вш\\5„ЕБ!†ы`X*Ю%оДNН3SхAMфюЛЖ”,ю1¬І®н\\ЇІcaП§ іщ@Ш¬ЛѓёB/„¬Нш0` уv2пЎ„§Њ`hDЕJO\$з…@p!9˜ !Ґ\n1ш7pB,>8F4Їеf ПЂ:“с7В„о3›Ј3…їа°T8—=+~Шn«Ов\\Дeё<br·ю шFШІ° ђ №CЎN‹:cЂ:Фl–<\r›г\\3а>с˜‡А6ЃONnЉд!;бс@›twл^FйЂLа;ЂЧ є,^aЏИ\ra\"ЮАЪ®'ъ:„vаJe4ГЧђ;•с_d\r4\rМ:ЫьА¬Sђ˜Џађ2ЃЂ[cЂ„XяК¦Pl˜\$№ЮЈђi“wеd#ЋB љbЃ›ОЧ¤х’™`:†ЂП~ <\0С2Щ·—‘RЊВЖPИ\rёJ8DЎt@мEЋи\0\rНњ6цудЮ7•Ѕд˜YПЈъ\"едАљ\rьѓ¦Аљ3ѓЎ.˜+«z3±;_КџvLЏЭдУwJї94АIђJa,A¦с€Ї;ѓs?ЦN\nRќ‡!Ћ§Эђ†Om…sИ_жа-zЫ­w„ЂЫzЬ­7ЎНЕzоч–MЌ”€Ђoї”Ґж\0ўѓa”ЕЭ№4е8иPfсYе?”тi—–eBОSа1\0ЙjDTeK”®UYSе?66R ¦cх 6Ry[cч”°5Щ]BН”ЦRщ_eA)&щ[凕XYRW–6VYaeU•fYeеw•ЋU№bеw”Eл°К†;z¤^W«9–дЧ§дЭ–хл\0<ޘиeк9SеО¤daЄ ”_-об‰LЧ8З…НQциTH[!<p\0Ј”Py5€|—#Ѓк‘Pі Ч9vаљ2В|Зёќбfa o†б,j8Ч\$A@kсѓїЋaЛ‘ЅbуcсИf4!4Ё‘¶cr,;™‘ж‘цbЖ=ЂВ;\0°шЕє…˜†cdГжXѕbмx™a™Rx0AгhЈ+wрxN[˜ЬBђ·pЪѓїw™TА8T%™љMљl2а‡ЅЎљђр—}ЎИs.kY„˜0\$/иfUЂ=юШs„gKГЎ€M› х?я›з`4c.Фш!Ў&Ђе€†g°ыfа/юf1ђ=Ї›V AE<#М№Ўf\n») Љл›Npт“г`.\"\"»Aзњ¤г—ь qёЃX“ Щ¬: aЙ8™№fЇ™Vsу‹G™ЮrЋ:жVЮЖcФgќVl™ќg=ќЃ`г“WЋЛэyТgUќАЛ™ЄбєјоeT=  гЂбЂЖx 0в Mј@€»љВ%ОєbЅњюw™ЖfЫЩOш筘Ь*0Ї…®|tб°%±™PИНpжъgKћщ¬?pф@JА<BЩџ#­`1„о9ю2зЃg¶!3~ШЬзоnlдЕfЉШVhщ¬Ћ.СЂа…aCСщ•?іЉы-а1њ68>A¤€aИ\r—¦ y‹0 Цi‘J«} а №ќ© Р z:\rЎ)‘Sю‚Ў@ ўеh@дцѓY№гґmCEgЎcyП†Ќ‚<хаНh@ј@«zh<WЩД`В•Ё±:zOгОЦ\rНкW«“°V08Щf7™(GyђѓІ`St#Ѓп„f†#ѓІЃњC(9ИВ˜ШЂdщжж8T:Ї»Њ0єи qµ  79· бЈphAgЬ6Љ.гж7 Fr™bд ИjљиA5о…†ѓбЎa1ъ Ъh•ZCh:–%№ОgUўрD9ЦЕЙ€„Ч№Пй0~vTi;ќVvSљ„wњШ\rОѓ?аЗfІЈ…яҐnЉП›iY™мaє¬3 О‡9Х,\n™Гr‘‰,/,@.:иY>&…љFС)Џъ™Ќ¶}љbЈЂиiOЭiќжљ:dиAЊn˜љc=¤L9O’h{¦ђ 8hY.’ЩА®ѕ‡®‡…њьЗ\r¬ЌЦ‡ЈА›Љй1QЇU ”C‘hф†eяO‰›°+2oМОмЮN‹˜ч§шzpиў(ю]УhЂеўZ|¬OЎcСzDбюЃ;хT\0jЎ\0…8#Ќ>ОЋБ=bZ8Fjумй;нЮєTй…Ўw®Н)¦эшN`жлЁ ¤Г…B{ыѓz\rуЎc“Уи|dTG“iњ/ыъ !i†К0±јш'`Z:ЉCHп(8ВЏк`VҐ™ЪгцЄ\0Ьꧩ†ЈWпЯЗЄ˜ХzgGѕ‘…ѓЅІ-[ГР iњкN\rqєй«n„„“o ЖҐfEJэЎapb№к}6Ј…Х=o¤–„,tиY+ц®EC\rЦPx4=јѕ™Щ@‡‰¦.†‘FЈЌ[ЎzqзЬиX6:FGЁ #°ы\$@&­ab¤юhE:Іѓе¬д`¶S­1—1g1©ю„2uhY‹¬_:BЯЎdcп–*я­†\0ъЖ—FYFњ:ЛЈЄn„ШМ=ЫЁH*ZјMhkђ/ЌлѓЎћzЩ№п‹ґ]љБh@фж©Шг1\0˜шZKщћўлОЖи^+є,vfуs®љ>€¤’Oг|иАКsГ\0Цњ5цX й‹оСЇF„чnїA€r]|ПIi4и…ю ШВC° h@Ш№ґџћ–cЯҐЁ6smOГе‰Ќ™›gX¬V2¦6g?~ЦГYХС°†sъcl \\RЉ\0ЊЁcњќA+Њ1°„›щМйЌ\n(СъГМ^368cz:=zч‚(дш ;иЈЁсЏsьF¶@`;мЂ,>yTЯп&–•dЅLЧџњя%Тѓ -лCHL8\r‡Зbы°°ЈъMj]4ђYm9ьЫьРZЪBшпP}<џыаXІЇ‰МҐб+gЕ^ШMЮ + B_Fd¬X„ш‹lуwИ~о\rвЅ‹и\":ФкqA1XѕмжІРшЇ3ЦО“Eбh±4ЯZZВуё& …жж1~!NЃfгґцo—€™\nMeЬ଄олXIО„нG@V*XЇ†;µY5{V€\nи»ПTйz\rF 3}m ¶Фp1н[Ђ>©tиe¶w™џжл@VЦz#‚ќ2Дп iффО{г9ѓ‚pМќ»gh‘Љж+[elU‰¦ЫAЯЩ¶Ујi1Д!Њѕommµ*Kа‡к}¶°!нЖінЎ®Э{me·f`“—mи˜CЫz=ћnЮ:}g° T›mLu1FЬЪ}=8ёZбниOћЫmFFMf¤…OOЂробА‹ѓишЯ/јйхёЮ“љеЂюV™oqjіІиn!+ЅђтµьZЁЛI№.М9!nG№\\„›3a№~…O+Ое::оK@Њ\nЪ@ѓ‘¤Hph‘ґ\\BДхdmќfvCићУPЫ\" жЅЫ.nW&–кnўшHYю+\r¶“Дzчi>MfqЫ¤о­єщЭQc‚[­H+жАo¤С*ъ1'¤ч#ДЃEwЂD_XнЃ)>РsЈ„-~\rT=ЅЈћач€а- нy§m§№жр{„hуџМjЪMи)Ђ^ћ№пА'@VеЎ+iИоОт›џеµ†Й;F“ D[Оb!јѕЏґB ¦¤:MP‹оуЫ­oCјvAE?йCІIiYН„#юp¶P\$kвJЮqЅ.Й07њюцx€l¦sC|пЅѕbo–2дXЄ>Mф\rl&»З:2г~ЫСcQІотІжoСЮdб‚-юиUЬRo‚YљnM;’n©#–Я\0–PѕfрЪPoЧї(CЪv<К¬ш[тoЫё”љыЧfСїЦьБ;Ябє–х[ъYџ.o®Upї®ЃpUЊш”.ћ ©B!'\0‹тг<Tсќ:1±Аѕ љг¤о<„›рn€оFірѓIўЗ”ґ‚V0КЗЃRO8‰wшО,aFъјЙҐ№[ґОџ…сYOщ«‰Ђ/\0™ЩoxЃчЗQр?§°:Щ‹лЖи`h@:ѓ«їцС/Mнmјx:Ы°c1¤ЦаыЇнvІ ;„‚и^жШЖ@®х@ЈърЅВЗ\n{ЇјВо‹а;з‘ґBјнё8‘є gеќ’д\\*gеyC)Ы„Eќ^эOДh Ўі¦Aѓu>Жиь@аDМ†Yжјн›в`o»<>Аѓp‰™ЉД·’q,Y1QЁБЯё†Џ/qgЊ\0+\0вже‡Dяѓз?¶ю о©ЪЯоk:щ\$©ы¬нЧҐ6~IҐ…=@ЋнС!ѕщvЪzOсЃљІв+НхЖ9Зiі–›јaпр†кы…gтрф оїќ—№я?Ѓљ0Gn˜qІ]{Тё,FбГшOЎв„Ю <_>f+ўЏ,сМ »Фс±&фњ†рнВ·јyкЗ©Oь:¬UВЇ€LЖ\nГГєI:2ії-;_ДўИ|%йеґї!Охfћ\$¦€†Xr\"Kniос—АР\$8#›g¤t-›Ђr@LУењЏи@SЈ<‘rN\nђD/rLdQkаЈ“”ЄхДоeредгР­еш\n=4)ѓ B˜”ЛЧљфМZ-|HbЎЃ†‘HkК* ЦQ!Р'ЃкG ћ›Ybt!їК(n,мPіOfqС+X “Y±я‚л\"b F6ЦМr fтќ\"ТЬі!NЎу^ј¦r±B_(н\"ЁKК_-<µт *QчтЁЩ/,)ЃH\0ќ„‰Іrз\"z2(№tЩ‡.F>†‡#3в®Ш¦ 268shЩ юЁЖ‘I1Sn20¶зК-Ќ«4’ЪЗ2Aњs(¬4дјЛ¶ЉЃ\0ЖЭ#„еrюK'ЛН·G'—7&\n>xЯьЬJШGO8,у…0 јв‹щ8”СУ\0уW9’ЭI€?:3nє\r-w:іВМЕЧ;3И‰”!П;іЬꃘ˜Z’RMѓ+>ЦЬрКй0/=R…'1П4Х8ыќСПmя%ИҐ}П‡9»;‚=ПnQцг=ПhhLх·GПkWО\rф %Ш4ТњsсО–JЂ3sЫ4—@™U‚%\$ЌЬСN;М?4­»уNЪП2|КуZЪ3Шh\0П3“5Ђ^Аxi2d\r|ыM·КЈbh|Э#vЗ` \0”кђ®даы\$\r2h#Џъ¤?і€ЏI\n’јЌ+o-њЉ?6`б№Ѕї.\$µљшKY%ШВЃJ?¦c°RЏN#K:°KбELБ>:БҐ@ЊгjP‘Мn_t&slm’'жР©ЙёУњІЊЅ—г;6Ы—HU5#мQ7U эWYЬU bNµ–Wы_ыЄ©;TCш[Э<Ъ–>ЕЗх‰WэCUЃФ6X#`MI:tщУµЂц u#`­fu«\$«t­ЃцXу`Ќf<Ф;bеghцСХ9Ч7ШS58х¬Э#^–-х\0кАъоХ№R*Ц'ЈЁ(хрхqZеЈЈкX№QЭFUvФW GWнсУTкЗWф~Ъ­^§WцДБХэJ=_Ш—bmЦЭbV \\lЃ·/ЪMХяTmTOXuК=_ЏэITvvu‹a\rL_ХqR/]]mТsu=H=uСg o\\UХ…gMЧ XVU А%хhэЎ53U™\\=ЎцQЯШM№v‡ЂЎgеmахueЎќ€ЩыhяbЭMЭGCeO5®ФЃЦO5…ФYЩ i=eХ GќTURvOa°*ЭivWX•J5<хЇbu ]€ЧЦръµ<хГЩХ\$u3v#Ч'eцuСR5m•Љv‹D5Џ.vЋЊхW=џU _е(ґ\\VШП_<хчSНn) Ь1M%QhбZ‡T…f5EХ'ХНWЅЉvЕUmiХ‚UФХ]aW©U§dRvбЩ-YUZuќЩUVќ—UiRЌVќ™хіУЗ[ЈнZMU§\\=Вv{ЫXэµјwQчhuHvЗЧgqЭґw!ЪoqtўU{TGqэ{ч#^G_ubQ„ке•i9Qb>ЪNUdє±k…Ѕ5hPЩmu[•\0Џ¦кЕ_¶й[хY-ЏрфчrхИХ(ЦCrMeэJх!h?QrX3 xяИП#‡чxЦ<Ы{u5~ѓнС-ЭuЋлYyQ\r-”о\0щuХЈuuЩїpUЪ…•)–PеЬ\r<u«S›0ЭЙw№Я-iЭуФ!МЦЉшBчбЖd]щиЕ‡ФЖEкрvlmQЭЏ6kјТJґ€wн¦ДћШГгЊED¶UЩR“eЌv:XЯcШNW}`-ЁtУH#e„Ѓbє±uЂгу ~B7к ?ѓ OPњCWђµЧSEН•V>¶“ЧUЫ7Яћз‰Фбm»У‚¬zя=µѓНШ1є™ѓ+ №mГI,>µX7ад] .‡Ѕ* ^оЉг°N…є.иО/\"„Џ˜ )Р …Ї‚sћ®|а¤зУџРlБ}г ёЋНз! уоѓ‘5n±p„jЈѕh’}Ѕирm“EбzHВaO0d=A|wлЯіглЧљОмuІњџvщШјGЂx#®…b” cSрo-‰щtOm`C‹т^MЊЕ@лґh­n\$kґ`ю`HD^ќPEа[дЊ]№ЁrRёmћ=‚.сЩ‡>Ayi‚ \"ъЂт Ц·oг-,.њ\nq+АҐеfXdЉ«¶г*ЯЅ€KОШѓ'Ьк Р%aфя‡щ9pыж—шKLM„а!ю,иКЛЋЁЊzX#˜Vб†uH%!Ањ63њJѕryХЃнщq_иu ъWщ±‡Ж|@3b1еИ7|~wп±іюнA7“ТВ›и™ ј™9cS&{гдТ%VxрпkZO‰Чw‰Ur?®„’ЄN О|…CЙ#Е°хеХЇ №/ъ™ 9ЃftЋEwёCБєa¦^\0шO<юW¦{Yг=йџeл˜эnЙ„нgyf0h@мSЭ\0:Cђ©ґ^ЂёVgpE9:85Г3жЮ§бєрЏ@»бЋj_Є[Ю+«кЗ©xѓ^“ꮆ~@С‡WЄёгг“њ†9x—FC˜ї­.ђгљзцьk^IЋыЎpU9ьШSџШчЅ—њ\$уу ш\r4ґ…щ\0ОиO°г‘Д)L[Вp?м.PECSмI1nm{ Е?ћPоWAЯІБ;ЂсмD°;SєaЏKfшт›%Џ?ґXхЮ+Џ¤B>Ѕ щ9їЇЩGj˜cћz‘AНЋч:кaіn0bJ{oҐ·!3А­!'’ШKГЕнщФ}г\\иО3Wшк5оx ПЙБL;ѓ2О¶n—a;ІЃнЧєXУ›]Йoєњxы{д¦5Ю™jXч€р—¶vУљйгqЮКEE{СЂ4БѕцД{нЩз М\nцК>щ™aпЇ·ѕьм§пШLыФыепяЅымс'рЅЮй{л\n‰—>JшЯЊЊбёУ—†чYП\rOКЅр‘tЇяыҐ-OГ¦ь4Фя9Fь;р§Б»ФьGршIЄFЯм1ВoяЯусOІѕйa{w—0У»п¤ЖЇ;с”„‘lьoсаJРTb\rwЗ2®Jµю=D#тnБ:ЙyсыSш^г,.ї?(ИI\$ЇКђЖЇнЁб3чГsр4MКaCRЙЖНGМ‘њъIЯ°n<ыzyСXNѕр?хв.Г ођ=—асґDЗјЌ\r›ћШй\nХуЁ\roхэ\nРџCl%БНYОыҐЯ°ПаGСюЪ}#ќVРќ%э(ФяТа3жЙЌ˜rћр};фыЧїGЙМnц[Є{Ґ№–“_<m4[ IҐўАјq°µ?р0cVэnms„іnMхх€\"Nj1хw?@м\$1¦ю>рТ^шХыҐц\\М{nВ\\Мћй7џ„їЩџic1пЪяhooк·?j<Gцx џlПщ©Sиr}НГЪ|\"}•ч/Ъ?sз¬tIдекј&^э1eуУtгф,Џ*'FёЯ=ќ/FЃkю,95rVвбшаАєм‘€ЃЫo9Нш/FА–_†~*^Чг{РIЖцЇг_ѓ‚ІЊ“^n„шюNџЉ~шбЕAн¦‘d©есюUшwдqY±еоґTё2АйGд?‡&–§жф:yщи%џ–Xз˜JЫCюd WиЯЋ~ъG!†ґJ}›—¤ъмщхДB-Уп±;оыњhГ*ујRґмцE¶ ~вжу.«~Йзж SAqDVxВоН='нЙEЩ(^Љыў~›щш ї›зтйзпo7~‚M[§ЃQго(іЬyёщnPС>[WX{qФaП¤ЖЙэ.&NЪ3]съHYпЭыѓлЫ[¶БЩ&ь8?С3„‹›¦¶§Э†Ъ»¶б#Њ¦ОBрeќ6ќл…@–“[°¤ЈыаРG\rО+э§ }ь˜чБяП_Эз7–|N„§«Ю4~(zБ~“»№п§%›–?±ЯУИ[№ш1ћSЄ]xШkцСKxO^йAЌЂ‰rZ+єя»Ѕ*ВWцЇkюwD(№ш»R:жэ\0•§нЌщ'¤Љу“m!OР\nдЕuи‚Жу.ђ[ ЃPЖ!№І}ЧПm Ып1pсuьв,T©зL ВЂ0}ќв&PЩҐ\nЂ=Dя=ѕсР\rВљA/·o@дь2гt 6аDKі¶\0ИВѓq†7„l јрBкЉъМ(ѓ;[с€kr\r‘;#‘ГдѓlЕ”\rі<}zb+ФРOс[ЂWrXѓ`ЃZ ЕЈ†Pm'Fn ј‰оSpЯ-°\0005А`dЁШчP„БЪЗѕ·Ы;ІМn\0‚5fпP„ЏїEJдwыЫ №.?А;¶§NтЮҐ,;Ж¦П-[7·ЮeюЪiЕв-“ЦоdЩЋ<[~”6k:&Р.7‡]Ѓ\0у©Ѓыл–щЌЏ/µ59 сБ@eT:煘Ї3ЕdђsЭќъ5дЏњ 5f\0РPµцHB–•н°Ѕє8JФLS\0vI\0€™З7DmђЖaћ3eЧнЋ?BіЄ\$ґ.E‹ЃРfЌЏЛ@Єnъѓ‰bтGbБПq3џ|ьљPaЛ€шПЇX7Tg>В.ЪpШп™’5ё«AHЕµ’Љ3Sр,˜Б@Ф#&wµо3†фm[ПАтIнСҐУ^“М¤J1?©gTбЃЅ#ПS±=_„‚_Ѓ± «ЈЙVq/CЫѕ·ЭЂО|ЛфбюђD ѓg>Ь„хлй 6\rЉ7}q”ЖЕ¤‹JGпB^о†\\gґЭхьЃњ&%­Ш[Є2IxГ¬Єс6\03]Б3Њ{Й@RUаЩMц v<е1Љї‘ѕsz±uP’5џЄF:Тiо|А`­qУч†V| »¦\nkђв}Р'|Ћgd†!Ё8¦ <,лP7˜m¦»||»я¶IЋAУЃ]BB ПFц0XПъі Љ DЦЯ`W µБqm¦OL‘ мё.Н(Бp‚јТЃд¶\"!‹ЏэЄ\0вНAпГф‡‰БVЂ–7kѓЊMё\$УN0\\Х§ѓ\"‹f ‘б Злс И\0uqћ—,Њ 5ЖгA6ЧpООИ\nрОђjYі7[pK°р4;ђlњ5n©Б@в\\fыРl ¦‚MцщыPБз3®—C HbРЊ©ёcEpP‰ЪР4eooeщ{ \r -аљ2.ФЦҐЅЊP50uБІ°G}Дв\0оЛхЁ<\rцњ!ёњ~Кэµѕус№\n7Fќ®d¶эа“њ>·ФaўЩ%єc6Фћ§хMАҐ|таd‹ы·мOУ_Ё?J„жЄ C0Д>РЃБ&7kM4Є`%fнlрΘB~ўwxСЪZGйP†2Їа0ь=ћ*p р†@€BeИ”ШП|2Д\rі?qёР8нёл±сНРЉ(·yrбц 0ао>њ>АE?wЬ|r]Ц%AvаэБЕд@Ћ+ЭXБЄAgвЙ Ыяsы®CРыAXmNТќъ4\0\rЪНЅ8JЭJрЗёDЏТљуґ:= •ру‡лЖS™4ЇсF; ¬\\&Ци†P!6%\$iдxi4cЅ0Bб;62=ЪЫ1ВщМ€PCШеВѓmЛН “dpc+Т5Ље\$/rCR†`ЈMQ¤6(\\ђб2A ¦№\\ЄЊlGтl¬\0Bq°¤P ЇrІышBђµ‰к›С‚№_6LlЛ!BQЋ‰IВЋGАеЬШрXRbsЎ]B—HrЏћг˜`ОX‹д\$pе±8р„• nbR,В±…L Ќ\"ВE%\0’aYB¦sњ…НD,ђ!ЖЧП›pN9 RbG·4ЖюM¬Њt…ёњ¬jUф¤Ађ§y\0мЭ%\$.˜iL!xВмТ“Е(Д.‘)6T(’I…мa%ТKИ]mДtҐф…ъ&‚уG7ЗITMуBъ\rzaВШ])va€%њ† І 41TБjН№(!…¬ЮЎЁ\\Ѓ\\ЖWВЬ\\t\$¤0Еж%б”\0aK\$иTљF(YаC@‚єHП ЋРHгЂnD’dГ†W p˜ЙhZЇ'бZC,/ЋќЎ\$ы¦Ј—JЎFBЁuЬ¬Q:ОҐВAц‰:-a#”м=jbЁ§lХUg;{R°ЂUє±EWnФUa»ЏVво•Nj¬§u‹GЙ*ЁyЦ№%ЭТ@Еп*Мд«ХYxк±_уІ§zЂ]л)v\"ЈзRХеLЇVIvк=`›ѕ'Є°UЭ) S\r~R˜•™\ni”Е)5S¦еD49~Кb”;)3‡,¦9M3ЇHsJkTњГњ‡(ў†ъ—uJ‰][\$ufЁнobЈµ№\n. ,оYЬµ9j1'µЊ!ц1ќ\$J¶‘gЪ¤ХџД†U0­УZuahЈ±·c HќҐ,ГYtІсKbц5—л5–’/dY¬іAUљТ…©‹[W>Ё_Vя\r€‘*·х©jЈ§-T±… zЦYКd•c®m‡Т№±Ш:№ЂьЛ[Ut-{Єµэl Јi+a)».[є•_:Ъ5ћдhѓт­WВ§Йm»Ґ%JI‘ґ[T«h>љ®µ·°•™;ЛXМєdкВџS›d‰Vж;\rЖ±!N€“K&—A€Ju4B…БdgОў.Vpўбmb‹…)ЗV!U\0GдёЁЌ“`‹Р­\\Ѓ…qвџ7Qцb«VLҐЮ:дХ‚ъѓу¬Z.­Nт˜Д*–ФЏU]Zґlжzл…Оцщ®ЗR D1IџеВЈСr:\0<1~;#АJbа¦КM˜yЭ+™Ы”/Ѓ\"П›j<3ж#“–МЊксЎ…:P.}кeчпЃтD\"qЩyJэGЊы·sopЊЌЇІюXЊ\rЭ іd–Ю\rxJ%–н‰ПЖјO:%yyгЕ,‡”%{О3<оXГёПМчЇ zВEОz(\0 ЂD_чЅџ.2+Цg®bєcЪxмpgЮЁБЯ|9CPЋыо˜48U Q§/Aq®ЭQј(4 7e\$D“‰v:ЊVЎbЧыN4[щ€iv °Ак2с\r•X1ј˜AJ(<PlFР\0ѕЁЂ\\zЭ)СзљWЂ(ь4фИГЪпў p•™УхК`µЗ\rіda6”ќЇьOЦнmсaґ}qЕ`ВА6Pѓ'hаз3§|љ’оГfЏ jИяAжѓz‰шЈ+ЊDЊUWшDнюЮ5ЕД%#й°x“ 3{«¶L\r-Н™]:jdЧP jьfЅq:Zч\"sadТ)уGШ3 ¤ђ+рЉr„N KЃц1QюЅз†x=>ы\"¤°-б:КFНхњIЩѓ*н@ФџЗy»Tн\\UиЁгЉY~ВЉ‰Ћдвљ‚3DЃеЂБ™гЁf,sў8HVЇ'Йt9v(:ђЦB9с\\ZЏљЎ…(‘&‚E8ЇѓНW\$X\0»\nЊћ9«WBА’bБГ66j9Р вК€„ѓ?,љ¬| щaѕќg1І\nPs \0 @Ѓ%#K„ёЂ \r\0Е§\0з€А0д?АЕЎ,д\0ФђhµСhЂ\08\0l\0Ц-ЬZђ±jbаЕ¬\0p\0Ю-Щf`qlўдЂ0\0i-Ь\\psўиЂ7‹e\"-ZрlbЯEС,д\0ИМ]P ўЪE¶‹b\0Ъ/,Zра\rА\0000‹[f-@\rУЇEЪ‹П/„Z8Ѕ‘~\"ЪЕЪ‹­ц. ^ТОQwЂЕП‹‚\0Ц/t_ИјА виEр‹Ц\0ж0d]µЂbъЕ¤‹|\0ИД\\Шј‚ўнE¤\0af0tZАСnЃJф\0l\0О0L^˜ґQj@ЕбЊJ€ґ^ё№q#F(Њ1є/м[µ1ЉўгЖЊIж.Ь^8»ђ\0[ЊqШМ[Г‘l\"еЖ ЊЂ\0ж0,dи¶А ЂЖ\rЊЃМ„cшµ{cEБ\0oв0¬]°\0\rc%ЕЫ‹—р€8ЅwўеЖZ‹µ-Д\\єс{гЕЦ‹GЄ/\\bp„…@1Ж\0aІ1щ‹ИПСsг!ЕЁЊ/о/М]8№‘~c\"ЕЫ‹Ею2фcО‘mЈ\"Ђ9Њqљ/\\^fQ~cЖ_‹ЈО-\$iћ\"Ц\0003ЊЛ¬¤fXєqx#\09Њ—Z.ґiёИЊ@F€Њ‰3tZHЙ \rcKЂb\0j’/DjшЙ1ЁввЖIЌ hґaИсvЂЖ©ЌOZ4њZтМС‚#YEЁ\0i–.hHТСsX/F<‹П†.дjшЛс­bиЖН\0mV/d\\иШс‹bчEі‹Јћ3T^(ЭС€cKFR‹Хщ‚ф]X¶qЅўшЕаЌ—’6Ф]hУсћc6EД‹у66Ьhђ‘џгn\0005Ќsn/dnёФ`\r\"СFЊіЪ-D`ИХ‘‹гNЂ2‹Y”¤bxАс”#\\Е닇V3x·1xЂFxЊѕ\0К6Њb°qЃЈѓЗ!Ћћ8|^‚МСubеЖаЌХ-фrШдqјг:ЖйЋ%ц0Њppс”#ЃЗ‹ў\0Ж6ФfХСЗўвЕ¬ЌdТ0„qHґ±ѕЈ\$З@‹qт-ј^B4±¦\"ъ\08Ћ1Є/lnxП‘ вкGЌ3:0tjhТ~@ЖјЋҐ¦3¤vHЖс№bЬG(Ћe„ђ4gШєqВг2Ж1ЊЙ-ЊnXЛсє\"гF<ЌQћ1\\jёё1®гИEЗ‹Зді4mЁХсЄг[ф‹nБz7ьyhЮ1§#ЖЮЋ/‚3\\xРqНKG‚ЊяЖ6дo˜С1{Ј°FJЌЧљ6јlXйqвЈ„ЖuЌ©Ю9њr(ї1Тг‡Gc\0Еf:„rXЅ  #РЕЅ\0iЮ<\\}ЧсеbоFЅ\0sЦ7Ьy2МСж#uFeЌ›\">4iШЕївФЖзЊй\n<{ёг‘ЌЈвЖ‰Њ J;¬]ШД1Е#ОЖ0ЏЩJ;4^иВDЅгуЗ®‹џЁі4iЁА(H#ЪЖEЊx–/¤nшы1рг/ЗЎ‹еj6,l˜Ы1tг/\0005%п0„]xь‘¶ЈGG5ђ!’0¤ЂЁЧсЪвй–rЊqў2МЁЮ‘ОгNFPЏo\"4ф_˜·1ЧdЗ%‹e І3¬s8й‘ьг†G5Ћ“ ж6Ф[Hл“cШHЏjYљ;ф[иѕ‘˜bл! Ћyт@Д\\ёЅqШ#WHNЏ‡Ћ;МcЖQиг:З-ђ%Є.њkXЖ‘эЈЪGНЊП†1DfЁЯ‘єcWFlђЎ!‚0ьЂ™Іc EЬђ©Ћ;l˜Сqђ\"лF©ЌЯў7\\\\ЁщсвЈФЖO‹qю.T|\"?‘сг™ЖEђіf9TyYС©гSG1ђыВA\$f9R\n\"ЮЖxЊ№>Bњ…HЪсЯ¤\0ЗЊ¶:\$e№1њЈіF?Џ=є3Tu)\nq№bйЗ~ЏЛО<TЃшО±Рc‰H.‘m~CфwHК±ё#/ИIЌ]~3д^€єС„#§Ж>‘Y®4Њ^ёОQjcКЗKЊ1\"Т8¬|6 Сеc\"ЗB‘µ\"b4гиж%њўФИG\0e\"’/t‹Ёґ1rЈ1ЖЏe!v2„yА±хд<З ЏЌ†8\\oЁКС’#tЕСђ\rz@ґ}HВ‘иbпЖиЌy о1М\\ЁрлdeG ЋБZ3Њ~йr)г1Иї‹Ы†Bl~HЅІ:ЈdFЈ‘-О?”k8ґqиc(FН‹ЉKЮ5|myсЂc1Ж<’*@ґjШбт1гЫЕѕЊ‹>IґZиНQjд•И2ЊЙ\$0¤‹hµQ€дVFTЊ \$ЖAl~цqЪЈИ±Ћ\$Ц>\\pЩ\rq‚\$/Иu%п!®Jq \$  гtEІ‹GN-Tq)т\"ўЫHКЊЛ¦=м–XЙ2-ЈH’«љ8\\n€µRW\$HЊл\"ўC\\_№\0»d\$Зf‘і\".D„u 'QЈzEнЊЩ&0to€уqjгъЖїЊіR@d—шЙдЈщЗuЌ##¶LLkЙ*qу\$*GД‘iО@TЉi‘lгтEЄ‘ѓО5Њ˜ѕr\\d–I–‘µ\"/МZЙ0’j\$TЕюЊz5Ld3’ЈлЙ’oВ.Tq№!1{ЈЖ‹еЦ9њZёѕQХbУFЊwJ94n€ТДЦд{Й(“-Ћ8·2h¤uИй“;\$†-DkшеrsЈ‡HћЏ™#Ў‚фЏY7т\"Ш/Eї’У  \$jў^т-Ј]З7Ћ[\"N\$’иВ‘“¤WИ‘ЇЦ/]а\$І+Ђ1Gaђ/&IDnшВ’@\$еЖ!‹з\$О-Њk!ќQЁвщК)(N/\$tёЭ№длЖOЏKzPґtXЬт[\0’GЋ’w(*K\$v€Л1уc Й'“ЮGМћIтxd­И\n“AТ8\\rX·ТaЈчI”iNњI%\$Ѕг’Ж_‘чЄ6¤fзQю#–ИI”5#ЋFґ—ШєсП#іEв’•\"о3\$ўIЬc‡H€‹ЭvR |щQЂ¤cEёЏс:R„eє±hд¶EОЏfK`8юr.#·EіЏs®0L…˜ьRЌд†F©‹·!\nC\$`Ицсґ\$фH?’ЛnPЬe™!сљҐ@F'”ї–/њ‡ё¶ДЦдяК”Ї%ВN,hИМrF\$цИюЊЗ3ґtшжТЂҐЕж’!1<„ЙCQП%ЙГ’№жJдZШf.Э6ЕЌ†њ·±C‰ҐКФњ.І[ю™BТїxлаѓи\0NRn`љИщY\n’%+NЁIMs:Г№Ydѓef¬B[¶°ЭnЖ№YЉтmЁБR®Ч’ыЙYЇЪC„XЊлЫjізU+Vk,Ї\0Pлэb @eІ№Ґx¬„VѕєyT¤7€uо«[Jп•И±\nDЇ§eRї¬mx&°l А\0)Њ}ЪJј,\0„IШZЖµ\$k!µЁсYbІБњ°ЂRВ‡e/QѕАђk°5.Бe‘­5•АЁћW‘`ЄҐ\0)ЂYv\"VВ\0•Г\n‡%—е–`YnЇХЎaфФxГ†Q!,х`\"‰ _.џеЃ©Ж–tm\$•\"“ІJ«¤ЦЌА§ ЋvЖ%‰M9j ‚° ж–§Д*іKpЦ”’;\\R јь3(§хЉ^ќЇ:}–Ип|>Вµa-'U%w*‰#>¤@ђМ¬e–Jяќ¤;Pw/+№б5E\rjnЎРГd–фў^[ъЇ§cО°ҐuЛz\\Шђ1mi\"x‚„pеГ;ЈМо€ж€P)дшЄЗ#„±Ш’Ў…Л!AЄ;ЁЯ 4міa{`aV{KќUаК8гЁџ0''oЂ2€ЁўycМё9]Kй@єТ—^рlB€вOrлФг,du¤ѕ8¤?х‰ЂХ%јgB»€о‚ЖYn+г%c¬e\0Њ°сऱYr@fм‹(]ЦјЁ\nbizоЦnЂSS2ЈБGdBPjЉ№Ц@Ђ(—ИҐ¦!а-зvІґeЪ*c\0„Є4Jжз‚’щХЩ,“UИ dєЙeрj'T€H]ФЉФG!њ)u‹ХЦЇџ•ТЇщZЛB5ыМ“WЋ‰0\n±бЎФR«БЃWЃ…\\¦Q jД^rК%lМ˜3,ТYyЧЙf3&М•ЬЋХQ:Пµ2„mЙR)”TЂѕ(KRБ 0ЄК”@«мYґўY:ЈЩe3\r%ґЁ°Tц%­X”Б№‡STФ.J\\л0ЩhфД…ЉD!Д:—uжкЙU\"ѕЕЃ Бo+7–\"„µЃ“f'є­R\0°‘ЮJќх2S–2и#nm »БIеЉњэ\"XьіІ[ђЦЂСм} JЁЇcј9p0ЄьХQ»(U\0ЈxDEW‚Њ.LхБ=<BФ0 +Ѕ)ZS V;в\\вµI{ђ5I‘AфЦГ,dWІuи5Ew\n\$%ТЃ…€Ѕ2i_\$ИЩ+мжO,Њ¬‡нX‹ґХ‘Jg&JЎъG’є%\\J“·b.ДЭ^L‹TтFlЊи–№]k#f@L·GЂДђTјЩ—ТНHПМ\"–q1SМ°щ‰jЏVЙ(О™„мZVzЯЕ†і,ќ§КиGЌ.1Fы±gNК;Ч1ГЉV¬¦5EНт5`т\0Ctи=F\nб№›О±•K‡ю™Ц\0­ЫЉ±%ЁЛD]Q\$\r\0‡3J\\,Н™љі<T4*Ј™Б.ТYKІD«QѓйLпS%,ЉgФЗеЄ§Ц<Лл™u0–фНUД‰Ц*x(©еNВ’Yv!юҐyН wЕ4fdЄҐrG•‰M \$дк‰^;єйќоЭж€)<Pг]DТ%%У;ФjКељI0жaУu^Jp—[)¦v©3RhRъEцА\nж–L_љ#5|ЬѕХm3Pс*Ё\\Y51X’’ iіN—Ис\$\"°єaь­хh*KUЭМпV8Ёеuт±%&„rжЇЛљ І5oЊХзgі;ЭrMl[ЖЁцgњіщЄ’·UНq™к№љh|ФeO2·f MlW2AP„Ч№˜’НАНv~eD¬eс3UУ«l‡E62iьОхмУUbМ«хUЊ¬©ЁошђэЄVркiI!\$iЁК­&Z:Ѕ–xm!Е†“.ЦOНfwТЇ!”МУkЭ¤Нѓ™Ќ6b\"«I™J]]:T™ќ6ТVrъ№}’ЬЗ«]™®±‘UўЋ ys7fФMЕ™я3€ЊЬОYњу:T_MНw%3ЖnПҐ\nОжz*™н3вhѓ· »`U–ІLяљ‡,ҐЫ„Р5Ёуvfѓ»Г›Щ42_Q‰јhЭЗНuD§\noЈ№)¤ДњХ«M9ї7foЫј©¤rЦЭЗОWB~iTЭeyQTвN\nљd¦pr§#›уM§;’˜…4жpЄј„tкя–(;љ›і5 |¬аЗ‚Љ­',AV7Ь”ФеUAц&мНRњPЇ\"дХy‡Т·•‰) [ЉnМХс-3V•Л,?њs6єpЉщ†3ЋfµОAљЫ9k|ЭЙ®S†f¬*@њ•5ЮgјѕЙї2·Н}њЊ®юUьЭ™‘рщжHОF›l%®pВ«Ieіbe—MЩSO\rЋ[јжiІ3ђfЙОLVб®r Щu®ЉѕҐЫNA›:о%r„Ъy3Qќ_Мё›W.СХИ^Sl@&МБќ5ЦYlВМ1ежО}VxкћgК…§^SnХМНQ!:5ЧZЮiZCФ€:ї›•3qgй%DбхЭЄ{UЎ3’tZ№`ыУu%w:ЙZQ:QмПЗW fо‡н›ї9Jplк)Ц3xФvМюќK7ћb#«щЅ«зX+Jљ(ўВhґмP*УЃќґ«О›юў!Ч”мЕЏSLзh*'ќ¤Ё\npBщ™ЪЄЏgNКќ§8BuТЄйВЋЇз ОЊќЅ8niк€IНsёUSНIљ‡;vvЪіUхsR•7NќuЧ8©H|нйЕУ·§МЋњ«8тqґХЩЮ+'СЯН`њxў9R€ Х®єзMaR8ъxд)ђё'!ПњЏ;±U¬ЧYЦ“’ЭsNIќg:ХKTлyЇ3®gЋНYќмлКkдгЙЬіn'LO(њї3љw4с4ЗПњЪкюl¬сОJЅќ–ЄwќЅ9Э\\мз•ууhf(ў_~мта}9Nц¦Х \0–ґеb\"ўYй¤ѓTh,Ъћ¤@ъ±DЎыЂ\$ЂIћ·;ЋeьиUКќnЁіћ·,№OЄЖ XЃяgґ-АћЙ+>ti'G‚ЃцЋlЄ%\0­8вVBЛU1«yeђ\0KTЖ4ыБИm’єV2)\r]I/\rFщ…ФX€ЧАЯЁсa·­GЉВ№т*€§»ћя>ERмчр ћ‡СZ›-)I\$®№нз:¦aЛ\0ѕFybaЩg«w§­(Я_@§v}цiхКіоЂS^Л25DФіР ИфURO±џJHќЦ\\ШisрfЖЛKљN±ЂqiчSgЧOВџ\nІF~|«µП*@gRЂ_Q<9sЬ¬3i+Ш—І.CwІІк|‚ЌшyЛ6aмOЬY9¶Њ¶Й–\nлФЅ-([®±†_€}нSы]c¤ S=В¤ОЩюОНФYОаU-> <ъ©µ\n<ЦsOфQ4F¦^}\0007uдk(/‹џЫ/5{Lя9µ\0§¬Р  &іЉ[<ПхџsЫ\0&Ни#…@hМйЄ3©V}РќHўЉЃ*Ьw+]'DР& @§ЦЃ])µи;TGe3ђЌ\\Окn®СЯЛd\$:¦uN4Еyktк-dR!7–Ѓ­Йe4(P!•џ-юЃ9А 4з_PMGbЏЃД±w…«ШЙ6O§S¦F‚вн)§Љyh0+ЂћІ§qT|·Љ +uФяО+ ЏA¬?тЮ цTи3.q Џ41Tґёe›Ђ\n:P шЇ–{Tо\nілh?«љTпAщSЈ­*«еТ+еuҐ>ъ\\кѕZйнКоYм·ўwEJЃц%·’s—L±ѕdЄљyА+\rCињЯЎ'Aсl,Тyе3юзІЛН—`є _*СPы ThKDVІ·–~5 а0ґ+бј,љ-?­]њєт3лЦЌKе—`Ї^†ё¤I42(]Єwћ.ж†rДКЛк]¬\nYЖЁB†Ј­Р ін–}Р‹R ѕЙgШ}: H§рJДWPІк„\"Юµ—рфV\\¬<——? >Ѕе—бя§Ь¬Э†ї=¦…:џ\n0Чи\\+сS–ґжfЭUЊін‰U,…WCЦ€и•OnЁтО…ў§.†e9|RчI'©[Ч/ЌєІДЩь2щ›«QћУBn:ЖIх\nц§gј9Ж\rь ,УR6іэзТQ\$XЭ+ё>ђ–©±`\nщ)/_8QiФщµк—=‡кv?5vќ\0 \nЁзЙLGҐDm€w\\лFЦЊ‡СўђЇБdкџµ}s‰\"‘ГYv¤|в™J*ґ9h­ЎС@XEUС*Ю(oQ]\$ЌBћ€,ыйЬ ѓ•KTњv¤AptCЙѓ\nЧC,/˜<Ў­Ъ™EW‹-VпPЎў=Wя*%Kк—-Q`9 (Къ59УЂиm)ЛXёЁ@з2ш эT@€Ы\nS–Ї‘bdЧEОґaЂ+ЂDXоб|UЪ ‹ ’ЎF® 2ъ%5\nj•m«ЂWЩ+ЌxкKЊжVМ3#„¶CTГek¤™–&О,Јl¬jbd7)У“\"\n+мPьєb’иIЉ@и3С•ЬµjUТМEsЮФ)Dўfл’ѓхЉЃы•ЗPЃZ3AОЊХ\nwTh𗲪ۘЕ4ZЏдЄ<КuЯ©Яd qвЛЉu(чћ“bKG±аҐйАnУTﮈ]zЁЌf%#ќ3IЛfSЁ®&}µ@D†@++щ¤AнhЄїђ\nЄпЂU—ЮҐ|BЎ;”…UmСЩU…E•NҐ!фx2±1Т\0§GmvH~хБHиTк)цW®іYNэ\"еk5©СvT#=µЪҐК<\n}‘#R3YѓHЕRН IНіЬ¦;МСRlЈ1lйuB%TQJо™*єк€Щ'єEл0i¬dw,ҐzКНҐ:\$†¦;Н? ьоj‘ї)§ф)ФЏК\$32J}Е&‡[і\$ЁхМЃ¤;DnђэEЧґА+0ЫaZ{ЁЌиC иыЂ(¤к :“ё ЪO@hшІDЈж\0Ў‰`PTou“іДпF®\rQv‚ыЁ˜oЅЬЎ\$Sоц+˜Т#7А¤Izr…pk  DW”€FsН9™ Qк  Р°1ЂgАЕ#•\0\\Lа\$Ш 3Ђg©XЋyфy њ-3h›АюГ!†nXиф]+±— ЙќЂc\0И\0јbШЕ\0\r‰ь‡-{ћ\0єQ(р QФ\$sЂ0…єйm(°[RuтVЖчТШ>Жј+аJ[©6а‘ТаJ\0Ц—ъ\\ґ¶г,Тй‚Kљ3э.к]a_\0RтJ Ж—`љ^Ф¶ClRЫIKо–щ\n \$®nЕЏТдҐпKj–©\nЂљБ©~/ҐЄmn˜].Є`фїijТв¦#Kѕ˜f:`\0…йЊЂ6¦7Kв–ЁzcфВ\0’Тх¦/K®–­/ЄdфДй‡FE\0aLЋ˜¤dZ`ѓJй†S‘ПК™…2ШН4О@/Ж(Њ‹Lт™х0Є`ґД©†Ђ_ЋLю™]4ZhфР©љSD¦M˜…4:cСй‹SRҐЧM—E4љiтЂйћSG¦EMj˜е4zdФХ©–SFKLЄ›%4ЄeФП%\$УlKM2–х1ИЪ”Фi¦УЌ©MV›­.ёЪ”ЦiґУЌ©Lz›/€чфЫЈУ„¦СMж›,`Љ_фаimSЉ¦gMЖњЂjg‘тйЗУ5¦9.›…9j_тйєSђҐµ.›Е9к_±тйѕS€¦‹.њ7Ъrт)ЙУ%§[2ќm8єuTжй™S±§3M:ќ]3єq”идnУ±§KN€1|^ТktП\"ТУH§gKjћ-;zcсiОУљ§ђ–ќ\r<к_І-iКУёҐс\"ЦћU.№ґуiлRЪ‘kOFћн=:\\фП\$ZУ©§MLE­5ъxфш©ВУ» _\"Цњ=<\0 сtйЩSз¦9OТћ­1Љ~”цiІУф§№Oкќн>к~qњ)тFёЁ ’ =6:~ФхгJФ‘ПP:џН=ЁеTя)ўЖ«§яPJ8х@кwфф©чЗ*§НOК5]>ЄЃtчЈ•T\n§е!\" Ќ6Y )ЂИHЁ/PЄћ…3Й йр†/ђ‘P~ ащ ЄУ®Ё!\"џЌC’МФэjЎ ЁeNJЎь€к€сФ*%Ф4¦1QЎЕCZ‡Q‘jTBЌQ.ў\rE)\0004Лк\$Ђ2ЁSM+е<j„tїj0Ф,¦9Q†Ў}F\0\$±s©ћTaЁќKОЈ]Ecj*Ђ'K»Mѕ—MGxЅХRЗT1¦#QкЎҐGЄЉ5Є:ФzЁLљЎ4u6zЏ•\"j\"T€KuNЦЈэGЪg\$jFSЬЁпQ2¤ҐHшоµ\"кMTѓ©%R¤•HzЋХ\$Є,ФwЁRe.\$rЄzµ)©ЫФ¦©-Qц НJ„№‘КЄ@Ф°©=R&/ќIК•1†*]Tі‹А7ј˜ѕQТеD&У©qN¦ _(ґqІc[TwЊQRфеґњJљ\0nвчT­Ёы.¦˜956cФЬЊХSzҐH˜Б•7ЄRФ}ЋSr8ҐNЉљХ\"bЦTи§БQЮ5MNЉ–х#гзФи©ESВ§-H˜Б7\"ЬTь©_Sк§}GШМ•?*yФ©‹‡Sт§ЅP*џ5#вцФЬЌПT:§]PКџхC*ЂФ‰‹T:Ё-K8Ж5CЄ„ХЄR¦--MИѕ•HЄ€Х Є'T‚Ё­HшЛхHЄЊФС‹ЧTЉЁнRЄЈх,вйФЬ‹GTЪ©-SJ¤хM*”Ф©‹UTЪ©mMHёхMЄ˜Х>ЄgSDі5MИВ•RЄњХHЄwU\"©нK8ХХRЄ ФЪЊЎU*Є-U*ЁаnВѕTЩIR­,tўZ«ХкY¶IUF«51Є¬µW)vХk‹_KЖ«pJ«5Zj­ЕЇ©RЌ4r\n¬^jIУCKє„‚Є}UК“_Є°Ф›ЄгO¬=N·R*ЇF-ЄЅRћ¬%Wљ‹Хcк¦Х\\ЋaV>«EYj–µdЄЄФГ«UО¬µWXН5*ИХ‹’№Uy‚хZЉ°1kг™ХЁ«7Vљ¬R\\HН5h*ЦUў©ПUЖ§M[ЉІ±kкvХё«3Vт­}[(д5WЄzХё«iB­Oє®1ЇкЇTэ«—V®;­[шоµpRжGu«;T@0>\0‚к/IіЄяW`н]¦ф\0ЄоЖ8«їPЉЇ]ИН1m*пХЗЌyUzЁmWЎх|ЄЭ“[«ЎЦЇ…]J¬С€кшU±««цЇ…Z*¤5\\j‘Ц«лZЄф`ZБ5~Є®Eм¬Wъ«4ZљБ5hЈQХ^‹cXZ®•Sъ®1o« VЄ№U&«ЌTєД5}cU^Ќ›Xљ°dm*і±’kUuҐ«SfG=[№хjдsХї‘ПX¦Kc\n®iRвHз«i#ћ±uWt»µЄЅҐє«»XВќХcД№•«U†¬”rЪўхUZ‹Х‡ѓNEў¬‘Xє¬…4ЪИudк·Eд¬eV^ІнKЙаnвтV8‹sXВҐНfЗх/ВhJі-J]У‚…™УОБХzO›±<Eh‰\$е‹“·Ўу\0Kњл<bw„с…>·”шNћ\")]bЈ в+zк.cS.ўiFз гЈµQNQђ«йV*ЄйЫОъЮO[X¤nxЉ¤P k­§oNшЈ}<aOт§IЯ“Бh·єљT;тrс‰‰¤ѓVD6QЯ;zЉ]jЧ~'’:л–[Ivфу7^К‘§ЦБћjлєw[«щжоєзњКЕ†Ґ:u ЕDs#¦їО\\wµ<n|*б‰h лmОKv;YТ€±Ъ3б]Њ«^#—ZЄjҐgyіjД§Y,”%;3ѕіКЪщЧ.ИW\"‘Г\$Щ3>gЪњєПУП¦ЄVЃTуZjҐhYЭjћkD*!љh&XzЛiЄ•Ґ+GV—­\"ҐжёZЏ:Т¤§+‡NoGҐZjjҐiЙ]КћkOР_­Ц¬ФђmjIЄ•Ё§tЇ–#Ѕ[вj\rnЉгк©ЧРn™ЯZҐ_,Хй†уgОДљ©:№јЕ9‰Бя«[L2®W=TФЧ0®гf¶\0P®U6\ns%7isYж?Јїuб3ѕ’Ѕnb5Ў«џ»љX|G~l•&Чk¤Ґ·M§ †Їъ¶ЊПyЎS–Й)О]њЬ­r·¶ЩёµёжмЦк›Е?Х}u'n 0W-О№®жb·ґЗЄмхџk?»vQэ7…Ь}p\nмхА’НЩ® Z*»9)Кб5Ю•ZW ­-ZBёІЊ:мхг«ЉWђ\0WZfp•GpхоНЩ®:ЏFpъ¤ЉдUЩлSN/™П\\©Ь%s9¬S{§ Ч8®ПZНasКЫ“’+ўN^®“9™MХ{…P5Уз ЧQ®ФоJєў«y§хХи;ЏњЪоzёѓВХYЪV Д3—:пњDЕIќЉГ+з‡эЇЈ19M;єҐЊ’фЁ“Vґ®љ\rQ{кЙХ®•¶Е+ЈѓFќCLД№ЉNҐ–©Ф€ќ\\щЮ)\$iЊЋЫN'\0¦°ЌPЉВљхКЗ]XМ^ќs1тfќ&Љ\"'<OшуљМЎЛL\0№\"‡@Ц ”Ґ%д6ъВUAх1эi(zМиЭЃЂ\rТХ‚д±ИbZА”+IQOп3ЂєЛ\r=*Д‰ ‰)сЁ!Бћ Р`Єјh°€,Р«mGPCЃЛA ќЩІнѓA„Њ (ZЕ°%ѓtм,h/Б‰ €i–Иk¬«ЎXEJ6р±„IDиИ¬\"›\nпaU- ›«\nvЋyќ°_ЂДВВ›Ъ«Їk aЅB<ЗVВѓЫD»/Pќ»фaоБ)9Lг¶(Z‚°8кЃvvГ№Шk §oРZXkдСе§| ґ&°.Вжќ±CЃ№’Шб° `Ђ1Ђ]7&Д™+™H¤CBcX“B7xXу|1“Ђ0¦гaљ6љ°ubpJLЗ…–(·љчmblЃ8I¶*Rц—@tk 0Ђ—ЎЇЕxXЫБУ;БЕ al]4s°tїнЕЄ р0§c‡'ґжlЯ`8MЊ8‘АГЂD4w`p?@706gМ€~K±\r‚Ы “Pґ…ЩbhЂ\"&ђЇ\nмq‘PDИРОу\$Р(Н0QP<ч°аАг¬ Q Ќ!Xґ…xъФ5Ђќ€R·`w/2°2#ЉАёЋ `¬»‘1†/€ЬЃ\rЎђЦ:ВІ–±ўЈB7цV7Z Њ›gMYъH3И „ЩbО ZБУJђЕцGвwЩglЃ^Ж-‘R-!Нl“7МІLх†Ж°<1 нQC/ХІhја)ПWћ6C ч*d€ю6]VK!mм…Ш ЬгЂ05G\$–R˜µ4Ї±=Cw&[жЏ «YPІ›dЙљі')VK,Ё5eИ\rЮКи†K+п1„X)bЫe)ДвuF2A#EС&g~‘eЎy’fp5ЁlYlІФњ5хѓцїЦ\nВЉЩm}`‚(¬M ЃPl9YЃяfш±эЦ]ЂVl-4ЋГ©¦«ВБ>`А•/ыіfPE™i‹\0k™vЖ\0ЯfhS0±&НВ¦lНјў#fuеМы5 i%я:FdЂц9Ћ™ШЂG<д {ц}мВs[7\0б¬Оћ3нft:+.И”–p >ШХ±Ј@!Pas6q,Аі—1bЗ¬Е‹гZK°к±Ь-ъ“ar`•?RxXБй‘ЎПVпъ˜#Д¤ФzВђЌ; АDЂ•ѕHІБ1Ґ’6D`ћюYк` чRЕPЦ‹>-Ж!\$ЩщімЧ~ПЂРЕа`>ЩпіхhФ0ф1†А¬–&\0Гh—лыI–wlыZ„\$“\\\rЌЎ8¶~,ђ\nєo_бАB2Dґ–Ѓѓa1кіаЗ©Џ=ўv<ПkFґp`Џ`”kBF¶6Ќ ДЦІ—hЖЙT TЦЋЃ ‡@?drСе‰ЂJАH@1°GґdnБТw‡ЖЏ%дЪJGљТ0bрTf]m(Шkґqg\\нЅЏуё–¬л°к ИС€3vk'э^dґЁAXя™~ ЗW™VsВ*јК±жdґыM А¬ќ@?ІДУ}§6\\–Ќm9<О±i”Э§›€Ф¬hЅ^s}ж-¦[Kњs±qгbОУ-“цOORm8\$ЮywДм##°Њ@вќ·\0фТШ¤ 5F7цЁѓ X\nУА|JЛ/-S™W!fЗ† 0¶,wЅЁD4ЩЎRUҐTґћ’оХрZXЗ=н`‰W\$@вФҐ(‹XG§‹ТЉµ—a>Ц*ыY¶І€\nіь\nЊмљ!«[mjњµЉ0,mu¬W@ FXъЪОтќрь=­ (¦э­bїэ<!\n\"”Є83Г'¦‚(R™ Э\n>”щ@ЁW¦r!LЈHЕkМ\r€E\nWЖЮ\rў‚'FHњ\$Ј‹ддАm„ЃИ=ФЫҐ{LY—…&СЬЈ_\0ЋЖьЭ#ўд”Ђ[„9\0¤\"ФТ@8ДiKЄ№ц0Щl‰СРp\ngо‚Ы'qbF–Шyб«cЏl@9Ы(#JU«ЭІѓ{io­‘Ґ. {ФНі4ЮVНЃЉVnFЙxрСьzО QаЮћ\$kSa~КЁ0s@ЈА«%…y@•А5HЋ†NОН¦ґ@†x’# Ь« /\\ҐЦ?<hЪ‚щ…јIђTЊ :Ќ3Г\n%—ё");}else{header("Content-Type: image/gif");switch($_GET["file"]){case"plus.gif":echo"GIF89a\0\0Ѓ\0001ооо\0\0Ђ™™™\0\0\0!щ\0\0\0,\0\0\0\0\0\0!„Џ©ЛнMсМ*)ѕoъЇ) q•Ўe€µо#ДтLЛ\0;";break;case"cross.gif":echo"GIF89a\0\0Ѓ\0001ооо\0\0Ђ™™™\0\0\0!щ\0\0\0,\0\0\0\0\0\0#„Џ©Лн#\naЦFo~yГ.Ѓ_wa”б1з±Jо GВLЧ6]\0\0;";break;case"up.gif":echo"GIF89a\0\0Ѓ\0001ооо\0\0Ђ™™™\0\0\0!щ\0\0\0,\0\0\0\0\0\0 „Џ©ЛнMQN\nп}фћa8ЉyљaЕ¶®\0Зт\0;";break;case"down.gif":echo"GIF89a\0\0Ѓ\0001ооо\0\0Ђ™™™\0\0\0!щ\0\0\0,\0\0\0\0\0\0 „Џ©ЛнMсМ*)ѕ[Wю\\ўЗL&ЩњЖ¶•\0Зт\0;";break;case"arrow.gif":echo"GIF89a\0\n\0Ђ\0\0ЂЂЂяяя!щ\0\0\0,\0\0\0\0\0\n\0\0‚i–±‹ћ”ЄУІЮ»\0\0;";break;}}exit;}if($_GET["script"]=="version"){$hd=file_open_lock(get_temp_dir()."/adminer.version");if($hd)file_write_unlock($hd,serialize(array("signature"=>$_POST["signature"],"version"=>$_POST["version"])));exit;}global$b,$g,$m,$dc,$lc,$vc,$n,$jd,$pd,$ba,$Od,$x,$ca,$je,$kf,$Vf,$Ah,$ud,$hi,$ni,$wi,$Ci,$ia;if(!$_SERVER["REQUEST_URI"])$_SERVER["REQUEST_URI"]=$_SERVER["ORIG_PATH_INFO"];if(!strpos($_SERVER["REQUEST_URI"],'?')&&$_SERVER["QUERY_STRING"]!="")$_SERVER["REQUEST_URI"].="?$_SERVER[QUERY_STRING]";if($_SERVER["HTTP_X_FORWARDED_PREFIX"])$_SERVER["REQUEST_URI"]=$_SERVER["HTTP_X_FORWARDED_PREFIX"].$_SERVER["REQUEST_URI"];$ba=($_SERVER["HTTPS"]&&strcasecmp($_SERVER["HTTPS"],"off"))||ini_bool("session.cookie_secure");@ini_set("session.use_trans_sid",false);if(!defined("SID")){session_cache_limiter("");session_name("adminer_sid");$If=array(0,preg_replace('~\?.*~','',$_SERVER["REQUEST_URI"]),"",$ba);if(version_compare(PHP_VERSION,'5.2.0')>=0)$If[]=true;call_user_func_array('session_set_cookie_params',$If);session_start();}remove_slashes(array(&$_GET,&$_POST,&$_COOKIE),$Uc);if(get_magic_quotes_runtime())set_magic_quotes_runtime(false);@set_time_limit(0);@ini_set("zend.ze1_compatibility_mode",false);@ini_set("precision",15);function
  170. get_lang(){return'en';}function
  171. lang($mi,$bf=null){if(is_array($mi)){$Yf=($bf==1?0:1);$mi=$mi[$Yf];}$mi=str_replace("%d","%s",$mi);$bf=format_number($bf);return
  172. sprintf($mi,$bf);}if(extension_loaded('pdo')){class
  173. Min_PDO
  174. extends
  175. PDO{var$_result,$server_info,$affected_rows,$errno,$error;function
  176. __construct(){global$b;$Yf=array_search("SQL",$b->operators);if($Yf!==false)unset($b->operators[$Yf]);}function
  177. dsn($ic,$V,$F,$sf=array()){try{parent::__construct($ic,$V,$F,$sf);}catch(Exception$_c){auth_error(h($_c->getMessage()));}$this->setAttribute(13,array('Min_PDOStatement'));$this->server_info=@$this->getAttribute(4);}function
  178. query($G,$xi=false){$H=parent::query($G);$this->error="";if(!$H){list(,$this->errno,$this->error)=$this->errorInfo();if(!$this->error)$this->error='Unknown error.';return
  179. false;}$this->store_result($H);return$H;}function
  180. multi_query($G){return$this->_result=$this->query($G);}function
  181. store_result($H=null){if(!$H){$H=$this->_result;if(!$H)return
  182. false;}if($H->columnCount()){$H->num_rows=$H->rowCount();return$H;}$this->affected_rows=$H->rowCount();return
  183. true;}function
  184. next_result(){if(!$this->_result)return
  185. false;$this->_result->_offset=0;return@$this->_result->nextRowset();}function
  186. result($G,$o=0){$H=$this->query($G);if(!$H)return
  187. false;$J=$H->fetch();return$J[$o];}}class
  188. Min_PDOStatement
  189. extends
  190. PDOStatement{var$_offset=0,$num_rows;function
  191. fetch_assoc(){return$this->fetch(2);}function
  192. fetch_row(){return$this->fetch(3);}function
  193. fetch_field(){$J=(object)$this->getColumnMeta($this->_offset++);$J->orgtable=$J->table;$J->orgname=$J->name;$J->charsetnr=(in_array("blob",(array)$J->flags)?63:0);return$J;}}}$dc=array();class
  194. Min_SQL{var$_conn;function
  195. __construct($g){$this->_conn=$g;}function
  196. select($R,$L,$Z,$md,$uf=array(),$z=1,$E=0,$gg=false){global$b,$x;$Vd=(count($md)<count($L));$G=$b->selectQueryBuild($L,$Z,$md,$uf,$z,$E);if(!$G)$G="SELECT".limit(($_GET["page"]!="last"&&$z!=""&&$md&&$Vd&&$x=="sql"?"SQL_CALC_FOUND_ROWS ":"").implode(", ",$L)."\nFROM ".table($R),($Z?"\nWHERE ".implode(" AND ",$Z):"").($md&&$Vd?"\nGROUP BY ".implode(", ",$md):"").($uf?"\nORDER BY ".implode(", ",$uf):""),($z!=""?+$z:null),($E?$z*$E:0),"\n");$xh=microtime(true);$I=$this->_conn->query($G);if($gg)echo$b->selectQuery($G,$xh,!$I);return$I;}function
  197. delete($R,$qg,$z=0){$G="FROM ".table($R);return
  198. queries("DELETE".($z?limit1($R,$G,$qg):" $G$qg"));}function
  199. update($R,$O,$qg,$z=0,$M="\n"){$Oi=array();foreach($O
  200. as$y=>$X)$Oi[]="$y = $X";$G=table($R)." SET$M".implode(",$M",$Oi);return
  201. queries("UPDATE".($z?limit1($R,$G,$qg,$M):" $G$qg"));}function
  202. insert($R,$O){return
  203. queries("INSERT INTO ".table($R).($O?" (".implode(", ",array_keys($O)).")\nVALUES (".implode(", ",$O).")":" DEFAULT VALUES"));}function
  204. insertUpdate($R,$K,$eg){return
  205. false;}function
  206. begin(){return
  207. queries("BEGIN");}function
  208. commit(){return
  209. queries("COMMIT");}function
  210. rollback(){return
  211. queries("ROLLBACK");}function
  212. slowQuery($G,$Yh){}function
  213. convertSearch($u,$X,$o){return$u;}function
  214. value($X,$o){return(method_exists($this->_conn,'value')?$this->_conn->value($X,$o):(is_resource($X)?stream_get_contents($X):$X));}function
  215. quoteBinary($Sg){return
  216. q($Sg);}function
  217. warnings(){return'';}function
  218. tableHelp($C){}}$dc["sqlite"]="SQLite 3";$dc["sqlite2"]="SQLite 2";if(isset($_GET["sqlite"])||isset($_GET["sqlite2"])){$bg=array((isset($_GET["sqlite"])?"SQLite3":"SQLite"),"PDO_SQLite");define("DRIVER",(isset($_GET["sqlite"])?"sqlite":"sqlite2"));if(class_exists(isset($_GET["sqlite"])?"SQLite3":"SQLiteDatabase")){if(isset($_GET["sqlite"])){class
  219. Min_SQLite{var$extension="SQLite3",$server_info,$affected_rows,$errno,$error,$_link;function
  220. __construct($Tc){$this->_link=new
  221. SQLite3($Tc);$Ri=$this->_link->version();$this->server_info=$Ri["versionString"];}function
  222. query($G){$H=@$this->_link->query($G);$this->error="";if(!$H){$this->errno=$this->_link->lastErrorCode();$this->error=$this->_link->lastErrorMsg();return
  223. false;}elseif($H->numColumns())return
  224. new
  225. Min_Result($H);$this->affected_rows=$this->_link->changes();return
  226. true;}function
  227. quote($Q){return(is_utf8($Q)?"'".$this->_link->escapeString($Q)."'":"x'".reset(unpack('H*',$Q))."'");}function
  228. store_result(){return$this->_result;}function
  229. result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
  230. false;$J=$H->_result->fetchArray();return$J[$o];}}class
  231. Min_Result{var$_result,$_offset=0,$num_rows;function
  232. __construct($H){$this->_result=$H;}function
  233. fetch_assoc(){return$this->_result->fetchArray(SQLITE3_ASSOC);}function
  234. fetch_row(){return$this->_result->fetchArray(SQLITE3_NUM);}function
  235. fetch_field(){$e=$this->_offset++;$U=$this->_result->columnType($e);return(object)array("name"=>$this->_result->columnName($e),"type"=>$U,"charsetnr"=>($U==SQLITE3_BLOB?63:0),);}function
  236. __desctruct(){return$this->_result->finalize();}}}else{class
  237. Min_SQLite{var$extension="SQLite",$server_info,$affected_rows,$error,$_link;function
  238. __construct($Tc){$this->server_info=sqlite_libversion();$this->_link=new
  239. SQLiteDatabase($Tc);}function
  240. query($G,$xi=false){$Ne=($xi?"unbufferedQuery":"query");$H=@$this->_link->$Ne($G,SQLITE_BOTH,$n);$this->error="";if(!$H){$this->error=$n;return
  241. false;}elseif($H===true){$this->affected_rows=$this->changes();return
  242. true;}return
  243. new
  244. Min_Result($H);}function
  245. quote($Q){return"'".sqlite_escape_string($Q)."'";}function
  246. store_result(){return$this->_result;}function
  247. result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
  248. false;$J=$H->_result->fetch();return$J[$o];}}class
  249. Min_Result{var$_result,$_offset=0,$num_rows;function
  250. __construct($H){$this->_result=$H;if(method_exists($H,'numRows'))$this->num_rows=$H->numRows();}function
  251. fetch_assoc(){$J=$this->_result->fetch(SQLITE_ASSOC);if(!$J)return
  252. false;$I=array();foreach($J
  253. as$y=>$X)$I[($y[0]=='"'?idf_unescape($y):$y)]=$X;return$I;}function
  254. fetch_row(){return$this->_result->fetch(SQLITE_NUM);}function
  255. fetch_field(){$C=$this->_result->fieldName($this->_offset++);$Uf='(\[.*]|"(?:[^"]|"")*"|(.+))';if(preg_match("~^($Uf\\.)?$Uf\$~",$C,$B)){$R=($B[3]!=""?$B[3]:idf_unescape($B[2]));$C=($B[5]!=""?$B[5]:idf_unescape($B[4]));}return(object)array("name"=>$C,"orgname"=>$C,"orgtable"=>$R,);}}}}elseif(extension_loaded("pdo_sqlite")){class
  256. Min_SQLite
  257. extends
  258. Min_PDO{var$extension="PDO_SQLite";function
  259. __construct($Tc){$this->dsn(DRIVER.":$Tc","","");}}}if(class_exists("Min_SQLite")){class
  260. Min_DB
  261. extends
  262. Min_SQLite{function
  263. __construct(){parent::__construct(":memory:");$this->query("PRAGMA foreign_keys = 1");}function
  264. select_db($Tc){if(is_readable($Tc)&&$this->query("ATTACH ".$this->quote(preg_match("~(^[/\\\\]|:)~",$Tc)?$Tc:dirname($_SERVER["SCRIPT_FILENAME"])."/$Tc")." AS a")){parent::__construct($Tc);$this->query("PRAGMA foreign_keys = 1");return
  265. true;}return
  266. false;}function
  267. multi_query($G){return$this->_result=$this->query($G);}function
  268. next_result(){return
  269. false;}}}class
  270. Min_Driver
  271. extends
  272. Min_SQL{function
  273. insertUpdate($R,$K,$eg){$Oi=array();foreach($K
  274. as$O)$Oi[]="(".implode(", ",$O).")";return
  275. queries("REPLACE INTO ".table($R)." (".implode(", ",array_keys(reset($K))).") VALUES\n".implode(",\n",$Oi));}function
  276. tableHelp($C){if($C=="sqlite_sequence")return"fileformat2.html#seqtab";if($C=="sqlite_master")return"fileformat2.html#$C";}}function
  277. idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
  278. table($u){return
  279. idf_escape($u);}function
  280. connect(){global$b;list(,,$F)=$b->credentials();if($F!="")return'Database does not support password.';return
  281. new
  282. Min_DB;}function
  283. get_databases(){return
  284. array();}function
  285. limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
  286. limit1($R,$G,$Z,$M="\n"){global$g;return(preg_match('~^INTO~',$G)||$g->result("SELECT sqlite_compileoption_used('ENABLE_UPDATE_DELETE_LIMIT')")?limit($G,$Z,1,0,$M):" $G WHERE rowid = (SELECT rowid FROM ".table($R).$Z.$M."LIMIT 1)");}function
  287. db_collation($l,$ob){global$g;return$g->result("PRAGMA encoding");}function
  288. engines(){return
  289. array();}function
  290. logged_user(){return
  291. get_current_user();}function
  292. tables_list(){return
  293. get_key_vals("SELECT name, type FROM sqlite_master WHERE type IN ('table', 'view') ORDER BY (name = 'sqlite_sequence'), name");}function
  294. count_tables($k){return
  295. array();}function
  296. table_status($C=""){global$g;$I=array();foreach(get_rows("SELECT name AS Name, type AS Engine, 'rowid' AS Oid, '' AS Auto_increment FROM sqlite_master WHERE type IN ('table', 'view') ".($C!=""?"AND name = ".q($C):"ORDER BY name"))as$J){$J["Rows"]=$g->result("SELECT COUNT(*) FROM ".idf_escape($J["Name"]));$I[$J["Name"]]=$J;}foreach(get_rows("SELECT * FROM sqlite_sequence",null,"")as$J)$I[$J["name"]]["Auto_increment"]=$J["seq"];return($C!=""?$I[$C]:$I);}function
  297. is_view($S){return$S["Engine"]=="view";}function
  298. fk_support($S){global$g;return!$g->result("SELECT sqlite_compileoption_used('OMIT_FOREIGN_KEY')");}function
  299. fields($R){global$g;$I=array();$eg="";foreach(get_rows("PRAGMA table_info(".table($R).")")as$J){$C=$J["name"];$U=strtolower($J["type"]);$Rb=$J["dflt_value"];$I[$C]=array("field"=>$C,"type"=>(preg_match('~int~i',$U)?"integer":(preg_match('~char|clob|text~i',$U)?"text":(preg_match('~blob~i',$U)?"blob":(preg_match('~real|floa|doub~i',$U)?"real":"numeric")))),"full_type"=>$U,"default"=>(preg_match("~'(.*)'~",$Rb,$B)?str_replace("''","'",$B[1]):($Rb=="NULL"?null:$Rb)),"null"=>!$J["notnull"],"privileges"=>array("select"=>1,"insert"=>1,"update"=>1),"primary"=>$J["pk"],);if($J["pk"]){if($eg!="")$I[$eg]["auto_increment"]=false;elseif(preg_match('~^integer$~i',$U))$I[$C]["auto_increment"]=true;$eg=$C;}}$sh=$g->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($R));preg_match_all('~(("[^"]*+")+|[a-z0-9_]+)\s+text\s+COLLATE\s+(\'[^\']+\'|\S+)~i',$sh,$_e,PREG_SET_ORDER);foreach($_e
  300. as$B){$C=str_replace('""','"',preg_replace('~^"|"$~','',$B[1]));if($I[$C])$I[$C]["collation"]=trim($B[3],"'");}return$I;}function
  301. indexes($R,$h=null){global$g;if(!is_object($h))$h=$g;$I=array();$sh=$h->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($R));if(preg_match('~\bPRIMARY\s+KEY\s*\((([^)"]+|"[^"]*"|`[^`]*`)++)~i',$sh,$B)){$I[""]=array("type"=>"PRIMARY","columns"=>array(),"lengths"=>array(),"descs"=>array());preg_match_all('~((("[^"]*+")+|(?:`[^`]*+`)+)|(\S+))(\s+(ASC|DESC))?(,\s*|$)~i',$B[1],$_e,PREG_SET_ORDER);foreach($_e
  302. as$B){$I[""]["columns"][]=idf_unescape($B[2]).$B[4];$I[""]["descs"][]=(preg_match('~DESC~i',$B[5])?'1':null);}}if(!$I){foreach(fields($R)as$C=>$o){if($o["primary"])$I[""]=array("type"=>"PRIMARY","columns"=>array($C),"lengths"=>array(),"descs"=>array(null));}}$vh=get_key_vals("SELECT name, sql FROM sqlite_master WHERE type = 'index' AND tbl_name = ".q($R),$h);foreach(get_rows("PRAGMA index_list(".table($R).")",$h)as$J){$C=$J["name"];$v=array("type"=>($J["unique"]?"UNIQUE":"INDEX"));$v["lengths"]=array();$v["descs"]=array();foreach(get_rows("PRAGMA index_info(".idf_escape($C).")",$h)as$Rg){$v["columns"][]=$Rg["name"];$v["descs"][]=null;}if(preg_match('~^CREATE( UNIQUE)? INDEX '.preg_quote(idf_escape($C).' ON '.idf_escape($R),'~').' \((.*)\)$~i',$vh[$C],$Bg)){preg_match_all('/("[^"]*+")+( DESC)?/',$Bg[2],$_e);foreach($_e[2]as$y=>$X){if($X)$v["descs"][$y]='1';}}if(!$I[""]||$v["type"]!="UNIQUE"||$v["columns"]!=$I[""]["columns"]||$v["descs"]!=$I[""]["descs"]||!preg_match("~^sqlite_~",$C))$I[$C]=$v;}return$I;}function
  303. foreign_keys($R){$I=array();foreach(get_rows("PRAGMA foreign_key_list(".table($R).")")as$J){$q=&$I[$J["id"]];if(!$q)$q=$J;$q["source"][]=$J["from"];$q["target"][]=$J["to"];}return$I;}function
  304. view($C){global$g;return
  305. array("select"=>preg_replace('~^(?:[^`"[]+|`[^`]*`|"[^"]*")* AS\s+~iU','',$g->result("SELECT sql FROM sqlite_master WHERE name = ".q($C))));}function
  306. collations(){return(isset($_GET["create"])?get_vals("PRAGMA collation_list",1):array());}function
  307. information_schema($l){return
  308. false;}function
  309. error(){global$g;return
  310. h($g->error);}function
  311. check_sqlite_name($C){global$g;$Jc="db|sdb|sqlite";if(!preg_match("~^[^\\0]*\\.($Jc)\$~",$C)){$g->error=sprintf('Please use one of the extensions %s.',str_replace("|",", ",$Jc));return
  312. false;}return
  313. true;}function
  314. create_database($l,$d){global$g;if(file_exists($l)){$g->error='File exists.';return
  315. false;}if(!check_sqlite_name($l))return
  316. false;try{$_=new
  317. Min_SQLite($l);}catch(Exception$_c){$g->error=$_c->getMessage();return
  318. false;}$_->query('PRAGMA encoding = "UTF-8"');$_->query('CREATE TABLE adminer (i)');$_->query('DROP TABLE adminer');return
  319. true;}function
  320. drop_databases($k){global$g;$g->__construct(":memory:");foreach($k
  321. as$l){if(!@unlink($l)){$g->error='File exists.';return
  322. false;}}return
  323. true;}function
  324. rename_database($C,$d){global$g;if(!check_sqlite_name($C))return
  325. false;$g->__construct(":memory:");$g->error='File exists.';return@rename(DB,$C);}function
  326. auto_increment(){return" PRIMARY KEY".(DRIVER=="sqlite"?" AUTOINCREMENT":"");}function
  327. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$Ii=($R==""||$bd);foreach($p
  328. as$o){if($o[0]!=""||!$o[1]||$o[2]){$Ii=true;break;}}$c=array();$Cf=array();foreach($p
  329. as$o){if($o[1]){$c[]=($Ii?$o[1]:"ADD ".implode($o[1]));if($o[0]!="")$Cf[$o[0]]=$o[1][0];}}if(!$Ii){foreach($c
  330. as$X){if(!queries("ALTER TABLE ".table($R)." $X"))return
  331. false;}if($R!=$C&&!queries("ALTER TABLE ".table($R)." RENAME TO ".table($C)))return
  332. false;}elseif(!recreate_table($R,$C,$c,$Cf,$bd))return
  333. false;if($La)queries("UPDATE sqlite_sequence SET seq = $La WHERE name = ".q($C));return
  334. true;}function
  335. recreate_table($R,$C,$p,$Cf,$bd,$w=array()){if($R!=""){if(!$p){foreach(fields($R)as$y=>$o){if($w)$o["auto_increment"]=0;$p[]=process_field($o,$o);$Cf[$y]=idf_escape($y);}}$fg=false;foreach($p
  336. as$o){if($o[6])$fg=true;}$gc=array();foreach($w
  337. as$y=>$X){if($X[2]=="DROP"){$gc[$X[1]]=true;unset($w[$y]);}}foreach(indexes($R)as$de=>$v){$f=array();foreach($v["columns"]as$y=>$e){if(!$Cf[$e])continue
  338. 2;$f[]=$Cf[$e].($v["descs"][$y]?" DESC":"");}if(!$gc[$de]){if($v["type"]!="PRIMARY"||!$fg)$w[]=array($v["type"],$de,$f);}}foreach($w
  339. as$y=>$X){if($X[0]=="PRIMARY"){unset($w[$y]);$bd[]=" PRIMARY KEY (".implode(", ",$X[2]).")";}}foreach(foreign_keys($R)as$de=>$q){foreach($q["source"]as$y=>$e){if(!$Cf[$e])continue
  340. 2;$q["source"][$y]=idf_unescape($Cf[$e]);}if(!isset($bd[" $de"]))$bd[]=" ".format_foreign_key($q);}queries("BEGIN");}foreach($p
  341. as$y=>$o)$p[$y]=" ".implode($o);$p=array_merge($p,array_filter($bd));if(!queries("CREATE TABLE ".table($R!=""?"adminer_$C":$C)." (\n".implode(",\n",$p)."\n)"))return
  342. false;if($R!=""){if($Cf&&!queries("INSERT INTO ".table("adminer_$C")." (".implode(", ",$Cf).") SELECT ".implode(", ",array_map('idf_escape',array_keys($Cf)))." FROM ".table($R)))return
  343. false;$ti=array();foreach(triggers($R)as$ri=>$Zh){$qi=trigger($ri);$ti[]="CREATE TRIGGER ".idf_escape($ri)." ".implode(" ",$Zh)." ON ".table($C)."\n$qi[Statement]";}if(!queries("DROP TABLE ".table($R)))return
  344. false;queries("ALTER TABLE ".table("adminer_$C")." RENAME TO ".table($C));if(!alter_indexes($C,$w))return
  345. false;foreach($ti
  346. as$qi){if(!queries($qi))return
  347. false;}queries("COMMIT");}return
  348. true;}function
  349. index_sql($R,$U,$C,$f){return"CREATE $U ".($U!="INDEX"?"INDEX ":"").idf_escape($C!=""?$C:uniqid($R."_"))." ON ".table($R)." $f";}function
  350. alter_indexes($R,$c){foreach($c
  351. as$eg){if($eg[0]=="PRIMARY")return
  352. recreate_table($R,$R,array(),array(),array(),$c);}foreach(array_reverse($c)as$X){if(!queries($X[2]=="DROP"?"DROP INDEX ".idf_escape($X[1]):index_sql($R,$X[0],$X[1],"(".implode(", ",$X[2]).")")))return
  353. false;}return
  354. true;}function
  355. truncate_tables($T){return
  356. apply_queries("DELETE FROM",$T);}function
  357. drop_views($Ti){return
  358. apply_queries("DROP VIEW",$Ti);}function
  359. drop_tables($T){return
  360. apply_queries("DROP TABLE",$T);}function
  361. move_tables($T,$Ti,$Qh){return
  362. false;}function
  363. trigger($C){global$g;if($C=="")return
  364. array("Statement"=>"BEGIN\n\t;\nEND");$u='(?:[^`"\s]+|`[^`]*`|"[^"]*")+';$si=trigger_options();preg_match("~^CREATE\\s+TRIGGER\\s*$u\\s*(".implode("|",$si["Timing"]).")\\s+([a-z]+)(?:\\s+OF\\s+($u))?\\s+ON\\s*$u\\s*(?:FOR\\s+EACH\\s+ROW\\s)?(.*)~is",$g->result("SELECT sql FROM sqlite_master WHERE type = 'trigger' AND name = ".q($C)),$B);$df=$B[3];return
  365. array("Timing"=>strtoupper($B[1]),"Event"=>strtoupper($B[2]).($df?" OF":""),"Of"=>($df[0]=='`'||$df[0]=='"'?idf_unescape($df):$df),"Trigger"=>$C,"Statement"=>$B[4],);}function
  366. triggers($R){$I=array();$si=trigger_options();foreach(get_rows("SELECT * FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($R))as$J){preg_match('~^CREATE\s+TRIGGER\s*(?:[^`"\s]+|`[^`]*`|"[^"]*")+\s*('.implode("|",$si["Timing"]).')\s*(.*)\s+ON\b~iU',$J["sql"],$B);$I[$J["name"]]=array($B[1],$B[2]);}return$I;}function
  367. trigger_options(){return
  368. array("Timing"=>array("BEFORE","AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","UPDATE OF","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
  369. begin(){return
  370. queries("BEGIN");}function
  371. last_id(){global$g;return$g->result("SELECT LAST_INSERT_ROWID()");}function
  372. explain($g,$G){return$g->query("EXPLAIN QUERY PLAN $G");}function
  373. found_rows($S,$Z){}function
  374. types(){return
  375. array();}function
  376. schemas(){return
  377. array();}function
  378. get_schema(){return"";}function
  379. set_schema($Vg){return
  380. true;}function
  381. create_sql($R,$La,$Bh){global$g;$I=$g->result("SELECT sql FROM sqlite_master WHERE type IN ('table', 'view') AND name = ".q($R));foreach(indexes($R)as$C=>$v){if($C=='')continue;$I.=";\n\n".index_sql($R,$v['type'],$C,"(".implode(", ",array_map('idf_escape',$v['columns'])).")");}return$I;}function
  382. truncate_sql($R){return"DELETE FROM ".table($R);}function
  383. use_sql($j){}function
  384. trigger_sql($R){return
  385. implode(get_vals("SELECT sql || ';;\n' FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($R)));}function
  386. show_variables(){global$g;$I=array();foreach(array("auto_vacuum","cache_size","count_changes","default_cache_size","empty_result_callbacks","encoding","foreign_keys","full_column_names","fullfsync","journal_mode","journal_size_limit","legacy_file_format","locking_mode","page_size","max_page_count","read_uncommitted","recursive_triggers","reverse_unordered_selects","secure_delete","short_column_names","synchronous","temp_store","temp_store_directory","schema_version","integrity_check","quick_check")as$y)$I[$y]=$g->result("PRAGMA $y");return$I;}function
  387. show_status(){$I=array();foreach(get_vals("PRAGMA compile_options")as$rf){list($y,$X)=explode("=",$rf,2);$I[$y]=$X;}return$I;}function
  388. convert_field($o){}function
  389. unconvert_field($o,$I){return$I;}function
  390. support($Oc){return
  391. preg_match('~^(columns|database|drop_col|dump|indexes|move_col|sql|status|table|trigger|variables|view|view_trigger)$~',$Oc);}$x="sqlite";$wi=array("integer"=>0,"real"=>0,"numeric"=>0,"text"=>0,"blob"=>0);$Ah=array_keys($wi);$Ci=array();$pf=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL","SQL");$jd=array("hex","length","lower","round","unixepoch","upper");$pd=array("avg","count","count distinct","group_concat","max","min","sum");$lc=array(array(),array("integer|real|numeric"=>"+/-","text"=>"||",));}$dc["pgsql"]="PostgreSQL";if(isset($_GET["pgsql"])){$bg=array("PgSQL","PDO_PgSQL");define("DRIVER","pgsql");if(extension_loaded("pgsql")){class
  392. Min_DB{var$extension="PgSQL",$_link,$_result,$_string,$_database=true,$server_info,$affected_rows,$error,$timeout;function
  393. _error($wc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
  394. connect($N,$V,$F){global$b;$l=$b->database();set_error_handler(array($this,'_error'));$this->_string="host='".str_replace(":","' port='",addcslashes($N,"'\\"))."' user='".addcslashes($V,"'\\")."' password='".addcslashes($F,"'\\")."'";$this->_link=@pg_connect("$this->_string dbname='".($l!=""?addcslashes($l,"'\\"):"postgres")."'",PGSQL_CONNECT_FORCE_NEW);if(!$this->_link&&$l!=""){$this->_database=false;$this->_link=@pg_connect("$this->_string dbname='postgres'",PGSQL_CONNECT_FORCE_NEW);}restore_error_handler();if($this->_link){$Ri=pg_version($this->_link);$this->server_info=$Ri["server"];pg_set_client_encoding($this->_link,"UTF8");}return(bool)$this->_link;}function
  395. quote($Q){return"'".pg_escape_string($this->_link,$Q)."'";}function
  396. value($X,$o){return($o["type"]=="bytea"?pg_unescape_bytea($X):$X);}function
  397. quoteBinary($Q){return"'".pg_escape_bytea($this->_link,$Q)."'";}function
  398. select_db($j){global$b;if($j==$b->database())return$this->_database;$I=@pg_connect("$this->_string dbname='".addcslashes($j,"'\\")."'",PGSQL_CONNECT_FORCE_NEW);if($I)$this->_link=$I;return$I;}function
  399. close(){$this->_link=@pg_connect("$this->_string dbname='postgres'");}function
  400. query($G,$xi=false){$H=@pg_query($this->_link,$G);$this->error="";if(!$H){$this->error=pg_last_error($this->_link);$I=false;}elseif(!pg_num_fields($H)){$this->affected_rows=pg_affected_rows($H);$I=true;}else$I=new
  401. Min_Result($H);if($this->timeout){$this->timeout=0;$this->query("RESET statement_timeout");}return$I;}function
  402. multi_query($G){return$this->_result=$this->query($G);}function
  403. store_result(){return$this->_result;}function
  404. next_result(){return
  405. false;}function
  406. result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
  407. false;return
  408. pg_fetch_result($H->_result,0,$o);}function
  409. warnings(){return
  410. h(pg_last_notice($this->_link));}}class
  411. Min_Result{var$_result,$_offset=0,$num_rows;function
  412. __construct($H){$this->_result=$H;$this->num_rows=pg_num_rows($H);}function
  413. fetch_assoc(){return
  414. pg_fetch_assoc($this->_result);}function
  415. fetch_row(){return
  416. pg_fetch_row($this->_result);}function
  417. fetch_field(){$e=$this->_offset++;$I=new
  418. stdClass;if(function_exists('pg_field_table'))$I->orgtable=pg_field_table($this->_result,$e);$I->name=pg_field_name($this->_result,$e);$I->orgname=$I->name;$I->type=pg_field_type($this->_result,$e);$I->charsetnr=($I->type=="bytea"?63:0);return$I;}function
  419. __destruct(){pg_free_result($this->_result);}}}elseif(extension_loaded("pdo_pgsql")){class
  420. Min_DB
  421. extends
  422. Min_PDO{var$extension="PDO_PgSQL",$timeout;function
  423. connect($N,$V,$F){global$b;$l=$b->database();$Q="pgsql:host='".str_replace(":","' port='",addcslashes($N,"'\\"))."' options='-c client_encoding=utf8'";$this->dsn("$Q dbname='".($l!=""?addcslashes($l,"'\\"):"postgres")."'",$V,$F);return
  424. true;}function
  425. select_db($j){global$b;return($b->database()==$j);}function
  426. quoteBinary($Sg){return
  427. q($Sg);}function
  428. query($G,$xi=false){$I=parent::query($G,$xi);if($this->timeout){$this->timeout=0;parent::query("RESET statement_timeout");}return$I;}function
  429. warnings(){return'';}function
  430. close(){}}}class
  431. Min_Driver
  432. extends
  433. Min_SQL{function
  434. insertUpdate($R,$K,$eg){global$g;foreach($K
  435. as$O){$Di=array();$Z=array();foreach($O
  436. as$y=>$X){$Di[]="$y = $X";if(isset($eg[idf_unescape($y)]))$Z[]="$y = $X";}if(!(($Z&&queries("UPDATE ".table($R)." SET ".implode(", ",$Di)." WHERE ".implode(" AND ",$Z))&&$g->affected_rows)||queries("INSERT INTO ".table($R)." (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).")")))return
  437. false;}return
  438. true;}function
  439. slowQuery($G,$Yh){$this->_conn->query("SET statement_timeout = ".(1000*$Yh));$this->_conn->timeout=1000*$Yh;return$G;}function
  440. convertSearch($u,$X,$o){return(preg_match('~char|text'.(!preg_match('~LIKE~',$X["op"])?'|date|time(stamp)?|boolean|uuid|'.number_type():'').'~',$o["type"])?$u:"CAST($u AS text)");}function
  441. quoteBinary($Sg){return$this->_conn->quoteBinary($Sg);}function
  442. warnings(){return$this->_conn->warnings();}function
  443. tableHelp($C){$te=array("information_schema"=>"infoschema","pg_catalog"=>"catalog",);$_=$te[$_GET["ns"]];if($_)return"$_-".str_replace("_","-",$C).".html";}}function
  444. idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
  445. table($u){return
  446. idf_escape($u);}function
  447. connect(){global$b,$wi,$Ah;$g=new
  448. Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2])){if(min_version(9,0,$g)){$g->query("SET application_name = 'Adminer'");if(min_version(9.2,0,$g)){$Ah['Strings'][]="json";$wi["json"]=4294967295;if(min_version(9.4,0,$g)){$Ah['Strings'][]="jsonb";$wi["jsonb"]=4294967295;}}}return$g;}return$g->error;}function
  449. get_databases(){return
  450. get_vals("SELECT datname FROM pg_database WHERE has_database_privilege(datname, 'CONNECT') ORDER BY datname");}function
  451. limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
  452. limit1($R,$G,$Z,$M="\n"){return(preg_match('~^INTO~',$G)?limit($G,$Z,1,0,$M):" $G".(is_view(table_status1($R))?$Z:" WHERE ctid = (SELECT ctid FROM ".table($R).$Z.$M."LIMIT 1)"));}function
  453. db_collation($l,$ob){global$g;return$g->result("SHOW LC_COLLATE");}function
  454. engines(){return
  455. array();}function
  456. logged_user(){global$g;return$g->result("SELECT user");}function
  457. tables_list(){$G="SELECT table_name, table_type FROM information_schema.tables WHERE table_schema = current_schema()";if(support('materializedview'))$G.="
  458. UNION ALL
  459. SELECT matviewname, 'MATERIALIZED VIEW'
  460. FROM pg_matviews
  461. WHERE schemaname = current_schema()";$G.="
  462. ORDER BY 1";return
  463. get_key_vals($G);}function
  464. count_tables($k){return
  465. array();}function
  466. table_status($C=""){$I=array();foreach(get_rows("SELECT c.relname AS \"Name\", CASE c.relkind WHEN 'r' THEN 'table' WHEN 'm' THEN 'materialized view' ELSE 'view' END AS \"Engine\", pg_relation_size(c.oid) AS \"Data_length\", pg_total_relation_size(c.oid) - pg_relation_size(c.oid) AS \"Index_length\", obj_description(c.oid, 'pg_class') AS \"Comment\", CASE WHEN c.relhasoids THEN 'oid' ELSE '' END AS \"Oid\", c.reltuples as \"Rows\", n.nspname
  467. FROM pg_class c
  468. JOIN pg_namespace n ON(n.nspname = current_schema() AND n.oid = c.relnamespace)
  469. WHERE relkind IN ('r', 'm', 'v', 'f')
  470. ".($C!=""?"AND relname = ".q($C):"ORDER BY relname"))as$J)$I[$J["Name"]]=$J;return($C!=""?$I[$C]:$I);}function
  471. is_view($S){return
  472. in_array($S["Engine"],array("view","materialized view"));}function
  473. fk_support($S){return
  474. true;}function
  475. fields($R){$I=array();$Ca=array('timestamp without time zone'=>'timestamp','timestamp with time zone'=>'timestamptz',);foreach(get_rows("SELECT a.attname AS field, format_type(a.atttypid, a.atttypmod) AS full_type, d.adsrc AS default, a.attnotnull::int, col_description(c.oid, a.attnum) AS comment
  476. FROM pg_class c
  477. JOIN pg_namespace n ON c.relnamespace = n.oid
  478. JOIN pg_attribute a ON c.oid = a.attrelid
  479. LEFT JOIN pg_attrdef d ON c.oid = d.adrelid AND a.attnum = d.adnum
  480. WHERE c.relname = ".q($R)."
  481. AND n.nspname = current_schema()
  482. AND NOT a.attisdropped
  483. AND a.attnum > 0
  484. ORDER BY a.attnum")as$J){preg_match('~([^([]+)(\((.*)\))?([a-z ]+)?((\[[0-9]*])*)$~',$J["full_type"],$B);list(,$U,$qe,$J["length"],$wa,$Fa)=$B;$J["length"].=$Fa;$db=$U.$wa;if(isset($Ca[$db])){$J["type"]=$Ca[$db];$J["full_type"]=$J["type"].$qe.$Fa;}else{$J["type"]=$U;$J["full_type"]=$J["type"].$qe.$wa.$Fa;}$J["null"]=!$J["attnotnull"];$J["auto_increment"]=preg_match('~^nextval\(~i',$J["default"]);$J["privileges"]=array("insert"=>1,"select"=>1,"update"=>1);if(preg_match('~(.+)::[^)]+(.*)~',$J["default"],$B))$J["default"]=($B[1]=="NULL"?null:(($B[1][0]=="'"?idf_unescape($B[1]):$B[1]).$B[2]));$I[$J["field"]]=$J;}return$I;}function
  485. indexes($R,$h=null){global$g;if(!is_object($h))$h=$g;$I=array();$Jh=$h->result("SELECT oid FROM pg_class WHERE relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema()) AND relname = ".q($R));$f=get_key_vals("SELECT attnum, attname FROM pg_attribute WHERE attrelid = $Jh AND attnum > 0",$h);foreach(get_rows("SELECT relname, indisunique::int, indisprimary::int, indkey, indoption , (indpred IS NOT NULL)::int as indispartial FROM pg_index i, pg_class ci WHERE i.indrelid = $Jh AND ci.oid = i.indexrelid",$h)as$J){$Cg=$J["relname"];$I[$Cg]["type"]=($J["indispartial"]?"INDEX":($J["indisprimary"]?"PRIMARY":($J["indisunique"]?"UNIQUE":"INDEX")));$I[$Cg]["columns"]=array();foreach(explode(" ",$J["indkey"])as$Kd)$I[$Cg]["columns"][]=$f[$Kd];$I[$Cg]["descs"]=array();foreach(explode(" ",$J["indoption"])as$Ld)$I[$Cg]["descs"][]=($Ld&1?'1':null);$I[$Cg]["lengths"]=array();}return$I;}function
  486. foreign_keys($R){global$kf;$I=array();foreach(get_rows("SELECT conname, condeferrable::int AS deferrable, pg_get_constraintdef(oid) AS definition
  487. FROM pg_constraint
  488. WHERE conrelid = (SELECT pc.oid FROM pg_class AS pc INNER JOIN pg_namespace AS pn ON (pn.oid = pc.relnamespace) WHERE pc.relname = ".q($R)." AND pn.nspname = current_schema())
  489. AND contype = 'f'::char
  490. ORDER BY conkey, conname")as$J){if(preg_match('~FOREIGN KEY\s*\((.+)\)\s*REFERENCES (.+)\((.+)\)(.*)$~iA',$J['definition'],$B)){$J['source']=array_map('trim',explode(',',$B[1]));if(preg_match('~^(("([^"]|"")+"|[^"]+)\.)?"?("([^"]|"")+"|[^"]+)$~',$B[2],$ze)){$J['ns']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$ze[2]));$J['table']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$ze[4]));}$J['target']=array_map('trim',explode(',',$B[3]));$J['on_delete']=(preg_match("~ON DELETE ($kf)~",$B[4],$ze)?$ze[1]:'NO ACTION');$J['on_update']=(preg_match("~ON UPDATE ($kf)~",$B[4],$ze)?$ze[1]:'NO ACTION');$I[$J['conname']]=$J;}}return$I;}function
  491. view($C){global$g;return
  492. array("select"=>trim($g->result("SELECT view_definition
  493. FROM information_schema.views
  494. WHERE table_schema = current_schema() AND table_name = ".q($C))));}function
  495. collations(){return
  496. array();}function
  497. information_schema($l){return($l=="information_schema");}function
  498. error(){global$g;$I=h($g->error);if(preg_match('~^(.*\n)?([^\n]*)\n( *)\^(\n.*)?$~s',$I,$B))$I=$B[1].preg_replace('~((?:[^&]|&[^;]*;){'.strlen($B[3]).'})(.*)~','\1<b>\2</b>',$B[2]).$B[4];return
  499. nl_br($I);}function
  500. create_database($l,$d){return
  501. queries("CREATE DATABASE ".idf_escape($l).($d?" ENCODING ".idf_escape($d):""));}function
  502. drop_databases($k){global$g;$g->close();return
  503. apply_queries("DROP DATABASE",$k,'idf_escape');}function
  504. rename_database($C,$d){return
  505. queries("ALTER DATABASE ".idf_escape(DB)." RENAME TO ".idf_escape($C));}function
  506. auto_increment(){return"";}function
  507. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();$pg=array();foreach($p
  508. as$o){$e=idf_escape($o[0]);$X=$o[1];if(!$X)$c[]="DROP $e";else{$Ni=$X[5];unset($X[5]);if(isset($X[6])&&$o[0]=="")$X[1]=($X[1]=="bigint"?" big":" ")."serial";if($o[0]=="")$c[]=($R!=""?"ADD ":" ").implode($X);else{if($e!=$X[0])$pg[]="ALTER TABLE ".table($R)." RENAME $e TO $X[0]";$c[]="ALTER $e TYPE$X[1]";if(!$X[6]){$c[]="ALTER $e ".($X[3]?"SET$X[3]":"DROP DEFAULT");$c[]="ALTER $e ".($X[2]==" NULL"?"DROP NOT":"SET").$X[2];}}if($o[0]!=""||$Ni!="")$pg[]="COMMENT ON COLUMN ".table($R).".$X[0] IS ".($Ni!=""?substr($Ni,9):"''");}}$c=array_merge($c,$bd);if($R=="")array_unshift($pg,"CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");elseif($c)array_unshift($pg,"ALTER TABLE ".table($R)."\n".implode(",\n",$c));if($R!=""&&$R!=$C)$pg[]="ALTER TABLE ".table($R)." RENAME TO ".table($C);if($R!=""||$tb!="")$pg[]="COMMENT ON TABLE ".table($C)." IS ".q($tb);if($La!=""){}foreach($pg
  509. as$G){if(!queries($G))return
  510. false;}return
  511. true;}function
  512. alter_indexes($R,$c){$i=array();$ec=array();$pg=array();foreach($c
  513. as$X){if($X[0]!="INDEX")$i[]=($X[2]=="DROP"?"\nDROP CONSTRAINT ".idf_escape($X[1]):"\nADD".($X[1]!=""?" CONSTRAINT ".idf_escape($X[1]):"")." $X[0] ".($X[0]=="PRIMARY"?"KEY ":"")."(".implode(", ",$X[2]).")");elseif($X[2]=="DROP")$ec[]=idf_escape($X[1]);else$pg[]="CREATE INDEX ".idf_escape($X[1]!=""?$X[1]:uniqid($R."_"))." ON ".table($R)." (".implode(", ",$X[2]).")";}if($i)array_unshift($pg,"ALTER TABLE ".table($R).implode(",",$i));if($ec)array_unshift($pg,"DROP INDEX ".implode(", ",$ec));foreach($pg
  514. as$G){if(!queries($G))return
  515. false;}return
  516. true;}function
  517. truncate_tables($T){return
  518. queries("TRUNCATE ".implode(", ",array_map('table',$T)));return
  519. true;}function
  520. drop_views($Ti){return
  521. drop_tables($Ti);}function
  522. drop_tables($T){foreach($T
  523. as$R){$P=table_status($R);if(!queries("DROP ".strtoupper($P["Engine"])." ".table($R)))return
  524. false;}return
  525. true;}function
  526. move_tables($T,$Ti,$Qh){foreach(array_merge($T,$Ti)as$R){$P=table_status($R);if(!queries("ALTER ".strtoupper($P["Engine"])." ".table($R)." SET SCHEMA ".idf_escape($Qh)))return
  527. false;}return
  528. true;}function
  529. trigger($C,$R=null){if($C=="")return
  530. array("Statement"=>"EXECUTE PROCEDURE ()");if($R===null)$R=$_GET['trigger'];$K=get_rows('SELECT t.trigger_name AS "Trigger", t.action_timing AS "Timing", (SELECT STRING_AGG(event_manipulation, \' OR \') FROM information_schema.triggers WHERE event_object_table = t.event_object_table AND trigger_name = t.trigger_name ) AS "Events", t.event_manipulation AS "Event", \'FOR EACH \' || t.action_orientation AS "Type", t.action_statement AS "Statement" FROM information_schema.triggers t WHERE t.event_object_table = '.q($R).' AND t.trigger_name = '.q($C));return
  531. reset($K);}function
  532. triggers($R){$I=array();foreach(get_rows("SELECT * FROM information_schema.triggers WHERE event_object_table = ".q($R))as$J)$I[$J["trigger_name"]]=array($J["action_timing"],$J["event_manipulation"]);return$I;}function
  533. trigger_options(){return
  534. array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW","FOR EACH STATEMENT"),);}function
  535. routine($C,$U){$K=get_rows('SELECT routine_definition AS definition, LOWER(external_language) AS language, *
  536. FROM information_schema.routines
  537. WHERE routine_schema = current_schema() AND specific_name = '.q($C));$I=$K[0];$I["returns"]=array("type"=>$I["type_udt_name"]);$I["fields"]=get_rows('SELECT parameter_name AS field, data_type AS type, character_maximum_length AS length, parameter_mode AS inout
  538. FROM information_schema.parameters
  539. WHERE specific_schema = current_schema() AND specific_name = '.q($C).'
  540. ORDER BY ordinal_position');return$I;}function
  541. routines(){return
  542. get_rows('SELECT specific_name AS "SPECIFIC_NAME", routine_type AS "ROUTINE_TYPE", routine_name AS "ROUTINE_NAME", type_udt_name AS "DTD_IDENTIFIER"
  543. FROM information_schema.routines
  544. WHERE routine_schema = current_schema()
  545. ORDER BY SPECIFIC_NAME');}function
  546. routine_languages(){return
  547. get_vals("SELECT LOWER(lanname) FROM pg_catalog.pg_language");}function
  548. routine_id($C,$J){$I=array();foreach($J["fields"]as$o)$I[]=$o["type"];return
  549. idf_escape($C)."(".implode(", ",$I).")";}function
  550. last_id(){return
  551. 0;}function
  552. explain($g,$G){return$g->query("EXPLAIN $G");}function
  553. found_rows($S,$Z){global$g;if(preg_match("~ rows=([0-9]+)~",$g->result("EXPLAIN SELECT * FROM ".idf_escape($S["Name"]).($Z?" WHERE ".implode(" AND ",$Z):"")),$Bg))return$Bg[1];return
  554. false;}function
  555. types(){return
  556. get_vals("SELECT typname
  557. FROM pg_type
  558. WHERE typnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema())
  559. AND typtype IN ('b','d','e')
  560. AND typelem = 0");}function
  561. schemas(){return
  562. get_vals("SELECT nspname FROM pg_namespace ORDER BY nspname");}function
  563. get_schema(){global$g;return$g->result("SELECT current_schema()");}function
  564. set_schema($Ug){global$g,$wi,$Ah;$I=$g->query("SET search_path TO ".idf_escape($Ug));foreach(types()as$U){if(!isset($wi[$U])){$wi[$U]=0;$Ah['User types'][]=$U;}}return$I;}function
  565. create_sql($R,$La,$Bh){global$g;$I='';$Kg=array();$eh=array();$P=table_status($R);$p=fields($R);$w=indexes($R);ksort($w);$Yc=foreign_keys($R);ksort($Yc);if(!$P||empty($p))return
  566. false;$I="CREATE TABLE ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." (\n ";foreach($p
  567. as$Qc=>$o){$Lf=idf_escape($o['field']).' '.$o['full_type'].default_value($o).($o['attnotnull']?" NOT NULL":"");$Kg[]=$Lf;if(preg_match('~nextval\(\'([^\']+)\'\)~',$o['default'],$_e)){$dh=$_e[1];$rh=reset(get_rows(min_version(10)?"SELECT *, cache_size AS cache_value FROM pg_sequences WHERE schemaname = current_schema() AND sequencename = ".q($dh):"SELECT * FROM $dh"));$eh[]=($Bh=="DROP+CREATE"?"DROP SEQUENCE IF EXISTS $dh;\n":"")."CREATE SEQUENCE $dh INCREMENT $rh[increment_by] MINVALUE $rh[min_value] MAXVALUE $rh[max_value] START ".($La?$rh['last_value']:1)." CACHE $rh[cache_value];";}}if(!empty($eh))$I=implode("\n\n",$eh)."\n\n$I";foreach($w
  568. as$Fd=>$v){switch($v['type']){case'UNIQUE':$Kg[]="CONSTRAINT ".idf_escape($Fd)." UNIQUE (".implode(', ',array_map('idf_escape',$v['columns'])).")";break;case'PRIMARY':$Kg[]="CONSTRAINT ".idf_escape($Fd)." PRIMARY KEY (".implode(', ',array_map('idf_escape',$v['columns'])).")";break;}}foreach($Yc
  569. as$Xc=>$Wc)$Kg[]="CONSTRAINT ".idf_escape($Xc)." $Wc[definition] ".($Wc['deferrable']?'DEFERRABLE':'NOT DEFERRABLE');$I.=implode(",\n ",$Kg)."\n) WITH (oids = ".($P['Oid']?'true':'false').");";foreach($w
  570. as$Fd=>$v){if($v['type']=='INDEX')$I.="\n\nCREATE INDEX ".idf_escape($Fd)." ON ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." USING btree (".implode(', ',array_map('idf_escape',$v['columns'])).");";}if($P['Comment'])$I.="\n\nCOMMENT ON TABLE ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." IS ".q($P['Comment']).";";foreach($p
  571. as$Qc=>$o){if($o['comment'])$I.="\n\nCOMMENT ON COLUMN ".idf_escape($P['nspname']).".".idf_escape($P['Name']).".".idf_escape($Qc)." IS ".q($o['comment']).";";}return
  572. rtrim($I,';');}function
  573. truncate_sql($R){return"TRUNCATE ".table($R);}function
  574. trigger_sql($R){$P=table_status($R);$I="";foreach(triggers($R)as$pi=>$oi){$qi=trigger($pi,$P['Name']);$I.="\nCREATE TRIGGER ".idf_escape($qi['Trigger'])." $qi[Timing] $qi[Events] ON ".idf_escape($P["nspname"]).".".idf_escape($P['Name'])." $qi[Type] $qi[Statement];;\n";}return$I;}function
  575. use_sql($j){return"\connect ".idf_escape($j);}function
  576. show_variables(){return
  577. get_key_vals("SHOW ALL");}function
  578. process_list(){return
  579. get_rows("SELECT * FROM pg_stat_activity ORDER BY ".(min_version(9.2)?"pid":"procpid"));}function
  580. show_status(){}function
  581. convert_field($o){}function
  582. unconvert_field($o,$I){return$I;}function
  583. support($Oc){return
  584. preg_match('~^(database|table|columns|sql|indexes|comment|view|'.(min_version(9.3)?'materializedview|':'').'scheme|routine|processlist|sequence|trigger|type|variables|drop_col|kill|dump)$~',$Oc);}function
  585. kill_process($X){return
  586. queries("SELECT pg_terminate_backend(".number($X).")");}function
  587. connection_id(){return"SELECT pg_backend_pid()";}function
  588. max_connections(){global$g;return$g->result("SHOW max_connections");}$x="pgsql";$wi=array();$Ah=array();foreach(array('Numbers'=>array("smallint"=>5,"integer"=>10,"bigint"=>19,"boolean"=>1,"numeric"=>0,"real"=>7,"double precision"=>16,"money"=>20),'Date and time'=>array("date"=>13,"time"=>17,"timestamp"=>20,"timestamptz"=>21,"interval"=>0),'Strings'=>array("character"=>0,"character varying"=>0,"text"=>0,"tsquery"=>0,"tsvector"=>0,"uuid"=>0,"xml"=>0),'Binary'=>array("bit"=>0,"bit varying"=>0,"bytea"=>0),'Network'=>array("cidr"=>43,"inet"=>43,"macaddr"=>17,"txid_snapshot"=>0),'Geometry'=>array("box"=>0,"circle"=>0,"line"=>0,"lseg"=>0,"path"=>0,"point"=>0,"polygon"=>0),)as$y=>$X){$wi+=$X;$Ah[$y]=array_keys($X);}$Ci=array();$pf=array("=","<",">","<=",">=","!=","~","!~","LIKE","LIKE %%","ILIKE","ILIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$jd=array("char_length","lower","round","to_hex","to_timestamp","upper");$pd=array("avg","count","count distinct","max","min","sum");$lc=array(array("char"=>"md5","date|time"=>"now",),array(number_type()=>"+/-","date|time"=>"+ interval/- interval","char|text"=>"||",));}$dc["oracle"]="Oracle (beta)";if(isset($_GET["oracle"])){$bg=array("OCI8","PDO_OCI");define("DRIVER","oracle");if(extension_loaded("oci8")){class
  589. Min_DB{var$extension="oci8",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
  590. _error($wc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
  591. connect($N,$V,$F){$this->_link=@oci_new_connect($V,$F,$N,"AL32UTF8");if($this->_link){$this->server_info=oci_server_version($this->_link);return
  592. true;}$n=oci_error();$this->error=$n["message"];return
  593. false;}function
  594. quote($Q){return"'".str_replace("'","''",$Q)."'";}function
  595. select_db($j){return
  596. true;}function
  597. query($G,$xi=false){$H=oci_parse($this->_link,$G);$this->error="";if(!$H){$n=oci_error($this->_link);$this->errno=$n["code"];$this->error=$n["message"];return
  598. false;}set_error_handler(array($this,'_error'));$I=@oci_execute($H);restore_error_handler();if($I){if(oci_num_fields($H))return
  599. new
  600. Min_Result($H);$this->affected_rows=oci_num_rows($H);}return$I;}function
  601. multi_query($G){return$this->_result=$this->query($G);}function
  602. store_result(){return$this->_result;}function
  603. next_result(){return
  604. false;}function
  605. result($G,$o=1){$H=$this->query($G);if(!is_object($H)||!oci_fetch($H->_result))return
  606. false;return
  607. oci_result($H->_result,$o);}}class
  608. Min_Result{var$_result,$_offset=1,$num_rows;function
  609. __construct($H){$this->_result=$H;}function
  610. _convert($J){foreach((array)$J
  611. as$y=>$X){if(is_a($X,'OCI-Lob'))$J[$y]=$X->load();}return$J;}function
  612. fetch_assoc(){return$this->_convert(oci_fetch_assoc($this->_result));}function
  613. fetch_row(){return$this->_convert(oci_fetch_row($this->_result));}function
  614. fetch_field(){$e=$this->_offset++;$I=new
  615. stdClass;$I->name=oci_field_name($this->_result,$e);$I->orgname=$I->name;$I->type=oci_field_type($this->_result,$e);$I->charsetnr=(preg_match("~raw|blob|bfile~",$I->type)?63:0);return$I;}function
  616. __destruct(){oci_free_statement($this->_result);}}}elseif(extension_loaded("pdo_oci")){class
  617. Min_DB
  618. extends
  619. Min_PDO{var$extension="PDO_OCI";function
  620. connect($N,$V,$F){$this->dsn("oci:dbname=//$N;charset=AL32UTF8",$V,$F);return
  621. true;}function
  622. select_db($j){return
  623. true;}}}class
  624. Min_Driver
  625. extends
  626. Min_SQL{function
  627. begin(){return
  628. true;}}function
  629. idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
  630. table($u){return
  631. idf_escape($u);}function
  632. connect(){global$b;$g=new
  633. Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
  634. get_databases(){return
  635. get_vals("SELECT tablespace_name FROM user_tablespaces");}function
  636. limit($G,$Z,$z,$D=0,$M=" "){return($D?" * FROM (SELECT t.*, rownum AS rnum FROM (SELECT $G$Z) t WHERE rownum <= ".($z+$D).") WHERE rnum > $D":($z!==null?" * FROM (SELECT $G$Z) WHERE rownum <= ".($z+$D):" $G$Z"));}function
  637. limit1($R,$G,$Z,$M="\n"){return" $G$Z";}function
  638. db_collation($l,$ob){global$g;return$g->result("SELECT value FROM nls_database_parameters WHERE parameter = 'NLS_CHARACTERSET'");}function
  639. engines(){return
  640. array();}function
  641. logged_user(){global$g;return$g->result("SELECT USER FROM DUAL");}function
  642. tables_list(){return
  643. get_key_vals("SELECT table_name, 'table' FROM all_tables WHERE tablespace_name = ".q(DB)."
  644. UNION SELECT view_name, 'view' FROM user_views
  645. ORDER BY 1");}function
  646. count_tables($k){return
  647. array();}function
  648. table_status($C=""){$I=array();$Wg=q($C);foreach(get_rows('SELECT table_name "Name", \'table\' "Engine", avg_row_len * num_rows "Data_length", num_rows "Rows" FROM all_tables WHERE tablespace_name = '.q(DB).($C!=""?" AND table_name = $Wg":"")."
  649. UNION SELECT view_name, 'view', 0, 0 FROM user_views".($C!=""?" WHERE view_name = $Wg":"")."
  650. ORDER BY 1")as$J){if($C!="")return$J;$I[$J["Name"]]=$J;}return$I;}function
  651. is_view($S){return$S["Engine"]=="view";}function
  652. fk_support($S){return
  653. true;}function
  654. fields($R){$I=array();foreach(get_rows("SELECT * FROM all_tab_columns WHERE table_name = ".q($R)." ORDER BY column_id")as$J){$U=$J["DATA_TYPE"];$qe="$J[DATA_PRECISION],$J[DATA_SCALE]";if($qe==",")$qe=$J["DATA_LENGTH"];$I[$J["COLUMN_NAME"]]=array("field"=>$J["COLUMN_NAME"],"full_type"=>$U.($qe?"($qe)":""),"type"=>strtolower($U),"length"=>$qe,"default"=>$J["DATA_DEFAULT"],"null"=>($J["NULLABLE"]=="Y"),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),);}return$I;}function
  655. indexes($R,$h=null){$I=array();foreach(get_rows("SELECT uic.*, uc.constraint_type
  656. FROM user_ind_columns uic
  657. LEFT JOIN user_constraints uc ON uic.index_name = uc.constraint_name AND uic.table_name = uc.table_name
  658. WHERE uic.table_name = ".q($R)."
  659. ORDER BY uc.constraint_type, uic.column_position",$h)as$J){$Fd=$J["INDEX_NAME"];$I[$Fd]["type"]=($J["CONSTRAINT_TYPE"]=="P"?"PRIMARY":($J["CONSTRAINT_TYPE"]=="U"?"UNIQUE":"INDEX"));$I[$Fd]["columns"][]=$J["COLUMN_NAME"];$I[$Fd]["lengths"][]=($J["CHAR_LENGTH"]&&$J["CHAR_LENGTH"]!=$J["COLUMN_LENGTH"]?$J["CHAR_LENGTH"]:null);$I[$Fd]["descs"][]=($J["DESCEND"]?'1':null);}return$I;}function
  660. view($C){$K=get_rows('SELECT text "select" FROM user_views WHERE view_name = '.q($C));return
  661. reset($K);}function
  662. collations(){return
  663. array();}function
  664. information_schema($l){return
  665. false;}function
  666. error(){global$g;return
  667. h($g->error);}function
  668. explain($g,$G){$g->query("EXPLAIN PLAN FOR $G");return$g->query("SELECT * FROM plan_table");}function
  669. found_rows($S,$Z){}function
  670. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=$ec=array();foreach($p
  671. as$o){$X=$o[1];if($X&&$o[0]!=""&&idf_escape($o[0])!=$X[0])queries("ALTER TABLE ".table($R)." RENAME COLUMN ".idf_escape($o[0])." TO $X[0]");if($X)$c[]=($R!=""?($o[0]!=""?"MODIFY (":"ADD ("):" ").implode($X).($R!=""?")":"");else$ec[]=idf_escape($o[0]);}if($R=="")return
  672. queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");return(!$c||queries("ALTER TABLE ".table($R)."\n".implode("\n",$c)))&&(!$ec||queries("ALTER TABLE ".table($R)." DROP (".implode(", ",$ec).")"))&&($R==$C||queries("ALTER TABLE ".table($R)." RENAME TO ".table($C)));}function
  673. foreign_keys($R){$I=array();$G="SELECT c_list.CONSTRAINT_NAME as NAME,
  674. c_src.COLUMN_NAME as SRC_COLUMN,
  675. c_dest.OWNER as DEST_DB,
  676. c_dest.TABLE_NAME as DEST_TABLE,
  677. c_dest.COLUMN_NAME as DEST_COLUMN,
  678. c_list.DELETE_RULE as ON_DELETE
  679. FROM ALL_CONSTRAINTS c_list, ALL_CONS_COLUMNS c_src, ALL_CONS_COLUMNS c_dest
  680. WHERE c_list.CONSTRAINT_NAME = c_src.CONSTRAINT_NAME
  681. AND c_list.R_CONSTRAINT_NAME = c_dest.CONSTRAINT_NAME
  682. AND c_list.CONSTRAINT_TYPE = 'R'
  683. AND c_src.TABLE_NAME = ".q($R);foreach(get_rows($G)as$J)$I[$J['NAME']]=array("db"=>$J['DEST_DB'],"table"=>$J['DEST_TABLE'],"source"=>array($J['SRC_COLUMN']),"target"=>array($J['DEST_COLUMN']),"on_delete"=>$J['ON_DELETE'],"on_update"=>null,);return$I;}function
  684. truncate_tables($T){return
  685. apply_queries("TRUNCATE TABLE",$T);}function
  686. drop_views($Ti){return
  687. apply_queries("DROP VIEW",$Ti);}function
  688. drop_tables($T){return
  689. apply_queries("DROP TABLE",$T);}function
  690. last_id(){return
  691. 0;}function
  692. schemas(){return
  693. get_vals("SELECT DISTINCT owner FROM dba_segments WHERE owner IN (SELECT username FROM dba_users WHERE default_tablespace NOT IN ('SYSTEM','SYSAUX'))");}function
  694. get_schema(){global$g;return$g->result("SELECT sys_context('USERENV', 'SESSION_USER') FROM dual");}function
  695. set_schema($Vg){global$g;return$g->query("ALTER SESSION SET CURRENT_SCHEMA = ".idf_escape($Vg));}function
  696. show_variables(){return
  697. get_key_vals('SELECT name, display_value FROM v$parameter');}function
  698. process_list(){return
  699. get_rows('SELECT sess.process AS "process", sess.username AS "user", sess.schemaname AS "schema", sess.status AS "status", sess.wait_class AS "wait_class", sess.seconds_in_wait AS "seconds_in_wait", sql.sql_text AS "sql_text", sess.machine AS "machine", sess.port AS "port"
  700. FROM v$session sess LEFT OUTER JOIN v$sql sql
  701. ON sql.sql_id = sess.sql_id
  702. WHERE sess.type = \'USER\'
  703. ORDER BY PROCESS
  704. ');}function
  705. show_status(){$K=get_rows('SELECT * FROM v$instance');return
  706. reset($K);}function
  707. convert_field($o){}function
  708. unconvert_field($o,$I){return$I;}function
  709. support($Oc){return
  710. preg_match('~^(columns|database|drop_col|indexes|processlist|scheme|sql|status|table|variables|view|view_trigger)$~',$Oc);}$x="oracle";$wi=array();$Ah=array();foreach(array('Numbers'=>array("number"=>38,"binary_float"=>12,"binary_double"=>21),'Date and time'=>array("date"=>10,"timestamp"=>29,"interval year"=>12,"interval day"=>28),'Strings'=>array("char"=>2000,"varchar2"=>4000,"nchar"=>2000,"nvarchar2"=>4000,"clob"=>4294967295,"nclob"=>4294967295),'Binary'=>array("raw"=>2000,"long raw"=>2147483648,"blob"=>4294967295,"bfile"=>4294967296),)as$y=>$X){$wi+=$X;$Ah[$y]=array_keys($X);}$Ci=array();$pf=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$jd=array("length","lower","round","upper");$pd=array("avg","count","count distinct","max","min","sum");$lc=array(array("date"=>"current_date","timestamp"=>"current_timestamp",),array("number|float|double"=>"+/-","date|timestamp"=>"+ interval/- interval","char|clob"=>"||",));}$dc["mssql"]="MS SQL (beta)";if(isset($_GET["mssql"])){$bg=array("SQLSRV","MSSQL","PDO_DBLIB");define("DRIVER","mssql");if(extension_loaded("sqlsrv")){class
  711. Min_DB{var$extension="sqlsrv",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
  712. _get_error(){$this->error="";foreach(sqlsrv_errors()as$n){$this->errno=$n["code"];$this->error.="$n[message]\n";}$this->error=rtrim($this->error);}function
  713. connect($N,$V,$F){$this->_link=@sqlsrv_connect(preg_replace('~:~',',',$N),array("UID"=>$V,"PWD"=>$F,"CharacterSet"=>"UTF-8"));if($this->_link){$Md=sqlsrv_server_info($this->_link);$this->server_info=$Md['SQLServerVersion'];}else$this->_get_error();return(bool)$this->_link;}function
  714. quote($Q){return"'".str_replace("'","''",$Q)."'";}function
  715. select_db($j){return$this->query("USE ".idf_escape($j));}function
  716. query($G,$xi=false){$H=sqlsrv_query($this->_link,$G);$this->error="";if(!$H){$this->_get_error();return
  717. false;}return$this->store_result($H);}function
  718. multi_query($G){$this->_result=sqlsrv_query($this->_link,$G);$this->error="";if(!$this->_result){$this->_get_error();return
  719. false;}return
  720. true;}function
  721. store_result($H=null){if(!$H)$H=$this->_result;if(!$H)return
  722. false;if(sqlsrv_field_metadata($H))return
  723. new
  724. Min_Result($H);$this->affected_rows=sqlsrv_rows_affected($H);return
  725. true;}function
  726. next_result(){return$this->_result?sqlsrv_next_result($this->_result):null;}function
  727. result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
  728. false;$J=$H->fetch_row();return$J[$o];}}class
  729. Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
  730. __construct($H){$this->_result=$H;}function
  731. _convert($J){foreach((array)$J
  732. as$y=>$X){if(is_a($X,'DateTime'))$J[$y]=$X->format("Y-m-d H:i:s");}return$J;}function
  733. fetch_assoc(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_ASSOC));}function
  734. fetch_row(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_NUMERIC));}function
  735. fetch_field(){if(!$this->_fields)$this->_fields=sqlsrv_field_metadata($this->_result);$o=$this->_fields[$this->_offset++];$I=new
  736. stdClass;$I->name=$o["Name"];$I->orgname=$o["Name"];$I->type=($o["Type"]==1?254:0);return$I;}function
  737. seek($D){for($s=0;$s<$D;$s++)sqlsrv_fetch($this->_result);}function
  738. __destruct(){sqlsrv_free_stmt($this->_result);}}}elseif(extension_loaded("mssql")){class
  739. Min_DB{var$extension="MSSQL",$_link,$_result,$server_info,$affected_rows,$error;function
  740. connect($N,$V,$F){$this->_link=@mssql_connect($N,$V,$F);if($this->_link){$H=$this->query("SELECT SERVERPROPERTY('ProductLevel'), SERVERPROPERTY('Edition')");if($H){$J=$H->fetch_row();$this->server_info=$this->result("sp_server_info 2",2)." [$J[0]] $J[1]";}}else$this->error=mssql_get_last_message();return(bool)$this->_link;}function
  741. quote($Q){return"'".str_replace("'","''",$Q)."'";}function
  742. select_db($j){return
  743. mssql_select_db($j);}function
  744. query($G,$xi=false){$H=@mssql_query($G,$this->_link);$this->error="";if(!$H){$this->error=mssql_get_last_message();return
  745. false;}if($H===true){$this->affected_rows=mssql_rows_affected($this->_link);return
  746. true;}return
  747. new
  748. Min_Result($H);}function
  749. multi_query($G){return$this->_result=$this->query($G);}function
  750. store_result(){return$this->_result;}function
  751. next_result(){return
  752. mssql_next_result($this->_result->_result);}function
  753. result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
  754. false;return
  755. mssql_result($H->_result,0,$o);}}class
  756. Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
  757. __construct($H){$this->_result=$H;$this->num_rows=mssql_num_rows($H);}function
  758. fetch_assoc(){return
  759. mssql_fetch_assoc($this->_result);}function
  760. fetch_row(){return
  761. mssql_fetch_row($this->_result);}function
  762. num_rows(){return
  763. mssql_num_rows($this->_result);}function
  764. fetch_field(){$I=mssql_fetch_field($this->_result);$I->orgtable=$I->table;$I->orgname=$I->name;return$I;}function
  765. seek($D){mssql_data_seek($this->_result,$D);}function
  766. __destruct(){mssql_free_result($this->_result);}}}elseif(extension_loaded("pdo_dblib")){class
  767. Min_DB
  768. extends
  769. Min_PDO{var$extension="PDO_DBLIB";function
  770. connect($N,$V,$F){$this->dsn("dblib:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\d)~',';port=\1',$N)),$V,$F);return
  771. true;}function
  772. select_db($j){return$this->query("USE ".idf_escape($j));}}}class
  773. Min_Driver
  774. extends
  775. Min_SQL{function
  776. insertUpdate($R,$K,$eg){foreach($K
  777. as$O){$Di=array();$Z=array();foreach($O
  778. as$y=>$X){$Di[]="$y = $X";if(isset($eg[idf_unescape($y)]))$Z[]="$y = $X";}if(!queries("MERGE ".table($R)." USING (VALUES(".implode(", ",$O).")) AS source (c".implode(", c",range(1,count($O))).") ON ".implode(" AND ",$Z)." WHEN MATCHED THEN UPDATE SET ".implode(", ",$Di)." WHEN NOT MATCHED THEN INSERT (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).");"))return
  779. false;}return
  780. true;}function
  781. begin(){return
  782. queries("BEGIN TRANSACTION");}}function
  783. idf_escape($u){return"[".str_replace("]","]]",$u)."]";}function
  784. table($u){return($_GET["ns"]!=""?idf_escape($_GET["ns"]).".":"").idf_escape($u);}function
  785. connect(){global$b;$g=new
  786. Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
  787. get_databases(){return
  788. get_vals("SELECT name FROM sys.databases WHERE name NOT IN ('master', 'tempdb', 'model', 'msdb')");}function
  789. limit($G,$Z,$z,$D=0,$M=" "){return($z!==null?" TOP (".($z+$D).")":"")." $G$Z";}function
  790. limit1($R,$G,$Z,$M="\n"){return
  791. limit($G,$Z,1,0,$M);}function
  792. db_collation($l,$ob){global$g;return$g->result("SELECT collation_name FROM sys.databases WHERE name = ".q($l));}function
  793. engines(){return
  794. array();}function
  795. logged_user(){global$g;return$g->result("SELECT SUSER_NAME()");}function
  796. tables_list(){return
  797. get_key_vals("SELECT name, type_desc FROM sys.all_objects WHERE schema_id = SCHEMA_ID(".q(get_schema()).") AND type IN ('S', 'U', 'V') ORDER BY name");}function
  798. count_tables($k){global$g;$I=array();foreach($k
  799. as$l){$g->select_db($l);$I[$l]=$g->result("SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES");}return$I;}function
  800. table_status($C=""){$I=array();foreach(get_rows("SELECT name AS Name, type_desc AS Engine FROM sys.all_objects WHERE schema_id = SCHEMA_ID(".q(get_schema()).") AND type IN ('S', 'U', 'V') ".($C!=""?"AND name = ".q($C):"ORDER BY name"))as$J){if($C!="")return$J;$I[$J["Name"]]=$J;}return$I;}function
  801. is_view($S){return$S["Engine"]=="VIEW";}function
  802. fk_support($S){return
  803. true;}function
  804. fields($R){$I=array();foreach(get_rows("SELECT c.max_length, c.precision, c.scale, c.name, c.is_nullable, c.is_identity, c.collation_name, t.name type, CAST(d.definition as text) [default]
  805. FROM sys.all_columns c
  806. JOIN sys.all_objects o ON c.object_id = o.object_id
  807. JOIN sys.types t ON c.user_type_id = t.user_type_id
  808. LEFT JOIN sys.default_constraints d ON c.default_object_id = d.parent_column_id
  809. WHERE o.schema_id = SCHEMA_ID(".q(get_schema()).") AND o.type IN ('S', 'U', 'V') AND o.name = ".q($R))as$J){$U=$J["type"];$qe=(preg_match("~char|binary~",$U)?$J["max_length"]:($U=="decimal"?"$J[precision],$J[scale]":""));$I[$J["name"]]=array("field"=>$J["name"],"full_type"=>$U.($qe?"($qe)":""),"type"=>$U,"length"=>$qe,"default"=>$J["default"],"null"=>$J["is_nullable"],"auto_increment"=>$J["is_identity"],"collation"=>$J["collation_name"],"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),"primary"=>$J["is_identity"],);}return$I;}function
  810. indexes($R,$h=null){$I=array();foreach(get_rows("SELECT i.name, key_ordinal, is_unique, is_primary_key, c.name AS column_name, is_descending_key
  811. FROM sys.indexes i
  812. INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
  813. INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
  814. WHERE OBJECT_NAME(i.object_id) = ".q($R),$h)as$J){$C=$J["name"];$I[$C]["type"]=($J["is_primary_key"]?"PRIMARY":($J["is_unique"]?"UNIQUE":"INDEX"));$I[$C]["lengths"]=array();$I[$C]["columns"][$J["key_ordinal"]]=$J["column_name"];$I[$C]["descs"][$J["key_ordinal"]]=($J["is_descending_key"]?'1':null);}return$I;}function
  815. view($C){global$g;return
  816. array("select"=>preg_replace('~^(?:[^[]|\[[^]]*])*\s+AS\s+~isU','',$g->result("SELECT VIEW_DEFINITION FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_SCHEMA = SCHEMA_NAME() AND TABLE_NAME = ".q($C))));}function
  817. collations(){$I=array();foreach(get_vals("SELECT name FROM fn_helpcollations()")as$d)$I[preg_replace('~_.*~','',$d)][]=$d;return$I;}function
  818. information_schema($l){return
  819. false;}function
  820. error(){global$g;return
  821. nl_br(h(preg_replace('~^(\[[^]]*])+~m','',$g->error)));}function
  822. create_database($l,$d){return
  823. queries("CREATE DATABASE ".idf_escape($l).(preg_match('~^[a-z0-9_]+$~i',$d)?" COLLATE $d":""));}function
  824. drop_databases($k){return
  825. queries("DROP DATABASE ".implode(", ",array_map('idf_escape',$k)));}function
  826. rename_database($C,$d){if(preg_match('~^[a-z0-9_]+$~i',$d))queries("ALTER DATABASE ".idf_escape(DB)." COLLATE $d");queries("ALTER DATABASE ".idf_escape(DB)." MODIFY NAME = ".idf_escape($C));return
  827. true;}function
  828. auto_increment(){return" IDENTITY".($_POST["Auto_increment"]!=""?"(".number($_POST["Auto_increment"]).",1)":"")." PRIMARY KEY";}function
  829. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();foreach($p
  830. as$o){$e=idf_escape($o[0]);$X=$o[1];if(!$X)$c["DROP"][]=" COLUMN $e";else{$X[1]=preg_replace("~( COLLATE )'(\\w+)'~",'\1\2',$X[1]);if($o[0]=="")$c["ADD"][]="\n ".implode("",$X).($R==""?substr($bd[$X[0]],16+strlen($X[0])):"");else{unset($X[6]);if($e!=$X[0])queries("EXEC sp_rename ".q(table($R).".$e").", ".q(idf_unescape($X[0])).", 'COLUMN'");$c["ALTER COLUMN ".implode("",$X)][]="";}}}if($R=="")return
  831. queries("CREATE TABLE ".table($C)." (".implode(",",(array)$c["ADD"])."\n)");if($R!=$C)queries("EXEC sp_rename ".q(table($R)).", ".q($C));if($bd)$c[""]=$bd;foreach($c
  832. as$y=>$X){if(!queries("ALTER TABLE ".idf_escape($C)." $y".implode(",",$X)))return
  833. false;}return
  834. true;}function
  835. alter_indexes($R,$c){$v=array();$ec=array();foreach($c
  836. as$X){if($X[2]=="DROP"){if($X[0]=="PRIMARY")$ec[]=idf_escape($X[1]);else$v[]=idf_escape($X[1])." ON ".table($R);}elseif(!queries(($X[0]!="PRIMARY"?"CREATE $X[0] ".($X[0]!="INDEX"?"INDEX ":"").idf_escape($X[1]!=""?$X[1]:uniqid($R."_"))." ON ".table($R):"ALTER TABLE ".table($R)." ADD PRIMARY KEY")." (".implode(", ",$X[2]).")"))return
  837. false;}return(!$v||queries("DROP INDEX ".implode(", ",$v)))&&(!$ec||queries("ALTER TABLE ".table($R)." DROP ".implode(", ",$ec)));}function
  838. last_id(){global$g;return$g->result("SELECT SCOPE_IDENTITY()");}function
  839. explain($g,$G){$g->query("SET SHOWPLAN_ALL ON");$I=$g->query($G);$g->query("SET SHOWPLAN_ALL OFF");return$I;}function
  840. found_rows($S,$Z){}function
  841. foreign_keys($R){$I=array();foreach(get_rows("EXEC sp_fkeys @fktable_name = ".q($R))as$J){$q=&$I[$J["FK_NAME"]];$q["table"]=$J["PKTABLE_NAME"];$q["source"][]=$J["FKCOLUMN_NAME"];$q["target"][]=$J["PKCOLUMN_NAME"];}return$I;}function
  842. truncate_tables($T){return
  843. apply_queries("TRUNCATE TABLE",$T);}function
  844. drop_views($Ti){return
  845. queries("DROP VIEW ".implode(", ",array_map('table',$Ti)));}function
  846. drop_tables($T){return
  847. queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
  848. move_tables($T,$Ti,$Qh){return
  849. apply_queries("ALTER SCHEMA ".idf_escape($Qh)." TRANSFER",array_merge($T,$Ti));}function
  850. trigger($C){if($C=="")return
  851. array();$K=get_rows("SELECT s.name [Trigger],
  852. CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsertTrigger') = 1 THEN 'INSERT' WHEN OBJECTPROPERTY(s.id, 'ExecIsUpdateTrigger') = 1 THEN 'UPDATE' WHEN OBJECTPROPERTY(s.id, 'ExecIsDeleteTrigger') = 1 THEN 'DELETE' END [Event],
  853. CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing],
  854. c.text
  855. FROM sysobjects s
  856. JOIN syscomments c ON s.id = c.id
  857. WHERE s.xtype = 'TR' AND s.name = ".q($C));$I=reset($K);if($I)$I["Statement"]=preg_replace('~^.+\s+AS\s+~isU','',$I["text"]);return$I;}function
  858. triggers($R){$I=array();foreach(get_rows("SELECT sys1.name,
  859. CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsertTrigger') = 1 THEN 'INSERT' WHEN OBJECTPROPERTY(sys1.id, 'ExecIsUpdateTrigger') = 1 THEN 'UPDATE' WHEN OBJECTPROPERTY(sys1.id, 'ExecIsDeleteTrigger') = 1 THEN 'DELETE' END [Event],
  860. CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing]
  861. FROM sysobjects sys1
  862. JOIN sysobjects sys2 ON sys1.parent_obj = sys2.id
  863. WHERE sys1.xtype = 'TR' AND sys2.name = ".q($R))as$J)$I[$J["name"]]=array($J["Timing"],$J["Event"]);return$I;}function
  864. trigger_options(){return
  865. array("Timing"=>array("AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("AS"),);}function
  866. schemas(){return
  867. get_vals("SELECT name FROM sys.schemas");}function
  868. get_schema(){global$g;if($_GET["ns"]!="")return$_GET["ns"];return$g->result("SELECT SCHEMA_NAME()");}function
  869. set_schema($Ug){return
  870. true;}function
  871. use_sql($j){return"USE ".idf_escape($j);}function
  872. show_variables(){return
  873. array();}function
  874. show_status(){return
  875. array();}function
  876. convert_field($o){}function
  877. unconvert_field($o,$I){return$I;}function
  878. support($Oc){return
  879. preg_match('~^(columns|database|drop_col|indexes|scheme|sql|table|trigger|view|view_trigger)$~',$Oc);}$x="mssql";$wi=array();$Ah=array();foreach(array('Numbers'=>array("tinyint"=>3,"smallint"=>5,"int"=>10,"bigint"=>20,"bit"=>1,"decimal"=>0,"real"=>12,"float"=>53,"smallmoney"=>10,"money"=>20),'Date and time'=>array("date"=>10,"smalldatetime"=>19,"datetime"=>19,"datetime2"=>19,"time"=>8,"datetimeoffset"=>10),'Strings'=>array("char"=>8000,"varchar"=>8000,"text"=>2147483647,"nchar"=>4000,"nvarchar"=>4000,"ntext"=>1073741823),'Binary'=>array("binary"=>8000,"varbinary"=>8000,"image"=>2147483647),)as$y=>$X){$wi+=$X;$Ah[$y]=array_keys($X);}$Ci=array();$pf=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$jd=array("len","lower","round","upper");$pd=array("avg","count","count distinct","max","min","sum");$lc=array(array("date|time"=>"getdate",),array("int|decimal|real|float|money|datetime"=>"+/-","char|text"=>"+",));}$dc['firebird']='Firebird (alpha)';if(isset($_GET["firebird"])){$bg=array("interbase");define("DRIVER","firebird");if(extension_loaded("interbase")){class
  880. Min_DB{var$extension="Firebird",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
  881. connect($N,$V,$F){$this->_link=ibase_connect($N,$V,$F);if($this->_link){$Gi=explode(':',$N);$this->service_link=ibase_service_attach($Gi[0],$V,$F);$this->server_info=ibase_server_info($this->service_link,IBASE_SVC_SERVER_VERSION);}else{$this->errno=ibase_errcode();$this->error=ibase_errmsg();}return(bool)$this->_link;}function
  882. quote($Q){return"'".str_replace("'","''",$Q)."'";}function
  883. select_db($j){return($j=="domain");}function
  884. query($G,$xi=false){$H=ibase_query($G,$this->_link);if(!$H){$this->errno=ibase_errcode();$this->error=ibase_errmsg();return
  885. false;}$this->error="";if($H===true){$this->affected_rows=ibase_affected_rows($this->_link);return
  886. true;}return
  887. new
  888. Min_Result($H);}function
  889. multi_query($G){return$this->_result=$this->query($G);}function
  890. store_result(){return$this->_result;}function
  891. next_result(){return
  892. false;}function
  893. result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
  894. false;$J=$H->fetch_row();return$J[$o];}}class
  895. Min_Result{var$num_rows,$_result,$_offset=0;function
  896. __construct($H){$this->_result=$H;}function
  897. fetch_assoc(){return
  898. ibase_fetch_assoc($this->_result);}function
  899. fetch_row(){return
  900. ibase_fetch_row($this->_result);}function
  901. fetch_field(){$o=ibase_field_info($this->_result,$this->_offset++);return(object)array('name'=>$o['name'],'orgname'=>$o['name'],'type'=>$o['type'],'charsetnr'=>$o['length'],);}function
  902. __destruct(){ibase_free_result($this->_result);}}}class
  903. Min_Driver
  904. extends
  905. Min_SQL{}function
  906. idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
  907. table($u){return
  908. idf_escape($u);}function
  909. connect(){global$b;$g=new
  910. Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
  911. get_databases($Zc){return
  912. array("domain");}function
  913. limit($G,$Z,$z,$D=0,$M=" "){$I='';$I.=($z!==null?$M."FIRST $z".($D?" SKIP $D":""):"");$I.=" $G$Z";return$I;}function
  914. limit1($R,$G,$Z,$M="\n"){return
  915. limit($G,$Z,1,0,$M);}function
  916. db_collation($l,$ob){}function
  917. engines(){return
  918. array();}function
  919. logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
  920. tables_list(){global$g;$G='SELECT RDB$RELATION_NAME FROM rdb$relations WHERE rdb$system_flag = 0';$H=ibase_query($g->_link,$G);$I=array();while($J=ibase_fetch_assoc($H))$I[$J['RDB$RELATION_NAME']]='table';ksort($I);return$I;}function
  921. count_tables($k){return
  922. array();}function
  923. table_status($C="",$Nc=false){global$g;$I=array();$Kb=tables_list();foreach($Kb
  924. as$v=>$X){$v=trim($v);$I[$v]=array('Name'=>$v,'Engine'=>'standard',);if($C==$v)return$I[$v];}return$I;}function
  925. is_view($S){return
  926. false;}function
  927. fk_support($S){return
  928. preg_match('~InnoDB|IBMDB2I~i',$S["Engine"]);}function
  929. fields($R){global$g;$I=array();$G='SELECT r.RDB$FIELD_NAME AS field_name,
  930. r.RDB$DESCRIPTION AS field_description,
  931. r.RDB$DEFAULT_VALUE AS field_default_value,
  932. r.RDB$NULL_FLAG AS field_not_null_constraint,
  933. f.RDB$FIELD_LENGTH AS field_length,
  934. f.RDB$FIELD_PRECISION AS field_precision,
  935. f.RDB$FIELD_SCALE AS field_scale,
  936. CASE f.RDB$FIELD_TYPE
  937. WHEN 261 THEN \'BLOB\'
  938. WHEN 14 THEN \'CHAR\'
  939. WHEN 40 THEN \'CSTRING\'
  940. WHEN 11 THEN \'D_FLOAT\'
  941. WHEN 27 THEN \'DOUBLE\'
  942. WHEN 10 THEN \'FLOAT\'
  943. WHEN 16 THEN \'INT64\'
  944. WHEN 8 THEN \'INTEGER\'
  945. WHEN 9 THEN \'QUAD\'
  946. WHEN 7 THEN \'SMALLINT\'
  947. WHEN 12 THEN \'DATE\'
  948. WHEN 13 THEN \'TIME\'
  949. WHEN 35 THEN \'TIMESTAMP\'
  950. WHEN 37 THEN \'VARCHAR\'
  951. ELSE \'UNKNOWN\'
  952. END AS field_type,
  953. f.RDB$FIELD_SUB_TYPE AS field_subtype,
  954. coll.RDB$COLLATION_NAME AS field_collation,
  955. cset.RDB$CHARACTER_SET_NAME AS field_charset
  956. FROM RDB$RELATION_FIELDS r
  957. LEFT JOIN RDB$FIELDS f ON r.RDB$FIELD_SOURCE = f.RDB$FIELD_NAME
  958. LEFT JOIN RDB$COLLATIONS coll ON f.RDB$COLLATION_ID = coll.RDB$COLLATION_ID
  959. LEFT JOIN RDB$CHARACTER_SETS cset ON f.RDB$CHARACTER_SET_ID = cset.RDB$CHARACTER_SET_ID
  960. WHERE r.RDB$RELATION_NAME = '.q($R).'
  961. ORDER BY r.RDB$FIELD_POSITION';$H=ibase_query($g->_link,$G);while($J=ibase_fetch_assoc($H))$I[trim($J['FIELD_NAME'])]=array("field"=>trim($J["FIELD_NAME"]),"full_type"=>trim($J["FIELD_TYPE"]),"type"=>trim($J["FIELD_SUB_TYPE"]),"default"=>trim($J['FIELD_DEFAULT_VALUE']),"null"=>(trim($J["FIELD_NOT_NULL_CONSTRAINT"])=="YES"),"auto_increment"=>'0',"collation"=>trim($J["FIELD_COLLATION"]),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),"comment"=>trim($J["FIELD_DESCRIPTION"]),);return$I;}function
  962. indexes($R,$h=null){$I=array();return$I;}function
  963. foreign_keys($R){return
  964. array();}function
  965. collations(){return
  966. array();}function
  967. information_schema($l){return
  968. false;}function
  969. error(){global$g;return
  970. h($g->error);}function
  971. types(){return
  972. array();}function
  973. schemas(){return
  974. array();}function
  975. get_schema(){return"";}function
  976. set_schema($Ug){return
  977. true;}function
  978. support($Oc){return
  979. preg_match("~^(columns|sql|status|table)$~",$Oc);}$x="firebird";$pf=array("=");$jd=array();$pd=array();$lc=array();}$dc["simpledb"]="SimpleDB";if(isset($_GET["simpledb"])){$bg=array("SimpleXML + allow_url_fopen");define("DRIVER","simpledb");if(class_exists('SimpleXMLElement')&&ini_bool('allow_url_fopen')){class
  980. Min_DB{var$extension="SimpleXML",$server_info='2009-04-15',$error,$timeout,$next,$affected_rows,$_result;function
  981. select_db($j){return($j=="domain");}function
  982. query($G,$xi=false){$If=array('SelectExpression'=>$G,'ConsistentRead'=>'true');if($this->next)$If['NextToken']=$this->next;$H=sdb_request_all('Select','Item',$If,$this->timeout);$this->timeout=0;if($H===false)return$H;if(preg_match('~^\s*SELECT\s+COUNT\(~i',$G)){$Eh=0;foreach($H
  983. as$Yd)$Eh+=$Yd->Attribute->Value;$H=array((object)array('Attribute'=>array((object)array('Name'=>'Count','Value'=>$Eh,))));}return
  984. new
  985. Min_Result($H);}function
  986. multi_query($G){return$this->_result=$this->query($G);}function
  987. store_result(){return$this->_result;}function
  988. next_result(){return
  989. false;}function
  990. quote($Q){return"'".str_replace("'","''",$Q)."'";}}class
  991. Min_Result{var$num_rows,$_rows=array(),$_offset=0;function
  992. __construct($H){foreach($H
  993. as$Yd){$J=array();if($Yd->Name!='')$J['itemName()']=(string)$Yd->Name;foreach($Yd->Attribute
  994. as$Ia){$C=$this->_processValue($Ia->Name);$Y=$this->_processValue($Ia->Value);if(isset($J[$C])){$J[$C]=(array)$J[$C];$J[$C][]=$Y;}else$J[$C]=$Y;}$this->_rows[]=$J;foreach($J
  995. as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
  996. _processValue($oc){return(is_object($oc)&&$oc['encoding']=='base64'?base64_decode($oc):(string)$oc);}function
  997. fetch_assoc(){$J=current($this->_rows);if(!$J)return$J;$I=array();foreach($this->_rows[0]as$y=>$X)$I[$y]=$J[$y];next($this->_rows);return$I;}function
  998. fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
  999. array_values($I);}function
  1000. fetch_field(){$ee=array_keys($this->_rows[0]);return(object)array('name'=>$ee[$this->_offset++]);}}}class
  1001. Min_Driver
  1002. extends
  1003. Min_SQL{public$eg="itemName()";function
  1004. _chunkRequest($Cd,$va,$If,$Dc=array()){global$g;foreach(array_chunk($Cd,25)as$hb){$Jf=$If;foreach($hb
  1005. as$s=>$t){$Jf["Item.$s.ItemName"]=$t;foreach($Dc
  1006. as$y=>$X)$Jf["Item.$s.$y"]=$X;}if(!sdb_request($va,$Jf))return
  1007. false;}$g->affected_rows=count($Cd);return
  1008. true;}function
  1009. _extractIds($R,$qg,$z){$I=array();if(preg_match_all("~itemName\(\) = (('[^']*+')+)~",$qg,$_e))$I=array_map('idf_unescape',$_e[1]);else{foreach(sdb_request_all('Select','Item',array('SelectExpression'=>'SELECT itemName() FROM '.table($R).$qg.($z?" LIMIT 1":"")))as$Yd)$I[]=$Yd->Name;}return$I;}function
  1010. select($R,$L,$Z,$md,$uf=array(),$z=1,$E=0,$gg=false){global$g;$g->next=$_GET["next"];$I=parent::select($R,$L,$Z,$md,$uf,$z,$E,$gg);$g->next=0;return$I;}function
  1011. delete($R,$qg,$z=0){return$this->_chunkRequest($this->_extractIds($R,$qg,$z),'BatchDeleteAttributes',array('DomainName'=>$R));}function
  1012. update($R,$O,$qg,$z=0,$M="\n"){$Tb=array();$Qd=array();$s=0;$Cd=$this->_extractIds($R,$qg,$z);$t=idf_unescape($O["`itemName()`"]);unset($O["`itemName()`"]);foreach($O
  1013. as$y=>$X){$y=idf_unescape($y);if($X=="NULL"||($t!=""&&array($t)!=$Cd))$Tb["Attribute.".count($Tb).".Name"]=$y;if($X!="NULL"){foreach((array)$X
  1014. as$ae=>$W){$Qd["Attribute.$s.Name"]=$y;$Qd["Attribute.$s.Value"]=(is_array($X)?$W:idf_unescape($W));if(!$ae)$Qd["Attribute.$s.Replace"]="true";$s++;}}}$If=array('DomainName'=>$R);return(!$Qd||$this->_chunkRequest(($t!=""?array($t):$Cd),'BatchPutAttributes',$If,$Qd))&&(!$Tb||$this->_chunkRequest($Cd,'BatchDeleteAttributes',$If,$Tb));}function
  1015. insert($R,$O){$If=array("DomainName"=>$R);$s=0;foreach($O
  1016. as$C=>$Y){if($Y!="NULL"){$C=idf_unescape($C);if($C=="itemName()")$If["ItemName"]=idf_unescape($Y);else{foreach((array)$Y
  1017. as$X){$If["Attribute.$s.Name"]=$C;$If["Attribute.$s.Value"]=(is_array($Y)?$X:idf_unescape($Y));$s++;}}}}return
  1018. sdb_request('PutAttributes',$If);}function
  1019. insertUpdate($R,$K,$eg){foreach($K
  1020. as$O){if(!$this->update($R,$O,"WHERE `itemName()` = ".q($O["`itemName()`"])))return
  1021. false;}return
  1022. true;}function
  1023. begin(){return
  1024. false;}function
  1025. commit(){return
  1026. false;}function
  1027. rollback(){return
  1028. false;}function
  1029. slowQuery($G,$Yh){$this->_conn->timeout=$Yh;return$G;}}function
  1030. connect(){global$b;list(,,$F)=$b->credentials();if($F!="")return'Database does not support password.';return
  1031. new
  1032. Min_DB;}function
  1033. support($Oc){return
  1034. preg_match('~sql~',$Oc);}function
  1035. logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
  1036. get_databases(){return
  1037. array("domain");}function
  1038. collations(){return
  1039. array();}function
  1040. db_collation($l,$ob){}function
  1041. tables_list(){global$g;$I=array();foreach(sdb_request_all('ListDomains','DomainName')as$R)$I[(string)$R]='table';if($g->error&&defined("PAGE_HEADER"))echo"<p class='error'>".error()."\n";return$I;}function
  1042. table_status($C="",$Nc=false){$I=array();foreach(($C!=""?array($C=>true):tables_list())as$R=>$U){$J=array("Name"=>$R,"Auto_increment"=>"");if(!$Nc){$Me=sdb_request('DomainMetadata',array('DomainName'=>$R));if($Me){foreach(array("Rows"=>"ItemCount","Data_length"=>"ItemNamesSizeBytes","Index_length"=>"AttributeValuesSizeBytes","Data_free"=>"AttributeNamesSizeBytes",)as$y=>$X)$J[$y]=(string)$Me->$X;}}if($C!="")return$J;$I[$R]=$J;}return$I;}function
  1043. explain($g,$G){}function
  1044. error(){global$g;return
  1045. h($g->error);}function
  1046. information_schema(){}function
  1047. is_view($S){}function
  1048. indexes($R,$h=null){return
  1049. array(array("type"=>"PRIMARY","columns"=>array("itemName()")),);}function
  1050. fields($R){return
  1051. fields_from_edit();}function
  1052. foreign_keys($R){return
  1053. array();}function
  1054. table($u){return
  1055. idf_escape($u);}function
  1056. idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
  1057. limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z":"");}function
  1058. unconvert_field($o,$I){return$I;}function
  1059. fk_support($S){}function
  1060. engines(){return
  1061. array();}function
  1062. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){return($R==""&&sdb_request('CreateDomain',array('DomainName'=>$C)));}function
  1063. drop_tables($T){foreach($T
  1064. as$R){if(!sdb_request('DeleteDomain',array('DomainName'=>$R)))return
  1065. false;}return
  1066. true;}function
  1067. count_tables($k){foreach($k
  1068. as$l)return
  1069. array($l=>count(tables_list()));}function
  1070. found_rows($S,$Z){return($Z?null:$S["Rows"]);}function
  1071. last_id(){}function
  1072. hmac($Ba,$Kb,$y,$ug=false){$Ua=64;if(strlen($y)>$Ua)$y=pack("H*",$Ba($y));$y=str_pad($y,$Ua,"\0");$be=$y^str_repeat("\x36",$Ua);$ce=$y^str_repeat("\x5C",$Ua);$I=$Ba($ce.pack("H*",$Ba($be.$Kb)));if($ug)$I=pack("H*",$I);return$I;}function
  1073. sdb_request($va,$If=array()){global$b,$g;list($_d,$If['AWSAccessKeyId'],$Xg)=$b->credentials();$If['Action']=$va;$If['Timestamp']=gmdate('Y-m-d\TH:i:s+00:00');$If['Version']='2009-04-15';$If['SignatureVersion']=2;$If['SignatureMethod']='HmacSHA1';ksort($If);$G='';foreach($If
  1074. as$y=>$X)$G.='&'.rawurlencode($y).'='.rawurlencode($X);$G=str_replace('%7E','~',substr($G,1));$G.="&Signature=".urlencode(base64_encode(hmac('sha1',"POST\n".preg_replace('~^https?://~','',$_d)."\n/\n$G",$Xg,true)));@ini_set('track_errors',1);$Sc=@file_get_contents((preg_match('~^https?://~',$_d)?$_d:"http://$_d"),false,stream_context_create(array('http'=>array('method'=>'POST','content'=>$G,'ignore_errors'=>1,))));if(!$Sc){$g->error=$php_errormsg;return
  1075. false;}libxml_use_internal_errors(true);$gj=simplexml_load_string($Sc);if(!$gj){$n=libxml_get_last_error();$g->error=$n->message;return
  1076. false;}if($gj->Errors){$n=$gj->Errors->Error;$g->error="$n->Message ($n->Code)";return
  1077. false;}$g->error='';$Ph=$va."Result";return($gj->$Ph?$gj->$Ph:true);}function
  1078. sdb_request_all($va,$Ph,$If=array(),$Yh=0){$I=array();$xh=($Yh?microtime(true):0);$z=(preg_match('~LIMIT\s+(\d+)\s*$~i',$If['SelectExpression'],$B)?$B[1]:0);do{$gj=sdb_request($va,$If);if(!$gj)break;foreach($gj->$Ph
  1079. as$oc)$I[]=$oc;if($z&&count($I)>=$z){$_GET["next"]=$gj->NextToken;break;}if($Yh&&microtime(true)-$xh>$Yh)return
  1080. false;$If['NextToken']=$gj->NextToken;if($z)$If['SelectExpression']=preg_replace('~\d+\s*$~',$z-count($I),$If['SelectExpression']);}while($gj->NextToken);return$I;}$x="simpledb";$pf=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","IS NOT NULL");$jd=array();$pd=array("count");$lc=array(array("json"));}$dc["mongo"]="MongoDB";if(isset($_GET["mongo"])){$bg=array("mongo","mongodb");define("DRIVER","mongo");if(class_exists('MongoDB')){class
  1081. Min_DB{var$extension="Mongo",$server_info=MongoClient::VERSION,$error,$last_id,$_link,$_db;function
  1082. connect($Ei,$sf){return@new
  1083. MongoClient($Ei,$sf);}function
  1084. query($G){return
  1085. false;}function
  1086. select_db($j){try{$this->_db=$this->_link->selectDB($j);return
  1087. true;}catch(Exception$_c){$this->error=$_c->getMessage();return
  1088. false;}}function
  1089. quote($Q){return$Q;}}class
  1090. Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
  1091. __construct($H){foreach($H
  1092. as$Yd){$J=array();foreach($Yd
  1093. as$y=>$X){if(is_a($X,'MongoBinData'))$this->_charset[$y]=63;$J[$y]=(is_a($X,'MongoId')?'ObjectId("'.strval($X).'")':(is_a($X,'MongoDate')?gmdate("Y-m-d H:i:s",$X->sec)." GMT":(is_a($X,'MongoBinData')?$X->bin:(is_a($X,'MongoRegex')?strval($X):(is_object($X)?get_class($X):$X)))));}$this->_rows[]=$J;foreach($J
  1094. as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
  1095. fetch_assoc(){$J=current($this->_rows);if(!$J)return$J;$I=array();foreach($this->_rows[0]as$y=>$X)$I[$y]=$J[$y];next($this->_rows);return$I;}function
  1096. fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
  1097. array_values($I);}function
  1098. fetch_field(){$ee=array_keys($this->_rows[0]);$C=$ee[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}class
  1099. Min_Driver
  1100. extends
  1101. Min_SQL{public$eg="_id";function
  1102. select($R,$L,$Z,$md,$uf=array(),$z=1,$E=0,$gg=false){$L=($L==array("*")?array():array_fill_keys($L,true));$oh=array();foreach($uf
  1103. as$X){$X=preg_replace('~ DESC$~','',$X,1,$Cb);$oh[$X]=($Cb?-1:1);}return
  1104. new
  1105. Min_Result($this->_conn->_db->selectCollection($R)->find(array(),$L)->sort($oh)->limit($z!=""?+$z:0)->skip($E*$z));}function
  1106. insert($R,$O){try{$I=$this->_conn->_db->selectCollection($R)->insert($O);$this->_conn->errno=$I['code'];$this->_conn->error=$I['err'];$this->_conn->last_id=$O['_id'];return!$I['err'];}catch(Exception$_c){$this->_conn->error=$_c->getMessage();return
  1107. false;}}}function
  1108. get_databases($Zc){global$g;$I=array();$Pb=$g->_link->listDBs();foreach($Pb['databases']as$l)$I[]=$l['name'];return$I;}function
  1109. count_tables($k){global$g;$I=array();foreach($k
  1110. as$l)$I[$l]=count($g->_link->selectDB($l)->getCollectionNames(true));return$I;}function
  1111. tables_list(){global$g;return
  1112. array_fill_keys($g->_db->getCollectionNames(true),'table');}function
  1113. drop_databases($k){global$g;foreach($k
  1114. as$l){$Gg=$g->_link->selectDB($l)->drop();if(!$Gg['ok'])return
  1115. false;}return
  1116. true;}function
  1117. indexes($R,$h=null){global$g;$I=array();foreach($g->_db->selectCollection($R)->getIndexInfo()as$v){$Wb=array();foreach($v["key"]as$e=>$U)$Wb[]=($U==-1?'1':null);$I[$v["name"]]=array("type"=>($v["name"]=="_id_"?"PRIMARY":($v["unique"]?"UNIQUE":"INDEX")),"columns"=>array_keys($v["key"]),"lengths"=>array(),"descs"=>$Wb,);}return$I;}function
  1118. fields($R){return
  1119. fields_from_edit();}function
  1120. found_rows($S,$Z){global$g;return$g->_db->selectCollection($_GET["select"])->count($Z);}$pf=array("=");}elseif(class_exists('MongoDB\Driver\Manager')){class
  1121. Min_DB{var$extension="MongoDB",$server_info=MONGODB_VERSION,$error,$last_id;var$_link;var$_db,$_db_name;function
  1122. connect($Ei,$sf){$jb='MongoDB\Driver\Manager';return
  1123. new$jb($Ei,$sf);}function
  1124. query($G){return
  1125. false;}function
  1126. select_db($j){$this->_db_name=$j;return
  1127. true;}function
  1128. quote($Q){return$Q;}}class
  1129. Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
  1130. __construct($H){foreach($H
  1131. as$Yd){$J=array();foreach($Yd
  1132. as$y=>$X){if(is_a($X,'MongoDB\BSON\Binary'))$this->_charset[$y]=63;$J[$y]=(is_a($X,'MongoDB\BSON\ObjectID')?'MongoDB\BSON\ObjectID("'.strval($X).'")':(is_a($X,'MongoDB\BSON\UTCDatetime')?$X->toDateTime()->format('Y-m-d H:i:s'):(is_a($X,'MongoDB\BSON\Binary')?$X->bin:(is_a($X,'MongoDB\BSON\Regex')?strval($X):(is_object($X)?json_encode($X,256):$X)))));}$this->_rows[]=$J;foreach($J
  1133. as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=$H->count;}function
  1134. fetch_assoc(){$J=current($this->_rows);if(!$J)return$J;$I=array();foreach($this->_rows[0]as$y=>$X)$I[$y]=$J[$y];next($this->_rows);return$I;}function
  1135. fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
  1136. array_values($I);}function
  1137. fetch_field(){$ee=array_keys($this->_rows[0]);$C=$ee[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}class
  1138. Min_Driver
  1139. extends
  1140. Min_SQL{public$eg="_id";function
  1141. select($R,$L,$Z,$md,$uf=array(),$z=1,$E=0,$gg=false){global$g;$L=($L==array("*")?array():array_fill_keys($L,1));if(count($L)&&!isset($L['_id']))$L['_id']=0;$Z=where_to_query($Z);$oh=array();foreach($uf
  1142. as$X){$X=preg_replace('~ DESC$~','',$X,1,$Cb);$oh[$X]=($Cb?-1:1);}if(isset($_GET['limit'])&&is_numeric($_GET['limit'])&&$_GET['limit']>0)$z=$_GET['limit'];$z=min(200,max(1,(int)$z));$lh=$E*$z;$jb='MongoDB\Driver\Query';$G=new$jb($Z,array('projection'=>$L,'limit'=>$z,'skip'=>$lh,'sort'=>$oh));$Jg=$g->_link->executeQuery("$g->_db_name.$R",$G);return
  1143. new
  1144. Min_Result($Jg);}function
  1145. update($R,$O,$qg,$z=0,$M="\n"){global$g;$l=$g->_db_name;$Z=sql_query_where_parser($qg);$jb='MongoDB\Driver\BulkWrite';$Ya=new$jb(array());if(isset($O['_id']))unset($O['_id']);$Dg=array();foreach($O
  1146. as$y=>$Y){if($Y=='NULL'){$Dg[$y]=1;unset($O[$y]);}}$Di=array('$set'=>$O);if(count($Dg))$Di['$unset']=$Dg;$Ya->update($Z,$Di,array('upsert'=>false));$Jg=$g->_link->executeBulkWrite("$l.$R",$Ya);$g->affected_rows=$Jg->getModifiedCount();return
  1147. true;}function
  1148. delete($R,$qg,$z=0){global$g;$l=$g->_db_name;$Z=sql_query_where_parser($qg);$jb='MongoDB\Driver\BulkWrite';$Ya=new$jb(array());$Ya->delete($Z,array('limit'=>$z));$Jg=$g->_link->executeBulkWrite("$l.$R",$Ya);$g->affected_rows=$Jg->getDeletedCount();return
  1149. true;}function
  1150. insert($R,$O){global$g;$l=$g->_db_name;$jb='MongoDB\Driver\BulkWrite';$Ya=new$jb(array());if(isset($O['_id'])&&empty($O['_id']))unset($O['_id']);$Ya->insert($O);$Jg=$g->_link->executeBulkWrite("$l.$R",$Ya);$g->affected_rows=$Jg->getInsertedCount();return
  1151. true;}}function
  1152. get_databases($Zc){global$g;$I=array();$jb='MongoDB\Driver\Command';$rb=new$jb(array('listDatabases'=>1));$Jg=$g->_link->executeCommand('admin',$rb);foreach($Jg
  1153. as$Pb){foreach($Pb->databases
  1154. as$l)$I[]=$l->name;}return$I;}function
  1155. count_tables($k){$I=array();return$I;}function
  1156. tables_list(){global$g;$jb='MongoDB\Driver\Command';$rb=new$jb(array('listCollections'=>1));$Jg=$g->_link->executeCommand($g->_db_name,$rb);$pb=array();foreach($Jg
  1157. as$H)$pb[$H->name]='table';return$pb;}function
  1158. drop_databases($k){return
  1159. false;}function
  1160. indexes($R,$h=null){global$g;$I=array();$jb='MongoDB\Driver\Command';$rb=new$jb(array('listIndexes'=>$R));$Jg=$g->_link->executeCommand($g->_db_name,$rb);foreach($Jg
  1161. as$v){$Wb=array();$f=array();foreach(get_object_vars($v->key)as$e=>$U){$Wb[]=($U==-1?'1':null);$f[]=$e;}$I[$v->name]=array("type"=>($v->name=="_id_"?"PRIMARY":(isset($v->unique)?"UNIQUE":"INDEX")),"columns"=>$f,"lengths"=>array(),"descs"=>$Wb,);}return$I;}function
  1162. fields($R){$p=fields_from_edit();if(!count($p)){global$m;$H=$m->select($R,array("*"),null,null,array(),10);while($J=$H->fetch_assoc()){foreach($J
  1163. as$y=>$X){$J[$y]=null;$p[$y]=array("field"=>$y,"type"=>"string","null"=>($y!=$m->primary),"auto_increment"=>($y==$m->primary),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1,),);}}}return$p;}function
  1164. found_rows($S,$Z){global$g;$Z=where_to_query($Z);$jb='MongoDB\Driver\Command';$rb=new$jb(array('count'=>$S['Name'],'query'=>$Z));$Jg=$g->_link->executeCommand($g->_db_name,$rb);$gi=$Jg->toArray();return$gi[0]->n;}function
  1165. sql_query_where_parser($qg){$qg=trim(preg_replace('/WHERE[\s]?[(]?\(?/','',$qg));$qg=preg_replace('/\)\)\)$/',')',$qg);$dj=explode(' AND ',$qg);$ej=explode(') OR (',$qg);$Z=array();foreach($dj
  1166. as$bj)$Z[]=trim($bj);if(count($ej)==1)$ej=array();elseif(count($ej)>1)$Z=array();return
  1167. where_to_query($Z,$ej);}function
  1168. where_to_query($Zi=array(),$aj=array()){global$b;$Kb=array();foreach(array('and'=>$Zi,'or'=>$aj)as$U=>$Z){if(is_array($Z)){foreach($Z
  1169. as$Gc){list($mb,$nf,$X)=explode(" ",$Gc,3);if($mb=="_id"){$X=str_replace('MongoDB\BSON\ObjectID("',"",$X);$X=str_replace('")',"",$X);$jb='MongoDB\BSON\ObjectID';$X=new$jb($X);}if(!in_array($nf,$b->operators))continue;if(preg_match('~^\(f\)(.+)~',$nf,$B)){$X=(float)$X;$nf=$B[1];}elseif(preg_match('~^\(date\)(.+)~',$nf,$B)){$Mb=new
  1170. DateTime($X);$jb='MongoDB\BSON\UTCDatetime';$X=new$jb($Mb->getTimestamp()*1000);$nf=$B[1];}switch($nf){case'=':$nf='$eq';break;case'!=':$nf='$ne';break;case'>':$nf='$gt';break;case'<':$nf='$lt';break;case'>=':$nf='$gte';break;case'<=':$nf='$lte';break;case'regex':$nf='$regex';break;default:continue;}if($U=='and')$Kb['$and'][]=array($mb=>array($nf=>$X));elseif($U=='or')$Kb['$or'][]=array($mb=>array($nf=>$X));}}}return$Kb;}$pf=array("=","!=",">","<",">=","<=","regex","(f)=","(f)!=","(f)>","(f)<","(f)>=","(f)<=","(date)=","(date)!=","(date)>","(date)<","(date)>=","(date)<=",);}function
  1171. table($u){return$u;}function
  1172. idf_escape($u){return$u;}function
  1173. table_status($C="",$Nc=false){$I=array();foreach(tables_list()as$R=>$U){$I[$R]=array("Name"=>$R);if($C==$R)return$I[$R];}return$I;}function
  1174. create_database($l,$d){return
  1175. true;}function
  1176. last_id(){global$g;return$g->last_id;}function
  1177. error(){global$g;return
  1178. h($g->error);}function
  1179. collations(){return
  1180. array();}function
  1181. logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
  1182. connect(){global$b;$g=new
  1183. Min_DB;list($N,$V,$F)=$b->credentials();$sf=array();if($V.$F!=""){$sf["username"]=$V;$sf["password"]=$F;}$l=$b->database();if($l!="")$sf["db"]=$l;try{$g->_link=$g->connect("mongodb://$N",$sf);if($F!=""){$sf["password"]="";try{$g->connect("mongodb://$N",$sf);return'Database does not support password.';}catch(Exception$_c){}}return$g;}catch(Exception$_c){return$_c->getMessage();}}function
  1184. alter_indexes($R,$c){global$g;foreach($c
  1185. as$X){list($U,$C,$O)=$X;if($O=="DROP")$I=$g->_db->command(array("deleteIndexes"=>$R,"index"=>$C));else{$f=array();foreach($O
  1186. as$e){$e=preg_replace('~ DESC$~','',$e,1,$Cb);$f[$e]=($Cb?-1:1);}$I=$g->_db->selectCollection($R)->ensureIndex($f,array("unique"=>($U=="UNIQUE"),"name"=>$C,));}if($I['errmsg']){$g->error=$I['errmsg'];return
  1187. false;}}return
  1188. true;}function
  1189. support($Oc){return
  1190. preg_match("~database|indexes~",$Oc);}function
  1191. db_collation($l,$ob){}function
  1192. information_schema(){}function
  1193. is_view($S){}function
  1194. convert_field($o){}function
  1195. unconvert_field($o,$I){return$I;}function
  1196. foreign_keys($R){return
  1197. array();}function
  1198. fk_support($S){}function
  1199. engines(){return
  1200. array();}function
  1201. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){global$g;if($R==""){$g->_db->createCollection($C);return
  1202. true;}}function
  1203. drop_tables($T){global$g;foreach($T
  1204. as$R){$Gg=$g->_db->selectCollection($R)->drop();if(!$Gg['ok'])return
  1205. false;}return
  1206. true;}function
  1207. truncate_tables($T){global$g;foreach($T
  1208. as$R){$Gg=$g->_db->selectCollection($R)->remove();if(!$Gg['ok'])return
  1209. false;}return
  1210. true;}$x="mongo";$jd=array();$pd=array();$lc=array(array("json"));}$dc["elastic"]="Elasticsearch (beta)";if(isset($_GET["elastic"])){$bg=array("json + allow_url_fopen");define("DRIVER","elastic");if(function_exists('json_decode')&&ini_bool('allow_url_fopen')){class
  1211. Min_DB{var$extension="JSON",$server_info,$errno,$error,$_url;function
  1212. rootQuery($Sf,$yb=array(),$Ne='GET'){@ini_set('track_errors',1);$Sc=@file_get_contents("$this->_url/".ltrim($Sf,'/'),false,stream_context_create(array('http'=>array('method'=>$Ne,'content'=>$yb===null?$yb:json_encode($yb),'header'=>'Content-Type: application/json','ignore_errors'=>1,))));if(!$Sc){$this->error=$php_errormsg;return$Sc;}if(!preg_match('~^HTTP/[0-9.]+ 2~i',$http_response_header[0])){$this->error=$Sc;return
  1213. false;}$I=json_decode($Sc,true);if($I===null){$this->errno=json_last_error();if(function_exists('json_last_error_msg'))$this->error=json_last_error_msg();else{$xb=get_defined_constants(true);foreach($xb['json']as$C=>$Y){if($Y==$this->errno&&preg_match('~^JSON_ERROR_~',$C)){$this->error=$C;break;}}}}return$I;}function
  1214. query($Sf,$yb=array(),$Ne='GET'){return$this->rootQuery(($this->_db!=""?"$this->_db/":"/").ltrim($Sf,'/'),$yb,$Ne);}function
  1215. connect($N,$V,$F){preg_match('~^(https?://)?(.*)~',$N,$B);$this->_url=($B[1]?$B[1]:"http://")."$V:$F@$B[2]";$I=$this->query('');if($I)$this->server_info=$I['version']['number'];return(bool)$I;}function
  1216. select_db($j){$this->_db=$j;return
  1217. true;}function
  1218. quote($Q){return$Q;}}class
  1219. Min_Result{var$num_rows,$_rows;function
  1220. __construct($K){$this->num_rows=count($this->_rows);$this->_rows=$K;reset($this->_rows);}function
  1221. fetch_assoc(){$I=current($this->_rows);next($this->_rows);return$I;}function
  1222. fetch_row(){return
  1223. array_values($this->fetch_assoc());}}}class
  1224. Min_Driver
  1225. extends
  1226. Min_SQL{function
  1227. select($R,$L,$Z,$md,$uf=array(),$z=1,$E=0,$gg=false){global$b;$Kb=array();$G="$R/_search";if($L!=array("*"))$Kb["fields"]=$L;if($uf){$oh=array();foreach($uf
  1228. as$mb){$mb=preg_replace('~ DESC$~','',$mb,1,$Cb);$oh[]=($Cb?array($mb=>"desc"):$mb);}$Kb["sort"]=$oh;}if($z){$Kb["size"]=+$z;if($E)$Kb["from"]=($E*$z);}foreach($Z
  1229. as$X){list($mb,$nf,$X)=explode(" ",$X,3);if($mb=="_id")$Kb["query"]["ids"]["values"][]=$X;elseif($mb.$X!=""){$Th=array("term"=>array(($mb!=""?$mb:"_all")=>$X));if($nf=="=")$Kb["query"]["filtered"]["filter"]["and"][]=$Th;else$Kb["query"]["filtered"]["query"]["bool"]["must"][]=$Th;}}if($Kb["query"]&&!$Kb["query"]["filtered"]["query"]&&!$Kb["query"]["ids"])$Kb["query"]["filtered"]["query"]=array("match_all"=>array());$xh=microtime(true);$Wg=$this->_conn->query($G,$Kb);if($gg)echo$b->selectQuery("$G: ".print_r($Kb,true),$xh,!$Wg);if(!$Wg)return
  1230. false;$I=array();foreach($Wg['hits']['hits']as$zd){$J=array();if($L==array("*"))$J["_id"]=$zd["_id"];$p=$zd['_source'];if($L!=array("*")){$p=array();foreach($L
  1231. as$y)$p[$y]=$zd['fields'][$y];}foreach($p
  1232. as$y=>$X){if($Kb["fields"])$X=$X[0];$J[$y]=(is_array($X)?json_encode($X):$X);}$I[]=$J;}return
  1233. new
  1234. Min_Result($I);}function
  1235. update($U,$vg,$qg,$z=0,$M="\n"){$Qf=preg_split('~ *= *~',$qg);if(count($Qf)==2){$t=trim($Qf[1]);$G="$U/$t";return$this->_conn->query($G,$vg,'POST');}return
  1236. false;}function
  1237. insert($U,$vg){$t="";$G="$U/$t";$Gg=$this->_conn->query($G,$vg,'POST');$this->_conn->last_id=$Gg['_id'];return$Gg['created'];}function
  1238. delete($U,$qg,$z=0){$Cd=array();if(is_array($_GET["where"])&&$_GET["where"]["_id"])$Cd[]=$_GET["where"]["_id"];if(is_array($_POST['check'])){foreach($_POST['check']as$cb){$Qf=preg_split('~ *= *~',$cb);if(count($Qf)==2)$Cd[]=trim($Qf[1]);}}$this->_conn->affected_rows=0;foreach($Cd
  1239. as$t){$G="{$U}/{$t}";$Gg=$this->_conn->query($G,'{}','DELETE');if(is_array($Gg)&&$Gg['found']==true)$this->_conn->affected_rows++;}return$this->_conn->affected_rows;}}function
  1240. connect(){global$b;$g=new
  1241. Min_DB;list($N,$V,$F)=$b->credentials();if($F!=""&&$g->connect($N,$V,""))return'Database does not support password.';if($g->connect($N,$V,$F))return$g;return$g->error;}function
  1242. support($Oc){return
  1243. preg_match("~database|table|columns~",$Oc);}function
  1244. logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
  1245. get_databases(){global$g;$I=$g->rootQuery('_aliases');if($I){$I=array_keys($I);sort($I,SORT_STRING);}return$I;}function
  1246. collations(){return
  1247. array();}function
  1248. db_collation($l,$ob){}function
  1249. engines(){return
  1250. array();}function
  1251. count_tables($k){global$g;$I=array();$H=$g->query('_stats');if($H&&$H['indices']){$Jd=$H['indices'];foreach($Jd
  1252. as$Id=>$yh){$Hd=$yh['total']['indexing'];$I[$Id]=$Hd['index_total'];}}return$I;}function
  1253. tables_list(){global$g;$I=$g->query('_mapping');if($I)$I=array_fill_keys(array_keys($I[$g->_db]["mappings"]),'table');return$I;}function
  1254. table_status($C="",$Nc=false){global$g;$Wg=$g->query("_search",array("size"=>0,"aggregations"=>array("count_by_type"=>array("terms"=>array("field"=>"_type")))),"POST");$I=array();if($Wg){$T=$Wg["aggregations"]["count_by_type"]["buckets"];foreach($T
  1255. as$R){$I[$R["key"]]=array("Name"=>$R["key"],"Engine"=>"table","Rows"=>$R["doc_count"],);if($C!=""&&$C==$R["key"])return$I[$C];}}return$I;}function
  1256. error(){global$g;return
  1257. h($g->error);}function
  1258. information_schema(){}function
  1259. is_view($S){}function
  1260. indexes($R,$h=null){return
  1261. array(array("type"=>"PRIMARY","columns"=>array("_id")),);}function
  1262. fields($R){global$g;$H=$g->query("$R/_mapping");$I=array();if($H){$we=$H[$R]['properties'];if(!$we)$we=$H[$g->_db]['mappings'][$R]['properties'];if($we){foreach($we
  1263. as$C=>$o){$I[$C]=array("field"=>$C,"full_type"=>$o["type"],"type"=>$o["type"],"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),);if($o["properties"]){unset($I[$C]["privileges"]["insert"]);unset($I[$C]["privileges"]["update"]);}}}}return$I;}function
  1264. foreign_keys($R){return
  1265. array();}function
  1266. table($u){return$u;}function
  1267. idf_escape($u){return$u;}function
  1268. convert_field($o){}function
  1269. unconvert_field($o,$I){return$I;}function
  1270. fk_support($S){}function
  1271. found_rows($S,$Z){return
  1272. null;}function
  1273. create_database($l){global$g;return$g->rootQuery(urlencode($l),null,'PUT');}function
  1274. drop_databases($k){global$g;return$g->rootQuery(urlencode(implode(',',$k)),array(),'DELETE');}function
  1275. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){global$g;$mg=array();foreach($p
  1276. as$Lc){$Qc=trim($Lc[1][0]);$Rc=trim($Lc[1][1]?$Lc[1][1]:"text");$mg[$Qc]=array('type'=>$Rc);}if(!empty($mg))$mg=array('properties'=>$mg);return$g->query("_mapping/{$C}",$mg,'PUT');}function
  1277. drop_tables($T){global$g;$I=true;foreach($T
  1278. as$R)$I=$I&&$g->query(urlencode($R),array(),'DELETE');return$I;}function
  1279. last_id(){global$g;return$g->last_id;}$x="elastic";$pf=array("=","query");$jd=array();$pd=array();$lc=array(array("json"));$wi=array();$Ah=array();foreach(array('Numbers'=>array("long"=>3,"integer"=>5,"short"=>8,"byte"=>10,"double"=>20,"float"=>66,"half_float"=>12,"scaled_float"=>21),'Date and time'=>array("date"=>10),'Strings'=>array("string"=>65535,"text"=>65535),'Binary'=>array("binary"=>255),)as$y=>$X){$wi+=$X;$Ah[$y]=array_keys($X);}}$dc=array("server"=>"MySQL")+$dc;if(!defined("DRIVER")){$bg=array("MySQLi","MySQL","PDO_MySQL");define("DRIVER","server");if(extension_loaded("mysqli")){class
  1280. Min_DB
  1281. extends
  1282. MySQLi{var$extension="MySQLi";function
  1283. __construct(){parent::init();}function
  1284. connect($N="",$V="",$F="",$j=null,$Xf=null,$nh=null){global$b;mysqli_report(MYSQLI_REPORT_OFF);list($_d,$Xf)=explode(":",$N,2);$wh=$b->connectSsl();if($wh)$this->ssl_set($wh['key'],$wh['cert'],$wh['ca'],'','');$I=@$this->real_connect(($N!=""?$_d:ini_get("mysqli.default_host")),($N.$V!=""?$V:ini_get("mysqli.default_user")),($N.$V.$F!=""?$F:ini_get("mysqli.default_pw")),$j,(is_numeric($Xf)?$Xf:ini_get("mysqli.default_port")),(!is_numeric($Xf)?$Xf:$nh),($wh?64:0));$this->options(MYSQLI_OPT_LOCAL_INFILE,false);return$I;}function
  1285. set_charset($bb){if(parent::set_charset($bb))return
  1286. true;parent::set_charset('utf8');return$this->query("SET NAMES $bb");}function
  1287. result($G,$o=0){$H=$this->query($G);if(!$H)return
  1288. false;$J=$H->fetch_array();return$J[$o];}function
  1289. quote($Q){return"'".$this->escape_string($Q)."'";}}}elseif(extension_loaded("mysql")&&!((ini_bool("sql.safe_mode")||ini_bool("mysql.allow_local_infile"))&&extension_loaded("pdo_mysql"))){class
  1290. Min_DB{var$extension="MySQL",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
  1291. connect($N,$V,$F){if(ini_bool("mysql.allow_local_infile")){$this->error=sprintf('Disable %s or enable %s or %s extensions.',"'mysql.allow_local_infile'","MySQLi","PDO_MySQL");return
  1292. false;}$this->_link=@mysql_connect(($N!=""?$N:ini_get("mysql.default_host")),("$N$V"!=""?$V:ini_get("mysql.default_user")),("$N$V$F"!=""?$F: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
  1293. set_charset($bb){if(function_exists('mysql_set_charset')){if(mysql_set_charset($bb,$this->_link))return
  1294. true;mysql_set_charset('utf8',$this->_link);}return$this->query("SET NAMES $bb");}function
  1295. quote($Q){return"'".mysql_real_escape_string($Q,$this->_link)."'";}function
  1296. select_db($j){return
  1297. mysql_select_db($j,$this->_link);}function
  1298. query($G,$xi=false){$H=@($xi?mysql_unbuffered_query($G,$this->_link):mysql_query($G,$this->_link));$this->error="";if(!$H){$this->errno=mysql_errno($this->_link);$this->error=mysql_error($this->_link);return
  1299. false;}if($H===true){$this->affected_rows=mysql_affected_rows($this->_link);$this->info=mysql_info($this->_link);return
  1300. true;}return
  1301. new
  1302. Min_Result($H);}function
  1303. multi_query($G){return$this->_result=$this->query($G);}function
  1304. store_result(){return$this->_result;}function
  1305. next_result(){return
  1306. false;}function
  1307. result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
  1308. false;return
  1309. mysql_result($H->_result,0,$o);}}class
  1310. Min_Result{var$num_rows,$_result,$_offset=0;function
  1311. __construct($H){$this->_result=$H;$this->num_rows=mysql_num_rows($H);}function
  1312. fetch_assoc(){return
  1313. mysql_fetch_assoc($this->_result);}function
  1314. fetch_row(){return
  1315. mysql_fetch_row($this->_result);}function
  1316. fetch_field(){$I=mysql_fetch_field($this->_result,$this->_offset++);$I->orgtable=$I->table;$I->orgname=$I->name;$I->charsetnr=($I->blob?63:0);return$I;}function
  1317. __destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
  1318. Min_DB
  1319. extends
  1320. Min_PDO{var$extension="PDO_MySQL";function
  1321. connect($N,$V,$F){global$b;$sf=array(PDO::MYSQL_ATTR_LOCAL_INFILE=>false);$wh=$b->connectSsl();if($wh)$sf+=array(PDO::MYSQL_ATTR_SSL_KEY=>$wh['key'],PDO::MYSQL_ATTR_SSL_CERT=>$wh['cert'],PDO::MYSQL_ATTR_SSL_CA=>$wh['ca'],);$this->dsn("mysql:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\d)~',';port=\1',$N)),$V,$F,$sf);return
  1322. true;}function
  1323. set_charset($bb){$this->query("SET NAMES $bb");}function
  1324. select_db($j){return$this->query("USE ".idf_escape($j));}function
  1325. query($G,$xi=false){$this->setAttribute(1000,!$xi);return
  1326. parent::query($G,$xi);}}}class
  1327. Min_Driver
  1328. extends
  1329. Min_SQL{function
  1330. insert($R,$O){return($O?parent::insert($R,$O):queries("INSERT INTO ".table($R)." ()\nVALUES ()"));}function
  1331. insertUpdate($R,$K,$eg){$f=array_keys(reset($K));$cg="INSERT INTO ".table($R)." (".implode(", ",$f).") VALUES\n";$Oi=array();foreach($f
  1332. as$y)$Oi[$y]="$y = VALUES($y)";$Dh="\nON DUPLICATE KEY UPDATE ".implode(", ",$Oi);$Oi=array();$qe=0;foreach($K
  1333. as$O){$Y="(".implode(", ",$O).")";if($Oi&&(strlen($cg)+$qe+strlen($Y)+strlen($Dh)>1e6)){if(!queries($cg.implode(",\n",$Oi).$Dh))return
  1334. false;$Oi=array();$qe=0;}$Oi[]=$Y;$qe+=strlen($Y)+2;}return
  1335. queries($cg.implode(",\n",$Oi).$Dh);}function
  1336. slowQuery($G,$Yh){if(min_version('5.7.8','10.1.2')){if(preg_match('~MariaDB~',$this->_conn->server_info))return"SET STATEMENT max_statement_time=$Yh FOR $G";elseif(preg_match('~^(SELECT\b)(.+)~is',$G,$B))return"$B[1] /*+ MAX_EXECUTION_TIME(".($Yh*1000).") */ $B[2]";}}function
  1337. convertSearch($u,$X,$o){return(preg_match('~char|text|enum|set~',$o["type"])&&!preg_match("~^utf8~",$o["collation"])&&preg_match('~[\x80-\xFF]~',$X['val'])?"CONVERT($u USING ".charset($this->_conn).")":$u);}function
  1338. warnings(){$H=$this->_conn->query("SHOW WARNINGS");if($H&&$H->num_rows){ob_start();select($H);return
  1339. ob_get_clean();}}function
  1340. tableHelp($C){$xe=preg_match('~MariaDB~',$this->_conn->server_info);if(information_schema(DB))return
  1341. strtolower(($xe?"information-schema-$C-table/":str_replace("_","-",$C)."-table.html"));if(DB=="mysql")return($xe?"mysql$C-table/":"system-database.html");}}function
  1342. idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
  1343. table($u){return
  1344. idf_escape($u);}function
  1345. connect(){global$b,$wi,$Ah;$g=new
  1346. Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2])){$g->set_charset(charset($g));$g->query("SET sql_quote_show_create = 1, autocommit = 1");if(min_version('5.7.8',10.2,$g)){$Ah['Strings'][]="json";$wi["json"]=4294967295;}return$g;}$I=$g->error;if(function_exists('iconv')&&!is_utf8($I)&&strlen($Sg=iconv("windows-1250","utf-8",$I))>strlen($I))$I=$Sg;return$I;}function
  1347. get_databases($Zc){$I=get_session("dbs");if($I===null){$G=(min_version(5)?"SELECT SCHEMA_NAME FROM information_schema.SCHEMATA ORDER BY SCHEMA_NAME":"SHOW DATABASES");$I=($Zc?slow_query($G):get_vals($G));restart_session();set_session("dbs",$I);stop_session();}return$I;}function
  1348. limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
  1349. limit1($R,$G,$Z,$M="\n"){return
  1350. limit($G,$Z,1,0,$M);}function
  1351. db_collation($l,$ob){global$g;$I=null;$i=$g->result("SHOW CREATE DATABASE ".idf_escape($l),1);if(preg_match('~ COLLATE ([^ ]+)~',$i,$B))$I=$B[1];elseif(preg_match('~ CHARACTER SET ([^ ]+)~',$i,$B))$I=$ob[$B[1]][-1];return$I;}function
  1352. engines(){$I=array();foreach(get_rows("SHOW ENGINES")as$J){if(preg_match("~YES|DEFAULT~",$J["Support"]))$I[]=$J["Engine"];}return$I;}function
  1353. logged_user(){global$g;return$g->result("SELECT USER()");}function
  1354. tables_list(){return
  1355. get_key_vals(min_version(5)?"SELECT TABLE_NAME, TABLE_TYPE FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ORDER BY TABLE_NAME":"SHOW TABLES");}function
  1356. count_tables($k){$I=array();foreach($k
  1357. as$l)$I[$l]=count(get_vals("SHOW TABLES IN ".idf_escape($l)));return$I;}function
  1358. table_status($C="",$Nc=false){$I=array();foreach(get_rows($Nc&&min_version(5)?"SELECT TABLE_NAME AS Name, ENGINE AS Engine, TABLE_COMMENT AS Comment FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ".($C!=""?"AND TABLE_NAME = ".q($C):"ORDER BY Name"):"SHOW TABLE STATUS".($C!=""?" LIKE ".q(addcslashes($C,"%_\\")):""))as$J){if($J["Engine"]=="InnoDB")$J["Comment"]=preg_replace('~(?:(.+); )?InnoDB free: .*~','\1',$J["Comment"]);if(!isset($J["Engine"]))$J["Comment"]="";if($C!="")return$J;$I[$J["Name"]]=$J;}return$I;}function
  1359. is_view($S){return$S["Engine"]===null;}function
  1360. fk_support($S){return
  1361. preg_match('~InnoDB|IBMDB2I~i',$S["Engine"])||(preg_match('~NDB~i',$S["Engine"])&&min_version(5.6));}function
  1362. fields($R){$I=array();foreach(get_rows("SHOW FULL COLUMNS FROM ".table($R))as$J){preg_match('~^([^( ]+)(?:\((.+)\))?( unsigned)?( zerofill)?$~',$J["Type"],$B);$I[$J["Field"]]=array("field"=>$J["Field"],"full_type"=>$J["Type"],"type"=>$B[1],"length"=>$B[2],"unsigned"=>ltrim($B[3].$B[4]),"default"=>($J["Default"]!=""||preg_match("~char|set~",$B[1])?$J["Default"]:null),"null"=>($J["Null"]=="YES"),"auto_increment"=>($J["Extra"]=="auto_increment"),"on_update"=>(preg_match('~^on update (.+)~i',$J["Extra"],$B)?$B[1]:""),"collation"=>$J["Collation"],"privileges"=>array_flip(preg_split('~, *~',$J["Privileges"])),"comment"=>$J["Comment"],"primary"=>($J["Key"]=="PRI"),);}return$I;}function
  1363. indexes($R,$h=null){$I=array();foreach(get_rows("SHOW INDEX FROM ".table($R),$h)as$J){$C=$J["Key_name"];$I[$C]["type"]=($C=="PRIMARY"?"PRIMARY":($J["Index_type"]=="FULLTEXT"?"FULLTEXT":($J["Non_unique"]?($J["Index_type"]=="SPATIAL"?"SPATIAL":"INDEX"):"UNIQUE")));$I[$C]["columns"][]=$J["Column_name"];$I[$C]["lengths"][]=($J["Index_type"]=="SPATIAL"?null:$J["Sub_part"]);$I[$C]["descs"][]=null;}return$I;}function
  1364. foreign_keys($R){global$g,$kf;static$Uf='`(?:[^`]|``)+`';$I=array();$Db=$g->result("SHOW CREATE TABLE ".table($R),1);if($Db){preg_match_all("~CONSTRAINT ($Uf) FOREIGN KEY ?\\(((?:$Uf,? ?)+)\\) REFERENCES ($Uf)(?:\\.($Uf))? \\(((?:$Uf,? ?)+)\\)(?: ON DELETE ($kf))?(?: ON UPDATE ($kf))?~",$Db,$_e,PREG_SET_ORDER);foreach($_e
  1365. as$B){preg_match_all("~$Uf~",$B[2],$ph);preg_match_all("~$Uf~",$B[5],$Qh);$I[idf_unescape($B[1])]=array("db"=>idf_unescape($B[4]!=""?$B[3]:$B[4]),"table"=>idf_unescape($B[4]!=""?$B[4]:$B[3]),"source"=>array_map('idf_unescape',$ph[0]),"target"=>array_map('idf_unescape',$Qh[0]),"on_delete"=>($B[6]?$B[6]:"RESTRICT"),"on_update"=>($B[7]?$B[7]:"RESTRICT"),);}}return$I;}function
  1366. view($C){global$g;return
  1367. array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)*\s+AS\s+~isU','',$g->result("SHOW CREATE VIEW ".table($C),1)));}function
  1368. collations(){$I=array();foreach(get_rows("SHOW COLLATION")as$J){if($J["Default"])$I[$J["Charset"]][-1]=$J["Collation"];else$I[$J["Charset"]][]=$J["Collation"];}ksort($I);foreach($I
  1369. as$y=>$X)asort($I[$y]);return$I;}function
  1370. information_schema($l){return(min_version(5)&&$l=="information_schema")||(min_version(5.5)&&$l=="performance_schema");}function
  1371. error(){global$g;return
  1372. h(preg_replace('~^You have an error.*syntax to use~U',"Syntax error",$g->error));}function
  1373. create_database($l,$d){return
  1374. queries("CREATE DATABASE ".idf_escape($l).($d?" COLLATE ".q($d):""));}function
  1375. drop_databases($k){$I=apply_queries("DROP DATABASE",$k,'idf_escape');restart_session();set_session("dbs",null);return$I;}function
  1376. rename_database($C,$d){$I=false;if(create_database($C,$d)){$Eg=array();foreach(tables_list()as$R=>$U)$Eg[]=table($R)." TO ".idf_escape($C).".".table($R);$I=(!$Eg||queries("RENAME TABLE ".implode(", ",$Eg)));if($I)queries("DROP DATABASE ".idf_escape(DB));restart_session();set_session("dbs",null);}return$I;}function
  1377. auto_increment(){$Ma=" PRIMARY KEY";if($_GET["create"]!=""&&$_POST["auto_increment_col"]){foreach(indexes($_GET["create"])as$v){if(in_array($_POST["fields"][$_POST["auto_increment_col"]]["orig"],$v["columns"],true)){$Ma="";break;}if($v["type"]=="PRIMARY")$Ma=" UNIQUE";}}return" AUTO_INCREMENT$Ma";}function
  1378. alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();foreach($p
  1379. as$o)$c[]=($o[1]?($R!=""?($o[0]!=""?"CHANGE ".idf_escape($o[0]):"ADD"):" ")." ".implode($o[1]).($R!=""?$o[2]:""):"DROP ".idf_escape($o[0]));$c=array_merge($c,$bd);$P=($tb!==null?" COMMENT=".q($tb):"").($tc?" ENGINE=".q($tc):"").($d?" COLLATE ".q($d):"").($La!=""?" AUTO_INCREMENT=$La":"");if($R=="")return
  1380. queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)$P$Of");if($R!=$C)$c[]="RENAME TO ".table($C);if($P)$c[]=ltrim($P);return($c||$Of?queries("ALTER TABLE ".table($R)."\n".implode(",\n",$c).$Of):true);}function
  1381. alter_indexes($R,$c){foreach($c
  1382. as$y=>$X)$c[$y]=($X[2]=="DROP"?"\nDROP INDEX ".idf_escape($X[1]):"\nADD $X[0] ".($X[0]=="PRIMARY"?"KEY ":"").($X[1]!=""?idf_escape($X[1])." ":"")."(".implode(", ",$X[2]).")");return
  1383. queries("ALTER TABLE ".table($R).implode(",",$c));}function
  1384. truncate_tables($T){return
  1385. apply_queries("TRUNCATE TABLE",$T);}function
  1386. drop_views($Ti){return
  1387. queries("DROP VIEW ".implode(", ",array_map('table',$Ti)));}function
  1388. drop_tables($T){return
  1389. queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
  1390. move_tables($T,$Ti,$Qh){$Eg=array();foreach(array_merge($T,$Ti)as$R)$Eg[]=table($R)." TO ".idf_escape($Qh).".".table($R);return
  1391. queries("RENAME TABLE ".implode(", ",$Eg));}function
  1392. copy_tables($T,$Ti,$Qh){queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");foreach($T
  1393. as$R){$C=($Qh==DB?table("copy_$R"):idf_escape($Qh).".".table($R));if(!queries("\nDROP TABLE IF EXISTS $C")||!queries("CREATE TABLE $C LIKE ".table($R))||!queries("INSERT INTO $C SELECT * FROM ".table($R)))return
  1394. false;foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($R,"%_\\")))as$J){$qi=$J["Trigger"];if(!queries("CREATE TRIGGER ".($Qh==DB?idf_escape("copy_$qi"):idf_escape($Qh).".".idf_escape($qi))." $J[Timing] $J[Event] ON $C FOR EACH ROW\n$J[Statement];"))return
  1395. false;}}foreach($Ti
  1396. as$R){$C=($Qh==DB?table("copy_$R"):idf_escape($Qh).".".table($R));$Si=view($R);if(!queries("DROP VIEW IF EXISTS $C")||!queries("CREATE VIEW $C AS $Si[select]"))return
  1397. false;}return
  1398. true;}function
  1399. trigger($C){if($C=="")return
  1400. array();$K=get_rows("SHOW TRIGGERS WHERE `Trigger` = ".q($C));return
  1401. reset($K);}function
  1402. triggers($R){$I=array();foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($R,"%_\\")))as$J)$I[$J["Trigger"]]=array($J["Timing"],$J["Event"]);return$I;}function
  1403. trigger_options(){return
  1404. array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
  1405. routine($C,$U){global$g,$vc,$Od,$wi;$Ca=array("bool","boolean","integer","double precision","real","dec","numeric","fixed","national char","national varchar");$qh="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$vi="((".implode("|",array_merge(array_keys($wi),$Ca)).")\\b(?:\\s*\\(((?:[^'\")]|$vc)++)\\))?\\s*(zerofill\\s*)?(unsigned(?:\\s+zerofill)?)?)(?:\\s*(?:CHARSET|CHARACTER\\s+SET)\\s*['\"]?([^'\"\\s,]+)['\"]?)?";$Uf="$qh*(".($U=="FUNCTION"?"":$Od).")?\\s*(?:`((?:[^`]|``)*)`\\s*|\\b(\\S+)\\s+)$vi";$i=$g->result("SHOW CREATE $U ".idf_escape($C),2);preg_match("~\\(((?:$Uf\\s*,?)*)\\)\\s*".($U=="FUNCTION"?"RETURNS\\s+$vi\\s+":"")."(.*)~is",$i,$B);$p=array();preg_match_all("~$Uf\\s*,?~is",$B[1],$_e,PREG_SET_ORDER);foreach($_e
  1406. as$Hf){$C=str_replace("``","`",$Hf[2]).$Hf[3];$p[]=array("field"=>$C,"type"=>strtolower($Hf[5]),"length"=>preg_replace_callback("~$vc~s",'normalize_enum',$Hf[6]),"unsigned"=>strtolower(preg_replace('~\s+~',' ',trim("$Hf[8] $Hf[7]"))),"null"=>1,"full_type"=>$Hf[4],"inout"=>strtoupper($Hf[1]),"collation"=>strtolower($Hf[9]),);}if($U!="FUNCTION")return
  1407. array("fields"=>$p,"definition"=>$B[11]);return
  1408. array("fields"=>$p,"returns"=>array("type"=>$B[12],"length"=>$B[13],"unsigned"=>$B[15],"collation"=>$B[16]),"definition"=>$B[17],"language"=>"SQL",);}function
  1409. routines(){return
  1410. get_rows("SELECT ROUTINE_NAME AS SPECIFIC_NAME, ROUTINE_NAME, ROUTINE_TYPE, DTD_IDENTIFIER FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".q(DB));}function
  1411. routine_languages(){return
  1412. array();}function
  1413. routine_id($C,$J){return
  1414. idf_escape($C);}function
  1415. last_id(){global$g;return$g->result("SELECT LAST_INSERT_ID()");}function
  1416. explain($g,$G){return$g->query("EXPLAIN ".(min_version(5.1)?"PARTITIONS ":"").$G);}function
  1417. found_rows($S,$Z){return($Z||$S["Engine"]!="InnoDB"?null:$S["Rows"]);}function
  1418. types(){return
  1419. array();}function
  1420. schemas(){return
  1421. array();}function
  1422. get_schema(){return"";}function
  1423. set_schema($Ug){return
  1424. true;}function
  1425. create_sql($R,$La,$Bh){global$g;$I=$g->result("SHOW CREATE TABLE ".table($R),1);if(!$La)$I=preg_replace('~ AUTO_INCREMENT=\d+~','',$I);return$I;}function
  1426. truncate_sql($R){return"TRUNCATE ".table($R);}function
  1427. use_sql($j){return"USE ".idf_escape($j);}function
  1428. trigger_sql($R){$I="";foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($R,"%_\\")),null,"-- ")as$J)$I.="\nCREATE TRIGGER ".idf_escape($J["Trigger"])." $J[Timing] $J[Event] ON ".table($J["Table"])." FOR EACH ROW\n$J[Statement];;\n";return$I;}function
  1429. show_variables(){return
  1430. get_key_vals("SHOW VARIABLES");}function
  1431. process_list(){return
  1432. get_rows("SHOW FULL PROCESSLIST");}function
  1433. show_status(){return
  1434. get_key_vals("SHOW STATUS");}function
  1435. convert_field($o){if(preg_match("~binary~",$o["type"]))return"HEX(".idf_escape($o["field"]).")";if($o["type"]=="bit")return"BIN(".idf_escape($o["field"])." + 0)";if(preg_match("~geometry|point|linestring|polygon~",$o["type"]))return(min_version(8)?"ST_":"")."AsWKT(".idf_escape($o["field"]).")";}function
  1436. unconvert_field($o,$I){if(preg_match("~binary~",$o["type"]))$I="UNHEX($I)";if($o["type"]=="bit")$I="CONV($I, 2, 10) + 0";if(preg_match("~geometry|point|linestring|polygon~",$o["type"]))$I=(min_version(8)?"ST_":"")."GeomFromText($I)";return$I;}function
  1437. support($Oc){return!preg_match("~scheme|sequence|type|view_trigger|materializedview".(min_version(5.1)?"":"|event|partitioning".(min_version(5)?"":"|routine|trigger|view"))."~",$Oc);}function
  1438. kill_process($X){return
  1439. queries("KILL ".number($X));}function
  1440. connection_id(){return"SELECT CONNECTION_ID()";}function
  1441. max_connections(){global$g;return$g->result("SELECT @@max_connections");}$x="sql";$wi=array();$Ah=array();foreach(array('Numbers'=>array("tinyint"=>3,"smallint"=>5,"mediumint"=>8,"int"=>10,"bigint"=>20,"decimal"=>66,"float"=>12,"double"=>21),'Date and time'=>array("date"=>10,"datetime"=>19,"timestamp"=>19,"time"=>10,"year"=>4),'Strings'=>array("char"=>255,"varchar"=>65535,"tinytext"=>255,"text"=>65535,"mediumtext"=>16777215,"longtext"=>4294967295),'Lists'=>array("enum"=>65535,"set"=>64),'Binary'=>array("bit"=>20,"binary"=>255,"varbinary"=>65535,"tinyblob"=>255,"blob"=>65535,"mediumblob"=>16777215,"longblob"=>4294967295),'Geometry'=>array("geometry"=>0,"point"=>0,"linestring"=>0,"polygon"=>0,"multipoint"=>0,"multilinestring"=>0,"multipolygon"=>0,"geometrycollection"=>0),)as$y=>$X){$wi+=$X;$Ah[$y]=array_keys($X);}$Ci=array("unsigned","zerofill","unsigned zerofill");$pf=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","REGEXP","IN","FIND_IN_SET","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$jd=array("char_length","date","from_unixtime","lower","round","floor","ceil","sec_to_time","time_to_sec","upper");$pd=array("avg","count","count distinct","group_concat","max","min","sum");$lc=array(array("char"=>"md5/sha1/password/encrypt/uuid","binary"=>"md5/sha1","date|time"=>"now",),array(number_type()=>"+/-","date"=>"+ interval/- interval","time"=>"addtime/subtime","char|text"=>"concat",));}define("SERVER",$_GET[DRIVER]);define("DB",$_GET["db"]);define("ME",preg_replace('~^[^?]*/([^?]*).*~','\1',$_SERVER["REQUEST_URI"]).'?'.(sid()?SID.'&':'').(SERVER!==null?DRIVER."=".urlencode(SERVER).'&':'').(isset($_GET["username"])?"username=".urlencode($_GET["username"]).'&':'').(DB!=""?'db='.urlencode(DB).'&'.(isset($_GET["ns"])?"ns=".urlencode($_GET["ns"])."&":""):''));$ia="4.6.3";class
  1442. Adminer{var$operators;function
  1443. name(){return"<a href='https://www.adminer.org/'".target_blank()." id='h1'>Adminer</a>";}function
  1444. credentials(){return
  1445. array(SERVER,$_GET["username"],get_password());}function
  1446. connectSsl(){}function
  1447. permanentLogin($i=false){return
  1448. password_file($i);}function
  1449. bruteForceKey(){return$_SERVER["REMOTE_ADDR"];}function
  1450. serverName($N){return
  1451. h($N);}function
  1452. database(){return
  1453. DB;}function
  1454. databases($Zc=true){return
  1455. get_databases($Zc);}function
  1456. schemas(){return
  1457. schemas();}function
  1458. queryTimeout(){return
  1459. 2;}function
  1460. headers(){}function
  1461. csp(){return
  1462. csp();}function
  1463. head(){return
  1464. true;}function
  1465. css(){$I=array();$Tc="adminer.css";if(file_exists($Tc))$I[]=$Tc;return$I;}function
  1466. loginForm(){global$dc;echo"<table cellspacing='0'>\n",$this->loginFormField('driver','<tr><th>'.'System'.'<td>',html_select("auth[driver]",$dc,DRIVER)."\n"),$this->loginFormField('server','<tr><th>'.'Server'.'<td>','<input name="auth[server]" value="'.h(SERVER).'" title="hostname[:port]" placeholder="localhost" autocapitalize="off">'."\n"),$this->loginFormField('username','<tr><th>'.'Username'.'<td>','<input name="auth[username]" id="username" value="'.h($_GET["username"]).'" autocapitalize="off">'.script("focus(qs('#username'));")),$this->loginFormField('password','<tr><th>'.'Password'.'<td>','<input type="password" name="auth[password]">'."\n"),$this->loginFormField('db','<tr><th>'.'Database'.'<td>','<input name="auth[db]" value="'.h($_GET["db"]).'" autocapitalize="off">'."\n"),"</table>\n","<p><input type='submit' value='".'Login'."'>\n",checkbox("auth[permanent]",1,$_COOKIE["adminer_permanent"],'Permanent login')."\n";}function
  1467. loginFormField($C,$wd,$Y){return$wd.$Y;}function
  1468. login($ue,$F){if($F=="")return
  1469. sprintf('Adminer does not support accessing a database without a password, <a href="https://www.adminer.org/en/password/"%s>more information</a>.',target_blank());return
  1470. true;}function
  1471. tableName($Hh){return
  1472. h($Hh["Name"]);}function
  1473. fieldName($o,$uf=0){return'<span title="'.h($o["full_type"]).'">'.h($o["field"]).'</span>';}function
  1474. selectLinks($Hh,$O=""){global$x,$m;echo'<p class="links">';$te=array("select"=>'Select data');if(support("table")||support("indexes"))$te["table"]='Show structure';if(support("table")){if(is_view($Hh))$te["view"]='Alter view';else$te["create"]='Alter table';}if($O!==null)$te["edit"]='New item';$C=$Hh["Name"];foreach($te
  1475. as$y=>$X)echo" <a href='".h(ME)."$y=".urlencode($C).($y=="edit"?$O:"")."'".bold(isset($_GET[$y])).">$X</a>";echo
  1476. doc_link(array($x=>$m->tableHelp($C)),"?"),"\n";}function
  1477. foreignKeys($R){return
  1478. foreign_keys($R);}function
  1479. backwardKeys($R,$Gh){return
  1480. array();}function
  1481. backwardKeysPrint($Oa,$J){}function
  1482. selectQuery($G,$xh,$Mc=false){global$x,$m;$I="</p>\n";if(!$Mc&&($Wi=$m->warnings())){$t="warnings";$I=", <a href='#$t'>".'Warnings'."</a>".script("qsl('a').onclick = partial(toggle, '$t');","")."$I<div id='$t' class='hidden'>\n$Wi</div>\n";}return"<p><code class='jush-$x'>".h(str_replace("\n"," ",$G))."</code> <span class='time'>(".format_time($xh).")</span>".(support("sql")?" <a href='".h(ME)."sql=".urlencode($G)."'>".'Edit'."</a>":"").$I;}function
  1483. sqlCommandQuery($G){return
  1484. shorten_utf8(trim($G),1000);}function
  1485. rowDescription($R){return"";}function
  1486. rowDescriptions($K,$cd){return$K;}function
  1487. selectLink($X,$o){}function
  1488. selectVal($X,$_,$o,$Bf){$I=($X===null?"<i>NULL</i>":(preg_match("~char|binary|boolean~",$o["type"])&&!preg_match("~var~",$o["type"])?"<code>$X</code>":$X));if(preg_match('~blob|bytea|raw|file~',$o["type"])&&!is_utf8($X))$I="<i>".lang(array('%d byte','%d bytes'),strlen($Bf))."</i>";if(preg_match('~json~',$o["type"]))$I="<code class='jush-js'>$I</code>";return($_?"<a href='".h($_)."'".(is_url($_)?target_blank():"").">$I</a>":$I);}function
  1489. editVal($X,$o){return$X;}function
  1490. tableStructurePrint($p){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr><th>".'Column'."<td>".'Type'.(support("comment")?"<td>".'Comment':"")."</thead>\n";foreach($p
  1491. as$o){echo"<tr".odd()."><th>".h($o["field"]),"<td><span title='".h($o["collation"])."'>".h($o["full_type"])."</span>",($o["null"]?" <i>NULL</i>":""),($o["auto_increment"]?" <i>".'Auto Increment'."</i>":""),(isset($o["default"])?" <span title='".'Default value'."'>[<b>".h($o["default"])."</b>]</span>":""),(support("comment")?"<td>".h($o["comment"]):""),"\n";}echo"</table>\n";}function
  1492. tableIndexesPrint($w){echo"<table cellspacing='0'>\n";foreach($w
  1493. as$C=>$v){ksort($v["columns"]);$gg=array();foreach($v["columns"]as$y=>$X)$gg[]="<i>".h($X)."</i>".($v["lengths"][$y]?"(".$v["lengths"][$y].")":"").($v["descs"][$y]?" DESC":"");echo"<tr title='".h($C)."'><th>$v[type]<td>".implode(", ",$gg)."\n";}echo"</table>\n";}function
  1494. selectColumnsPrint($L,$f){global$jd,$pd;print_fieldset("select",'Select',$L);$s=0;$L[""]=array();foreach($L
  1495. as$y=>$X){$X=$_GET["columns"][$y];$e=select_input(" name='columns[$s][col]'",$f,$X["col"],($y!==""?"selectFieldChange":"selectAddRow"));echo"<div>".($jd||$pd?"<select name='columns[$s][fun]'>".optionlist(array(-1=>"")+array_filter(array('Functions'=>$jd,'Aggregation'=>$pd)),$X["fun"])."</select>".on_help("getTarget(event).value && getTarget(event).value.replace(/ |\$/, '(') + ')'",1).script("qsl('select').onchange = function () { helpClose();".($y!==""?"":" qsl('select, input', this.parentNode).onchange();")." };","")."($e)":$e)."</div>\n";$s++;}echo"</div></fieldset>\n";}function
  1496. selectSearchPrint($Z,$f,$w){print_fieldset("search",'Search',$Z);foreach($w
  1497. as$s=>$v){if($v["type"]=="FULLTEXT"){echo"<div>(<i>".implode("</i>, <i>",array_map('h',$v["columns"]))."</i>) AGAINST"," <input type='search' name='fulltext[$s]' value='".h($_GET["fulltext"][$s])."'>",script("qsl('input').oninput = selectFieldChange;",""),checkbox("boolean[$s]",1,isset($_GET["boolean"][$s]),"BOOL"),"</div>\n";}}$ab="this.parentNode.firstChild.onchange();";foreach(array_merge((array)$_GET["where"],array(array()))as$s=>$X){if(!$X||("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators))){echo"<div>".select_input(" name='where[$s][col]'",$f,$X["col"],($X?"selectFieldChange":"selectAddRow"),"(".'anywhere'.")"),html_select("where[$s][op]",$this->operators,$X["op"],$ab),"<input type='search' name='where[$s][val]' value='".h($X["val"])."'>",script("mixin(qsl('input'), {oninput: function () { $ab }, onkeydown: selectSearchKeydown, onsearch: selectSearchSearch});",""),"</div>\n";}}echo"</div></fieldset>\n";}function
  1498. selectOrderPrint($uf,$f,$w){print_fieldset("sort",'Sort',$uf);$s=0;foreach((array)$_GET["order"]as$y=>$X){if($X!=""){echo"<div>".select_input(" name='order[$s]'",$f,$X,"selectFieldChange"),checkbox("desc[$s]",1,isset($_GET["desc"][$y]),'descending')."</div>\n";$s++;}}echo"<div>".select_input(" name='order[$s]'",$f,"","selectAddRow"),checkbox("desc[$s]",1,false,'descending')."</div>\n","</div></fieldset>\n";}function
  1499. selectLimitPrint($z){echo"<fieldset><legend>".'Limit'."</legend><div>";echo"<input type='number' name='limit' class='size' value='".h($z)."'>",script("qsl('input').oninput = selectFieldChange;",""),"</div></fieldset>\n";}function
  1500. selectLengthPrint($Wh){if($Wh!==null){echo"<fieldset><legend>".'Text length'."</legend><div>","<input type='number' name='text_length' class='size' value='".h($Wh)."'>","</div></fieldset>\n";}}function
  1501. selectActionPrint($w){echo"<fieldset><legend>".'Action'."</legend><div>","<input type='submit' value='".'Select'."'>"," <span id='noindex' title='".'Full table scan'."'></span>","<script".nonce().">\n","var indexColumns = ";$f=array();foreach($w
  1502. as$v){$Jb=reset($v["columns"]);if($v["type"]!="FULLTEXT"&&$Jb)$f[$Jb]=1;}$f[""]=1;foreach($f
  1503. as$y=>$X)json_row($y);echo";\n","selectFieldChange.call(qs('#form')['select']);\n","</script>\n","</div></fieldset>\n";}function
  1504. selectCommandPrint(){return!information_schema(DB);}function
  1505. selectImportPrint(){return!information_schema(DB);}function
  1506. selectEmailPrint($qc,$f){}function
  1507. selectColumnsProcess($f,$w){global$jd,$pd;$L=array();$md=array();foreach((array)$_GET["columns"]as$y=>$X){if($X["fun"]=="count"||($X["col"]!=""&&(!$X["fun"]||in_array($X["fun"],$jd)||in_array($X["fun"],$pd)))){$L[$y]=apply_sql_function($X["fun"],($X["col"]!=""?idf_escape($X["col"]):"*"));if(!in_array($X["fun"],$pd))$md[]=$L[$y];}}return
  1508. array($L,$md);}function
  1509. selectSearchProcess($p,$w){global$g,$m;$I=array();foreach($w
  1510. as$s=>$v){if($v["type"]=="FULLTEXT"&&$_GET["fulltext"][$s]!="")$I[]="MATCH (".implode(", ",array_map('idf_escape',$v["columns"])).") AGAINST (".q($_GET["fulltext"][$s]).(isset($_GET["boolean"][$s])?" IN BOOLEAN MODE":"").")";}foreach((array)$_GET["where"]as$y=>$X){if("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators)){$cg="";$vb=" $X[op]";if(preg_match('~IN$~',$X["op"])){$Ed=process_length($X["val"]);$vb.=" ".($Ed!=""?$Ed:"(NULL)");}elseif($X["op"]=="SQL")$vb=" $X[val]";elseif($X["op"]=="LIKE %%")$vb=" LIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif($X["op"]=="ILIKE %%")$vb=" ILIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif($X["op"]=="FIND_IN_SET"){$cg="$X[op](".q($X["val"]).", ";$vb=")";}elseif(!preg_match('~NULL$~',$X["op"]))$vb.=" ".$this->processInput($p[$X["col"]],$X["val"]);if($X["col"]!="")$I[]=$cg.$m->convertSearch(idf_escape($X["col"]),$X,$p[$X["col"]]).$vb;else{$qb=array();foreach($p
  1511. as$C=>$o){if((preg_match('~^[-\d.'.(preg_match('~IN$~',$X["op"])?',':'').']+$~',$X["val"])||!preg_match('~'.number_type().'|bit~',$o["type"]))&&(!preg_match("~[\x80-\xFF]~",$X["val"])||preg_match('~char|text|enum|set~',$o["type"])))$qb[]=$cg.$m->convertSearch(idf_escape($C),$X,$o).$vb;}$I[]=($qb?"(".implode(" OR ",$qb).")":"1 = 0");}}}return$I;}function
  1512. selectOrderProcess($p,$w){$I=array();foreach((array)$_GET["order"]as$y=>$X){if($X!="")$I[]=(preg_match('~^((COUNT\(DISTINCT |[A-Z0-9_]+\()(`(?:[^`]|``)+`|"(?:[^"]|"")+")\)|COUNT\(\*\))$~',$X)?$X:idf_escape($X)).(isset($_GET["desc"][$y])?" DESC":"");}return$I;}function
  1513. selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"50");}function
  1514. selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
  1515. selectEmailProcess($Z,$cd){return
  1516. false;}function
  1517. selectQueryBuild($L,$Z,$md,$uf,$z,$E){return"";}function
  1518. messageQuery($G,$Xh,$Mc=false){global$x,$m;restart_session();$xd=&get_session("queries");if(!$xd[$_GET["db"]])$xd[$_GET["db"]]=array();if(strlen($G)>1e6)$G=preg_replace('~[\x80-\xFF]+$~','',substr($G,0,1e6))."\n...";$xd[$_GET["db"]][]=array($G,time(),$Xh);$uh="sql-".count($xd[$_GET["db"]]);$I="<a href='#$uh' class='toggle'>".'SQL command'."</a>\n";if(!$Mc&&($Wi=$m->warnings())){$t="warnings-".count($xd[$_GET["db"]]);$I="<a href='#$t' class='toggle'>".'Warnings'."</a>, $I<div id='$t' class='hidden'>\n$Wi</div>\n";}return" <span class='time'>".@date("H:i:s")."</span>"." $I<div id='$uh' class='hidden'><pre><code class='jush-$x'>".shorten_utf8($G,1000)."</code></pre>".($Xh?" <span class='time'>($Xh)</span>":'').(support("sql")?'<p><a href="'.h(str_replace("db=".urlencode(DB),"db=".urlencode($_GET["db"]),ME).'sql=&history='.(count($xd[$_GET["db"]])-1)).'">'.'Edit'.'</a>':'').'</div>';}function
  1519. editFunctions($o){global$lc;$I=($o["null"]?"NULL/":"");foreach($lc
  1520. as$y=>$jd){if(!$y||(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET)))){foreach($jd
  1521. as$Uf=>$X){if(!$Uf||preg_match("~$Uf~",$o["type"]))$I.="/$X";}if($y&&!preg_match('~set|blob|bytea|raw|file~',$o["type"]))$I.="/SQL";}}if($o["auto_increment"]&&!isset($_GET["select"])&&!where($_GET))$I='Auto Increment';return
  1522. explode("/",$I);}function
  1523. editInput($R,$o,$Ja,$Y){if($o["type"]=="enum")return(isset($_GET["select"])?"<label><input type='radio'$Ja value='-1' checked><i>".'original'."</i></label> ":"").($o["null"]?"<label><input type='radio'$Ja value=''".($Y!==null||isset($_GET["select"])?"":" checked")."><i>NULL</i></label> ":"").enum_input("radio",$Ja,$o,$Y,0);return"";}function
  1524. editHint($R,$o,$Y){return"";}function
  1525. processInput($o,$Y,$r=""){if($r=="SQL")return$Y;$C=$o["field"];$I=q($Y);if(preg_match('~^(now|getdate|uuid)$~',$r))$I="$r()";elseif(preg_match('~^current_(date|timestamp)$~',$r))$I=$r;elseif(preg_match('~^([+-]|\|\|)$~',$r))$I=idf_escape($C)." $r $I";elseif(preg_match('~^[+-] interval$~',$r))$I=idf_escape($C)." $r ".(preg_match("~^(\\d+|'[0-9.: -]') [A-Z_]+\$~i",$Y)?$Y:$I);elseif(preg_match('~^(addtime|subtime|concat)$~',$r))$I="$r(".idf_escape($C).", $I)";elseif(preg_match('~^(md5|sha1|password|encrypt)$~',$r))$I="$r($I)";return
  1526. unconvert_field($o,$I);}function
  1527. dumpOutput(){$I=array('text'=>'open','file'=>'save');if(function_exists('gzencode'))$I['gz']='gzip';return$I;}function
  1528. dumpFormat(){return
  1529. array('sql'=>'SQL','csv'=>'CSV,','csv;'=>'CSV;','tsv'=>'TSV');}function
  1530. dumpDatabase($l){}function
  1531. dumpTable($R,$Bh,$Xd=0){if($_POST["format"]!="sql"){echo"\xef\xbb\xbf";if($Bh)dump_csv(array_keys(fields($R)));}else{if($Xd==2){$p=array();foreach(fields($R)as$C=>$o)$p[]=idf_escape($C)." $o[full_type]";$i="CREATE TABLE ".table($R)." (".implode(", ",$p).")";}else$i=create_sql($R,$_POST["auto_increment"],$Bh);set_utf8mb4($i);if($Bh&&$i){if($Bh=="DROP+CREATE"||$Xd==1)echo"DROP ".($Xd==2?"VIEW":"TABLE")." IF EXISTS ".table($R).";\n";if($Xd==1)$i=remove_definer($i);echo"$i;\n\n";}}}function
  1532. dumpData($R,$Bh,$G){global$g,$x;$Be=($x=="sqlite"?0:1048576);if($Bh){if($_POST["format"]=="sql"){if($Bh=="TRUNCATE+INSERT")echo
  1533. truncate_sql($R).";\n";$p=fields($R);}$H=$g->query($G,1);if($H){$Qd="";$Xa="";$ee=array();$Dh="";$Pc=($R!=''?'fetch_assoc':'fetch_row');while($J=$H->$Pc()){if(!$ee){$Oi=array();foreach($J
  1534. as$X){$o=$H->fetch_field();$ee[]=$o->name;$y=idf_escape($o->name);$Oi[]="$y = VALUES($y)";}$Dh=($Bh=="INSERT+UPDATE"?"\nON DUPLICATE KEY UPDATE ".implode(", ",$Oi):"").";\n";}if($_POST["format"]!="sql"){if($Bh=="table"){dump_csv($ee);$Bh="INSERT";}dump_csv($J);}else{if(!$Qd)$Qd="INSERT INTO ".table($R)." (".implode(", ",array_map('idf_escape',$ee)).") VALUES";foreach($J
  1535. as$y=>$X){$o=$p[$y];$J[$y]=($X!==null?unconvert_field($o,preg_match(number_type(),$o["type"])&&$X!=''?$X:q(($X===false?0:$X))):"NULL");}$Sg=($Be?"\n":" ")."(".implode(",\t",$J).")";if(!$Xa)$Xa=$Qd.$Sg;elseif(strlen($Xa)+4+strlen($Sg)+strlen($Dh)<$Be)$Xa.=",$Sg";else{echo$Xa.$Dh;$Xa=$Qd.$Sg;}}}if($Xa)echo$Xa.$Dh;}elseif($_POST["format"]=="sql")echo"-- ".str_replace("\n"," ",$g->error)."\n";}}function
  1536. dumpFilename($Bd){return
  1537. friendly_url($Bd!=""?$Bd:(SERVER!=""?SERVER:"localhost"));}function
  1538. dumpHeaders($Bd,$Qe=false){$Ef=$_POST["output"];$Hc=(preg_match('~sql~',$_POST["format"])?"sql":($Qe?"tar":"csv"));header("Content-Type: ".($Ef=="gz"?"application/x-gzip":($Hc=="tar"?"application/x-tar":($Hc=="sql"||$Ef!="file"?"text/plain":"text/csv")."; charset=utf-8")));if($Ef=="gz")ob_start('ob_gzencode',1e6);return$Hc;}function
  1539. importServerPath(){return"adminer.sql";}function
  1540. homepage(){echo'<p class="links">'.($_GET["ns"]==""&&support("database")?'<a href="'.h(ME).'database=">'.'Alter database'."</a>\n":""),(support("scheme")?"<a href='".h(ME)."scheme='>".($_GET["ns"]!=""?'Alter schema':'Create schema')."</a>\n":""),($_GET["ns"]!==""?'<a href="'.h(ME).'schema=">'.'Database schema'."</a>\n":""),(support("privileges")?"<a href='".h(ME)."privileges='>".'Privileges'."</a>\n":"");return
  1541. true;}function
  1542. navigation($Pe){global$ia,$x,$dc,$g;echo'<h1>
  1543. ',$this->name(),' <span class="version">',$ia,'</span>
  1544. <a href="https://www.adminer.org/#download"',target_blank(),' id="version">',(version_compare($ia,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
  1545. </h1>
  1546. ';if($Pe=="auth"){$Vc=true;foreach((array)$_SESSION["pwds"]as$Qi=>$gh){foreach($gh
  1547. as$N=>$Li){foreach($Li
  1548. as$V=>$F){if($F!==null){if($Vc){echo"<p id='logins'>".script("mixin(qs('#logins'), {onmouseover: menuOver, onmouseout: menuOut});");$Vc=false;}$Pb=$_SESSION["db"][$Qi][$N][$V];foreach(($Pb?array_keys($Pb):array(""))as$l)echo"<a href='".h(auth_url($Qi,$N,$V,$l))."'>($dc[$Qi]) ".h($V.($N!=""?"@".$this->serverName($N):"").($l!=""?" - $l":""))."</a><br>\n";}}}}}else{if($_GET["ns"]!==""&&!$Pe&&DB!=""){$g->select_db(DB);$T=table_status('',true);}echo
  1549. script_src(preg_replace("~\\?.*~","",ME)."?file=jush.js&version=4.6.3");if(support("sql")){echo'<script',nonce(),'>
  1550. ';if($T){$te=array();foreach($T
  1551. as$R=>$U)$te[]=preg_quote($R,'/');echo"var jushLinks = { $x: [ '".js_escape(ME).(support("table")?"table=":"select=")."\$&', /\\b(".implode("|",$te).")\\b/g ] };\n";foreach(array("bac","bra","sqlite_quo","mssql_bra")as$X)echo"jushLinks.$X = jushLinks.$x;\n";}$fh=$g->server_info;echo'bodyLoad(\'',(is_object($g)?preg_replace('~^(\d\.?\d).*~s','\1',$fh):""),'\'',(preg_match('~MariaDB~',$fh)?", true":""),');
  1552. </script>
  1553. ';}$this->databasesPrint($Pe);if(DB==""||!$Pe){echo"<p class='links'>".(support("sql")?"<a href='".h(ME)."sql='".bold(isset($_GET["sql"])&&!isset($_GET["import"])).">".'SQL command'."</a>\n<a href='".h(ME)."import='".bold(isset($_GET["import"])).">".'Import'."</a>\n":"")."";if(support("dump"))echo"<a href='".h(ME)."dump=".urlencode(isset($_GET["table"])?$_GET["table"]:$_GET["select"])."' id='dump'".bold(isset($_GET["dump"])).">".'Export'."</a>\n";}if($_GET["ns"]!==""&&!$Pe&&DB!=""){echo'<a href="'.h(ME).'create="'.bold($_GET["create"]==="").">".'Create table'."</a>\n";if(!$T)echo"<p class='message'>".'No tables.'."\n";else$this->tablesPrint($T);}}}function
  1554. databasesPrint($Pe){global$b,$g;$k=$this->databases();if($k&&!in_array(DB,$k))array_unshift($k,DB);echo'<form action="">
  1555. <p id="dbs">
  1556. ';hidden_fields_get();$Nb=script("mixin(qsl('select'), {onmousedown: dbMouseDown, onchange: dbChange});");echo"<span title='".'database'."'>".'DB'."</span>: ".($k?"<select name='db'>".optionlist(array(""=>"")+$k,DB)."</select>$Nb":"<input name='db' value='".h(DB)."' autocapitalize='off'>\n"),"<input type='submit' value='".'Use'."'".($k?" class='hidden'":"").">\n";if($Pe!="db"&&DB!=""&&$g->select_db(DB)){if(support("scheme")){echo"<br>".'Schema'.": <select name='ns'>".optionlist(array(""=>"")+$b->schemas(),$_GET["ns"])."</select>$Nb";if($_GET["ns"]!="")set_schema($_GET["ns"]);}}foreach(array("import","sql","schema","dump","privileges")as$X){if(isset($_GET[$X])){echo"<input type='hidden' name='$X' value=''>";break;}}echo"</p></form>\n";}function
  1557. tablesPrint($T){echo"<ul id='tables'>".script("mixin(qs('#tables'), {onmouseover: menuOver, onmouseout: menuOut});");foreach($T
  1558. as$R=>$P){$C=$this->tableName($P);if($C!=""){echo'<li><a href="'.h(ME).'select='.urlencode($R).'"'.bold($_GET["select"]==$R||$_GET["edit"]==$R,"select").">".'select'."</a> ",(support("table")||support("indexes")?'<a href="'.h(ME).'table='.urlencode($R).'"'.bold(in_array($R,array($_GET["table"],$_GET["create"],$_GET["indexes"],$_GET["foreign"],$_GET["trigger"])),(is_view($P)?"view":"structure"))." title='".'Show structure'."'>$C</a>":"<span>$C</span>")."\n";}}echo"</ul>\n";}}$b=(function_exists('adminer_object')?adminer_object():new
  1559. Adminer);if($b->operators===null)$b->operators=$pf;function
  1560. page_header($ai,$n="",$Wa=array(),$bi=""){global$ca,$ia,$b,$dc,$x;page_headers();if(is_ajax()&&$n){page_messages($n);exit;}$ci=$ai.($bi!=""?": $bi":"");$di=strip_tags($ci.(SERVER!=""&&SERVER!="localhost"?h(" - ".SERVER):"")." - ".$b->name());echo'<!DOCTYPE html>
  1561. <html lang="en" dir="ltr">
  1562. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  1563. <meta name="robots" content="noindex">
  1564. <title>',$di,'</title>
  1565. <link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",ME)."?file=default.css&version=4.6.3"),'">
  1566. ',script_src(preg_replace("~\\?.*~","",ME)."?file=functions.js&version=4.6.3");if($b->head()){echo'<link rel="shortcut icon" type="image/x-icon" href="',h(preg_replace("~\\?.*~","",ME)."?file=favicon.ico&version=4.6.3"),'">
  1567. <link rel="apple-touch-icon" href="',h(preg_replace("~\\?.*~","",ME)."?file=favicon.ico&version=4.6.3"),'">
  1568. ';foreach($b->css()as$Hb){echo'<link rel="stylesheet" type="text/css" href="',h($Hb),'">
  1569. ';}}echo'
  1570. <body class="ltr nojs">
  1571. ';$Tc=get_temp_dir()."/adminer.version";if(!$_COOKIE["adminer_version"]&&function_exists('openssl_verify')&&file_exists($Tc)&&filemtime($Tc)+86400>time()){$Ri=unserialize(file_get_contents($Tc));$ng="-----BEGIN PUBLIC KEY-----
  1572. MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwqWOVuF5uw7/+Z70djoK
  1573. RlHIZFZPO0uYRezq90+7Amk+FDNd7KkL5eDve+vHRJBLAszF/7XKXe11xwliIsFs
  1574. DFWQlsABVZB3oisKCBEuI71J4kPH8dKGEWR9jDHFw3cWmoH3PmqImX6FISWbG3B8
  1575. h7FIx3jEaw5ckVPVTeo5JRm/1DZzJxjyDenXvBQ/6o9DgZKeNDgxwKzH+sw9/YCO
  1576. jHnq1cFpOIISzARlrHMa/43YfeNRAm/tsBXjSxembBPo7aQZLAWHmaj5+K19H10B
  1577. nCpz9Y++cipkVEiKRGih4ZEvjoFysEOdRLj6WiD/uUNky4xGeA6LaJqh5XpkFkcQ
  1578. fQIDAQAB
  1579. -----END PUBLIC KEY-----
  1580. ";if(openssl_verify($Ri["version"],base64_decode($Ri["signature"]),$ng)==1)$_COOKIE["adminer_version"]=$Ri["version"];}echo'<script',nonce(),'>
  1581. mixin(document.body, {onkeydown: bodyKeydown, onclick: bodyClick',(isset($_COOKIE["adminer_version"])?"":", onload: partial(verifyVersion, '$ia', '".js_escape(ME)."', '".get_token()."')");?>});
  1582. document.body.className = document.body.className.replace(/ nojs/, ' js');
  1583. var offlineMessage = '<?php echo
  1584. js_escape('You are offline.'),'\';
  1585. var thousandsSeparator = \'',js_escape(','),'\';
  1586. </script>
  1587.  
  1588. <div id="help" class="jush-',$x,' jsonly hidden"></div>
  1589. ',script("mixin(qs('#help'), {onmouseover: function () { helpOpen = 1; }, onmouseout: helpMouseout});"),'
  1590. <div id="content">
  1591. ';if($Wa!==null){$_=substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.h($_?$_:".").'">'.$dc[DRIVER].'</a> &raquo; ';$_=substr(preg_replace('~\b(db|ns)=[^&]*&~','',ME),0,-1);$N=$b->serverName(SERVER);$N=($N!=""?$N:'Server');if($Wa===false)echo"$N\n";else{echo"<a href='".($_?h($_):".")."' accesskey='1' title='Alt+Shift+1'>$N</a> &raquo; ";if($_GET["ns"]!=""||(DB!=""&&is_array($Wa)))echo'<a href="'.h($_."&db=".urlencode(DB).(support("scheme")?"&ns=":"")).'">'.h(DB).'</a> &raquo; ';if(is_array($Wa)){if($_GET["ns"]!="")echo'<a href="'.h(substr(ME,0,-1)).'">'.h($_GET["ns"]).'</a> &raquo; ';foreach($Wa
  1592. as$y=>$X){$Vb=(is_array($X)?$X[1]:h($X));if($Vb!="")echo"<a href='".h(ME."$y=").urlencode(is_array($X)?$X[0]:$X)."'>$Vb</a> &raquo; ";}}echo"$ai\n";}}echo"<h2>$ci</h2>\n","<div id='ajaxstatus' class='jsonly hidden'></div>\n";restart_session();page_messages($n);$k=&get_session("dbs");if(DB!=""&&$k&&!in_array(DB,$k,true))$k=null;stop_session();define("PAGE_HEADER",1);}function
  1593. page_headers(){global$b;header("Content-Type: text/html; charset=utf-8");header("Cache-Control: no-cache");header("X-Frame-Options: deny");header("X-XSS-Protection: 0");header("X-Content-Type-Options: nosniff");header("Referrer-Policy: origin-when-cross-origin");foreach($b->csp()as$Gb){$vd=array();foreach($Gb
  1594. as$y=>$X)$vd[]="$y $X";header("Content-Security-Policy: ".implode("; ",$vd));}$b->headers();}function
  1595. csp(){return
  1596. array(array("script-src"=>"'self' 'unsafe-inline' 'nonce-".get_nonce()."' 'strict-dynamic'","connect-src"=>"'self'","frame-src"=>"https://www.adminer.org","object-src"=>"'none'","base-uri"=>"'none'","form-action"=>"'self'",),);}function
  1597. get_nonce(){static$Ze;if(!$Ze)$Ze=base64_encode(rand_string());return$Ze;}function
  1598. page_messages($n){$Ei=preg_replace('~^[^?]*~','',$_SERVER["REQUEST_URI"]);$Le=$_SESSION["messages"][$Ei];if($Le){echo"<div class='message'>".implode("</div>\n<div class='message'>",$Le)."</div>".script("messagesPrint();");unset($_SESSION["messages"][$Ei]);}if($n)echo"<div class='error'>$n</div>\n";}function
  1599. page_footer($Pe=""){global$b,$hi;echo'</div>
  1600.  
  1601. ';if($Pe!="auth"){echo'<form action="" method="post">
  1602. <p class="logout">
  1603. <input type="submit" name="logout" value="Logout" id="logout">
  1604. <input type="hidden" name="token" value="',$hi,'">
  1605. </p>
  1606. </form>
  1607. ';}echo'<div id="menu">
  1608. ';$b->navigation($Pe);echo'</div>
  1609. ',script("setupSubmitHighlight(document);");}function
  1610. int32($Se){while($Se>=2147483648)$Se-=4294967296;while($Se<=-2147483649)$Se+=4294967296;return(int)$Se;}function
  1611. long2str($W,$Vi){$Sg='';foreach($W
  1612. as$X)$Sg.=pack('V',$X);if($Vi)return
  1613. substr($Sg,0,end($W));return$Sg;}function
  1614. str2long($Sg,$Vi){$W=array_values(unpack('V*',str_pad($Sg,4*ceil(strlen($Sg)/4),"\0")));if($Vi)$W[]=strlen($Sg);return$W;}function
  1615. xxtea_mx($ij,$hj,$Eh,$ae){return
  1616. int32((($ij>>5&0x7FFFFFF)^$hj<<2)+(($hj>>3&0x1FFFFFFF)^$ij<<4))^int32(($Eh^$hj)+($ae^$ij));}function
  1617. encrypt_string($_h,$y){if($_h=="")return"";$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($_h,true);$Se=count($W)-1;$ij=$W[$Se];$hj=$W[0];$og=floor(6+52/($Se+1));$Eh=0;while($og-->0){$Eh=int32($Eh+0x9E3779B9);$kc=$Eh>>2&3;for($Ff=0;$Ff<$Se;$Ff++){$hj=$W[$Ff+1];$Re=xxtea_mx($ij,$hj,$Eh,$y[$Ff&3^$kc]);$ij=int32($W[$Ff]+$Re);$W[$Ff]=$ij;}$hj=$W[0];$Re=xxtea_mx($ij,$hj,$Eh,$y[$Ff&3^$kc]);$ij=int32($W[$Se]+$Re);$W[$Se]=$ij;}return
  1618. long2str($W,false);}function
  1619. decrypt_string($_h,$y){if($_h=="")return"";if(!$y)return
  1620. false;$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($_h,false);$Se=count($W)-1;$ij=$W[$Se];$hj=$W[0];$og=floor(6+52/($Se+1));$Eh=int32($og*0x9E3779B9);while($Eh){$kc=$Eh>>2&3;for($Ff=$Se;$Ff>0;$Ff--){$ij=$W[$Ff-1];$Re=xxtea_mx($ij,$hj,$Eh,$y[$Ff&3^$kc]);$hj=int32($W[$Ff]-$Re);$W[$Ff]=$hj;}$ij=$W[$Se];$Re=xxtea_mx($ij,$hj,$Eh,$y[$Ff&3^$kc]);$hj=int32($W[0]-$Re);$W[0]=$hj;$Eh=int32($Eh-0x9E3779B9);}return
  1621. long2str($W,true);}$g='';$ud=$_SESSION["token"];if(!$ud)$_SESSION["token"]=rand(1,1e6);$hi=get_token();$Vf=array();if($_COOKIE["adminer_permanent"]){foreach(explode(" ",$_COOKIE["adminer_permanent"])as$X){list($y)=explode(":",$X);$Vf[$y]=$X;}}function
  1622. add_invalid_login(){global$b;$hd=file_open_lock(get_temp_dir()."/adminer.invalid");if(!$hd)return;$Td=unserialize(stream_get_contents($hd));$Xh=time();if($Td){foreach($Td
  1623. as$Ud=>$X){if($X[0]<$Xh)unset($Td[$Ud]);}}$Sd=&$Td[$b->bruteForceKey()];if(!$Sd)$Sd=array($Xh+30*60,0);$Sd[1]++;file_write_unlock($hd,serialize($Td));}function
  1624. check_invalid_login(){global$b;$Td=unserialize(@file_get_contents(get_temp_dir()."/adminer.invalid"));$Sd=$Td[$b->bruteForceKey()];$Ye=($Sd[1]>29?$Sd[0]-time():0);if($Ye>0)auth_error(lang(array('Too many unsuccessful logins, try again in %d minute.','Too many unsuccessful logins, try again in %d minutes.'),ceil($Ye/60)));}$Ka=$_POST["auth"];if($Ka){session_regenerate_id();$Qi=$Ka["driver"];$N=$Ka["server"];$V=$Ka["username"];$F=(string)$Ka["password"];$l=$Ka["db"];set_password($Qi,$N,$V,$F);$_SESSION["db"][$Qi][$N][$V][$l]=true;if($Ka["permanent"]){$y=base64_encode($Qi)."-".base64_encode($N)."-".base64_encode($V)."-".base64_encode($l);$hg=$b->permanentLogin(true);$Vf[$y]="$y:".base64_encode($hg?encrypt_string($F,$hg):"");cookie("adminer_permanent",implode(" ",$Vf));}if(count($_POST)==1||DRIVER!=$Qi||SERVER!=$N||$_GET["username"]!==$V||DB!=$l)redirect(auth_url($Qi,$N,$V,$l));}elseif($_POST["logout"]){if($ud&&!verify_token()){page_header('Logout','Invalid CSRF token. Send the form again.');page_footer("db");exit;}else{foreach(array("pwds","db","dbs","queries")as$y)set_session($y,null);unset_permanent();redirect(substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1),'Logout successful.'.' '.sprintf('Thanks for using Adminer, consider <a href="%s">donating</a>.','https://sourceforge.net/donate/index.php?group_id=264133'));}}elseif($Vf&&!$_SESSION["pwds"]){session_regenerate_id();$hg=$b->permanentLogin();foreach($Vf
  1625. as$y=>$X){list(,$ib)=explode(":",$X);list($Qi,$N,$V,$l)=array_map('base64_decode',explode("-",$y));set_password($Qi,$N,$V,decrypt_string(base64_decode($ib),$hg));$_SESSION["db"][$Qi][$N][$V][$l]=true;}}function
  1626. unset_permanent(){global$Vf;foreach($Vf
  1627. as$y=>$X){list($Qi,$N,$V,$l)=array_map('base64_decode',explode("-",$y));if($Qi==DRIVER&&$N==SERVER&&$V==$_GET["username"]&&$l==DB)unset($Vf[$y]);}cookie("adminer_permanent",implode(" ",$Vf));}function
  1628. auth_error($n){global$b,$ud;$hh=session_name();if(isset($_GET["username"])){header("HTTP/1.1 403 Forbidden");if(($_COOKIE[$hh]||$_GET[$hh])&&!$ud)$n='Session expired, please login again.';else{restart_session();add_invalid_login();$F=get_password();if($F!==null){if($F===false)$n.='<br>'.sprintf('Master password expired. <a href="https://www.adminer.org/en/extension/"%s>Implement</a> %s method to make it permanent.',target_blank(),'<code>permanentLogin()</code>');set_password(DRIVER,SERVER,$_GET["username"],null);}unset_permanent();}}if(!$_COOKIE[$hh]&&$_GET[$hh]&&ini_bool("session.use_only_cookies"))$n='Session support must be enabled.';$If=session_get_cookie_params();cookie("adminer_key",($_COOKIE["adminer_key"]?$_COOKIE["adminer_key"]:rand_string()),$If["lifetime"]);page_header('Login',$n,null);echo"<form action='' method='post'>\n","<div>";if(hidden_fields($_POST,array("auth")))echo"<p class='message'>".'The action will be performed after successful login with the same credentials.'."\n";echo"</div>\n";$b->loginForm();echo"</form>\n";page_footer("auth");exit;}if(isset($_GET["username"])&&!class_exists("Min_DB")){unset($_SESSION["pwds"][DRIVER]);unset_permanent();page_header('No extension',sprintf('None of the supported PHP extensions (%s) are available.',implode(", ",$bg)),false);page_footer("auth");exit;}stop_session(true);if(isset($_GET["username"])){list($_d,$Xf)=explode(":",SERVER,2);if(is_numeric($Xf)&&$Xf<1024)auth_error('Connecting to privileged ports is not allowed.');check_invalid_login();$g=connect();$m=new
  1629. Min_Driver($g);}$ue=null;if(!is_object($g)||($ue=$b->login($_GET["username"],get_password()))!==true)auth_error((is_string($g)?h($g):(is_string($ue)?$ue:'Invalid credentials.')));if($Ka&&$_POST["token"])$_POST["token"]=$hi;$n='';if($_POST){if(!verify_token()){$Nd="max_input_vars";$Fe=ini_get($Nd);if(extension_loaded("suhosin")){foreach(array("suhosin.request.max_vars","suhosin.post.max_vars")as$y){$X=ini_get($y);if($X&&(!$Fe||$X<$Fe)){$Nd=$y;$Fe=$X;}}}$n=(!$_POST["token"]&&$Fe?sprintf('Maximum number of allowed fields exceeded. Please increase %s.',"'$Nd'"):'Invalid CSRF token. Send the form again.'.' '.'If you did not send this request from Adminer then close this page.');}}elseif($_SERVER["REQUEST_METHOD"]=="POST"){$n=sprintf('Too big POST data. Reduce the data or increase the %s configuration directive.',"'post_max_size'");if(isset($_GET["sql"]))$n.=' '.'You can upload a big SQL file via FTP and import it from server.';}function
  1630. select($H,$h=null,$xf=array(),$z=0){global$x;$te=array();$w=array();$f=array();$Ta=array();$wi=array();$I=array();odd('');for($s=0;(!$z||$s<$z)&&($J=$H->fetch_row());$s++){if(!$s){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr>";for($Zd=0;$Zd<count($J);$Zd++){$o=$H->fetch_field();$C=$o->name;$wf=$o->orgtable;$vf=$o->orgname;$I[$o->table]=$wf;if($xf&&$x=="sql")$te[$Zd]=($C=="table"?"table=":($C=="possible_keys"?"indexes=":null));elseif($wf!=""){if(!isset($w[$wf])){$w[$wf]=array();foreach(indexes($wf,$h)as$v){if($v["type"]=="PRIMARY"){$w[$wf]=array_flip($v["columns"]);break;}}$f[$wf]=$w[$wf];}if(isset($f[$wf][$vf])){unset($f[$wf][$vf]);$w[$wf][$vf]=$Zd;$te[$Zd]=$wf;}}if($o->charsetnr==63)$Ta[$Zd]=true;$wi[$Zd]=$o->type;echo"<th".($wf!=""||$o->name!=$vf?" title='".h(($wf!=""?"$wf.":"").$vf)."'":"").">".h($C).($xf?doc_link(array('sql'=>"explain-output.html#explain_".strtolower($C),'mariadb'=>"explain/#the-columns-in-explain-select",)):"");}echo"</thead>\n";}echo"<tr".odd().">";foreach($J
  1631. as$y=>$X){if($X===null)$X="<i>NULL</i>";elseif($Ta[$y]&&!is_utf8($X))$X="<i>".lang(array('%d byte','%d bytes'),strlen($X))."</i>";else{$X=h($X);if($wi[$y]==254)$X="<code>$X</code>";}if(isset($te[$y])&&!$f[$te[$y]]){if($xf&&$x=="sql"){$R=$J[array_search("table=",$te)];$_=$te[$y].urlencode($xf[$R]!=""?$xf[$R]:$R);}else{$_="edit=".urlencode($te[$y]);foreach($w[$te[$y]]as$mb=>$Zd)$_.="&where".urlencode("[".bracket_escape($mb)."]")."=".urlencode($J[$Zd]);}$X="<a href='".h(ME.$_)."'>$X</a>";}echo"<td>$X";}}echo($s?"</table>":"<p class='message'>".'No rows.')."\n";return$I;}function
  1632. referencable_primary($bh){$I=array();foreach(table_status('',true)as$Ih=>$R){if($Ih!=$bh&&fk_support($R)){foreach(fields($Ih)as$o){if($o["primary"]){if($I[$Ih]){unset($I[$Ih]);break;}$I[$Ih]=$o;}}}}return$I;}function
  1633. textarea($C,$Y,$K=10,$qb=80){global$x;echo"<textarea name='$C' rows='$K' cols='$qb' class='sqlarea jush-$x' spellcheck='false' wrap='off'>";if(is_array($Y)){foreach($Y
  1634. as$X)echo
  1635. h($X[0])."\n\n\n";}else
  1636. echo
  1637. h($Y);echo"</textarea>";}function
  1638. edit_type($y,$o,$ob,$dd=array(),$Kc=array()){global$Ah,$wi,$Ci,$kf;$U=$o["type"];echo'<td><select name="',h($y),'[type]" class="type" aria-labelledby="label-type">';if($U&&!isset($wi[$U])&&!isset($dd[$U])&&!in_array($U,$Kc))$Kc[]=$U;if($dd)$Ah['Foreign keys']=$dd;echo
  1639. optionlist(array_merge($Kc,$Ah),$U),'</select>
  1640. ',on_help("getTarget(event).value",1),script("mixin(qsl('select'), {onfocus: function () { lastType = selectValue(this); }, onchange: editingTypeChange});",""),'<td><input name="',h($y),'[length]" value="',h($o["length"]),'" size="3"',(!$o["length"]&&preg_match('~var(char|binary)$~',$U)?" class='required'":"");echo' aria-labelledby="label-length">',script("mixin(qsl('input'), {onfocus: editingLengthFocus, oninput: editingLengthChange});",""),'<td class="options">',"<select name='".h($y)."[collation]'".(preg_match('~(char|text|enum|set)$~',$U)?"":" class='hidden'").'><option value="">('.'collation'.')'.optionlist($ob,$o["collation"]).'</select>',($Ci?"<select name='".h($y)."[unsigned]'".(!$U||preg_match(number_type(),$U)?"":" class='hidden'").'><option>'.optionlist($Ci,$o["unsigned"]).'</select>':''),(isset($o['on_update'])?"<select name='".h($y)."[on_update]'".(preg_match('~timestamp|datetime~',$U)?"":" class='hidden'").'>'.optionlist(array(""=>"(".'ON UPDATE'.")","CURRENT_TIMESTAMP"),$o["on_update"]).'</select>':''),($dd?"<select name='".h($y)."[on_delete]'".(preg_match("~`~",$U)?"":" class='hidden'")."><option value=''>(".'ON DELETE'.")".optionlist(explode("|",$kf),$o["on_delete"])."</select> ":" ");}function
  1641. process_length($qe){global$vc;return(preg_match("~^\\s*\\(?\\s*$vc(?:\\s*,\\s*$vc)*+\\s*\\)?\\s*\$~",$qe)&&preg_match_all("~$vc~",$qe,$_e)?"(".implode(",",$_e[0]).")":preg_replace('~^[0-9].*~','(\0)',preg_replace('~[^-0-9,+()[\]]~','',$qe)));}function
  1642. process_type($o,$nb="COLLATE"){global$Ci;return" $o[type]".process_length($o["length"]).(preg_match(number_type(),$o["type"])&&in_array($o["unsigned"],$Ci)?" $o[unsigned]":"").(preg_match('~char|text|enum|set~',$o["type"])&&$o["collation"]?" $nb ".q($o["collation"]):"");}function
  1643. process_field($o,$ui){return
  1644. array(idf_escape(trim($o["field"])),process_type($ui),($o["null"]?" NULL":" NOT NULL"),default_value($o),(preg_match('~timestamp|datetime~',$o["type"])&&$o["on_update"]?" ON UPDATE $o[on_update]":""),(support("comment")&&$o["comment"]!=""?" COMMENT ".q($o["comment"]):""),($o["auto_increment"]?auto_increment():null),);}function
  1645. default_value($o){$Rb=$o["default"];return($Rb===null?"":" DEFAULT ".(preg_match('~char|binary|text|enum|set~',$o["type"])||preg_match('~^(?![a-z])~i',$Rb)?q($Rb):$Rb));}function
  1646. type_class($U){foreach(array('char'=>'text','date'=>'time|year','binary'=>'blob','enum'=>'set',)as$y=>$X){if(preg_match("~$y|$X~",$U))return" class='$y'";}}function
  1647. edit_fields($p,$ob,$U="TABLE",$dd=array(),$ub=false){global$Od;$p=array_values($p);echo'<thead><tr>
  1648. ';if($U=="PROCEDURE"){echo'<td>';}echo'<th id="label-name">',($U=="TABLE"?'Column name':'Parameter name'),'<td id="label-type">Type<textarea id="enum-edit" rows="4" cols="12" wrap="off" style="display: none;"></textarea>',script("qs('#enum-edit').onblur = editingLengthBlur;"),'<td id="label-length">Length
  1649. <td>','Options';if($U=="TABLE"){echo'<td id="label-null">NULL
  1650. <td><input type="radio" name="auto_increment_col" value=""><acronym id="label-ai" title="Auto Increment">AI</acronym>',doc_link(array('sql'=>"example-auto-increment.html",'mariadb'=>"auto_increment/",'sqlite'=>"autoinc.html",'pgsql'=>"datatype.html#DATATYPE-SERIAL",'mssql'=>"ms186775.aspx",)),'<td id="label-default">Default value
  1651. ',(support("comment")?"<td id='label-comment'".($ub?"":" class='hidden'").">".'Comment':"");}echo'<td>',"<input type='image' class='icon' name='add[".(support("move_col")?0:count($p))."]' src='".h(preg_replace("~\\?.*~","",ME)."?file=plus.gif&version=4.6.3")."' alt='+' title='".'Add next'."'>".script("row_count = ".count($p).";"),'</thead>
  1652. <tbody>
  1653. ',script("mixin(qsl('tbody'), {onclick: editingClick, onkeydown: editingKeydown, oninput: editingInput});");foreach($p
  1654. as$s=>$o){$s++;$yf=$o[($_POST?"orig":"field")];$Zb=(isset($_POST["add"][$s-1])||(isset($o["field"])&&!$_POST["drop_col"][$s]))&&(support("drop_col")||$yf=="");echo'<tr',($Zb?"":" style='display: none;'"),'>
  1655. ',($U=="PROCEDURE"?"<td>".html_select("fields[$s][inout]",explode("|",$Od),$o["inout"]):""),'<th>';if($Zb){echo'<input name="fields[',$s,'][field]" value="',h($o["field"]),'" maxlength="64" autocapitalize="off" aria-labelledby="label-name">',script("qsl('input').oninput = function () { editingNameChange.call(this);".($o["field"]!=""||count($p)>1?"":" editingAddRow.call(this);")." };","");}echo'<input type="hidden" name="fields[',$s,'][orig]" value="',h($yf),'">
  1656. ';edit_type("fields[$s]",$o,$ob,$dd);if($U=="TABLE"){echo'<td>',checkbox("fields[$s][null]",1,$o["null"],"","","block","label-null"),'<td><label class="block"><input type="radio" name="auto_increment_col" value="',$s,'"';if($o["auto_increment"]){echo' checked';}echo' aria-labelledby="label-ai"></label><td>',checkbox("fields[$s][has_default]",1,$o["has_default"],"","","","label-default"),'<input name="fields[',$s,'][default]" value="',h($o["default"]),'" aria-labelledby="label-default">',(support("comment")?"<td".($ub?"":" class='hidden'")."><input name='fields[$s][comment]' value='".h($o["comment"])."' maxlength='".(min_version(5.5)?1024:255)."' aria-labelledby='label-comment'>":"");}echo"<td>",(support("move_col")?"<input type='image' class='icon' name='add[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=plus.gif&version=4.6.3")."' alt='+' title='".'Add next'."'> "."<input type='image' class='icon' name='up[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=up.gif&version=4.6.3")."' alt='↑' title='".'Move up'."'> "."<input type='image' class='icon' name='down[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=down.gif&version=4.6.3")."' alt='↓' title='".'Move down'."'> ":""),($yf==""||support("drop_col")?"<input type='image' class='icon' name='drop_col[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=cross.gif&version=4.6.3")."' alt='x' title='".'Remove'."'>":"");}}function
  1657. process_fields(&$p){$D=0;if($_POST["up"]){$ke=0;foreach($p
  1658. as$y=>$o){if(key($_POST["up"])==$y){unset($p[$y]);array_splice($p,$ke,0,array($o));break;}if(isset($o["field"]))$ke=$D;$D++;}}elseif($_POST["down"]){$fd=false;foreach($p
  1659. as$y=>$o){if(isset($o["field"])&&$fd){unset($p[key($_POST["down"])]);array_splice($p,$D,0,array($fd));break;}if(key($_POST["down"])==$y)$fd=$o;$D++;}}elseif($_POST["add"]){$p=array_values($p);array_splice($p,key($_POST["add"]),0,array(array()));}elseif(!$_POST["drop_col"])return
  1660. false;return
  1661. true;}function
  1662. normalize_enum($B){return"'".str_replace("'","''",addcslashes(stripcslashes(str_replace($B[0][0].$B[0][0],$B[0][0],substr($B[0],1,-1))),'\\'))."'";}function
  1663. grant($kd,$jg,$f,$jf){if(!$jg)return
  1664. true;if($jg==array("ALL PRIVILEGES","GRANT OPTION"))return($kd=="GRANT"?queries("$kd ALL PRIVILEGES$jf WITH GRANT OPTION"):queries("$kd ALL PRIVILEGES$jf")&&queries("$kd GRANT OPTION$jf"));return
  1665. queries("$kd ".preg_replace('~(GRANT OPTION)\([^)]*\)~','\1',implode("$f, ",$jg).$f).$jf);}function
  1666. drop_create($ec,$i,$fc,$Uh,$hc,$A,$Ke,$Ie,$Je,$gf,$Ve){if($_POST["drop"])query_redirect($ec,$A,$Ke);elseif($gf=="")query_redirect($i,$A,$Je);elseif($gf!=$Ve){$Eb=queries($i);queries_redirect($A,$Ie,$Eb&&queries($ec));if($Eb)queries($fc);}else
  1667. queries_redirect($A,$Ie,queries($Uh)&&queries($hc)&&queries($ec)&&queries($i));}function
  1668. create_trigger($jf,$J){global$x;$Zh=" $J[Timing] $J[Event]".($J["Event"]=="UPDATE OF"?" ".idf_escape($J["Of"]):"");return"CREATE TRIGGER ".idf_escape($J["Trigger"]).($x=="mssql"?$jf.$Zh:$Zh.$jf).rtrim(" $J[Type]\n$J[Statement]",";").";";}function
  1669. create_routine($Og,$J){global$Od,$x;$O=array();$p=(array)$J["fields"];ksort($p);foreach($p
  1670. as$o){if($o["field"]!="")$O[]=(preg_match("~^($Od)\$~",$o["inout"])?"$o[inout] ":"").idf_escape($o["field"]).process_type($o,"CHARACTER SET");}$Sb=rtrim("\n$J[definition]",";");return"CREATE $Og ".idf_escape(trim($J["name"]))." (".implode(", ",$O).")".(isset($_GET["function"])?" RETURNS".process_type($J["returns"],"CHARACTER SET"):"").($J["language"]?" LANGUAGE $J[language]":"").($x=="pgsql"?" AS ".q($Sb):"$Sb;");}function
  1671. remove_definer($G){return
  1672. preg_replace('~^([A-Z =]+) DEFINER=`'.preg_replace('~@(.*)~','`@`(%|\1)',logged_user()).'`~','\1',$G);}function
  1673. format_foreign_key($q){global$kf;return" FOREIGN KEY (".implode(", ",array_map('idf_escape',$q["source"])).") REFERENCES ".table($q["table"])." (".implode(", ",array_map('idf_escape',$q["target"])).")".(preg_match("~^($kf)\$~",$q["on_delete"])?" ON DELETE $q[on_delete]":"").(preg_match("~^($kf)\$~",$q["on_update"])?" ON UPDATE $q[on_update]":"");}function
  1674. tar_file($Tc,$ei){$I=pack("a100a8a8a8a12a12",$Tc,644,0,0,decoct($ei->size),decoct(time()));$gb=8*32;for($s=0;$s<strlen($I);$s++)$gb+=ord($I[$s]);$I.=sprintf("%06o",$gb)."\0 ";echo$I,str_repeat("\0",512-strlen($I));$ei->send();echo
  1675. str_repeat("\0",511-($ei->size+511)%512);}function
  1676. ini_bytes($Nd){$X=ini_get($Nd);switch(strtolower(substr($X,-1))){case'g':$X*=1024;case'm':$X*=1024;case'k':$X*=1024;}return$X;}function
  1677. doc_link($Tf,$Vh="<sup>?</sup>"){global$x,$g;$fh=$g->server_info;$Ri=preg_replace('~^(\d\.?\d).*~s','\1',$fh);$Hi=array('sql'=>"https://dev.mysql.com/doc/refman/$Ri/en/",'sqlite'=>"https://www.sqlite.org/",'pgsql'=>"https://www.postgresql.org/docs/$Ri/static/",'mssql'=>"https://msdn.microsoft.com/library/",'oracle'=>"https://download.oracle.com/docs/cd/B19306_01/server.102/b14200/",);if(preg_match('~MariaDB~',$fh)){$Hi['sql']="https://mariadb.com/kb/en/library/";$Tf['sql']=(isset($Tf['mariadb'])?$Tf['mariadb']:str_replace(".html","/",$Tf['sql']));}return($Tf[$x]?"<a href='$Hi[$x]$Tf[$x]'".target_blank().">$Vh</a>":"");}function
  1678. ob_gzencode($Q){return
  1679. gzencode($Q);}function
  1680. db_size($l){global$g;if(!$g->select_db($l))return"?";$I=0;foreach(table_status()as$S)$I+=$S["Data_length"]+$S["Index_length"];return
  1681. format_number($I);}function
  1682. set_utf8mb4($i){global$g;static$O=false;if(!$O&&preg_match('~\butf8mb4~i',$i)){$O=true;echo"SET NAMES ".charset($g).";\n\n";}}function
  1683. connect_error(){global$b,$g,$hi,$n,$dc;if(DB!=""){header("HTTP/1.1 404 Not Found");page_header('Database'.": ".h(DB),'Invalid database.',true);}else{if($_POST["db"]&&!$n)queries_redirect(substr(ME,0,-1),'Databases have been dropped.',drop_databases($_POST["db"]));page_header('Select database',$n,false);echo"<p class='links'>\n";foreach(array('database'=>'Create database','privileges'=>'Privileges','processlist'=>'Process list','variables'=>'Variables','status'=>'Status',)as$y=>$X){if(support($y))echo"<a href='".h(ME)."$y='>$X</a>\n";}echo"<p>".sprintf('%s version: %s through PHP extension %s',$dc[DRIVER],"<b>".h($g->server_info)."</b>","<b>$g->extension</b>")."\n","<p>".sprintf('Logged as: %s',"<b>".h(logged_user())."</b>")."\n";$k=$b->databases();if($k){$Vg=support("scheme");$ob=collations();echo"<form action='' method='post'>\n","<table cellspacing='0' class='checkable'>\n",script("mixin(qsl('table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true)});"),"<thead><tr>".(support("database")?"<td>":"")."<th>".'Database'." - <a href='".h(ME)."refresh=1'>".'Refresh'."</a>"."<td>".'Collation'."<td>".'Tables'."<td>".'Size'." - <a href='".h(ME)."dbsize=1'>".'Compute'."</a>".script("qsl('a').onclick = partial(ajaxSetHtml, '".js_escape(ME)."script=connect');","")."</thead>\n";$k=($_GET["dbsize"]?count_tables($k):array_flip($k));foreach($k
  1684. as$l=>$T){$Ng=h(ME)."db=".urlencode($l);$t=h("Db-".$l);echo"<tr".odd().">".(support("database")?"<td>".checkbox("db[]",$l,in_array($l,(array)$_POST["db"]),"","","",$t):""),"<th><a href='$Ng' id='$t'>".h($l)."</a>";$d=h(db_collation($l,$ob));echo"<td>".(support("database")?"<a href='$Ng".($Vg?"&amp;ns=":"")."&amp;database=' title='".'Alter database'."'>$d</a>":$d),"<td align='right'><a href='$Ng&amp;schema=' id='tables-".h($l)."' title='".'Database schema'."'>".($_GET["dbsize"]?$T:"?")."</a>","<td align='right' id='size-".h($l)."'>".($_GET["dbsize"]?db_size($l):"?"),"\n";}echo"</table>\n",(support("database")?"<div class='footer'><div>\n"."<fieldset><legend>".'Selected'." <span id='selected'></span></legend><div>\n"."<input type='hidden' name='all' value=''>".script("qsl('input').onclick = function () { selectCount('selected', formChecked(this, /^db/)); };")."<input type='submit' name='drop' value='".'Drop'."'>".confirm()."\n"."</div></fieldset>\n"."</div></div>\n":""),"<input type='hidden' name='token' value='$hi'>\n","</form>\n",script("tableCheck();");}}page_footer("db");}if(isset($_GET["status"]))$_GET["variables"]=$_GET["status"];if(isset($_GET["import"]))$_GET["sql"]=$_GET["import"];if(!(DB!=""?$g->select_db(DB):isset($_GET["sql"])||isset($_GET["dump"])||isset($_GET["database"])||isset($_GET["processlist"])||isset($_GET["privileges"])||isset($_GET["user"])||isset($_GET["variables"])||$_GET["script"]=="connect"||$_GET["script"]=="kill")){if(DB!=""||$_GET["refresh"]){restart_session();set_session("dbs",null);}connect_error();exit;}if(support("scheme")&&DB!=""&&$_GET["ns"]!==""){if(!isset($_GET["ns"]))redirect(preg_replace('~ns=[^&]*&~','',ME)."ns=".get_schema());if(!set_schema($_GET["ns"])){header("HTTP/1.1 404 Not Found");page_header('Schema'.": ".h($_GET["ns"]),'Invalid schema.',true);page_footer("ns");exit;}}$kf="RESTRICT|NO ACTION|CASCADE|SET NULL|SET DEFAULT";class
  1685. TmpFile{var$handler;var$size;function
  1686. __construct(){$this->handler=tmpfile();}function
  1687. write($zb){$this->size+=strlen($zb);fwrite($this->handler,$zb);}function
  1688. send(){fseek($this->handler,0);fpassthru($this->handler);fclose($this->handler);}}$vc="'(?:''|[^'\\\\]|\\\\.)*'";$Od="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"])){$a=$_GET["download"];$p=fields($a);header("Content-Type: application/octet-stream");header("Content-Disposition: attachment; filename=".friendly_url("$a-".implode("_",$_GET["where"])).".".friendly_url($_GET["field"]));$L=array(idf_escape($_GET["field"]));$H=$m->select($a,$L,array(where($_GET,$p)),$L);$J=($H?$H->fetch_row():array());echo$m->value($J[0],$p[$_GET["field"]]);exit;}elseif(isset($_GET["table"])){$a=$_GET["table"];$p=fields($a);if(!$p)$n=error();$S=table_status1($a,true);$C=$b->tableName($S);page_header(($p&&is_view($S)?$S['Engine']=='materialized view'?'Materialized view':'View':'Table').": ".($C!=""?$C:h($a)),$n);$b->selectLinks($S);$tb=$S["Comment"];if($tb!="")echo"<p class='nowrap'>".'Comment'.": ".h($tb)."\n";if($p)$b->tableStructurePrint($p);if(!is_view($S)){if(support("indexes")){echo"<h3 id='indexes'>".'Indexes'."</h3>\n";$w=indexes($a);if($w)$b->tableIndexesPrint($w);echo'<p class="links"><a href="'.h(ME).'indexes='.urlencode($a).'">'.'Alter indexes'."</a>\n";}if(fk_support($S)){echo"<h3 id='foreign-keys'>".'Foreign keys'."</h3>\n";$dd=foreign_keys($a);if($dd){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Source'."<td>".'Target'."<td>".'ON DELETE'."<td>".'ON UPDATE'."<td></thead>\n";foreach($dd
  1689. as$C=>$q){echo"<tr title='".h($C)."'>","<th><i>".implode("</i>, <i>",array_map('h',$q["source"]))."</i>","<td><a href='".h($q["db"]!=""?preg_replace('~db=[^&]*~',"db=".urlencode($q["db"]),ME):($q["ns"]!=""?preg_replace('~ns=[^&]*~',"ns=".urlencode($q["ns"]),ME):ME))."table=".urlencode($q["table"])."'>".($q["db"]!=""?"<b>".h($q["db"])."</b>.":"").($q["ns"]!=""?"<b>".h($q["ns"])."</b>.":"").h($q["table"])."</a>","(<i>".implode("</i>, <i>",array_map('h',$q["target"]))."</i>)","<td>".h($q["on_delete"])."\n","<td>".h($q["on_update"])."\n",'<td><a href="'.h(ME.'foreign='.urlencode($a).'&name='.urlencode($C)).'">'.'Alter'.'</a>';}echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'foreign='.urlencode($a).'">'.'Add foreign key'."</a>\n";}}if(support(is_view($S)?"view_trigger":"trigger")){echo"<h3 id='triggers'>".'Triggers'."</h3>\n";$ti=triggers($a);if($ti){echo"<table cellspacing='0'>\n";foreach($ti
  1690. as$y=>$X)echo"<tr valign='top'><td>".h($X[0])."<td>".h($X[1])."<th>".h($y)."<td><a href='".h(ME.'trigger='.urlencode($a).'&name='.urlencode($y))."'>".'Alter'."</a>\n";echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'trigger='.urlencode($a).'">'.'Add trigger'."</a>\n";}}elseif(isset($_GET["schema"])){page_header('Database schema',"",array(),h(DB.($_GET["ns"]?".$_GET[ns]":"")));$Kh=array();$Lh=array();$ea=($_GET["schema"]?$_GET["schema"]:$_COOKIE["adminer_schema-".str_replace(".","_",DB)]);preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~',$ea,$_e,PREG_SET_ORDER);foreach($_e
  1691. as$s=>$B){$Kh[$B[1]]=array($B[2],$B[3]);$Lh[]="\n\t'".js_escape($B[1])."': [ $B[2], $B[3] ]";}$ii=0;$Qa=-1;$Ug=array();$_g=array();$oe=array();foreach(table_status('',true)as$R=>$S){if(is_view($S))continue;$Yf=0;$Ug[$R]["fields"]=array();foreach(fields($R)as$C=>$o){$Yf+=1.25;$o["pos"]=$Yf;$Ug[$R]["fields"][$C]=$o;}$Ug[$R]["pos"]=($Kh[$R]?$Kh[$R]:array($ii,0));foreach($b->foreignKeys($R)as$X){if(!$X["db"]){$me=$Qa;if($Kh[$R][1]||$Kh[$X["table"]][1])$me=min(floatval($Kh[$R][1]),floatval($Kh[$X["table"]][1]))-1;else$Qa-=.1;while($oe[(string)$me])$me-=.0001;$Ug[$R]["references"][$X["table"]][(string)$me]=array($X["source"],$X["target"]);$_g[$X["table"]][$R][(string)$me]=$X["target"];$oe[(string)$me]=true;}}$ii=max($ii,$Ug[$R]["pos"][0]+2.5+$Yf);}echo'<div id="schema" style="height: ',$ii,'em;">
  1692. <script',nonce(),'>
  1693. qs(\'#schema\').onselectstart = function () { return false; };
  1694. var tablePos = {',implode(",",$Lh)."\n",'};
  1695. var em = qs(\'#schema\').offsetHeight / ',$ii,';
  1696. document.onmousemove = schemaMousemove;
  1697. document.onmouseup = partialArg(schemaMouseup, \'',js_escape(DB),'\');
  1698. </script>
  1699. ';foreach($Ug
  1700. as$C=>$R){echo"<div class='table' style='top: ".$R["pos"][0]."em; left: ".$R["pos"][1]."em;'>",'<a href="'.h(ME).'table='.urlencode($C).'"><b>'.h($C)."</b></a>",script("qsl('div').onmousedown = schemaMousedown;");foreach($R["fields"]as$o){$X='<span'.type_class($o["type"]).' title="'.h($o["full_type"].($o["null"]?" NULL":'')).'">'.h($o["field"]).'</span>';echo"<br>".($o["primary"]?"<i>$X</i>":$X);}foreach((array)$R["references"]as$Rh=>$Ag){foreach($Ag
  1701. as$me=>$xg){$ne=$me-$Kh[$C][1];$s=0;foreach($xg[0]as$ph)echo"\n<div class='references' title='".h($Rh)."' id='refs$me-".($s++)."' style='left: $ne"."em; top: ".$R["fields"][$ph]["pos"]."em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: ".(-$ne)."em;'></div></div>";}}foreach((array)$_g[$C]as$Rh=>$Ag){foreach($Ag
  1702. as$me=>$f){$ne=$me-$Kh[$C][1];$s=0;foreach($f
  1703. as$Qh)echo"\n<div class='references' title='".h($Rh)."' id='refd$me-".($s++)."' style='left: $ne"."em; top: ".$R["fields"][$Qh]["pos"]."em; height: 1.25em; background: url(".h(preg_replace("~\\?.*~","",ME)."?file=arrow.gif) no-repeat right center;&version=4.6.3")."'><div style='height: .5em; border-bottom: 1px solid Gray; width: ".(-$ne)."em;'></div></div>";}}echo"\n</div>\n";}foreach($Ug
  1704. as$C=>$R){foreach((array)$R["references"]as$Rh=>$Ag){foreach($Ag
  1705. as$me=>$xg){$Oe=$ii;$De=-10;foreach($xg[0]as$y=>$ph){$Zf=$R["pos"][0]+$R["fields"][$ph]["pos"];$ag=$Ug[$Rh]["pos"][0]+$Ug[$Rh]["fields"][$xg[1][$y]]["pos"];$Oe=min($Oe,$Zf,$ag);$De=max($De,$Zf,$ag);}echo"<div class='references' id='refl$me' style='left: $me"."em; top: $Oe"."em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: ".($De-$Oe)."em;'></div></div>\n";}}}echo'</div>
  1706. <p class="links"><a href="',h(ME."schema=".urlencode($ea)),'" id="schema-link">Permanent link</a>
  1707. ';}elseif(isset($_GET["dump"])){$a=$_GET["dump"];if($_POST&&!$n){$Bb="";foreach(array("output","format","db_style","routines","events","table_style","auto_increment","triggers","data_style")as$y)$Bb.="&$y=".urlencode($_POST[$y]);cookie("adminer_export",substr($Bb,1));$T=array_flip((array)$_POST["tables"])+array_flip((array)$_POST["data"]);$Hc=dump_headers((count($T)==1?key($T):DB),(DB==""||count($T)>1));$Wd=preg_match('~sql~',$_POST["format"]);if($Wd){echo"-- Adminer $ia ".$dc[DRIVER]." dump\n\n";if($x=="sql"){echo"SET NAMES utf8;
  1708. SET time_zone = '+00:00';
  1709. ".($_POST["data_style"]?"SET foreign_key_checks = 0;
  1710. SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';
  1711. ":"")."
  1712. ";$g->query("SET time_zone = '+00:00';");}}$Bh=$_POST["db_style"];$k=array(DB);if(DB==""){$k=$_POST["databases"];if(is_string($k))$k=explode("\n",rtrim(str_replace("\r","",$k),"\n"));}foreach((array)$k
  1713. as$l){$b->dumpDatabase($l);if($g->select_db($l)){if($Wd&&preg_match('~CREATE~',$Bh)&&($i=$g->result("SHOW CREATE DATABASE ".idf_escape($l),1))){set_utf8mb4($i);if($Bh=="DROP+CREATE")echo"DROP DATABASE IF EXISTS ".idf_escape($l).";\n";echo"$i;\n";}if($Wd){if($Bh)echo
  1714. use_sql($l).";\n\n";$Df="";if($_POST["routines"]){foreach(array("FUNCTION","PROCEDURE")as$Og){foreach(get_rows("SHOW $Og STATUS WHERE Db = ".q($l),null,"-- ")as$J){$i=remove_definer($g->result("SHOW CREATE $Og ".idf_escape($J["Name"]),2));set_utf8mb4($i);$Df.=($Bh!='DROP+CREATE'?"DROP $Og IF EXISTS ".idf_escape($J["Name"]).";;\n":"")."$i;;\n\n";}}}if($_POST["events"]){foreach(get_rows("SHOW EVENTS",null,"-- ")as$J){$i=remove_definer($g->result("SHOW CREATE EVENT ".idf_escape($J["Name"]),3));set_utf8mb4($i);$Df.=($Bh!='DROP+CREATE'?"DROP EVENT IF EXISTS ".idf_escape($J["Name"]).";;\n":"")."$i;;\n\n";}}if($Df)echo"DELIMITER ;;\n\n$Df"."DELIMITER ;\n\n";}if($_POST["table_style"]||$_POST["data_style"]){$Ti=array();foreach(table_status('',true)as$C=>$S){$R=(DB==""||in_array($C,(array)$_POST["tables"]));$Kb=(DB==""||in_array($C,(array)$_POST["data"]));if($R||$Kb){if($Hc=="tar"){$ei=new
  1715. TmpFile;ob_start(array($ei,'write'),1e5);}$b->dumpTable($C,($R?$_POST["table_style"]:""),(is_view($S)?2:0));if(is_view($S))$Ti[]=$C;elseif($Kb){$p=fields($C);$b->dumpData($C,$_POST["data_style"],"SELECT *".convert_fields($p,$p)." FROM ".table($C));}if($Wd&&$_POST["triggers"]&&$R&&($ti=trigger_sql($C)))echo"\nDELIMITER ;;\n$ti\nDELIMITER ;\n";if($Hc=="tar"){ob_end_flush();tar_file((DB!=""?"":"$l/")."$C.csv",$ei);}elseif($Wd)echo"\n";}}foreach($Ti
  1716. as$Si)$b->dumpTable($Si,$_POST["table_style"],1);if($Hc=="tar")echo
  1717. pack("x512");}}}if($Wd)echo"-- ".$g->result("SELECT NOW()")."\n";exit;}page_header('Export',$n,($_GET["export"]!=""?array("table"=>$_GET["export"]):array()),h(DB));echo'
  1718. <form action="" method="post">
  1719. <table cellspacing="0">
  1720. ';$Ob=array('','USE','DROP+CREATE','CREATE');$Mh=array('','DROP+CREATE','CREATE');$Lb=array('','TRUNCATE+INSERT','INSERT');if($x=="sql")$Lb[]='INSERT+UPDATE';parse_str($_COOKIE["adminer_export"],$J);if(!$J)$J=array("output"=>"text","format"=>"sql","db_style"=>(DB!=""?"":"CREATE"),"table_style"=>"DROP+CREATE","data_style"=>"INSERT");if(!isset($J["events"])){$J["routines"]=$J["events"]=($_GET["dump"]=="");$J["triggers"]=$J["table_style"];}echo"<tr><th>".'Output'."<td>".html_select("output",$b->dumpOutput(),$J["output"],0)."\n";echo"<tr><th>".'Format'."<td>".html_select("format",$b->dumpFormat(),$J["format"],0)."\n";echo($x=="sqlite"?"":"<tr><th>".'Database'."<td>".html_select('db_style',$Ob,$J["db_style"]).(support("routine")?checkbox("routines",1,$J["routines"],'Routines'):"").(support("event")?checkbox("events",1,$J["events"],'Events'):"")),"<tr><th>".'Tables'."<td>".html_select('table_style',$Mh,$J["table_style"]).checkbox("auto_increment",1,$J["auto_increment"],'Auto Increment').(support("trigger")?checkbox("triggers",1,$J["triggers"],'Triggers'):""),"<tr><th>".'Data'."<td>".html_select('data_style',$Lb,$J["data_style"]),'</table>
  1721. <p><input type="submit" value="Export">
  1722. <input type="hidden" name="token" value="',$hi,'">
  1723.  
  1724. <table cellspacing="0">
  1725. ',script("qsl('table').onclick = dumpClick;");$dg=array();if(DB!=""){$eb=($a!=""?"":" checked");echo"<thead><tr>","<th style='text-align: left;'><label class='block'><input type='checkbox' id='check-tables'$eb>".'Tables'."</label>".script("qs('#check-tables').onclick = partial(formCheck, /^tables\\[/);",""),"<th style='text-align: right;'><label class='block'>".'Data'."<input type='checkbox' id='check-data'$eb></label>".script("qs('#check-data').onclick = partial(formCheck, /^data\\[/);",""),"</thead>\n";$Ti="";$Nh=tables_list();foreach($Nh
  1726. as$C=>$U){$cg=preg_replace('~_.*~','',$C);$eb=($a==""||$a==(substr($a,-1)=="%"?"$cg%":$C));$gg="<tr><td>".checkbox("tables[]",$C,$eb,$C,"","block");if($U!==null&&!preg_match('~table~i',$U))$Ti.="$gg\n";else
  1727. echo"$gg<td align='right'><label class='block'><span id='Rows-".h($C)."'></span>".checkbox("data[]",$C,$eb)."</label>\n";$dg[$cg]++;}echo$Ti;if($Nh)echo
  1728. script("ajaxSetHtml('".js_escape(ME)."script=db');");}else{echo"<thead><tr><th style='text-align: left;'>","<label class='block'><input type='checkbox' id='check-databases'".($a==""?" checked":"").">".'Database'."</label>",script("qs('#check-databases').onclick = partial(formCheck, /^databases\\[/);",""),"</thead>\n";$k=$b->databases();if($k){foreach($k
  1729. as$l){if(!information_schema($l)){$cg=preg_replace('~_.*~','',$l);echo"<tr><td>".checkbox("databases[]",$l,$a==""||$a=="$cg%",$l,"","block")."\n";$dg[$cg]++;}}}else
  1730. echo"<tr><td><textarea name='databases' rows='10' cols='20'></textarea>";}echo'</table>
  1731. </form>
  1732. ';$Vc=true;foreach($dg
  1733. as$y=>$X){if($y!=""&&$X>1){echo($Vc?"<p>":" ")."<a href='".h(ME)."dump=".urlencode("$y%")."'>".h($y)."</a>";$Vc=false;}}}elseif(isset($_GET["privileges"])){page_header('Privileges');echo'<p class="links"><a href="'.h(ME).'user=">'.'Create user'."</a>";$H=$g->query("SELECT User, Host FROM mysql.".(DB==""?"user":"db WHERE ".q(DB)." LIKE Db")." ORDER BY Host, User");$kd=$H;if(!$H)$H=$g->query("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', 1) AS User, SUBSTRING_INDEX(CURRENT_USER, '@', -1) AS Host");echo"<form action=''><p>\n";hidden_fields_get();echo"<input type='hidden' name='db' value='".h(DB)."'>\n",($kd?"":"<input type='hidden' name='grant' value=''>\n"),"<table cellspacing='0'>\n","<thead><tr><th>".'Username'."<th>".'Server'."<th></thead>\n";while($J=$H->fetch_assoc())echo'<tr'.odd().'><td>'.h($J["User"])."<td>".h($J["Host"]).'<td><a href="'.h(ME.'user='.urlencode($J["User"]).'&host='.urlencode($J["Host"])).'">'.'Edit'."</a>\n";if(!$kd||DB!="")echo"<tr".odd()."><td><input name='user' autocapitalize='off'><td><input name='host' value='localhost' autocapitalize='off'><td><input type='submit' value='".'Edit'."'>\n";echo"</table>\n","</form>\n";}elseif(isset($_GET["sql"])){if(!$n&&$_POST["export"]){dump_headers("sql");$b->dumpTable("","");$b->dumpData("","table",$_POST["query"]);exit;}restart_session();$yd=&get_session("queries");$xd=&$yd[DB];if(!$n&&$_POST["clear"]){$xd=array();redirect(remove_from_uri("history"));}page_header((isset($_GET["import"])?'Import':'SQL command'),$n);if(!$n&&$_POST){$hd=false;if(!isset($_GET["import"]))$G=$_POST["query"];elseif($_POST["webfile"]){$th=$b->importServerPath();$hd=@fopen((file_exists($th)?$th:"compress.zlib://$th.gz"),"rb");$G=($hd?fread($hd,1e6):false);}else$G=get_file("sql_file",true);if(is_string($G)){if(function_exists('memory_get_usage'))@ini_set("memory_limit",max(ini_bytes("memory_limit"),2*strlen($G)+memory_get_usage()+8e6));if($G!=""&&strlen($G)<1e6){$og=$G.(preg_match("~;[ \t\r\n]*\$~",$G)?"":";");if(!$xd||reset(end($xd))!=$og){restart_session();$xd[]=array($og,time());set_session("queries",$yd);stop_session();}}$qh="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$Ub=";";$D=0;$sc=true;$h=connect();if(is_object($h)&&DB!="")$h->select_db(DB);$sb=0;$xc=array();$Kf='[\'"'.($x=="sql"?'`#':($x=="sqlite"?'`[':($x=="mssql"?'[':''))).']|/\*|-- |$'.($x=="pgsql"?'|\$[^$]*\$':'');$ji=microtime(true);parse_str($_COOKIE["adminer_export"],$xa);$jc=$b->dumpFormat();unset($jc["sql"]);while($G!=""){if(!$D&&preg_match("~^$qh*+DELIMITER\\s+(\\S+)~i",$G,$B)){$Ub=$B[1];$G=substr($G,strlen($B[0]));}else{preg_match('('.preg_quote($Ub)."\\s*|$Kf)",$G,$B,PREG_OFFSET_CAPTURE,$D);list($fd,$Yf)=$B[0];if(!$fd&&$hd&&!feof($hd))$G.=fread($hd,1e5);else{if(!$fd&&rtrim($G)=="")break;$D=$Yf+strlen($fd);if($fd&&rtrim($fd)!=$Ub){while(preg_match('('.($fd=='/*'?'\*/':($fd=='['?']':(preg_match('~^-- |^#~',$fd)?"\n":preg_quote($fd)."|\\\\."))).'|$)s',$G,$B,PREG_OFFSET_CAPTURE,$D)){$Sg=$B[0][0];if(!$Sg&&$hd&&!feof($hd))$G.=fread($hd,1e5);else{$D=$B[0][1]+strlen($Sg);if($Sg[0]!="\\")break;}}}else{$sc=false;$og=substr($G,0,$Yf);$sb++;$gg="<pre id='sql-$sb'><code class='jush-$x'>".$b->sqlCommandQuery($og)."</code></pre>\n";if($x=="sqlite"&&preg_match("~^$qh*+ATTACH\\b~i",$og,$B)){echo$gg,"<p class='error'>".'ATTACH queries are not supported.'."\n";$xc[]=" <a href='#sql-$sb'>$sb</a>";if($_POST["error_stops"])break;}else{if(!$_POST["only_errors"]){echo$gg;ob_flush();flush();}$xh=microtime(true);if($g->multi_query($og)&&is_object($h)&&preg_match("~^$qh*+USE\\b~i",$og))$h->query($og);do{$H=$g->store_result();if($g->error){echo($_POST["only_errors"]?$gg:""),"<p class='error'>".'Error in query'.($g->errno?" ($g->errno)":"").": ".error()."\n";$xc[]=" <a href='#sql-$sb'>$sb</a>";if($_POST["error_stops"])break
  1734. 2;}else{$Xh=" <span class='time'>(".format_time($xh).")</span>".(strlen($og)<1000?" <a href='".h(ME)."sql=".urlencode(trim($og))."'>".'Edit'."</a>":"");$za=$g->affected_rows;$Wi=($_POST["only_errors"]?"":$m->warnings());$Xi="warnings-$sb";if($Wi)$Xh.=", <a href='#$Xi'>".'Warnings'."</a>".script("qsl('a').onclick = partial(toggle, '$Xi');","");$Ec=null;$Fc="explain-$sb";if(is_object($H)){$z=$_POST["limit"];$xf=select($H,$h,array(),$z);if(!$_POST["only_errors"]){echo"<form action='' method='post'>\n";$af=$H->num_rows;echo"<p>".($af?($z&&$af>$z?sprintf('%d / ',$z):"").lang(array('%d row','%d rows'),$af):""),$Xh;if($h&&preg_match("~^($qh|\\()*+SELECT\\b~i",$og)&&($Ec=explain($h,$og)))echo", <a href='#$Fc'>Explain</a>".script("qsl('a').onclick = partial(toggle, '$Fc');","");$t="export-$sb";echo", <a href='#$t'>".'Export'."</a>".script("qsl('a').onclick = partial(toggle, '$t');","")."<span id='$t' class='hidden'>: ".html_select("output",$b->dumpOutput(),$xa["output"])." ".html_select("format",$jc,$xa["format"])."<input type='hidden' name='query' value='".h($og)."'>"." <input type='submit' name='export' value='".'Export'."'><input type='hidden' name='token' value='$hi'></span>\n"."</form>\n";}}else{if(preg_match("~^$qh*+(CREATE|DROP|ALTER)$qh++(DATABASE|SCHEMA)\\b~i",$og)){restart_session();set_session("dbs",null);stop_session();}if(!$_POST["only_errors"])echo"<p class='message' title='".h($g->info)."'>".lang(array('Query executed OK, %d row affected.','Query executed OK, %d rows affected.'),$za)."$Xh\n";}echo($Wi?"<div id='$Xi' class='hidden'>\n$Wi</div>\n":"");if($Ec){echo"<div id='$Fc' class='hidden'>\n";select($Ec,$h,$xf);echo"</div>\n";}}$xh=microtime(true);}while($g->next_result());}$G=substr($G,$D);$D=0;}}}}if($sc)echo"<p class='message'>".'No commands to execute.'."\n";elseif($_POST["only_errors"]){echo"<p class='message'>".lang(array('%d query executed OK.','%d queries executed OK.'),$sb-count($xc))," <span class='time'>(".format_time($ji).")</span>\n";}elseif($xc&&$sb>1)echo"<p class='error'>".'Error in query'.": ".implode("",$xc)."\n";}else
  1735. echo"<p class='error'>".upload_error($G)."\n";}echo'
  1736. <form action="" method="post" enctype="multipart/form-data" id="form">
  1737. ';$Bc="<input type='submit' value='".'Execute'."' title='Ctrl+Enter'>";if(!isset($_GET["import"])){$og=$_GET["sql"];if($_POST)$og=$_POST["query"];elseif($_GET["history"]=="all")$og=$xd;elseif($_GET["history"]!="")$og=$xd[$_GET["history"]][0];echo"<p>";textarea("query",$og,20);echo($_POST?"":script("qs('textarea').focus();")),"<p>$Bc\n",'Limit rows'.": <input type='number' name='limit' class='size' value='".h($_POST?$_POST["limit"]:$_GET["limit"])."'>\n";}else{echo"<fieldset><legend>".'File upload'."</legend><div>";$qd=(extension_loaded("zlib")?"[.gz]":"");echo(ini_bool("file_uploads")?"SQL$qd (&lt; ".ini_get("upload_max_filesize")."B): <input type='file' name='sql_file[]' multiple>\n$Bc":'File uploads are disabled.'),"</div></fieldset>\n","<fieldset><legend>".'From server'."</legend><div>",sprintf('Webserver file %s',"<code>".h($b->importServerPath())."$qd</code>"),' <input type="submit" name="webfile" value="'.'Run file'.'">',"</div></fieldset>\n","<p>";}echo
  1738. checkbox("error_stops",1,($_POST?$_POST["error_stops"]:isset($_GET["import"])),'Stop on error')."\n",checkbox("only_errors",1,($_POST?$_POST["only_errors"]:isset($_GET["import"])),'Show only errors')."\n","<input type='hidden' name='token' value='$hi'>\n";if(!isset($_GET["import"])&&$xd){print_fieldset("history",'History',$_GET["history"]!="");for($X=end($xd);$X;$X=prev($xd)){$y=key($xd);list($og,$Xh,$nc)=$X;echo'<a href="'.h(ME."sql=&history=$y").'">'.'Edit'."</a>"." <span class='time' title='".@date('Y-m-d',$Xh)."'>".@date("H:i:s",$Xh)."</span>"." <code class='jush-$x'>".shorten_utf8(ltrim(str_replace("\n"," ",str_replace("\r","",preg_replace('~^(#|-- ).*~m','',$og)))),80,"</code>").($nc?" <span class='time'>($nc)</span>":"")."<br>\n";}echo"<input type='submit' name='clear' value='".'Clear'."'>\n","<a href='".h(ME."sql=&history=all")."'>".'Edit all'."</a>\n","</div></fieldset>\n";}echo'</form>
  1739. ';}elseif(isset($_GET["edit"])){$a=$_GET["edit"];$p=fields($a);$Z=(isset($_GET["select"])?($_POST["check"]&&count($_POST["check"])==1?where_check($_POST["check"][0],$p):""):where($_GET,$p));$Di=(isset($_GET["select"])?$_POST["edit"]:$Z);foreach($p
  1740. as$C=>$o){if(!isset($o["privileges"][$Di?"update":"insert"])||$b->fieldName($o)=="")unset($p[$C]);}if($_POST&&!$n&&!isset($_GET["select"])){$A=$_POST["referer"];if($_POST["insert"])$A=($Di?null:$_SERVER["REQUEST_URI"]);elseif(!preg_match('~^.+&select=.+$~',$A))$A=ME."select=".urlencode($a);$w=indexes($a);$zi=unique_array($_GET["where"],$w);$rg="\nWHERE $Z";if(isset($_POST["delete"]))queries_redirect($A,'Item has been deleted.',$m->delete($a,$rg,!$zi));else{$O=array();foreach($p
  1741. as$C=>$o){$X=process_input($o);if($X!==false&&$X!==null)$O[idf_escape($C)]=$X;}if($Di){if(!$O)redirect($A);queries_redirect($A,'Item has been updated.',$m->update($a,$O,$rg,!$zi));if(is_ajax()){page_headers();page_messages($n);exit;}}else{$H=$m->insert($a,$O);$le=($H?last_id():0);queries_redirect($A,sprintf('Item%s has been inserted.',($le?" $le":"")),$H);}}}$J=null;if($_POST["save"])$J=(array)$_POST["fields"];elseif($Z){$L=array();foreach($p
  1742. as$C=>$o){if(isset($o["privileges"]["select"])){$Ga=convert_field($o);if($_POST["clone"]&&$o["auto_increment"])$Ga="''";if($x=="sql"&&preg_match("~enum|set~",$o["type"]))$Ga="1*".idf_escape($C);$L[]=($Ga?"$Ga AS ":"").idf_escape($C);}}$J=array();if(!support("table"))$L=array("*");if($L){$H=$m->select($a,$L,array($Z),$L,array(),(isset($_GET["select"])?2:1));if(!$H)$n=error();else{$J=$H->fetch_assoc();if(!$J)$J=false;}if(isset($_GET["select"])&&(!$J||$H->fetch_assoc()))$J=null;}}if(!support("table")&&!$p){if(!$Z){$H=$m->select($a,array("*"),$Z,array("*"));$J=($H?$H->fetch_assoc():false);if(!$J)$J=array($m->primary=>"");}if($J){foreach($J
  1743. as$y=>$X){if(!$Z)$J[$y]=null;$p[$y]=array("field"=>$y,"null"=>($y!=$m->primary),"auto_increment"=>($y==$m->primary));}}}edit_form($a,$p,$J,$Di);}elseif(isset($_GET["create"])){$a=$_GET["create"];$Mf=array();foreach(array('HASH','LINEAR HASH','KEY','LINEAR KEY','RANGE','LIST')as$y)$Mf[$y]=$y;$zg=referencable_primary($a);$dd=array();foreach($zg
  1744. as$Ih=>$o)$dd[str_replace("`","``",$Ih)."`".str_replace("`","``",$o["field"])]=$Ih;$_f=array();$S=array();if($a!=""){$_f=fields($a);$S=table_status($a);if(!$S)$n='No tables.';}$J=$_POST;$J["fields"]=(array)$J["fields"];if($J["auto_increment_col"])$J["fields"][$J["auto_increment_col"]]["auto_increment"]=true;if($_POST&&!process_fields($J["fields"])&&!$n){if($_POST["drop"])queries_redirect(substr(ME,0,-1),'Table has been dropped.',drop_tables(array($a)));else{$p=array();$Da=array();$Ii=false;$bd=array();$zf=reset($_f);$Aa=" FIRST";foreach($J["fields"]as$y=>$o){$q=$dd[$o["type"]];$ui=($q!==null?$zg[$q]:$o);if($o["field"]!=""){if(!$o["has_default"])$o["default"]=null;if($y==$J["auto_increment_col"])$o["auto_increment"]=true;$lg=process_field($o,$ui);$Da[]=array($o["orig"],$lg,$Aa);if($lg!=process_field($zf,$zf)){$p[]=array($o["orig"],$lg,$Aa);if($o["orig"]!=""||$Aa)$Ii=true;}if($q!==null)$bd[idf_escape($o["field"])]=($a!=""&&$x!="sqlite"?"ADD":" ").format_foreign_key(array('table'=>$dd[$o["type"]],'source'=>array($o["field"]),'target'=>array($ui["field"]),'on_delete'=>$o["on_delete"],));$Aa=" AFTER ".idf_escape($o["field"]);}elseif($o["orig"]!=""){$Ii=true;$p[]=array($o["orig"]);}if($o["orig"]!=""){$zf=next($_f);if(!$zf)$Aa="";}}$Of="";if($Mf[$J["partition_by"]]){$Pf=array();if($J["partition_by"]=='RANGE'||$J["partition_by"]=='LIST'){foreach(array_filter($J["partition_names"])as$y=>$X){$Y=$J["partition_values"][$y];$Pf[]="\n PARTITION ".idf_escape($X)." VALUES ".($J["partition_by"]=='RANGE'?"LESS THAN":"IN").($Y!=""?" ($Y)":" MAXVALUE");}}$Of.="\nPARTITION BY $J[partition_by]($J[partition])".($Pf?" (".implode(",",$Pf)."\n)":($J["partitions"]?" PARTITIONS ".(+$J["partitions"]):""));}elseif(support("partitioning")&&preg_match("~partitioned~",$S["Create_options"]))$Of.="\nREMOVE PARTITIONING";$He='Table has been altered.';if($a==""){cookie("adminer_engine",$J["Engine"]);$He='Table has been created.';}$C=trim($J["name"]);queries_redirect(ME.(support("table")?"table=":"select=").urlencode($C),$He,alter_table($a,$C,($x=="sqlite"&&($Ii||$bd)?$Da:$p),$bd,($J["Comment"]!=$S["Comment"]?$J["Comment"]:null),($J["Engine"]&&$J["Engine"]!=$S["Engine"]?$J["Engine"]:""),($J["Collation"]&&$J["Collation"]!=$S["Collation"]?$J["Collation"]:""),($J["Auto_increment"]!=""?number($J["Auto_increment"]):""),$Of));}}page_header(($a!=""?'Alter table':'Create table'),$n,array("table"=>$a),h($a));if(!$_POST){$J=array("Engine"=>$_COOKIE["adminer_engine"],"fields"=>array(array("field"=>"","type"=>(isset($wi["int"])?"int":(isset($wi["integer"])?"integer":"")),"on_update"=>"")),"partition_names"=>array(""),);if($a!=""){$J=$S;$J["name"]=$a;$J["fields"]=array();if(!$_GET["auto_increment"])$J["Auto_increment"]="";foreach($_f
  1745. as$o){$o["has_default"]=isset($o["default"]);$J["fields"][]=$o;}if(support("partitioning")){$id="FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA = ".q(DB)." AND TABLE_NAME = ".q($a);$H=$g->query("SELECT PARTITION_METHOD, PARTITION_ORDINAL_POSITION, PARTITION_EXPRESSION $id ORDER BY PARTITION_ORDINAL_POSITION DESC LIMIT 1");list($J["partition_by"],$J["partitions"],$J["partition"])=$H->fetch_row();$Pf=get_key_vals("SELECT PARTITION_NAME, PARTITION_DESCRIPTION $id AND PARTITION_NAME != '' ORDER BY PARTITION_ORDINAL_POSITION");$Pf[""]="";$J["partition_names"]=array_keys($Pf);$J["partition_values"]=array_values($Pf);}}}$ob=collations();$uc=engines();foreach($uc
  1746. as$tc){if(!strcasecmp($tc,$J["Engine"])){$J["Engine"]=$tc;break;}}echo'
  1747. <form action="" method="post" id="form">
  1748. <p>
  1749. ';if(support("columns")||$a==""){echo'Table name: <input name="name" maxlength="64" value="',h($J["name"]),'" autocapitalize="off">
  1750. ';if($a==""&&!$_POST)echo
  1751. script("focus(qs('#form')['name']);");echo($uc?"<select name='Engine'>".optionlist(array(""=>"(".'engine'.")")+$uc,$J["Engine"])."</select>".on_help("getTarget(event).value",1).script("qsl('select').onchange = helpClose;"):""),' ',($ob&&!preg_match("~sqlite|mssql~",$x)?html_select("Collation",array(""=>"(".'collation'.")")+$ob,$J["Collation"]):""),' <input type="submit" value="Save">
  1752. ';}echo'
  1753. ';if(support("columns")){echo'<table cellspacing="0" id="edit-fields" class="nowrap">
  1754. ';$ub=($_POST?$_POST["comments"]:$J["Comment"]!="");if(!$_POST&&!$ub){foreach($J["fields"]as$o){if($o["comment"]!=""){$ub=true;break;}}}edit_fields($J["fields"],$ob,"TABLE",$dd,$ub);echo'</table>
  1755. <p>
  1756. Auto Increment: <input type="number" name="Auto_increment" size="6" value="',h($J["Auto_increment"]),'">
  1757. ',checkbox("defaults",1,!$_POST||$_POST["defaults"],'Default values',"columnShow(this.checked, 5)","jsonly"),($_POST?"":script("editingHideDefaults();")),(support("comment")?"<label><input type='checkbox' name='comments' value='1' class='jsonly'".($ub?" checked":"").">".'Comment'."</label>".script("qsl('input').onclick = partial(editingCommentsClick, true);").' <input name="Comment" value="'.h($J["Comment"]).'" maxlength="'.(min_version(5.5)?2048:60).'"'.($ub?'':' class="hidden"').'>':''),'<p>
  1758. <input type="submit" value="Save">
  1759. ';}echo'
  1760. ';if($a!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$a));}if(support("partitioning")){$Nf=preg_match('~RANGE|LIST~',$J["partition_by"]);print_fieldset("partition",'Partition by',$J["partition_by"]);echo'<p>
  1761. ',"<select name='partition_by'>".optionlist(array(""=>"")+$Mf,$J["partition_by"])."</select>".on_help("getTarget(event).value.replace(/./, 'PARTITION BY \$&')",1).script("qsl('select').onchange = partitionByChange;"),'(<input name="partition" value="',h($J["partition"]),'">)
  1762. Partitions: <input type="number" name="partitions" class="size',($Nf||!$J["partition_by"]?" hidden":""),'" value="',h($J["partitions"]),'">
  1763. <table cellspacing="0" id="partition-table"',($Nf?"":" class='hidden'"),'>
  1764. <thead><tr><th>Partition name<th>Values</thead>
  1765. ';foreach($J["partition_names"]as$y=>$X){echo'<tr>','<td><input name="partition_names[]" value="'.h($X).'" autocapitalize="off">',($y==count($J["partition_names"])-1?script("qsl('input').oninput = partitionNameChange;"):''),'<td><input name="partition_values[]" value="'.h($J["partition_values"][$y]).'">';}echo'</table>
  1766. </div></fieldset>
  1767. ';}echo'<input type="hidden" name="token" value="',$hi,'">
  1768. </form>
  1769. ',script("qs('#form')['defaults'].onclick();".(support("comment")?" editingCommentsClick.call(qs('#form')['comments']);":""));}elseif(isset($_GET["indexes"])){$a=$_GET["indexes"];$Gd=array("PRIMARY","UNIQUE","INDEX");$S=table_status($a,true);if(preg_match('~MyISAM|M?aria'.(min_version(5.6,'10.0.5')?'|InnoDB':'').'~i',$S["Engine"]))$Gd[]="FULLTEXT";if(preg_match('~MyISAM|M?aria'.(min_version(5.7,'10.2.2')?'|InnoDB':'').'~i',$S["Engine"]))$Gd[]="SPATIAL";$w=indexes($a);$eg=array();if($x=="mongo"){$eg=$w["_id_"];unset($Gd[0]);unset($w["_id_"]);}$J=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["drop_col"]){$c=array();foreach($J["indexes"]as$v){$C=$v["name"];if(in_array($v["type"],$Gd)){$f=array();$re=array();$Wb=array();$O=array();ksort($v["columns"]);foreach($v["columns"]as$y=>$e){if($e!=""){$qe=$v["lengths"][$y];$Vb=$v["descs"][$y];$O[]=idf_escape($e).($qe?"(".(+$qe).")":"").($Vb?" DESC":"");$f[]=$e;$re[]=($qe?$qe:null);$Wb[]=$Vb;}}if($f){$Cc=$w[$C];if($Cc){ksort($Cc["columns"]);ksort($Cc["lengths"]);ksort($Cc["descs"]);if($v["type"]==$Cc["type"]&&array_values($Cc["columns"])===$f&&(!$Cc["lengths"]||array_values($Cc["lengths"])===$re)&&array_values($Cc["descs"])===$Wb){unset($w[$C]);continue;}}$c[]=array($v["type"],$C,$O);}}}foreach($w
  1770. as$C=>$Cc)$c[]=array($Cc["type"],$C,"DROP");if(!$c)redirect(ME."table=".urlencode($a));queries_redirect(ME."table=".urlencode($a),'Indexes have been altered.',alter_indexes($a,$c));}page_header('Indexes',$n,array("table"=>$a),h($a));$p=array_keys(fields($a));if($_POST["add"]){foreach($J["indexes"]as$y=>$v){if($v["columns"][count($v["columns"])]!="")$J["indexes"][$y]["columns"][]="";}$v=end($J["indexes"]);if($v["type"]||array_filter($v["columns"],'strlen'))$J["indexes"][]=array("columns"=>array(1=>""));}if(!$J){foreach($w
  1771. as$y=>$v){$w[$y]["name"]=$y;$w[$y]["columns"][]="";}$w[]=array("columns"=>array(1=>""));$J["indexes"]=$w;}echo'
  1772. <form action="" method="post">
  1773. <table cellspacing="0" class="nowrap">
  1774. <thead><tr>
  1775. <th id="label-type">Index Type
  1776. <th><input type="submit" class="wayoff">Column (length)
  1777. <th id="label-name">Name
  1778. <th><noscript>',"<input type='image' class='icon' name='add[0]' src='".h(preg_replace("~\\?.*~","",ME)."?file=plus.gif&version=4.6.3")."' alt='+' title='".'Add next'."'>",'</noscript>
  1779. </thead>
  1780. ';if($eg){echo"<tr><td>PRIMARY<td>";foreach($eg["columns"]as$y=>$e){echo
  1781. select_input(" disabled",$p,$e),"<label><input disabled type='checkbox'>".'descending'."</label> ";}echo"<td><td>\n";}$Zd=1;foreach($J["indexes"]as$v){if(!$_POST["drop_col"]||$Zd!=key($_POST["drop_col"])){echo"<tr><td>".html_select("indexes[$Zd][type]",array(-1=>"")+$Gd,$v["type"],($Zd==count($J["indexes"])?"indexesAddRow.call(this);":1),"label-type"),"<td>";ksort($v["columns"]);$s=1;foreach($v["columns"]as$y=>$e){echo"<span>".select_input(" name='indexes[$Zd][columns][$s]' title='".'Column'."'",($p?array_combine($p,$p):$p),$e,"partial(".($s==count($v["columns"])?"indexesAddColumn":"indexesChangeColumn").", '".js_escape($x=="sql"?"":$_GET["indexes"]."_")."')"),($x=="sql"||$x=="mssql"?"<input type='number' name='indexes[$Zd][lengths][$s]' class='size' value='".h($v["lengths"][$y])."' title='".'Length'."'>":""),($x!="sql"?checkbox("indexes[$Zd][descs][$s]",1,$v["descs"][$y],'descending'):"")," </span>";$s++;}echo"<td><input name='indexes[$Zd][name]' value='".h($v["name"])."' autocapitalize='off' aria-labelledby='label-name'>\n","<td><input type='image' class='icon' name='drop_col[$Zd]' src='".h(preg_replace("~\\?.*~","",ME)."?file=cross.gif&version=4.6.3")."' alt='x' title='".'Remove'."'>".script("qsl('input').onclick = partial(editingRemoveRow, 'indexes\$1[type]');");}$Zd++;}echo'</table>
  1782. <p>
  1783. <input type="submit" value="Save">
  1784. <input type="hidden" name="token" value="',$hi,'">
  1785. </form>
  1786. ';}elseif(isset($_GET["database"])){$J=$_POST;if($_POST&&!$n&&!isset($_POST["add_x"])){$C=trim($J["name"]);if($_POST["drop"]){$_GET["db"]="";queries_redirect(remove_from_uri("db|database"),'Database has been dropped.',drop_databases(array(DB)));}elseif(DB!==$C){if(DB!=""){$_GET["db"]=$C;queries_redirect(preg_replace('~\bdb=[^&]*&~','',ME)."db=".urlencode($C),'Database has been renamed.',rename_database($C,$J["collation"]));}else{$k=explode("\n",str_replace("\r","",$C));$Ch=true;$ke="";foreach($k
  1787. as$l){if(count($k)==1||$l!=""){if(!create_database($l,$J["collation"]))$Ch=false;$ke=$l;}}restart_session();set_session("dbs",null);queries_redirect(ME."db=".urlencode($ke),'Database has been created.',$Ch);}}else{if(!$J["collation"])redirect(substr(ME,0,-1));query_redirect("ALTER DATABASE ".idf_escape($C).(preg_match('~^[a-z0-9_]+$~i',$J["collation"])?" COLLATE $J[collation]":""),substr(ME,0,-1),'Database has been altered.');}}page_header(DB!=""?'Alter database':'Create database',$n,array(),h(DB));$ob=collations();$C=DB;if($_POST)$C=$J["name"];elseif(DB!="")$J["collation"]=db_collation(DB,$ob);elseif($x=="sql"){foreach(get_vals("SHOW GRANTS")as$kd){if(preg_match('~ ON (`(([^\\\\`]|``|\\\\.)*)%`\.\*)?~',$kd,$B)&&$B[1]){$C=stripcslashes(idf_unescape("`$B[2]`"));break;}}}echo'
  1788. <form action="" method="post">
  1789. <p>
  1790. ',($_POST["add_x"]||strpos($C,"\n")?'<textarea id="name" name="name" rows="10" cols="40">'.h($C).'</textarea><br>':'<input name="name" id="name" value="'.h($C).'" maxlength="64" autocapitalize="off">')."\n".($ob?html_select("collation",array(""=>"(".'collation'.")")+$ob,$J["collation"]).doc_link(array('sql'=>"charset-charsets.html",'mariadb'=>"supported-character-sets-and-collations/",'mssql'=>"ms187963.aspx",)):""),script("focus(qs('#name'));"),'<input type="submit" value="Save">
  1791. ';if(DB!="")echo"<input type='submit' name='drop' value='".'Drop'."'>".confirm(sprintf('Drop %s?',DB))."\n";elseif(!$_POST["add_x"]&&$_GET["db"]=="")echo"<input type='image' class='icon' name='add' src='".h(preg_replace("~\\?.*~","",ME)."?file=plus.gif&version=4.6.3")."' alt='+' title='".'Add next'."'>\n";echo'<input type="hidden" name="token" value="',$hi,'">
  1792. </form>
  1793. ';}elseif(isset($_GET["scheme"])){$J=$_POST;if($_POST&&!$n){$_=preg_replace('~ns=[^&]*&~','',ME)."ns=";if($_POST["drop"])query_redirect("DROP SCHEMA ".idf_escape($_GET["ns"]),$_,'Schema has been dropped.');else{$C=trim($J["name"]);$_.=urlencode($C);if($_GET["ns"]=="")query_redirect("CREATE SCHEMA ".idf_escape($C),$_,'Schema has been created.');elseif($_GET["ns"]!=$C)query_redirect("ALTER SCHEMA ".idf_escape($_GET["ns"])." RENAME TO ".idf_escape($C),$_,'Schema has been altered.');else
  1794. redirect($_);}}page_header($_GET["ns"]!=""?'Alter schema':'Create schema',$n);if(!$J)$J["name"]=$_GET["ns"];echo'
  1795. <form action="" method="post">
  1796. <p><input name="name" id="name" value="',h($J["name"]),'" autocapitalize="off">
  1797. ',script("focus(qs('#name'));"),'<input type="submit" value="Save">
  1798. ';if($_GET["ns"]!="")echo"<input type='submit' name='drop' value='".'Drop'."'>".confirm(sprintf('Drop %s?',$_GET["ns"]))."\n";echo'<input type="hidden" name="token" value="',$hi,'">
  1799. </form>
  1800. ';}elseif(isset($_GET["call"])){$da=($_GET["name"]?$_GET["name"]:$_GET["call"]);page_header('Call'.": ".h($da),$n);$Og=routine($_GET["call"],(isset($_GET["callf"])?"FUNCTION":"PROCEDURE"));$Ed=array();$Df=array();foreach($Og["fields"]as$s=>$o){if(substr($o["inout"],-3)=="OUT")$Df[$s]="@".idf_escape($o["field"])." AS ".idf_escape($o["field"]);if(!$o["inout"]||substr($o["inout"],0,2)=="IN")$Ed[]=$s;}if(!$n&&$_POST){$Za=array();foreach($Og["fields"]as$y=>$o){if(in_array($y,$Ed)){$X=process_input($o);if($X===false)$X="''";if(isset($Df[$y]))$g->query("SET @".idf_escape($o["field"])." = $X");}$Za[]=(isset($Df[$y])?"@".idf_escape($o["field"]):$X);}$G=(isset($_GET["callf"])?"SELECT":"CALL")." ".table($da)."(".implode(", ",$Za).")";$xh=microtime(true);$H=$g->multi_query($G);$za=$g->affected_rows;echo$b->selectQuery($G,$xh,!$H);if(!$H)echo"<p class='error'>".error()."\n";else{$h=connect();if(is_object($h))$h->select_db(DB);do{$H=$g->store_result();if(is_object($H))select($H,$h);else
  1801. echo"<p class='message'>".lang(array('Routine has been called, %d row affected.','Routine has been called, %d rows affected.'),$za)."\n";}while($g->next_result());if($Df)select($g->query("SELECT ".implode(", ",$Df)));}}echo'
  1802. <form action="" method="post">
  1803. ';if($Ed){echo"<table cellspacing='0'>\n";foreach($Ed
  1804. as$y){$o=$Og["fields"][$y];$C=$o["field"];echo"<tr><th>".$b->fieldName($o);$Y=$_POST["fields"][$C];if($Y!=""){if($o["type"]=="enum")$Y=+$Y;if($o["type"]=="set")$Y=array_sum($Y);}input($o,$Y,(string)$_POST["function"][$C]);echo"\n";}echo"</table>\n";}echo'<p>
  1805. <input type="submit" value="Call">
  1806. <input type="hidden" name="token" value="',$hi,'">
  1807. </form>
  1808. ';}elseif(isset($_GET["foreign"])){$a=$_GET["foreign"];$C=$_GET["name"];$J=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["change"]&&!$_POST["change-js"]){$He=($_POST["drop"]?'Foreign key has been dropped.':($C!=""?'Foreign key has been altered.':'Foreign key has been created.'));$A=ME."table=".urlencode($a);if(!$_POST["drop"]){$J["source"]=array_filter($J["source"],'strlen');ksort($J["source"]);$Qh=array();foreach($J["source"]as$y=>$X)$Qh[$y]=$J["target"][$y];$J["target"]=$Qh;}if($x=="sqlite")queries_redirect($A,$He,recreate_table($a,$a,array(),array(),array(" $C"=>($_POST["drop"]?"":" ".format_foreign_key($J)))));else{$c="ALTER TABLE ".table($a);$ec="\nDROP ".($x=="sql"?"FOREIGN KEY ":"CONSTRAINT ").idf_escape($C);if($_POST["drop"])query_redirect($c.$ec,$A,$He);else{query_redirect($c.($C!=""?"$ec,":"")."\nADD".format_foreign_key($J),$A,$He);$n='Source and target columns must have the same data type, there must be an index on the target columns and referenced data must exist.'."<br>$n";}}}page_header('Foreign key',$n,array("table"=>$a),h($a));if($_POST){ksort($J["source"]);if($_POST["add"])$J["source"][]="";elseif($_POST["change"]||$_POST["change-js"])$J["target"]=array();}elseif($C!=""){$dd=foreign_keys($a);$J=$dd[$C];$J["source"][]="";}else{$J["table"]=$a;$J["source"]=array("");}$ph=array_keys(fields($a));$Qh=($a===$J["table"]?$ph:array_keys(fields($J["table"])));$yg=array_keys(array_filter(table_status('',true),'fk_support'));echo'
  1809. <form action="" method="post">
  1810. <p>
  1811. ';if($J["db"]==""&&$J["ns"]==""){echo'Target table:
  1812. ',html_select("table",$yg,$J["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
  1813. <noscript><p><input type="submit" name="change" value="Change"></noscript>
  1814. <table cellspacing="0">
  1815. <thead><tr><th id="label-source">Source<th id="label-target">Target</thead>
  1816. ';$Zd=0;foreach($J["source"]as$y=>$X){echo"<tr>","<td>".html_select("source[".(+$y)."]",array(-1=>"")+$ph,$X,($Zd==count($J["source"])-1?"foreignAddRow.call(this);":1),"label-source"),"<td>".html_select("target[".(+$y)."]",$Qh,$J["target"][$y],1,"label-target");$Zd++;}echo'</table>
  1817. <p>
  1818. ON DELETE: ',html_select("on_delete",array(-1=>"")+explode("|",$kf),$J["on_delete"]),' ON UPDATE: ',html_select("on_update",array(-1=>"")+explode("|",$kf),$J["on_update"]),doc_link(array('sql'=>"innodb-foreign-key-constraints.html",'mariadb'=>"foreign-keys/",'pgsql'=>"sql-createtable.html#SQL-CREATETABLE-REFERENCES",'mssql'=>"ms174979.aspx",'oracle'=>"clauses002.htm#sthref2903",)),'<p>
  1819. <input type="submit" value="Save">
  1820. <noscript><p><input type="submit" name="add" value="Add column"></noscript>
  1821. ';}if($C!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$C));}echo'<input type="hidden" name="token" value="',$hi,'">
  1822. </form>
  1823. ';}elseif(isset($_GET["view"])){$a=$_GET["view"];$J=$_POST;$Af="VIEW";if($x=="pgsql"&&$a!=""){$P=table_status($a);$Af=strtoupper($P["Engine"]);}if($_POST&&!$n){$C=trim($J["name"]);$Ga=" AS\n$J[select]";$A=ME."table=".urlencode($C);$He='View has been altered.';$U=($_POST["materialized"]?"MATERIALIZED VIEW":"VIEW");if(!$_POST["drop"]&&$a==$C&&$x!="sqlite"&&$U=="VIEW"&&$Af=="VIEW")query_redirect(($x=="mssql"?"ALTER":"CREATE OR REPLACE")." VIEW ".table($C).$Ga,$A,$He);else{$Sh=$C."_adminer_".uniqid();drop_create("DROP $Af ".table($a),"CREATE $U ".table($C).$Ga,"DROP $U ".table($C),"CREATE $U ".table($Sh).$Ga,"DROP $U ".table($Sh),($_POST["drop"]?substr(ME,0,-1):$A),'View has been dropped.',$He,'View has been created.',$a,$C);}}if(!$_POST&&$a!=""){$J=view($a);$J["name"]=$a;$J["materialized"]=($Af!="VIEW");if(!$n)$n=error();}page_header(($a!=""?'Alter view':'Create view'),$n,array("table"=>$a),h($a));echo'
  1824. <form action="" method="post">
  1825. <p>Name: <input name="name" value="',h($J["name"]),'" maxlength="64" autocapitalize="off">
  1826. ',(support("materializedview")?" ".checkbox("materialized",1,$J["materialized"],'Materialized view'):""),'<p>';textarea("select",$J["select"]);echo'<p>
  1827. <input type="submit" value="Save">
  1828. ';if($a!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$a));}echo'<input type="hidden" name="token" value="',$hi,'">
  1829. </form>
  1830. ';}elseif(isset($_GET["event"])){$aa=$_GET["event"];$Rd=array("YEAR","QUARTER","MONTH","DAY","HOUR","MINUTE","WEEK","SECOND","YEAR_MONTH","DAY_HOUR","DAY_MINUTE","DAY_SECOND","HOUR_MINUTE","HOUR_SECOND","MINUTE_SECOND");$zh=array("ENABLED"=>"ENABLE","DISABLED"=>"DISABLE","SLAVESIDE_DISABLED"=>"DISABLE ON SLAVE");$J=$_POST;if($_POST&&!$n){if($_POST["drop"])query_redirect("DROP EVENT ".idf_escape($aa),substr(ME,0,-1),'Event has been dropped.');elseif(in_array($J["INTERVAL_FIELD"],$Rd)&&isset($zh[$J["STATUS"]])){$Tg="\nON SCHEDULE ".($J["INTERVAL_VALUE"]?"EVERY ".q($J["INTERVAL_VALUE"])." $J[INTERVAL_FIELD]".($J["STARTS"]?" STARTS ".q($J["STARTS"]):"").($J["ENDS"]?" ENDS ".q($J["ENDS"]):""):"AT ".q($J["STARTS"]))." ON COMPLETION".($J["ON_COMPLETION"]?"":" NOT")." PRESERVE";queries_redirect(substr(ME,0,-1),($aa!=""?'Event has been altered.':'Event has been created.'),queries(($aa!=""?"ALTER EVENT ".idf_escape($aa).$Tg.($aa!=$J["EVENT_NAME"]?"\nRENAME TO ".idf_escape($J["EVENT_NAME"]):""):"CREATE EVENT ".idf_escape($J["EVENT_NAME"]).$Tg)."\n".$zh[$J["STATUS"]]." COMMENT ".q($J["EVENT_COMMENT"]).rtrim(" DO\n$J[EVENT_DEFINITION]",";").";"));}}page_header(($aa!=""?'Alter event'.": ".h($aa):'Create event'),$n);if(!$J&&$aa!=""){$K=get_rows("SELECT * FROM information_schema.EVENTS WHERE EVENT_SCHEMA = ".q(DB)." AND EVENT_NAME = ".q($aa));$J=reset($K);}echo'
  1831. <form action="" method="post">
  1832. <table cellspacing="0">
  1833. <tr><th>Name<td><input name="EVENT_NAME" value="',h($J["EVENT_NAME"]),'" maxlength="64" autocapitalize="off">
  1834. <tr><th title="datetime">Start<td><input name="STARTS" value="',h("$J[EXECUTE_AT]$J[STARTS]"),'">
  1835. <tr><th title="datetime">End<td><input name="ENDS" value="',h($J["ENDS"]),'">
  1836. <tr><th>Every<td><input type="number" name="INTERVAL_VALUE" value="',h($J["INTERVAL_VALUE"]),'" class="size"> ',html_select("INTERVAL_FIELD",$Rd,$J["INTERVAL_FIELD"]),'<tr><th>Status<td>',html_select("STATUS",$zh,$J["STATUS"]),'<tr><th>Comment<td><input name="EVENT_COMMENT" value="',h($J["EVENT_COMMENT"]),'" maxlength="64">
  1837. <tr><th><td>',checkbox("ON_COMPLETION","PRESERVE",$J["ON_COMPLETION"]=="PRESERVE",'On completion preserve'),'</table>
  1838. <p>';textarea("EVENT_DEFINITION",$J["EVENT_DEFINITION"]);echo'<p>
  1839. <input type="submit" value="Save">
  1840. ';if($aa!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$aa));}echo'<input type="hidden" name="token" value="',$hi,'">
  1841. </form>
  1842. ';}elseif(isset($_GET["procedure"])){$da=($_GET["name"]?$_GET["name"]:$_GET["procedure"]);$Og=(isset($_GET["function"])?"FUNCTION":"PROCEDURE");$J=$_POST;$J["fields"]=(array)$J["fields"];if($_POST&&!process_fields($J["fields"])&&!$n){$yf=routine($_GET["procedure"],$Og);$Sh="$J[name]_adminer_".uniqid();drop_create("DROP $Og ".routine_id($da,$yf),create_routine($Og,$J),"DROP $Og ".routine_id($J["name"],$J),create_routine($Og,array("name"=>$Sh)+$J),"DROP $Og ".routine_id($Sh,$J),substr(ME,0,-1),'Routine has been dropped.','Routine has been altered.','Routine has been created.',$da,$J["name"]);}page_header(($da!=""?(isset($_GET["function"])?'Alter function':'Alter procedure').": ".h($da):(isset($_GET["function"])?'Create function':'Create procedure')),$n);if(!$_POST&&$da!=""){$J=routine($_GET["procedure"],$Og);$J["name"]=$da;}$ob=get_vals("SHOW CHARACTER SET");sort($ob);$Pg=routine_languages();echo'
  1843. <form action="" method="post" id="form">
  1844. <p>Name: <input name="name" value="',h($J["name"]),'" maxlength="64" autocapitalize="off">
  1845. ',($Pg?'Language'.": ".html_select("language",$Pg,$J["language"])."\n":""),'<input type="submit" value="Save">
  1846. <table cellspacing="0" class="nowrap">
  1847. ';edit_fields($J["fields"],$ob,$Og);if(isset($_GET["function"])){echo"<tr><td>".'Return type';edit_type("returns",$J["returns"],$ob,array(),($x=="pgsql"?array("void","trigger"):array()));}echo'</table>
  1848. <p>';textarea("definition",$J["definition"]);echo'<p>
  1849. <input type="submit" value="Save">
  1850. ';if($da!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$da));}echo'<input type="hidden" name="token" value="',$hi,'">
  1851. </form>
  1852. ';}elseif(isset($_GET["sequence"])){$fa=$_GET["sequence"];$J=$_POST;if($_POST&&!$n){$_=substr(ME,0,-1);$C=trim($J["name"]);if($_POST["drop"])query_redirect("DROP SEQUENCE ".idf_escape($fa),$_,'Sequence has been dropped.');elseif($fa=="")query_redirect("CREATE SEQUENCE ".idf_escape($C),$_,'Sequence has been created.');elseif($fa!=$C)query_redirect("ALTER SEQUENCE ".idf_escape($fa)." RENAME TO ".idf_escape($C),$_,'Sequence has been altered.');else
  1853. redirect($_);}page_header($fa!=""?'Alter sequence'.": ".h($fa):'Create sequence',$n);if(!$J)$J["name"]=$fa;echo'
  1854. <form action="" method="post">
  1855. <p><input name="name" value="',h($J["name"]),'" autocapitalize="off">
  1856. <input type="submit" value="Save">
  1857. ';if($fa!="")echo"<input type='submit' name='drop' value='".'Drop'."'>".confirm(sprintf('Drop %s?',$fa))."\n";echo'<input type="hidden" name="token" value="',$hi,'">
  1858. </form>
  1859. ';}elseif(isset($_GET["type"])){$ga=$_GET["type"];$J=$_POST;if($_POST&&!$n){$_=substr(ME,0,-1);if($_POST["drop"])query_redirect("DROP TYPE ".idf_escape($ga),$_,'Type has been dropped.');else
  1860. query_redirect("CREATE TYPE ".idf_escape(trim($J["name"]))." $J[as]",$_,'Type has been created.');}page_header($ga!=""?'Alter type'.": ".h($ga):'Create type',$n);if(!$J)$J["as"]="AS ";echo'
  1861. <form action="" method="post">
  1862. <p>
  1863. ';if($ga!="")echo"<input type='submit' name='drop' value='".'Drop'."'>".confirm(sprintf('Drop %s?',$ga))."\n";else{echo"<input name='name' value='".h($J['name'])."' autocapitalize='off'>\n";textarea("as",$J["as"]);echo"<p><input type='submit' value='".'Save'."'>\n";}echo'<input type="hidden" name="token" value="',$hi,'">
  1864. </form>
  1865. ';}elseif(isset($_GET["trigger"])){$a=$_GET["trigger"];$C=$_GET["name"];$si=trigger_options();$J=(array)trigger($C)+array("Trigger"=>$a."_bi");if($_POST){if(!$n&&in_array($_POST["Timing"],$si["Timing"])&&in_array($_POST["Event"],$si["Event"])&&in_array($_POST["Type"],$si["Type"])){$jf=" ON ".table($a);$ec="DROP TRIGGER ".idf_escape($C).($x=="pgsql"?$jf:"");$A=ME."table=".urlencode($a);if($_POST["drop"])query_redirect($ec,$A,'Trigger has been dropped.');else{if($C!="")queries($ec);queries_redirect($A,($C!=""?'Trigger has been altered.':'Trigger has been created.'),queries(create_trigger($jf,$_POST)));if($C!="")queries(create_trigger($jf,$J+array("Type"=>reset($si["Type"]))));}}$J=$_POST;}page_header(($C!=""?'Alter trigger'.": ".h($C):'Create trigger'),$n,array("table"=>$a));echo'
  1866. <form action="" method="post" id="form">
  1867. <table cellspacing="0">
  1868. <tr><th>Time<td>',html_select("Timing",$si["Timing"],$J["Timing"],"triggerChange(/^".preg_quote($a,"/")."_[ba][iud]$/, '".js_escape($a)."', this.form);"),'<tr><th>Event<td>',html_select("Event",$si["Event"],$J["Event"],"this.form['Timing'].onchange();"),(in_array("UPDATE OF",$si["Event"])?" <input name='Of' value='".h($J["Of"])."' class='hidden'>":""),'<tr><th>Type<td>',html_select("Type",$si["Type"],$J["Type"]),'</table>
  1869. <p>Name: <input name="Trigger" value="',h($J["Trigger"]),'" maxlength="64" autocapitalize="off">
  1870. ',script("qs('#form')['Timing'].onchange();"),'<p>';textarea("Statement",$J["Statement"]);echo'<p>
  1871. <input type="submit" value="Save">
  1872. ';if($C!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$C));}echo'<input type="hidden" name="token" value="',$hi,'">
  1873. </form>
  1874. ';}elseif(isset($_GET["user"])){$ha=$_GET["user"];$jg=array(""=>array("All privileges"=>""));foreach(get_rows("SHOW PRIVILEGES")as$J){foreach(explode(",",($J["Privilege"]=="Grant option"?"":$J["Context"]))as$_b)$jg[$_b][$J["Privilege"]]=$J["Comment"];}$jg["Server Admin"]+=$jg["File access on server"];$jg["Databases"]["Create routine"]=$jg["Procedures"]["Create routine"];unset($jg["Procedures"]["Create routine"]);$jg["Columns"]=array();foreach(array("Select","Insert","Update","References")as$X)$jg["Columns"][$X]=$jg["Tables"][$X];unset($jg["Server Admin"]["Usage"]);foreach($jg["Tables"]as$y=>$X)unset($jg["Databases"][$y]);$Ue=array();if($_POST){foreach($_POST["objects"]as$y=>$X)$Ue[$X]=(array)$Ue[$X]+(array)$_POST["grants"][$y];}$ld=array();$hf="";if(isset($_GET["host"])&&($H=$g->query("SHOW GRANTS FOR ".q($ha)."@".q($_GET["host"])))){while($J=$H->fetch_row()){if(preg_match('~GRANT (.*) ON (.*) TO ~',$J[0],$B)&&preg_match_all('~ *([^(,]*[^ ,(])( *\([^)]+\))?~',$B[1],$_e,PREG_SET_ORDER)){foreach($_e
  1875. as$X){if($X[1]!="USAGE")$ld["$B[2]$X[2]"][$X[1]]=true;if(preg_match('~ WITH GRANT OPTION~',$J[0]))$ld["$B[2]$X[2]"]["GRANT OPTION"]=true;}}if(preg_match("~ IDENTIFIED BY PASSWORD '([^']+)~",$J[0],$B))$hf=$B[1];}}if($_POST&&!$n){$if=(isset($_GET["host"])?q($ha)."@".q($_GET["host"]):"''");if($_POST["drop"])query_redirect("DROP USER $if",ME."privileges=",'User has been dropped.');else{$We=q($_POST["user"])."@".q($_POST["host"]);$Rf=$_POST["pass"];if($Rf!=''&&!$_POST["hashed"]){$Rf=$g->result("SELECT PASSWORD(".q($Rf).")");$n=!$Rf;}$Eb=false;if(!$n){if($if!=$We){$Eb=queries((min_version(5)?"CREATE USER":"GRANT USAGE ON *.* TO")." $We IDENTIFIED BY PASSWORD ".q($Rf));$n=!$Eb;}elseif($Rf!=$hf)queries("SET PASSWORD FOR $We = ".q($Rf));}if(!$n){$Lg=array();foreach($Ue
  1876. as$cf=>$kd){if(isset($_GET["grant"]))$kd=array_filter($kd);$kd=array_keys($kd);if(isset($_GET["grant"]))$Lg=array_diff(array_keys(array_filter($Ue[$cf],'strlen')),$kd);elseif($if==$We){$ff=array_keys((array)$ld[$cf]);$Lg=array_diff($ff,$kd);$kd=array_diff($kd,$ff);unset($ld[$cf]);}if(preg_match('~^(.+)\s*(\(.*\))?$~U',$cf,$B)&&(!grant("REVOKE",$Lg,$B[2]," ON $B[1] FROM $We")||!grant("GRANT",$kd,$B[2]," ON $B[1] TO $We"))){$n=true;break;}}}if(!$n&&isset($_GET["host"])){if($if!=$We)queries("DROP USER $if");elseif(!isset($_GET["grant"])){foreach($ld
  1877. as$cf=>$Lg){if(preg_match('~^(.+)(\(.*\))?$~U',$cf,$B))grant("REVOKE",array_keys($Lg),$B[2]," ON $B[1] FROM $We");}}}queries_redirect(ME."privileges=",(isset($_GET["host"])?'User has been altered.':'User has been created.'),!$n);if($Eb)$g->query("DROP USER $We");}}page_header((isset($_GET["host"])?'Username'.": ".h("$ha@$_GET[host]"):'Create user'),$n,array("privileges"=>array('','Privileges')));if($_POST){$J=$_POST;$ld=$Ue;}else{$J=$_GET+array("host"=>$g->result("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', -1)"));$J["pass"]=$hf;if($hf!="")$J["hashed"]=true;$ld[(DB==""||$ld?"":idf_escape(addcslashes(DB,"%_\\"))).".*"]=array();}echo'<form action="" method="post">
  1878. <table cellspacing="0">
  1879. <tr><th>Server<td><input name="host" maxlength="60" value="',h($J["host"]),'" autocapitalize="off">
  1880. <tr><th>Username<td><input name="user" maxlength="16" value="',h($J["user"]),'" autocapitalize="off">
  1881. <tr><th>Password<td><input name="pass" id="pass" value="',h($J["pass"]),'" autocomplete="new-password">
  1882. ';if(!$J["hashed"])echo
  1883. script("typePassword(qs('#pass'));");echo
  1884. checkbox("hashed",1,$J["hashed"],'Hashed',"typePassword(this.form['pass'], this.checked);"),'</table>
  1885.  
  1886. ';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".'Privileges'.doc_link(array('sql'=>"grant.html#priv_level"));$s=0;foreach($ld
  1887. as$cf=>$kd){echo'<th>'.($cf!="*.*"?"<input name='objects[$s]' value='".h($cf)."' size='10' autocapitalize='off'>":"<input type='hidden' name='objects[$s]' value='*.*' size='10'>*.*");$s++;}echo"</thead>\n";foreach(array(""=>"","Server Admin"=>'Server',"Databases"=>'Database',"Tables"=>'Table',"Columns"=>'Column',"Procedures"=>'Routine',)as$_b=>$Vb){foreach((array)$jg[$_b]as$ig=>$tb){echo"<tr".odd()."><td".($Vb?">$Vb<td":" colspan='2'").' lang="en" title="'.h($tb).'">'.h($ig);$s=0;foreach($ld
  1888. as$cf=>$kd){$C="'grants[$s][".h(strtoupper($ig))."]'";$Y=$kd[strtoupper($ig)];if($_b=="Server Admin"&&$cf!=(isset($ld["*.*"])?"*.*":".*"))echo"<td>";elseif(isset($_GET["grant"]))echo"<td><select name=$C><option><option value='1'".($Y?" selected":"").">".'Grant'."<option value='0'".($Y=="0"?" selected":"").">".'Revoke'."</select>";else{echo"<td align='center'><label class='block'>","<input type='checkbox' name=$C value='1'".($Y?" checked":"").($ig=="All privileges"?" id='grants-$s-all'>":">".($ig=="Grant option"?"":script("qsl('input').onclick = function () { if (this.checked) formUncheck('grants-$s-all'); };"))),"</label>";}$s++;}}}echo"</table>\n",'<p>
  1889. <input type="submit" value="Save">
  1890. ';if(isset($_GET["host"])){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',"$ha@$_GET[host]"));}echo'<input type="hidden" name="token" value="',$hi,'">
  1891. </form>
  1892. ';}elseif(isset($_GET["processlist"])){if(support("kill")&&$_POST&&!$n){$ge=0;foreach((array)$_POST["kill"]as$X){if(kill_process($X))$ge++;}queries_redirect(ME."processlist=",lang(array('%d process has been killed.','%d processes have been killed.'),$ge),$ge||!$_POST["kill"]);}page_header('Process list',$n);echo'
  1893. <form action="" method="post">
  1894. <table cellspacing="0" class="nowrap checkable">
  1895. ',script("mixin(qsl('table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true)});");$s=-1;foreach(process_list()as$s=>$J){if(!$s){echo"<thead><tr lang='en'>".(support("kill")?"<th>":"");foreach($J
  1896. as$y=>$X)echo"<th>$y".doc_link(array('sql'=>"show-processlist.html#processlist_".strtolower($y),'pgsql'=>"monitoring-stats.html#PG-STAT-ACTIVITY-VIEW",'oracle'=>"../b14237/dynviews_2088.htm",));echo"</thead>\n";}echo"<tr".odd().">".(support("kill")?"<td>".checkbox("kill[]",$J[$x=="sql"?"Id":"pid"],0):"");foreach($J
  1897. as$y=>$X)echo"<td>".(($x=="sql"&&$y=="Info"&&preg_match("~Query|Killed~",$J["Command"])&&$X!="")||($x=="pgsql"&&$y=="current_query"&&$X!="<IDLE>")||($x=="oracle"&&$y=="sql_text"&&$X!="")?"<code class='jush-$x'>".shorten_utf8($X,100,"</code>").' <a href="'.h(ME.($J["db"]!=""?"db=".urlencode($J["db"])."&":"")."sql=".urlencode($X)).'">'.'Clone'.'</a>':h($X));echo"\n";}echo'</table>
  1898. <p>
  1899. ';if(support("kill")){echo($s+1)."/".sprintf('%d in total',max_connections()),"<p><input type='submit' value='".'Kill'."'>\n";}echo'<input type="hidden" name="token" value="',$hi,'">
  1900. </form>
  1901. ',script("tableCheck();");}elseif(isset($_GET["select"])){$a=$_GET["select"];$S=table_status1($a);$w=indexes($a);$p=fields($a);$dd=column_foreign_keys($a);$ef=$S["Oid"];parse_str($_COOKIE["adminer_import"],$ya);$Mg=array();$f=array();$Wh=null;foreach($p
  1902. as$y=>$o){$C=$b->fieldName($o);if(isset($o["privileges"]["select"])&&$C!=""){$f[$y]=html_entity_decode(strip_tags($C),ENT_QUOTES);if(is_shortable($o))$Wh=$b->selectLengthProcess();}$Mg+=$o["privileges"];}list($L,$md)=$b->selectColumnsProcess($f,$w);$Vd=count($md)<count($L);$Z=$b->selectSearchProcess($p,$w);$uf=$b->selectOrderProcess($p,$w);$z=$b->selectLimitProcess();if($_GET["val"]&&is_ajax()){header("Content-Type: text/plain; charset=utf-8");foreach($_GET["val"]as$_i=>$J){$Ga=convert_field($p[key($J)]);$L=array($Ga?$Ga:idf_escape(key($J)));$Z[]=where_check($_i,$p);$I=$m->select($a,$L,$Z,$L);if($I)echo
  1903. reset($I->fetch_row());}exit;}$eg=$Bi=null;foreach($w
  1904. as$v){if($v["type"]=="PRIMARY"){$eg=array_flip($v["columns"]);$Bi=($L?$eg:array());foreach($Bi
  1905. as$y=>$X){if(in_array(idf_escape($y),$L))unset($Bi[$y]);}break;}}if($ef&&!$eg){$eg=$Bi=array($ef=>0);$w[]=array("type"=>"PRIMARY","columns"=>array($ef));}if($_POST&&!$n){$cj=$Z;if(!$_POST["all"]&&is_array($_POST["check"])){$fb=array();foreach($_POST["check"]as$cb)$fb[]=where_check($cb,$p);$cj[]="((".implode(") OR (",$fb)."))";}$cj=($cj?"\nWHERE ".implode(" AND ",$cj):"");if($_POST["export"]){cookie("adminer_import","output=".urlencode($_POST["output"])."&format=".urlencode($_POST["format"]));dump_headers($a);$b->dumpTable($a,"");$id=($L?implode(", ",$L):"*").convert_fields($f,$p,$L)."\nFROM ".table($a);$od=($md&&$Vd?"\nGROUP BY ".implode(", ",$md):"").($uf?"\nORDER BY ".implode(", ",$uf):"");if(!is_array($_POST["check"])||$eg)$G="SELECT $id$cj$od";else{$yi=array();foreach($_POST["check"]as$X)$yi[]="(SELECT".limit($id,"\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p).$od,1).")";$G=implode(" UNION ALL ",$yi);}$b->dumpData($a,"table",$G);exit;}if(!$b->selectEmailProcess($Z,$dd)){if($_POST["save"]||$_POST["delete"]){$H=true;$za=0;$O=array();if(!$_POST["delete"]){foreach($f
  1906. as$C=>$X){$X=process_input($p[$C]);if($X!==null&&($_POST["clone"]||$X!==false))$O[idf_escape($C)]=($X!==false?$X:idf_escape($C));}}if($_POST["delete"]||$O){if($_POST["clone"])$G="INTO ".table($a)." (".implode(", ",array_keys($O)).")\nSELECT ".implode(", ",$O)."\nFROM ".table($a);if($_POST["all"]||($eg&&is_array($_POST["check"]))||$Vd){$H=($_POST["delete"]?$m->delete($a,$cj):($_POST["clone"]?queries("INSERT $G$cj"):$m->update($a,$O,$cj)));$za=$g->affected_rows;}else{foreach((array)$_POST["check"]as$X){$Yi="\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p);$H=($_POST["delete"]?$m->delete($a,$Yi,1):($_POST["clone"]?queries("INSERT".limit1($a,$G,$Yi)):$m->update($a,$O,$Yi,1)));if(!$H)break;$za+=$g->affected_rows;}}}$He=lang(array('%d item has been affected.','%d items have been affected.'),$za);if($_POST["clone"]&&$H&&$za==1){$le=last_id();if($le)$He=sprintf('Item%s has been inserted.'," $le");}queries_redirect(remove_from_uri($_POST["all"]&&$_POST["delete"]?"page":""),$He,$H);if(!$_POST["delete"]){edit_form($a,$p,(array)$_POST["fields"],!$_POST["clone"]);page_footer();exit;}}elseif(!$_POST["import"]){if(!$_POST["val"])$n='Ctrl+click on a value to modify it.';else{$H=true;$za=0;foreach($_POST["val"]as$_i=>$J){$O=array();foreach($J
  1907. as$y=>$X){$y=bracket_escape($y,1);$O[idf_escape($y)]=(preg_match('~char|text~',$p[$y]["type"])||$X!=""?$b->processInput($p[$y],$X):"NULL");}$H=$m->update($a,$O," WHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($_i,$p),!$Vd&&!$eg," ");if(!$H)break;$za+=$g->affected_rows;}queries_redirect(remove_from_uri(),lang(array('%d item has been affected.','%d items have been affected.'),$za),$H);}}elseif(!is_string($Sc=get_file("csv_file",true)))$n=upload_error($Sc);elseif(!preg_match('~~u',$Sc))$n='File must be in UTF-8 encoding.';else{cookie("adminer_import","output=".urlencode($ya["output"])."&format=".urlencode($_POST["separator"]));$H=true;$qb=array_keys($p);preg_match_all('~(?>"[^"]*"|[^"\r\n]+)+~',$Sc,$_e);$za=count($_e[0]);$m->begin();$M=($_POST["separator"]=="csv"?",":($_POST["separator"]=="tsv"?"\t":";"));$K=array();foreach($_e[0]as$y=>$X){preg_match_all("~((?>\"[^\"]*\")+|[^$M]*)$M~",$X.$M,$Ae);if(!$y&&!array_diff($Ae[1],$qb)){$qb=$Ae[1];$za--;}else{$O=array();foreach($Ae[1]as$s=>$mb)$O[idf_escape($qb[$s])]=($mb==""&&$p[$qb[$s]]["null"]?"NULL":q(str_replace('""','"',preg_replace('~^"|"$~','',$mb))));$K[]=$O;}}$H=(!$K||$m->insertUpdate($a,$K,$eg));if($H)$H=$m->commit();queries_redirect(remove_from_uri("page"),lang(array('%d row has been imported.','%d rows have been imported.'),$za),$H);$m->rollback();}}}$Ih=$b->tableName($S);if(is_ajax()){page_headers();ob_start();}else
  1908. page_header('Select'.": $Ih",$n);$O=null;if(isset($Mg["insert"])||!support("table")){$O="";foreach((array)$_GET["where"]as$X){if($dd[$X["col"]]&&count($dd[$X["col"]])==1&&($X["op"]=="="||(!$X["op"]&&!preg_match('~[_%]~',$X["val"]))))$O.="&set".urlencode("[".bracket_escape($X["col"])."]")."=".urlencode($X["val"]);}}$b->selectLinks($S,$O);if(!$f&&support("table"))echo"<p class='error'>".'Unable to select the table'.($p?".":": ".error())."\n";else{echo"<form action='' id='form'>\n","<div style='display: none;'>";hidden_fields_get();echo(DB!=""?'<input type="hidden" name="db" value="'.h(DB).'">'.(isset($_GET["ns"])?'<input type="hidden" name="ns" value="'.h($_GET["ns"]).'">':""):"");echo'<input type="hidden" name="select" value="'.h($a).'">',"</div>\n";$b->selectColumnsPrint($L,$f);$b->selectSearchPrint($Z,$f,$w);$b->selectOrderPrint($uf,$f,$w);$b->selectLimitPrint($z);$b->selectLengthPrint($Wh);$b->selectActionPrint($w);echo"</form>\n";$E=$_GET["page"];if($E=="last"){$gd=$g->result(count_rows($a,$Z,$Vd,$md));$E=floor(max(0,$gd-1)/$z);}$Yg=$L;$nd=$md;if(!$Yg){$Yg[]="*";$Ab=convert_fields($f,$p,$L);if($Ab)$Yg[]=substr($Ab,2);}foreach($L
  1909. as$y=>$X){$o=$p[idf_unescape($X)];if($o&&($Ga=convert_field($o)))$Yg[$y]="$Ga AS $X";}if(!$Vd&&$Bi){foreach($Bi
  1910. as$y=>$X){$Yg[]=idf_escape($y);if($nd)$nd[]=idf_escape($y);}}$H=$m->select($a,$Yg,$Z,$nd,$uf,$z,$E,true);if(!$H)echo"<p class='error'>".error()."\n";else{if($x=="mssql"&&$E)$H->seek($z*$E);$rc=array();echo"<form action='' method='post' enctype='multipart/form-data'>\n";$K=array();while($J=$H->fetch_assoc()){if($E&&$x=="oracle")unset($J["RNUM"]);$K[]=$J;}if($_GET["page"]!="last"&&$z!=""&&$md&&$Vd&&$x=="sql")$gd=$g->result(" SELECT FOUND_ROWS()");if(!$K)echo"<p class='message'>".'No rows.'."\n";else{$Pa=$b->backwardKeys($a,$Ih);echo"<table id='table' cellspacing='0' class='nowrap checkable'>",script("mixin(qs('#table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true), onkeydown: editingKeydown});"),"<thead><tr>".(!$md&&$L?"":"<td><input type='checkbox' id='all-page' class='jsonly'>".script("qs('#all-page').onclick = partial(formCheck, /check/);","")." <a href='".h($_GET["modify"]?remove_from_uri("modify"):$_SERVER["REQUEST_URI"]."&modify=1")."'>".'Modify'."</a>");$Te=array();$jd=array();reset($L);$tg=1;foreach($K[0]as$y=>$X){if(!isset($Bi[$y])){$X=$_GET["columns"][key($L)];$o=$p[$L?($X?$X["col"]:current($L)):$y];$C=($o?$b->fieldName($o,$tg):($X["fun"]?"*":$y));if($C!=""){$tg++;$Te[$y]=$C;$e=idf_escape($y);$Ad=remove_from_uri('(order|desc)[^=]*|page').'&order%5B0%5D='.urlencode($y);$Vb="&desc%5B0%5D=1";echo"<th>".script("mixin(qsl('th'), {onmouseover: partial(columnMouse), onmouseout: partial(columnMouse, ' hidden')});",""),'<a href="'.h($Ad.($uf[0]==$e||$uf[0]==$y||(!$uf&&$Vd&&$md[0]==$e)?$Vb:'')).'">';echo
  1911. apply_sql_function($X["fun"],$C)."</a>";echo"<span class='column hidden'>","<a href='".h($Ad.$Vb)."' title='".'descending'."' class='text'> ↓</a>";if(!$X["fun"]){echo'<a href="#fieldset-search" title="'.'Search'.'" class="text jsonly"> =</a>',script("qsl('a').onclick = partial(selectSearch, '".js_escape($y)."');");}echo"</span>";}$jd[$y]=$X["fun"];next($L);}}$re=array();if($_GET["modify"]){foreach($K
  1912. as$J){foreach($J
  1913. as$y=>$X)$re[$y]=max($re[$y],min(40,strlen(utf8_decode($X))));}}echo($Pa?"<th>".'Relations':"")."</thead>\n";if(is_ajax()){if($z%2==1&&$E%2==1)odd();ob_end_clean();}foreach($b->rowDescriptions($K,$dd)as$Se=>$J){$zi=unique_array($K[$Se],$w);if(!$zi){$zi=array();foreach($K[$Se]as$y=>$X){if(!preg_match('~^(COUNT\((\*|(DISTINCT )?`(?:[^`]|``)+`)\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\(`(?:[^`]|``)+`\))$~',$y))$zi[$y]=$X;}}$_i="";foreach($zi
  1914. as$y=>$X){if(($x=="sql"||$x=="pgsql")&&preg_match('~char|text|enum|set~',$p[$y]["type"])&&strlen($X)>64){$y=(strpos($y,'(')?$y:idf_escape($y));$y="MD5(".($x!='sql'||preg_match("~^utf8~",$p[$y]["collation"])?$y:"CONVERT($y USING ".charset($g).")").")";$X=md5($X);}$_i.="&".($X!==null?urlencode("where[".bracket_escape($y)."]")."=".urlencode($X):"null%5B%5D=".urlencode($y));}echo"<tr".odd().">".(!$md&&$L?"":"<td>".checkbox("check[]",substr($_i,1),in_array(substr($_i,1),(array)$_POST["check"])).($Vd||information_schema(DB)?"":" <a href='".h(ME."edit=".urlencode($a).$_i)."' class='edit'>".'edit'."</a>"));foreach($J
  1915. as$y=>$X){if(isset($Te[$y])){$o=$p[$y];$X=$m->value($X,$o);if($X!=""&&(!isset($rc[$y])||$rc[$y]!=""))$rc[$y]=(is_mail($X)?$Te[$y]:"");$_="";if(preg_match('~blob|bytea|raw|file~',$o["type"])&&$X!="")$_=ME.'download='.urlencode($a).'&field='.urlencode($y).$_i;if(!$_&&$X!==null){foreach((array)$dd[$y]as$q){if(count($dd[$y])==1||end($q["source"])==$y){$_="";foreach($q["source"]as$s=>$ph)$_.=where_link($s,$q["target"][$s],$K[$Se][$ph]);$_=($q["db"]!=""?preg_replace('~([?&]db=)[^&]+~','\1'.urlencode($q["db"]),ME):ME).'select='.urlencode($q["table"]).$_;if($q["ns"])$_=preg_replace('~([?&]ns=)[^&]+~','\1'.urlencode($q["ns"]),$_);if(count($q["source"])==1)break;}}}if($y=="COUNT(*)"){$_=ME."select=".urlencode($a);$s=0;foreach((array)$_GET["where"]as$W){if(!array_key_exists($W["col"],$zi))$_.=where_link($s++,$W["col"],$W["val"],$W["op"]);}foreach($zi
  1916. as$ae=>$W)$_.=where_link($s++,$ae,$W);}$X=select_value($X,$_,$o,$Wh);$t=h("val[$_i][".bracket_escape($y)."]");$Y=$_POST["val"][$_i][bracket_escape($y)];$mc=!is_array($J[$y])&&is_utf8($X)&&$K[$Se][$y]==$J[$y]&&!$jd[$y];$Vh=preg_match('~text|lob~',$o["type"]);if(($_GET["modify"]&&$mc)||$Y!==null){$rd=h($Y!==null?$Y:$J[$y]);echo"<td>".($Vh?"<textarea name='$t' cols='30' rows='".(substr_count($J[$y],"\n")+1)."'>$rd</textarea>":"<input name='$t' value='$rd' size='$re[$y]'>");}else{$ve=strpos($X,"<i>...</i>");echo"<td id='$t' data-text='".($ve?2:($Vh?1:0))."'".($mc?"":" data-warning='".h('Use edit link to modify this value.')."'").">$X</td>";}}}if($Pa)echo"<td>";$b->backwardKeysPrint($Pa,$K[$Se]);echo"</tr>\n";}if(is_ajax())exit;echo"</table>\n";}if(!is_ajax()){if($K||$E){$Ac=true;if($_GET["page"]!="last"){if($z==""||(count($K)<$z&&($K||!$E)))$gd=($E?$E*$z:0)+count($K);elseif($x!="sql"||!$Vd){$gd=($Vd?false:found_rows($S,$Z));if($gd<max(1e4,2*($E+1)*$z))$gd=reset(slow_query(count_rows($a,$Z,$Vd,$md)));else$Ac=false;}}$Gf=($z!=""&&($gd===false||$gd>$z||$E));if($Gf){echo(($gd===false?count($K)+1:$gd-$E*$z)>$z?'<p><a href="'.h(remove_from_uri("page")."&page=".($E+1)).'" class="loadmore">'.'Load more data'.'</a>'.script("qsl('a').onclick = partial(selectLoadMore, ".(+$z).", '".'Loading'."...');",""):''),"\n";}}echo"<div class='footer'><div>\n";if($K||$E){if($Gf){$Ce=($gd===false?$E+(count($K)>=$z?2:1):floor(($gd-1)/$z));echo"<fieldset>";if($x!="simpledb"){echo"<legend><a href='".h(remove_from_uri("page"))."'>".'Page'."</a></legend>",script("qsl('a').onclick = function () { pageClick(this.href, +prompt('".'Page'."', '".($E+1)."')); return false; };"),pagination(0,$E).($E>5?" ...":"");for($s=max(1,$E-4);$s<min($Ce,$E+5);$s++)echo
  1917. pagination($s,$E);if($Ce>0){echo($E+5<$Ce?" ...":""),($Ac&&$gd!==false?pagination($Ce,$E):" <a href='".h(remove_from_uri("page")."&page=last")."' title='~$Ce'>".'last'."</a>");}}else{echo"<legend>".'Page'."</legend>",pagination(0,$E).($E>1?" ...":""),($E?pagination($E,$E):""),($Ce>$E?pagination($E+1,$E).($Ce>$E+1?" ...":""):"");}echo"</fieldset>\n";}echo"<fieldset>","<legend>".'Whole result'."</legend>";$ac=($Ac?"":"~ ").$gd;echo
  1918. checkbox("all",1,0,($gd!==false?($Ac?"":"~ ").lang(array('%d row','%d rows'),$gd):""),"var checked = formChecked(this, /check/); selectCount('selected', this.checked ? '$ac' : checked); selectCount('selected2', this.checked || !checked ? '$ac' : checked);")."\n","</fieldset>\n";if($b->selectCommandPrint()){echo'<fieldset',($_GET["modify"]?'':' class="jsonly"'),'><legend>Modify</legend><div>
  1919. <input type="submit" value="Save"',($_GET["modify"]?'':' title="'.'Ctrl+click on a value to modify it.'.'"'),'>
  1920. </div></fieldset>
  1921. <fieldset><legend>Selected <span id="selected"></span></legend><div>
  1922. <input type="submit" name="edit" value="Edit">
  1923. <input type="submit" name="clone" value="Clone">
  1924. <input type="submit" name="delete" value="Delete">',confirm(),'</div></fieldset>
  1925. ';}$ed=$b->dumpFormat();foreach((array)$_GET["columns"]as$e){if($e["fun"]){unset($ed['sql']);break;}}if($ed){print_fieldset("export",'Export'." <span id='selected2'></span>");$Ef=$b->dumpOutput();echo($Ef?html_select("output",$Ef,$ya["output"])." ":""),html_select("format",$ed,$ya["format"])," <input type='submit' name='export' value='".'Export'."'>\n","</div></fieldset>\n";}$b->selectEmailPrint(array_filter($rc,'strlen'),$f);}echo"</div></div>\n";if($b->selectImportPrint()){echo"<div>","<a href='#import'>".'Import'."</a>",script("qsl('a').onclick = partial(toggle, 'import');",""),"<span id='import' class='hidden'>: ","<input type='file' name='csv_file'> ",html_select("separator",array("csv"=>"CSV,","csv;"=>"CSV;","tsv"=>"TSV"),$ya["format"],1);echo" <input type='submit' name='import' value='".'Import'."'>","</span>","</div>";}echo"<input type='hidden' name='token' value='$hi'>\n","</form>\n",(!$md&&$L?"":script("tableCheck();"));}}}if(is_ajax()){ob_end_clean();exit;}}elseif(isset($_GET["variables"])){$P=isset($_GET["status"]);page_header($P?'Status':'Variables');$Pi=($P?show_status():show_variables());if(!$Pi)echo"<p class='message'>".'No rows.'."\n";else{echo"<table cellspacing='0'>\n";foreach($Pi
  1926. as$y=>$X){echo"<tr>","<th><code class='jush-".$x.($P?"status":"set")."'>".h($y)."</code>","<td>".h($X);}echo"</table>\n";}}elseif(isset($_GET["script"])){header("Content-Type: text/javascript; charset=utf-8");if($_GET["script"]=="db"){$Fh=array("Data_length"=>0,"Index_length"=>0,"Data_free"=>0);foreach(table_status()as$C=>$S){json_row("Comment-$C",h($S["Comment"]));if(!is_view($S)){foreach(array("Engine","Collation")as$y)json_row("$y-$C",h($S[$y]));foreach($Fh+array("Auto_increment"=>0,"Rows"=>0)as$y=>$X){if($S[$y]!=""){$X=format_number($S[$y]);json_row("$y-$C",($y=="Rows"&&$X&&$S["Engine"]==($sh=="pgsql"?"table":"InnoDB")?"~ $X":$X));if(isset($Fh[$y]))$Fh[$y]+=($S["Engine"]!="InnoDB"||$y!="Data_free"?$S[$y]:0);}elseif(array_key_exists($y,$S))json_row("$y-$C");}}}foreach($Fh
  1927. as$y=>$X)json_row("sum-$y",format_number($X));json_row("");}elseif($_GET["script"]=="kill")$g->query("KILL ".number($_POST["kill"]));else{foreach(count_tables($b->databases())as$l=>$X){json_row("tables-$l",$X);json_row("size-$l",db_size($l));}json_row("");}exit;}else{$Oh=array_merge((array)$_POST["tables"],(array)$_POST["views"]);if($Oh&&!$n&&!$_POST["search"]){$H=true;$He="";if($x=="sql"&&$_POST["tables"]&&count($_POST["tables"])>1&&($_POST["drop"]||$_POST["truncate"]||$_POST["copy"]))queries("SET foreign_key_checks = 0");if($_POST["truncate"]){if($_POST["tables"])$H=truncate_tables($_POST["tables"]);$He='Tables have been truncated.';}elseif($_POST["move"]){$H=move_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$He='Tables have been moved.';}elseif($_POST["copy"]){$H=copy_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$He='Tables have been copied.';}elseif($_POST["drop"]){if($_POST["views"])$H=drop_views($_POST["views"]);if($H&&$_POST["tables"])$H=drop_tables($_POST["tables"]);$He='Tables have been dropped.';}elseif($x!="sql"){$H=($x=="sqlite"?queries("VACUUM"):apply_queries("VACUUM".($_POST["optimize"]?"":" ANALYZE"),$_POST["tables"]));$He='Tables have been optimized.';}elseif(!$_POST["tables"])$He='No tables.';elseif($H=queries(($_POST["optimize"]?"OPTIMIZE":($_POST["check"]?"CHECK":($_POST["repair"]?"REPAIR":"ANALYZE")))." TABLE ".implode(", ",array_map('idf_escape',$_POST["tables"])))){while($J=$H->fetch_assoc())$He.="<b>".h($J["Table"])."</b>: ".h($J["Msg_text"])."<br>";}queries_redirect(substr(ME,0,-1),$He,$H);}page_header(($_GET["ns"]==""?'Database'.": ".h(DB):'Schema'.": ".h($_GET["ns"])),$n,true);if($b->homepage()){if($_GET["ns"]!==""){echo"<h3 id='tables-views'>".'Tables and views'."</h3>\n";$Nh=tables_list();if(!$Nh)echo"<p class='message'>".'No tables.'."\n";else{echo"<form action='' method='post'>\n";if(support("table")){echo"<fieldset><legend>".'Search data in tables'." <span id='selected2'></span></legend><div>","<input type='search' name='query' value='".h($_POST["query"])."'>",script("qsl('input').onkeydown = partialArg(bodyKeydown, 'search');","")," <input type='submit' name='search' value='".'Search'."'>\n","</div></fieldset>\n";if($_POST["search"]&&$_POST["query"]!=""){$_GET["where"][0]["op"]="LIKE %%";search_tables();}}$bc=doc_link(array('sql'=>'show-table-status.html'));echo"<table cellspacing='0' class='nowrap checkable'>\n",script("mixin(qsl('table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true)});"),'<thead><tr class="wrap">','<td><input id="check-all" type="checkbox" class="jsonly">'.script("qs('#check-all').onclick = partial(formCheck, /^(tables|views)\[/);",""),'<th>'.'Table','<td>'.'Engine'.doc_link(array('sql'=>'storage-engines.html')),'<td>'.'Collation'.doc_link(array('sql'=>'charset-charsets.html','mariadb'=>'supported-character-sets-and-collations/')),'<td>'.'Data Length'.$bc,'<td>'.'Index Length'.$bc,'<td>'.'Data Free'.$bc,'<td>'.'Auto Increment'.doc_link(array('sql'=>'example-auto-increment.html','mariadb'=>'auto_increment/')),'<td>'.'Rows'.$bc,(support("comment")?'<td>'.'Comment'.$bc:''),"</thead>\n";$T=0;foreach($Nh
  1928. as$C=>$U){$Si=($U!==null&&!preg_match('~table~i',$U));$t=h("Table-".$C);echo'<tr'.odd().'><td>'.checkbox(($Si?"views[]":"tables[]"),$C,in_array($C,$Oh,true),"","","",$t),'<th>'.(support("table")||support("indexes")?"<a href='".h(ME)."table=".urlencode($C)."' title='".'Show structure'."' id='$t'>".h($C).'</a>':h($C));if($Si){echo'<td colspan="6"><a href="'.h(ME)."view=".urlencode($C).'" title="'.'Alter view'.'">'.(preg_match('~materialized~i',$U)?'Materialized view':'View').'</a>','<td align="right"><a href="'.h(ME)."select=".urlencode($C).'" title="'.'Select data'.'">?</a>';}else{foreach(array("Engine"=>array(),"Collation"=>array(),"Data_length"=>array("create",'Alter table'),"Index_length"=>array("indexes",'Alter indexes'),"Data_free"=>array("edit",'New item'),"Auto_increment"=>array("auto_increment=1&create",'Alter table'),"Rows"=>array("select",'Select data'),)as$y=>$_){$t=" id='$y-".h($C)."'";echo($_?"<td align='right'>".(support("table")||$y=="Rows"||(support("indexes")&&$y!="Data_length")?"<a href='".h(ME."$_[0]=").urlencode($C)."'$t title='$_[1]'>?</a>":"<span$t>?</span>"):"<td id='$y-".h($C)."'>");}$T++;}echo(support("comment")?"<td id='Comment-".h($C)."'>":"");}echo"<tr><td><th>".sprintf('%d in total',count($Nh)),"<td>".h($x=="sql"?$g->result("SELECT @@storage_engine"):""),"<td>".h(db_collation(DB,collations()));foreach(array("Data_length","Index_length","Data_free")as$y)echo"<td align='right' id='sum-$y'>";echo"</table>\n";if(!information_schema(DB)){echo"<div class='footer'><div>\n";$Mi="<input type='submit' value='".'Vacuum'."'> ".on_help("'VACUUM'");$qf="<input type='submit' name='optimize' value='".'Optimize'."'> ".on_help($x=="sql"?"'OPTIMIZE TABLE'":"'VACUUM OPTIMIZE'");echo"<fieldset><legend>".'Selected'." <span id='selected'></span></legend><div>".($x=="sqlite"?$Mi:($x=="pgsql"?$Mi.$qf:($x=="sql"?"<input type='submit' value='".'Analyze'."'> ".on_help("'ANALYZE TABLE'").$qf."<input type='submit' name='check' value='".'Check'."'> ".on_help("'CHECK TABLE'")."<input type='submit' name='repair' value='".'Repair'."'> ".on_help("'REPAIR TABLE'"):"")))."<input type='submit' name='truncate' value='".'Truncate'."'> ".on_help($x=="sqlite"?"'DELETE'":"'TRUNCATE".($x=="pgsql"?"'":" TABLE'")).confirm()."<input type='submit' name='drop' value='".'Drop'."'>".on_help("'DROP TABLE'").confirm()."\n";$k=(support("scheme")?$b->schemas():$b->databases());if(count($k)!=1&&$x!="sqlite"){$l=(isset($_POST["target"])?$_POST["target"]:(support("scheme")?$_GET["ns"]:DB));echo"<p>".'Move to other database'.": ",($k?html_select("target",$k,$l):'<input name="target" value="'.h($l).'" autocapitalize="off">')," <input type='submit' name='move' value='".'Move'."'>",(support("copy")?" <input type='submit' name='copy' value='".'Copy'."'>":""),"\n";}echo"<input type='hidden' name='all' value=''>";echo
  1929. script("qsl('input').onclick = function () { selectCount('selected', formChecked(this, /^(tables|views)\[/));".(support("table")?" selectCount('selected2', formChecked(this, /^tables\[/) || $T);":"")." }"),"<input type='hidden' name='token' value='$hi'>\n","</div></fieldset>\n","</div></div>\n";}echo"</form>\n",script("tableCheck();");}echo'<p class="links"><a href="'.h(ME).'create=">'.'Create table'."</a>\n",(support("view")?'<a href="'.h(ME).'view=">'.'Create view'."</a>\n":"");if(support("routine")){echo"<h3 id='routines'>".'Routines'."</h3>\n";$Qg=routines();if($Qg){echo"<table cellspacing='0'>\n",'<thead><tr><th>'.'Name'.'<td>'.'Type'.'<td>'.'Return type'."<td></thead>\n";odd('');foreach($Qg
  1930. as$J){$C=($J["SPECIFIC_NAME"]==$J["ROUTINE_NAME"]?"":"&name=".urlencode($J["ROUTINE_NAME"]));echo'<tr'.odd().'>','<th><a href="'.h(ME.($J["ROUTINE_TYPE"]!="PROCEDURE"?'callf=':'call=').urlencode($J["SPECIFIC_NAME"]).$C).'">'.h($J["ROUTINE_NAME"]).'</a>','<td>'.h($J["ROUTINE_TYPE"]),'<td>'.h($J["DTD_IDENTIFIER"]),'<td><a href="'.h(ME.($J["ROUTINE_TYPE"]!="PROCEDURE"?'function=':'procedure=').urlencode($J["SPECIFIC_NAME"]).$C).'">'.'Alter'."</a>";}echo"</table>\n";}echo'<p class="links">'.(support("procedure")?'<a href="'.h(ME).'procedure=">'.'Create procedure'.'</a>':'').'<a href="'.h(ME).'function=">'.'Create function'."</a>\n";}if(support("sequence")){echo"<h3 id='sequences'>".'Sequences'."</h3>\n";$eh=get_vals("SELECT sequence_name FROM information_schema.sequences WHERE sequence_schema = current_schema() ORDER BY sequence_name");if($eh){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Name'."</thead>\n";odd('');foreach($eh
  1931. as$X)echo"<tr".odd()."><th><a href='".h(ME)."sequence=".urlencode($X)."'>".h($X)."</a>\n";echo"</table>\n";}echo"<p class='links'><a href='".h(ME)."sequence='>".'Create sequence'."</a>\n";}if(support("type")){echo"<h3 id='user-types'>".'User types'."</h3>\n";$Ki=types();if($Ki){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Name'."</thead>\n";odd('');foreach($Ki
  1932. as$X)echo"<tr".odd()."><th><a href='".h(ME)."type=".urlencode($X)."'>".h($X)."</a>\n";echo"</table>\n";}echo"<p class='links'><a href='".h(ME)."type='>".'Create type'."</a>\n";}if(support("event")){echo"<h3 id='events'>".'Events'."</h3>\n";$K=get_rows("SHOW EVENTS");if($K){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Name'."<td>".'Schedule'."<td>".'Start'."<td>".'End'."<td></thead>\n";foreach($K
  1933. as$J){echo"<tr>","<th>".h($J["Name"]),"<td>".($J["Execute at"]?'At given time'."<td>".$J["Execute at"]:'Every'." ".$J["Interval value"]." ".$J["Interval field"]."<td>$J[Starts]"),"<td>$J[Ends]",'<td><a href="'.h(ME).'event='.urlencode($J["Name"]).'">'.'Alter'.'</a>';}echo"</table>\n";$zc=$g->result("SELECT @@event_scheduler");if($zc&&$zc!="ON")echo"<p class='error'><code class='jush-sqlset'>event_scheduler</code>: ".h($zc)."\n";}echo'<p class="links"><a href="'.h(ME).'event=">'.'Create event'."</a>\n";}if($Nh)echo
  1934. script("ajaxSetHtml('".js_escape(ME)."script=db');");}}}page_footer();
Add Comment
Please, Sign In to add comment