Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- <?php
- /** Adminer - Compact database management
- * @link https://www.adminer.org/
- * @author Jakub Vrana, https://www.vrana.cz/
- * @copyright 2007 Jakub Vrana
- * @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
- * @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
- * @version 4.6.3
- */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
- connection(){global$g;return$g;}function
- adminer(){global$b;return$b;}function
- version(){global$ia;return$ia;}function
- idf_unescape($u){$ke=substr($u,-1);return
- str_replace($ke.$ke,$ke,substr($u,1,-1));}function
- escape_string($X){return
- substr(q($X),1,-1);}function
- number($X){return
- preg_replace('~[^0-9]+~','',$X);}function
- number_type(){return'((?<!o)int(?!er)|numeric|real|float|double|decimal|money)';}function
- remove_slashes($kg,$Uc=false){if(get_magic_quotes_gpc()){while(list($y,$X)=each($kg)){foreach($X
- 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
- bracket_escape($u,$Na=false){static$li=array(':'=>':1',']'=>':2','['=>':3','"'=>':4');return
- strtr($u,($Na?array_flip($li):$li));}function
- 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
- charset($g){return(min_version("5.5.3",0,$g)?"utf8mb4":"utf8");}function
- script($ph,$ki="\n"){return"<script".nonce().">$ph</script>$ki";}function
- script_src($Fi){return"<script src='".h($Fi)."'".nonce()."></script>\n";}function
- nonce(){return' nonce="'.get_nonce().'"';}function
- target_blank(){return' target="_blank" rel="noreferrer noopener"';}function
- h($Q){return
- str_replace("\0","�",htmlspecialchars($Q,ENT_QUOTES,'utf-8'));}function
- nl_br($Q){return
- str_replace("\n","<br>",$Q);}function
- 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
- optionlist($sf,$Zg=null,$Ji=false){$I="";foreach($sf
- as$ae=>$W){$tf=array($ae=>$W);if(is_array($W)){$I.='<optgroup label="'.h($ae).'">';$tf=$W;}foreach($tf
- 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
- 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
- as$y=>$X)$I.="<label><input type='radio' name='".h($C)."' value='".h($y)."'".($y==$Y?" checked":"").">".h($X)."</label>";return$I;}function
- 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
- confirm($He="",$ah="qsl('input')"){return
- script("$ah.onclick = function () { return confirm('".($He?js_escape($He):'Are you sure?')."'); };","");}function
- 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
- bold($Va,$jb=""){return($Va?" class='active $jb'":($jb?" class='$jb'":""));}function
- odd($I=' class="odd"'){static$s=0;if(!$I)$s=-1;return($s++%2?$I:'');}function
- js_escape($Q){return
- addcslashes($Q,"\r\n'\\/");}function
- 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
- ini_bool($Nd){$X=ini_get($Nd);return(preg_match('~^(on|true|yes)$~i',$X)||(int)$X);}function
- sid(){static$I;if($I===null)$I=(SID&&!($_COOKIE&&ini_bool("session.use_cookies")));return$I;}function
- 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
- 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
- q($Q){global$g;return$g->quote($Q);}function
- 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
- 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
- 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
- unique_array($J,$w){foreach($w
- as$v){if(preg_match("~PRIMARY|UNIQUE~",$v["type"])){$I=array();foreach($v["columns"]as$y){if(!isset($J[$y]))continue
- 2;$I[$y]=$J[$y];}return$I;}}}function
- 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
- idf_escape($y);}function
- 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
- implode(" AND ",$I);}function
- where_check($X,$p=array()){parse_str($X,$cb);remove_slashes(array(&$cb));return
- where($cb,$p);}function
- 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
- convert_fields($f,$p,$L=array()){$I="";foreach($f
- 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
- cookie($C,$Y,$se=2592000){global$ba;return
- 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
- restart_session(){if(!ini_bool("session.use_cookies"))session_start();}function
- 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
- set_session($y,$X){$_SESSION[$y][DRIVER][SERVER][$_GET["username"]]=$X;}function
- 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
- is_ajax(){return($_SERVER["HTTP_X_REQUESTED_WITH"]=="XMLHttpRequest");}function
- 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
- 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
- false;}if($wg)redirect($A,$He.$sh);return
- true;}function
- queries($G){global$g;static$pg=array();static$xh;if(!$xh)$xh=microtime(true);if($G===null)return
- array(implode("\n",$pg),format_time($xh));$pg[]=(preg_match('~;$~',$G)?"DELIMITER ;;\n$G;\nDELIMITER ":$G).";";return$g->query($G);}function
- apply_queries($G,$T,$yc='table'){foreach($T
- as$R){if(!queries("$G ".$yc($R)))return
- false;}return
- true;}function
- queries_redirect($A,$He,$wg){list($pg,$Xh)=queries(null);return
- query_redirect($pg,$A,$He,$wg,false,!$wg,$Xh);}function
- format_time($xh){return
- sprintf('%.3f s',max(0,microtime(true)-$xh));}function
- remove_from_uri($Hf=""){return
- substr(preg_replace("~(?<=[?&])($Hf".(SID?"":"|".session_name()).")=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
- 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
- get_file($y,$Qb=false){$Sc=$_FILES[$y];if(!$Sc)return
- null;foreach($Sc
- 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
- 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
- repeat_pattern($Uf,$qe){return
- str_repeat("$Uf{0,65535}",$qe/65535)."$Uf{0,".($qe%65535)."}";}function
- is_utf8($X){return(preg_match('~~u',$X)&&!preg_match('~[\0-\x8\xB\xC\xE-\x1F]~',$X));}function
- 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
- h($B[1]).$Dh.(isset($B[2])?"":"<i>...</i>");}function
- format_number($X){return
- strtr(number_format($X,0,".",','),preg_split('~~u','0123456789',-1,PREG_SPLIT_NO_EMPTY));}function
- friendly_url($X){return
- preg_replace('~[^a-z0-9_]~i','-',$X);}function
- hidden_fields($kg,$Dd=array()){$I=false;while(list($y,$X)=each($kg)){if(!in_array($y,$Dd)){if(is_array($X)){foreach($X
- as$ae=>$W)$kg[$y."[$ae]"]=$W;}else{$I=true;echo'<input type="hidden" name="'.h($y).'" value="'.h($X).'">';}}}return$I;}function
- 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
- table_status1($R,$Nc=false){$I=table_status($R,$Nc);return($I?$I:array("Name"=>$R));}function
- 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
- 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
- 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
- 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
- as$y=>$X){if($y===""||!$X)break;$Vc++;}if($Vc)echo
- script("mixin(qsl('td'), {onchange: partial(skipOriginal, $Vc), oninput: function () { this.onchange(); }});");}}function
- 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
- false;if($Y=="")return"NULL";return+$Y;}if($o["auto_increment"]&&$Y=="")return
- 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
- array_sum((array)$Y);if($r=="json"){$r="";$Y=json_decode($Y,true);if(!is_array($Y))return
- 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
- false;return$m->quoteBinary($Sc);}return$b->processInput($o,$Y,$r);}function
- 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
- 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
- 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
- dump_csv($J){foreach($J
- as$y=>$X){if(preg_match("~[\"\n,;\t]~",$X)||$X==="")$J[$y]='"'.str_replace('"','""',$X).'"';}echo
- implode(($_POST["format"]=="csv"?",":($_POST["format"]=="tsv"?"\t":";")),$J)."\r\n";}function
- apply_sql_function($r,$e){return($r?($r=="unixepoch"?"DATETIME($e, '$r')":($r=="count distinct"?"COUNT(DISTINCT ":strtoupper("$r("))."$e)"):$e);}function
- 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
- false;$I=dirname($Tc);unlink($Tc);}}return$I;}function
- 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
- file_write_unlock($hd,$Kb){rewind($hd);fwrite($hd,$Kb);ftruncate($hd,strlen($Kb));flock($hd,LOCK_UN);fclose($hd);}function
- 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
- rand_string(){return
- md5(uniqid(mt_rand(),true));}function
- select_value($X,$_,$o,$Wh){global$b;if(is_array($X)){$I="";foreach($X
- 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
- 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
- is_string($pc)&&preg_match("(^$Uf(,\\s*$Uf)*\$)i",$pc);}function
- is_url($Q){$cc='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return
- preg_match("~^(https?)://($cc?\\.)+$cc(:\\d+)?(/.*)?(\\?.*)?(#.*)?\$~i",$Q);}function
- is_shortable($o){return
- preg_match('~char|text|json|lob|geometry|point|linestring|polygon|string|bytea~',$o["type"]);}function
- 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
- 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(),'>
- var timeout = setTimeout(function () {
- ajax(\'',js_escape(ME),'script=kill\', function () {
- }, \'kill=',$fe,'&token=',$hi,'\');
- }, ',1000*$Yh,');
- </script>
- ';}else$h=null;ob_flush();flush();$I=@get_key_vals(($mh?$mh:$G),$h,false);if($h){echo
- script("clearTimeout(timeout);");ob_flush();flush();}return$I;}function
- get_token(){$sg=rand(1,1e6);return($sg^$_SESSION["token"]).":$sg";}function
- verify_token(){list($hi,$sg)=explode(":",$_POST["token"]);return($sg^$_SESSION["token"])==$hi;}function
- 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
- 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
- on_help($rb,$jh=0){return
- script("mixin(qsl('select, input'), {onmouseover: function (event) { helpMouseover.call(this, event, $rb, $jh) }, onmouseout: helpMouseout});","");}function
- 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">
- ';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
- 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"]),'">
- <input type="hidden" name="save" value="1">
- <input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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
- 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
- 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|Б‰фўЫ–*фFAquvyO’Ѕ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|п™Cy,Є<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‹а@*УT2Щ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
- 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¤Жeh+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\0ta ¶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ы¦aZKpиЮ§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б”@Иѓ3t`¶†¶-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ЎQte=‘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ЩшC9M5рк*шЏ`кk’г¬Ћ цю©AhYВ©*–©ЄЉ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 ¤ЩсєD2!°ф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М/–щІЋМЏўМндътXWe+&›%ДСІ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.м‰ЕRkвЂ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Є¦Џ»+Є»%р:Й_,ФeoиП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{Љ.‚зyS‰ љ#Й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ћзл±Й™¬bhU-Ў‚,Ђr гLk8§ Ц«†V&Ъal§ШлаdнЊЧ2; '-Ў¶Jyu—›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ЈКFZВ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цD6/Цї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УАиЊ2Aђ1,µтC¤ixрtѓТ ђG]qмO(Д™±Џ\nіV9drбD'5@x\$‹r6‰’;\"ЗЈЈзЁ7Г\0M0Е†H_#дcаpn>¤<aaq@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ХR6<ЋOєSТ_BCS+”„†з'V€ю2T#LcмF»NBD%я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о|ћЎџ(Г&Ќ@:тј \"-ЮЋщшΜк,А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µЛbx}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
- 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†г©¶yHchдВ-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бБ@јЙЌГа@„}&„Ѓ€L7U°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ЃК–и-яЬхУ 9O\$ґ‰Ш·zyM™3„\\9Ьи.oЉ¶љМлёE(iеаћњДУ7 tЯљйќ-&ў\nj!\rЃАyњyаD1gрТц]«ЬyRФ7\"рж§·ѓ€~АнаЬ)TZ0E9MеYZtXe!Э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.I53Q3Qф»J„”g ’5…sаъЋ&jСЊ’Хu‚ЩРЄGQMTmGBѓtl-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ЈЬ-N99f–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†5bp#Е}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 >Г2j…;=Ъ¬Ы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ф Ў\rTЦЧ›Ѓ Ђ+\\»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ЈEAJF4а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д*р66A'э,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(№‘ЮЎ”„¬ќaGн§М+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а\$mvќЁ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с_<ЃАж9pBU\"\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НЊјЊpqGLqqцGІyНH.«^аћ\0zХ\$ЂAT9Fs†Р…ўD{нa§шcc_ЂGИz†)уі‡ Ь}QЖЕhуМHBЦёЌ<‚y!L“ЂЫ!\\‚І€о ш'’H(‚д-µ\"ѓin]Дћ€і\\Ё!Ъ`MH,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з+hR·КФ8о‰ЂаhR±,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\\Ы”dGеьp#и¤> 0А«\$2“4z )А`ВWр +\0Љ‘80ЈиЏ¦• ¤Є”дz\"TРд0Ф:\0Љ\ne \$ЂЋrM”=Ўr\nІN‰PчCmt80ръ #¤Ш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Єei9Рмњv))СµGb6‰Ђ±H\r48С@‚M‰:ЂіFШtQТ!H•”{R} фURpЏНФO\0ҐI…t8¤ШрыОЗ[D4FСDЌ#КС+DЅ'фMЏК•А>RgIХґЉQпJЁ””UТ)EmаЏьTZEµ'гкЈiEЭґЈТqFzAЄє>э)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гуRyEE#эщ @эГшд%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=\\Ќ-UUUVC•ДЧ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/#¬”е#й…ЅOPХл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ЃйNXnM):№·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жQKEА #Ђї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ЅQ7П“”П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ВJSЌЭўЅц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В|Зёќбfao†б,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Љ.гж7Fr™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:Іѓе¬д`¶S1—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трфоїќ—№я?Ѓљ0GnqІ]{Тё,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ЊЕ@лґhn\$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їЇЩGjcћ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¦ <,лP7m¦»||»я¶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,ђ!ЖЧП›pN9RbG·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Г†WpЙ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Ј±·cHќҐ,Г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а¦КMyЭ+™Ы”/Ѓ\"П›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„NKЃц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Є%\08в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Я©ЯdqвЛЉ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У©§MLE5ъ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Хё«iBOє®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'n0W-О№®ж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ц—@tk0Ђ—ЎЇЕ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
- get_lang(){return'en';}function
- 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
- sprintf($mi,$bf);}if(extension_loaded('pdo')){class
- Min_PDO
- extends
- PDO{var$_result,$server_info,$affected_rows,$errno,$error;function
- __construct(){global$b;$Yf=array_search("SQL",$b->operators);if($Yf!==false)unset($b->operators[$Yf]);}function
- 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
- 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
- false;}$this->store_result($H);return$H;}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result($H=null){if(!$H){$H=$this->_result;if(!$H)return
- false;}if($H->columnCount()){$H->num_rows=$H->rowCount();return$H;}$this->affected_rows=$H->rowCount();return
- true;}function
- next_result(){if(!$this->_result)return
- false;$this->_result->_offset=0;return@$this->_result->nextRowset();}function
- result($G,$o=0){$H=$this->query($G);if(!$H)return
- false;$J=$H->fetch();return$J[$o];}}class
- Min_PDOStatement
- extends
- PDOStatement{var$_offset=0,$num_rows;function
- fetch_assoc(){return$this->fetch(2);}function
- fetch_row(){return$this->fetch(3);}function
- fetch_field(){$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
- Min_SQL{var$_conn;function
- __construct($g){$this->_conn=$g;}function
- 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
- delete($R,$qg,$z=0){$G="FROM ".table($R);return
- queries("DELETE".($z?limit1($R,$G,$qg):" $G$qg"));}function
- update($R,$O,$qg,$z=0,$M="\n"){$Oi=array();foreach($O
- as$y=>$X)$Oi[]="$y = $X";$G=table($R)." SET$M".implode(",$M",$Oi);return
- queries("UPDATE".($z?limit1($R,$G,$qg,$M):" $G$qg"));}function
- insert($R,$O){return
- queries("INSERT INTO ".table($R).($O?" (".implode(", ",array_keys($O)).")\nVALUES (".implode(", ",$O).")":" DEFAULT VALUES"));}function
- insertUpdate($R,$K,$eg){return
- false;}function
- begin(){return
- queries("BEGIN");}function
- commit(){return
- queries("COMMIT");}function
- rollback(){return
- queries("ROLLBACK");}function
- slowQuery($G,$Yh){}function
- convertSearch($u,$X,$o){return$u;}function
- value($X,$o){return(method_exists($this->_conn,'value')?$this->_conn->value($X,$o):(is_resource($X)?stream_get_contents($X):$X));}function
- quoteBinary($Sg){return
- q($Sg);}function
- warnings(){return'';}function
- 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
- Min_SQLite{var$extension="SQLite3",$server_info,$affected_rows,$errno,$error,$_link;function
- __construct($Tc){$this->_link=new
- SQLite3($Tc);$Ri=$this->_link->version();$this->server_info=$Ri["versionString"];}function
- query($G){$H=@$this->_link->query($G);$this->error="";if(!$H){$this->errno=$this->_link->lastErrorCode();$this->error=$this->_link->lastErrorMsg();return
- false;}elseif($H->numColumns())return
- new
- Min_Result($H);$this->affected_rows=$this->_link->changes();return
- true;}function
- quote($Q){return(is_utf8($Q)?"'".$this->_link->escapeString($Q)."'":"x'".reset(unpack('H*',$Q))."'");}function
- store_result(){return$this->_result;}function
- result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
- false;$J=$H->_result->fetchArray();return$J[$o];}}class
- Min_Result{var$_result,$_offset=0,$num_rows;function
- __construct($H){$this->_result=$H;}function
- fetch_assoc(){return$this->_result->fetchArray(SQLITE3_ASSOC);}function
- fetch_row(){return$this->_result->fetchArray(SQLITE3_NUM);}function
- 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
- __desctruct(){return$this->_result->finalize();}}}else{class
- Min_SQLite{var$extension="SQLite",$server_info,$affected_rows,$error,$_link;function
- __construct($Tc){$this->server_info=sqlite_libversion();$this->_link=new
- SQLiteDatabase($Tc);}function
- query($G,$xi=false){$Ne=($xi?"unbufferedQuery":"query");$H=@$this->_link->$Ne($G,SQLITE_BOTH,$n);$this->error="";if(!$H){$this->error=$n;return
- false;}elseif($H===true){$this->affected_rows=$this->changes();return
- true;}return
- new
- Min_Result($H);}function
- quote($Q){return"'".sqlite_escape_string($Q)."'";}function
- store_result(){return$this->_result;}function
- result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
- false;$J=$H->_result->fetch();return$J[$o];}}class
- Min_Result{var$_result,$_offset=0,$num_rows;function
- __construct($H){$this->_result=$H;if(method_exists($H,'numRows'))$this->num_rows=$H->numRows();}function
- fetch_assoc(){$J=$this->_result->fetch(SQLITE_ASSOC);if(!$J)return
- false;$I=array();foreach($J
- as$y=>$X)$I[($y[0]=='"'?idf_unescape($y):$y)]=$X;return$I;}function
- fetch_row(){return$this->_result->fetch(SQLITE_NUM);}function
- 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
- Min_SQLite
- extends
- Min_PDO{var$extension="PDO_SQLite";function
- __construct($Tc){$this->dsn(DRIVER.":$Tc","","");}}}if(class_exists("Min_SQLite")){class
- Min_DB
- extends
- Min_SQLite{function
- __construct(){parent::__construct(":memory:");$this->query("PRAGMA foreign_keys = 1");}function
- 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
- true;}return
- false;}function
- multi_query($G){return$this->_result=$this->query($G);}function
- next_result(){return
- false;}}}class
- Min_Driver
- extends
- Min_SQL{function
- insertUpdate($R,$K,$eg){$Oi=array();foreach($K
- as$O)$Oi[]="(".implode(", ",$O).")";return
- queries("REPLACE INTO ".table($R)." (".implode(", ",array_keys(reset($K))).") VALUES\n".implode(",\n",$Oi));}function
- tableHelp($C){if($C=="sqlite_sequence")return"fileformat2.html#seqtab";if($C=="sqlite_master")return"fileformat2.html#$C";}}function
- idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
- table($u){return
- idf_escape($u);}function
- connect(){global$b;list(,,$F)=$b->credentials();if($F!="")return'Database does not support password.';return
- new
- Min_DB;}function
- get_databases(){return
- array();}function
- limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
- 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
- db_collation($l,$ob){global$g;return$g->result("PRAGMA encoding");}function
- engines(){return
- array();}function
- logged_user(){return
- get_current_user();}function
- tables_list(){return
- get_key_vals("SELECT name, type FROM sqlite_master WHERE type IN ('table', 'view') ORDER BY (name = 'sqlite_sequence'), name");}function
- count_tables($k){return
- array();}function
- 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
- is_view($S){return$S["Engine"]=="view";}function
- fk_support($S){global$g;return!$g->result("SELECT sqlite_compileoption_used('OMIT_FOREIGN_KEY')");}function
- 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
- as$B){$C=str_replace('""','"',preg_replace('~^"|"$~','',$B[1]));if($I[$C])$I[$C]["collation"]=trim($B[3],"'");}return$I;}function
- 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
- 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
- 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
- view($C){global$g;return
- array("select"=>preg_replace('~^(?:[^`"[]+|`[^`]*`|"[^"]*")* AS\s+~iU','',$g->result("SELECT sql FROM sqlite_master WHERE name = ".q($C))));}function
- collations(){return(isset($_GET["create"])?get_vals("PRAGMA collation_list",1):array());}function
- information_schema($l){return
- false;}function
- error(){global$g;return
- h($g->error);}function
- 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
- false;}return
- true;}function
- create_database($l,$d){global$g;if(file_exists($l)){$g->error='File exists.';return
- false;}if(!check_sqlite_name($l))return
- false;try{$_=new
- Min_SQLite($l);}catch(Exception$_c){$g->error=$_c->getMessage();return
- false;}$_->query('PRAGMA encoding = "UTF-8"');$_->query('CREATE TABLE adminer (i)');$_->query('DROP TABLE adminer');return
- true;}function
- drop_databases($k){global$g;$g->__construct(":memory:");foreach($k
- as$l){if(!@unlink($l)){$g->error='File exists.';return
- false;}}return
- true;}function
- rename_database($C,$d){global$g;if(!check_sqlite_name($C))return
- false;$g->__construct(":memory:");$g->error='File exists.';return@rename(DB,$C);}function
- auto_increment(){return" PRIMARY KEY".(DRIVER=="sqlite"?" AUTOINCREMENT":"");}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$Ii=($R==""||$bd);foreach($p
- as$o){if($o[0]!=""||!$o[1]||$o[2]){$Ii=true;break;}}$c=array();$Cf=array();foreach($p
- 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
- as$X){if(!queries("ALTER TABLE ".table($R)." $X"))return
- false;}if($R!=$C&&!queries("ALTER TABLE ".table($R)." RENAME TO ".table($C)))return
- false;}elseif(!recreate_table($R,$C,$c,$Cf,$bd))return
- false;if($La)queries("UPDATE sqlite_sequence SET seq = $La WHERE name = ".q($C));return
- true;}function
- 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
- as$o){if($o[6])$fg=true;}$gc=array();foreach($w
- 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
- 2;$f[]=$Cf[$e].($v["descs"][$y]?" DESC":"");}if(!$gc[$de]){if($v["type"]!="PRIMARY"||!$fg)$w[]=array($v["type"],$de,$f);}}foreach($w
- 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
- 2;$q["source"][$y]=idf_unescape($Cf[$e]);}if(!isset($bd[" $de"]))$bd[]=" ".format_foreign_key($q);}queries("BEGIN");}foreach($p
- 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
- 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
- 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
- false;queries("ALTER TABLE ".table("adminer_$C")." RENAME TO ".table($C));if(!alter_indexes($C,$w))return
- false;foreach($ti
- as$qi){if(!queries($qi))return
- false;}queries("COMMIT");}return
- true;}function
- index_sql($R,$U,$C,$f){return"CREATE $U ".($U!="INDEX"?"INDEX ":"").idf_escape($C!=""?$C:uniqid($R."_"))." ON ".table($R)." $f";}function
- alter_indexes($R,$c){foreach($c
- as$eg){if($eg[0]=="PRIMARY")return
- 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
- false;}return
- true;}function
- truncate_tables($T){return
- apply_queries("DELETE FROM",$T);}function
- drop_views($Ti){return
- apply_queries("DROP VIEW",$Ti);}function
- drop_tables($T){return
- apply_queries("DROP TABLE",$T);}function
- move_tables($T,$Ti,$Qh){return
- false;}function
- trigger($C){global$g;if($C=="")return
- 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
- 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
- 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
- trigger_options(){return
- array("Timing"=>array("BEFORE","AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","UPDATE OF","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
- begin(){return
- queries("BEGIN");}function
- last_id(){global$g;return$g->result("SELECT LAST_INSERT_ROWID()");}function
- explain($g,$G){return$g->query("EXPLAIN QUERY PLAN $G");}function
- found_rows($S,$Z){}function
- types(){return
- array();}function
- schemas(){return
- array();}function
- get_schema(){return"";}function
- set_schema($Vg){return
- true;}function
- 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
- truncate_sql($R){return"DELETE FROM ".table($R);}function
- use_sql($j){}function
- trigger_sql($R){return
- implode(get_vals("SELECT sql || ';;\n' FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($R)));}function
- 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
- show_status(){$I=array();foreach(get_vals("PRAGMA compile_options")as$rf){list($y,$X)=explode("=",$rf,2);$I[$y]=$X;}return$I;}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- support($Oc){return
- 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
- Min_DB{var$extension="PgSQL",$_link,$_result,$_string,$_database=true,$server_info,$affected_rows,$error,$timeout;function
- _error($wc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
- 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
- quote($Q){return"'".pg_escape_string($this->_link,$Q)."'";}function
- value($X,$o){return($o["type"]=="bytea"?pg_unescape_bytea($X):$X);}function
- quoteBinary($Q){return"'".pg_escape_bytea($this->_link,$Q)."'";}function
- 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
- close(){$this->_link=@pg_connect("$this->_string dbname='postgres'");}function
- 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
- Min_Result($H);if($this->timeout){$this->timeout=0;$this->query("RESET statement_timeout");}return$I;}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- false;}function
- result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
- false;return
- pg_fetch_result($H->_result,0,$o);}function
- warnings(){return
- h(pg_last_notice($this->_link));}}class
- Min_Result{var$_result,$_offset=0,$num_rows;function
- __construct($H){$this->_result=$H;$this->num_rows=pg_num_rows($H);}function
- fetch_assoc(){return
- pg_fetch_assoc($this->_result);}function
- fetch_row(){return
- pg_fetch_row($this->_result);}function
- fetch_field(){$e=$this->_offset++;$I=new
- 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
- __destruct(){pg_free_result($this->_result);}}}elseif(extension_loaded("pdo_pgsql")){class
- Min_DB
- extends
- Min_PDO{var$extension="PDO_PgSQL",$timeout;function
- 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
- true;}function
- select_db($j){global$b;return($b->database()==$j);}function
- quoteBinary($Sg){return
- q($Sg);}function
- query($G,$xi=false){$I=parent::query($G,$xi);if($this->timeout){$this->timeout=0;parent::query("RESET statement_timeout");}return$I;}function
- warnings(){return'';}function
- close(){}}}class
- Min_Driver
- extends
- Min_SQL{function
- insertUpdate($R,$K,$eg){global$g;foreach($K
- as$O){$Di=array();$Z=array();foreach($O
- 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
- false;}return
- true;}function
- slowQuery($G,$Yh){$this->_conn->query("SET statement_timeout = ".(1000*$Yh));$this->_conn->timeout=1000*$Yh;return$G;}function
- 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
- quoteBinary($Sg){return$this->_conn->quoteBinary($Sg);}function
- warnings(){return$this->_conn->warnings();}function
- tableHelp($C){$te=array("information_schema"=>"infoschema","pg_catalog"=>"catalog",);$_=$te[$_GET["ns"]];if($_)return"$_-".str_replace("_","-",$C).".html";}}function
- idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
- table($u){return
- idf_escape($u);}function
- connect(){global$b,$wi,$Ah;$g=new
- 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
- get_databases(){return
- get_vals("SELECT datname FROM pg_database WHERE has_database_privilege(datname, 'CONNECT') ORDER BY datname");}function
- limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
- 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
- db_collation($l,$ob){global$g;return$g->result("SHOW LC_COLLATE");}function
- engines(){return
- array();}function
- logged_user(){global$g;return$g->result("SELECT user");}function
- tables_list(){$G="SELECT table_name, table_type FROM information_schema.tables WHERE table_schema = current_schema()";if(support('materializedview'))$G.="
- UNION ALL
- SELECT matviewname, 'MATERIALIZED VIEW'
- FROM pg_matviews
- WHERE schemaname = current_schema()";$G.="
- ORDER BY 1";return
- get_key_vals($G);}function
- count_tables($k){return
- array();}function
- 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
- FROM pg_class c
- JOIN pg_namespace n ON(n.nspname = current_schema() AND n.oid = c.relnamespace)
- WHERE relkind IN ('r', 'm', 'v', 'f')
- ".($C!=""?"AND relname = ".q($C):"ORDER BY relname"))as$J)$I[$J["Name"]]=$J;return($C!=""?$I[$C]:$I);}function
- is_view($S){return
- in_array($S["Engine"],array("view","materialized view"));}function
- fk_support($S){return
- true;}function
- 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
- FROM pg_class c
- JOIN pg_namespace n ON c.relnamespace = n.oid
- JOIN pg_attribute a ON c.oid = a.attrelid
- LEFT JOIN pg_attrdef d ON c.oid = d.adrelid AND a.attnum = d.adnum
- WHERE c.relname = ".q($R)."
- AND n.nspname = current_schema()
- AND NOT a.attisdropped
- AND a.attnum > 0
- 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
- 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
- foreign_keys($R){global$kf;$I=array();foreach(get_rows("SELECT conname, condeferrable::int AS deferrable, pg_get_constraintdef(oid) AS definition
- FROM pg_constraint
- 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())
- AND contype = 'f'::char
- 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
- view($C){global$g;return
- array("select"=>trim($g->result("SELECT view_definition
- FROM information_schema.views
- WHERE table_schema = current_schema() AND table_name = ".q($C))));}function
- collations(){return
- array();}function
- information_schema($l){return($l=="information_schema");}function
- 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
- nl_br($I);}function
- create_database($l,$d){return
- queries("CREATE DATABASE ".idf_escape($l).($d?" ENCODING ".idf_escape($d):""));}function
- drop_databases($k){global$g;$g->close();return
- apply_queries("DROP DATABASE",$k,'idf_escape');}function
- rename_database($C,$d){return
- queries("ALTER DATABASE ".idf_escape(DB)." RENAME TO ".idf_escape($C));}function
- auto_increment(){return"";}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();$pg=array();foreach($p
- 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
- as$G){if(!queries($G))return
- false;}return
- true;}function
- alter_indexes($R,$c){$i=array();$ec=array();$pg=array();foreach($c
- 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
- as$G){if(!queries($G))return
- false;}return
- true;}function
- truncate_tables($T){return
- queries("TRUNCATE ".implode(", ",array_map('table',$T)));return
- true;}function
- drop_views($Ti){return
- drop_tables($Ti);}function
- drop_tables($T){foreach($T
- as$R){$P=table_status($R);if(!queries("DROP ".strtoupper($P["Engine"])." ".table($R)))return
- false;}return
- true;}function
- 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
- false;}return
- true;}function
- trigger($C,$R=null){if($C=="")return
- 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
- reset($K);}function
- 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
- trigger_options(){return
- array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW","FOR EACH STATEMENT"),);}function
- routine($C,$U){$K=get_rows('SELECT routine_definition AS definition, LOWER(external_language) AS language, *
- FROM information_schema.routines
- 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
- FROM information_schema.parameters
- WHERE specific_schema = current_schema() AND specific_name = '.q($C).'
- ORDER BY ordinal_position');return$I;}function
- routines(){return
- get_rows('SELECT specific_name AS "SPECIFIC_NAME", routine_type AS "ROUTINE_TYPE", routine_name AS "ROUTINE_NAME", type_udt_name AS "DTD_IDENTIFIER"
- FROM information_schema.routines
- WHERE routine_schema = current_schema()
- ORDER BY SPECIFIC_NAME');}function
- routine_languages(){return
- get_vals("SELECT LOWER(lanname) FROM pg_catalog.pg_language");}function
- routine_id($C,$J){$I=array();foreach($J["fields"]as$o)$I[]=$o["type"];return
- idf_escape($C)."(".implode(", ",$I).")";}function
- last_id(){return
- 0;}function
- explain($g,$G){return$g->query("EXPLAIN $G");}function
- 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
- false;}function
- types(){return
- get_vals("SELECT typname
- FROM pg_type
- WHERE typnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema())
- AND typtype IN ('b','d','e')
- AND typelem = 0");}function
- schemas(){return
- get_vals("SELECT nspname FROM pg_namespace ORDER BY nspname");}function
- get_schema(){global$g;return$g->result("SELECT current_schema()");}function
- 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
- 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
- false;$I="CREATE TABLE ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." (\n ";foreach($p
- 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
- 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
- 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
- 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
- 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
- rtrim($I,';');}function
- truncate_sql($R){return"TRUNCATE ".table($R);}function
- 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
- use_sql($j){return"\connect ".idf_escape($j);}function
- show_variables(){return
- get_key_vals("SHOW ALL");}function
- process_list(){return
- get_rows("SELECT * FROM pg_stat_activity ORDER BY ".(min_version(9.2)?"pid":"procpid"));}function
- show_status(){}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- support($Oc){return
- 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
- kill_process($X){return
- queries("SELECT pg_terminate_backend(".number($X).")");}function
- connection_id(){return"SELECT pg_backend_pid()";}function
- 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
- Min_DB{var$extension="oci8",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
- _error($wc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
- 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
- true;}$n=oci_error();$this->error=$n["message"];return
- false;}function
- quote($Q){return"'".str_replace("'","''",$Q)."'";}function
- select_db($j){return
- true;}function
- 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
- false;}set_error_handler(array($this,'_error'));$I=@oci_execute($H);restore_error_handler();if($I){if(oci_num_fields($H))return
- new
- Min_Result($H);$this->affected_rows=oci_num_rows($H);}return$I;}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- false;}function
- result($G,$o=1){$H=$this->query($G);if(!is_object($H)||!oci_fetch($H->_result))return
- false;return
- oci_result($H->_result,$o);}}class
- Min_Result{var$_result,$_offset=1,$num_rows;function
- __construct($H){$this->_result=$H;}function
- _convert($J){foreach((array)$J
- as$y=>$X){if(is_a($X,'OCI-Lob'))$J[$y]=$X->load();}return$J;}function
- fetch_assoc(){return$this->_convert(oci_fetch_assoc($this->_result));}function
- fetch_row(){return$this->_convert(oci_fetch_row($this->_result));}function
- fetch_field(){$e=$this->_offset++;$I=new
- 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
- __destruct(){oci_free_statement($this->_result);}}}elseif(extension_loaded("pdo_oci")){class
- Min_DB
- extends
- Min_PDO{var$extension="PDO_OCI";function
- connect($N,$V,$F){$this->dsn("oci:dbname=//$N;charset=AL32UTF8",$V,$F);return
- true;}function
- select_db($j){return
- true;}}}class
- Min_Driver
- extends
- Min_SQL{function
- begin(){return
- true;}}function
- idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
- table($u){return
- idf_escape($u);}function
- connect(){global$b;$g=new
- Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
- get_databases(){return
- get_vals("SELECT tablespace_name FROM user_tablespaces");}function
- 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
- limit1($R,$G,$Z,$M="\n"){return" $G$Z";}function
- db_collation($l,$ob){global$g;return$g->result("SELECT value FROM nls_database_parameters WHERE parameter = 'NLS_CHARACTERSET'");}function
- engines(){return
- array();}function
- logged_user(){global$g;return$g->result("SELECT USER FROM DUAL");}function
- tables_list(){return
- get_key_vals("SELECT table_name, 'table' FROM all_tables WHERE tablespace_name = ".q(DB)."
- UNION SELECT view_name, 'view' FROM user_views
- ORDER BY 1");}function
- count_tables($k){return
- array();}function
- 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":"")."
- UNION SELECT view_name, 'view', 0, 0 FROM user_views".($C!=""?" WHERE view_name = $Wg":"")."
- ORDER BY 1")as$J){if($C!="")return$J;$I[$J["Name"]]=$J;}return$I;}function
- is_view($S){return$S["Engine"]=="view";}function
- fk_support($S){return
- true;}function
- 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
- indexes($R,$h=null){$I=array();foreach(get_rows("SELECT uic.*, uc.constraint_type
- FROM user_ind_columns uic
- LEFT JOIN user_constraints uc ON uic.index_name = uc.constraint_name AND uic.table_name = uc.table_name
- WHERE uic.table_name = ".q($R)."
- 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
- view($C){$K=get_rows('SELECT text "select" FROM user_views WHERE view_name = '.q($C));return
- reset($K);}function
- collations(){return
- array();}function
- information_schema($l){return
- false;}function
- error(){global$g;return
- h($g->error);}function
- explain($g,$G){$g->query("EXPLAIN PLAN FOR $G");return$g->query("SELECT * FROM plan_table");}function
- found_rows($S,$Z){}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=$ec=array();foreach($p
- 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
- 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
- foreign_keys($R){$I=array();$G="SELECT c_list.CONSTRAINT_NAME as NAME,
- c_src.COLUMN_NAME as SRC_COLUMN,
- c_dest.OWNER as DEST_DB,
- c_dest.TABLE_NAME as DEST_TABLE,
- c_dest.COLUMN_NAME as DEST_COLUMN,
- c_list.DELETE_RULE as ON_DELETE
- FROM ALL_CONSTRAINTS c_list, ALL_CONS_COLUMNS c_src, ALL_CONS_COLUMNS c_dest
- WHERE c_list.CONSTRAINT_NAME = c_src.CONSTRAINT_NAME
- AND c_list.R_CONSTRAINT_NAME = c_dest.CONSTRAINT_NAME
- AND c_list.CONSTRAINT_TYPE = 'R'
- 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
- truncate_tables($T){return
- apply_queries("TRUNCATE TABLE",$T);}function
- drop_views($Ti){return
- apply_queries("DROP VIEW",$Ti);}function
- drop_tables($T){return
- apply_queries("DROP TABLE",$T);}function
- last_id(){return
- 0;}function
- schemas(){return
- get_vals("SELECT DISTINCT owner FROM dba_segments WHERE owner IN (SELECT username FROM dba_users WHERE default_tablespace NOT IN ('SYSTEM','SYSAUX'))");}function
- get_schema(){global$g;return$g->result("SELECT sys_context('USERENV', 'SESSION_USER') FROM dual");}function
- set_schema($Vg){global$g;return$g->query("ALTER SESSION SET CURRENT_SCHEMA = ".idf_escape($Vg));}function
- show_variables(){return
- get_key_vals('SELECT name, display_value FROM v$parameter');}function
- process_list(){return
- 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"
- FROM v$session sess LEFT OUTER JOIN v$sql sql
- ON sql.sql_id = sess.sql_id
- WHERE sess.type = \'USER\'
- ORDER BY PROCESS
- ');}function
- show_status(){$K=get_rows('SELECT * FROM v$instance');return
- reset($K);}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- support($Oc){return
- 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
- Min_DB{var$extension="sqlsrv",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
- _get_error(){$this->error="";foreach(sqlsrv_errors()as$n){$this->errno=$n["code"];$this->error.="$n[message]\n";}$this->error=rtrim($this->error);}function
- 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
- quote($Q){return"'".str_replace("'","''",$Q)."'";}function
- select_db($j){return$this->query("USE ".idf_escape($j));}function
- query($G,$xi=false){$H=sqlsrv_query($this->_link,$G);$this->error="";if(!$H){$this->_get_error();return
- false;}return$this->store_result($H);}function
- multi_query($G){$this->_result=sqlsrv_query($this->_link,$G);$this->error="";if(!$this->_result){$this->_get_error();return
- false;}return
- true;}function
- store_result($H=null){if(!$H)$H=$this->_result;if(!$H)return
- false;if(sqlsrv_field_metadata($H))return
- new
- Min_Result($H);$this->affected_rows=sqlsrv_rows_affected($H);return
- true;}function
- next_result(){return$this->_result?sqlsrv_next_result($this->_result):null;}function
- result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
- false;$J=$H->fetch_row();return$J[$o];}}class
- Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
- __construct($H){$this->_result=$H;}function
- _convert($J){foreach((array)$J
- as$y=>$X){if(is_a($X,'DateTime'))$J[$y]=$X->format("Y-m-d H:i:s");}return$J;}function
- fetch_assoc(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_ASSOC));}function
- fetch_row(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_NUMERIC));}function
- fetch_field(){if(!$this->_fields)$this->_fields=sqlsrv_field_metadata($this->_result);$o=$this->_fields[$this->_offset++];$I=new
- stdClass;$I->name=$o["Name"];$I->orgname=$o["Name"];$I->type=($o["Type"]==1?254:0);return$I;}function
- seek($D){for($s=0;$s<$D;$s++)sqlsrv_fetch($this->_result);}function
- __destruct(){sqlsrv_free_stmt($this->_result);}}}elseif(extension_loaded("mssql")){class
- Min_DB{var$extension="MSSQL",$_link,$_result,$server_info,$affected_rows,$error;function
- 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
- quote($Q){return"'".str_replace("'","''",$Q)."'";}function
- select_db($j){return
- mssql_select_db($j);}function
- query($G,$xi=false){$H=@mssql_query($G,$this->_link);$this->error="";if(!$H){$this->error=mssql_get_last_message();return
- false;}if($H===true){$this->affected_rows=mssql_rows_affected($this->_link);return
- true;}return
- new
- Min_Result($H);}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- mssql_next_result($this->_result->_result);}function
- result($G,$o=0){$H=$this->query($G);if(!is_object($H))return
- false;return
- mssql_result($H->_result,0,$o);}}class
- Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
- __construct($H){$this->_result=$H;$this->num_rows=mssql_num_rows($H);}function
- fetch_assoc(){return
- mssql_fetch_assoc($this->_result);}function
- fetch_row(){return
- mssql_fetch_row($this->_result);}function
- num_rows(){return
- mssql_num_rows($this->_result);}function
- fetch_field(){$I=mssql_fetch_field($this->_result);$I->orgtable=$I->table;$I->orgname=$I->name;return$I;}function
- seek($D){mssql_data_seek($this->_result,$D);}function
- __destruct(){mssql_free_result($this->_result);}}}elseif(extension_loaded("pdo_dblib")){class
- Min_DB
- extends
- Min_PDO{var$extension="PDO_DBLIB";function
- connect($N,$V,$F){$this->dsn("dblib:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\d)~',';port=\1',$N)),$V,$F);return
- true;}function
- select_db($j){return$this->query("USE ".idf_escape($j));}}}class
- Min_Driver
- extends
- Min_SQL{function
- insertUpdate($R,$K,$eg){foreach($K
- as$O){$Di=array();$Z=array();foreach($O
- 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
- false;}return
- true;}function
- begin(){return
- queries("BEGIN TRANSACTION");}}function
- idf_escape($u){return"[".str_replace("]","]]",$u)."]";}function
- table($u){return($_GET["ns"]!=""?idf_escape($_GET["ns"]).".":"").idf_escape($u);}function
- connect(){global$b;$g=new
- Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
- get_databases(){return
- get_vals("SELECT name FROM sys.databases WHERE name NOT IN ('master', 'tempdb', 'model', 'msdb')");}function
- limit($G,$Z,$z,$D=0,$M=" "){return($z!==null?" TOP (".($z+$D).")":"")." $G$Z";}function
- limit1($R,$G,$Z,$M="\n"){return
- limit($G,$Z,1,0,$M);}function
- db_collation($l,$ob){global$g;return$g->result("SELECT collation_name FROM sys.databases WHERE name = ".q($l));}function
- engines(){return
- array();}function
- logged_user(){global$g;return$g->result("SELECT SUSER_NAME()");}function
- tables_list(){return
- 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
- count_tables($k){global$g;$I=array();foreach($k
- as$l){$g->select_db($l);$I[$l]=$g->result("SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES");}return$I;}function
- 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
- is_view($S){return$S["Engine"]=="VIEW";}function
- fk_support($S){return
- true;}function
- 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]
- FROM sys.all_columns c
- JOIN sys.all_objects o ON c.object_id = o.object_id
- JOIN sys.types t ON c.user_type_id = t.user_type_id
- LEFT JOIN sys.default_constraints d ON c.default_object_id = d.parent_column_id
- 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
- 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
- FROM sys.indexes i
- INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
- INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
- 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
- view($C){global$g;return
- 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
- collations(){$I=array();foreach(get_vals("SELECT name FROM fn_helpcollations()")as$d)$I[preg_replace('~_.*~','',$d)][]=$d;return$I;}function
- information_schema($l){return
- false;}function
- error(){global$g;return
- nl_br(h(preg_replace('~^(\[[^]]*])+~m','',$g->error)));}function
- create_database($l,$d){return
- queries("CREATE DATABASE ".idf_escape($l).(preg_match('~^[a-z0-9_]+$~i',$d)?" COLLATE $d":""));}function
- drop_databases($k){return
- queries("DROP DATABASE ".implode(", ",array_map('idf_escape',$k)));}function
- 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
- true;}function
- auto_increment(){return" IDENTITY".($_POST["Auto_increment"]!=""?"(".number($_POST["Auto_increment"]).",1)":"")." PRIMARY KEY";}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();foreach($p
- 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
- 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
- as$y=>$X){if(!queries("ALTER TABLE ".idf_escape($C)." $y".implode(",",$X)))return
- false;}return
- true;}function
- alter_indexes($R,$c){$v=array();$ec=array();foreach($c
- 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
- false;}return(!$v||queries("DROP INDEX ".implode(", ",$v)))&&(!$ec||queries("ALTER TABLE ".table($R)." DROP ".implode(", ",$ec)));}function
- last_id(){global$g;return$g->result("SELECT SCOPE_IDENTITY()");}function
- explain($g,$G){$g->query("SET SHOWPLAN_ALL ON");$I=$g->query($G);$g->query("SET SHOWPLAN_ALL OFF");return$I;}function
- found_rows($S,$Z){}function
- 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
- truncate_tables($T){return
- apply_queries("TRUNCATE TABLE",$T);}function
- drop_views($Ti){return
- queries("DROP VIEW ".implode(", ",array_map('table',$Ti)));}function
- drop_tables($T){return
- queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
- move_tables($T,$Ti,$Qh){return
- apply_queries("ALTER SCHEMA ".idf_escape($Qh)." TRANSFER",array_merge($T,$Ti));}function
- trigger($C){if($C=="")return
- array();$K=get_rows("SELECT s.name [Trigger],
- 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],
- CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing],
- c.text
- FROM sysobjects s
- JOIN syscomments c ON s.id = c.id
- 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
- triggers($R){$I=array();foreach(get_rows("SELECT sys1.name,
- 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],
- CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing]
- FROM sysobjects sys1
- JOIN sysobjects sys2 ON sys1.parent_obj = sys2.id
- WHERE sys1.xtype = 'TR' AND sys2.name = ".q($R))as$J)$I[$J["name"]]=array($J["Timing"],$J["Event"]);return$I;}function
- trigger_options(){return
- array("Timing"=>array("AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("AS"),);}function
- schemas(){return
- get_vals("SELECT name FROM sys.schemas");}function
- get_schema(){global$g;if($_GET["ns"]!="")return$_GET["ns"];return$g->result("SELECT SCHEMA_NAME()");}function
- set_schema($Ug){return
- true;}function
- use_sql($j){return"USE ".idf_escape($j);}function
- show_variables(){return
- array();}function
- show_status(){return
- array();}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- support($Oc){return
- 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
- Min_DB{var$extension="Firebird",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
- 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
- quote($Q){return"'".str_replace("'","''",$Q)."'";}function
- select_db($j){return($j=="domain");}function
- query($G,$xi=false){$H=ibase_query($G,$this->_link);if(!$H){$this->errno=ibase_errcode();$this->error=ibase_errmsg();return
- false;}$this->error="";if($H===true){$this->affected_rows=ibase_affected_rows($this->_link);return
- true;}return
- new
- Min_Result($H);}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- false;}function
- result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
- false;$J=$H->fetch_row();return$J[$o];}}class
- Min_Result{var$num_rows,$_result,$_offset=0;function
- __construct($H){$this->_result=$H;}function
- fetch_assoc(){return
- ibase_fetch_assoc($this->_result);}function
- fetch_row(){return
- ibase_fetch_row($this->_result);}function
- 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
- __destruct(){ibase_free_result($this->_result);}}}class
- Min_Driver
- extends
- Min_SQL{}function
- idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
- table($u){return
- idf_escape($u);}function
- connect(){global$b;$g=new
- Min_DB;$Fb=$b->credentials();if($g->connect($Fb[0],$Fb[1],$Fb[2]))return$g;return$g->error;}function
- get_databases($Zc){return
- array("domain");}function
- limit($G,$Z,$z,$D=0,$M=" "){$I='';$I.=($z!==null?$M."FIRST $z".($D?" SKIP $D":""):"");$I.=" $G$Z";return$I;}function
- limit1($R,$G,$Z,$M="\n"){return
- limit($G,$Z,1,0,$M);}function
- db_collation($l,$ob){}function
- engines(){return
- array();}function
- logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
- 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
- count_tables($k){return
- array();}function
- table_status($C="",$Nc=false){global$g;$I=array();$Kb=tables_list();foreach($Kb
- as$v=>$X){$v=trim($v);$I[$v]=array('Name'=>$v,'Engine'=>'standard',);if($C==$v)return$I[$v];}return$I;}function
- is_view($S){return
- false;}function
- fk_support($S){return
- preg_match('~InnoDB|IBMDB2I~i',$S["Engine"]);}function
- fields($R){global$g;$I=array();$G='SELECT r.RDB$FIELD_NAME AS field_name,
- r.RDB$DESCRIPTION AS field_description,
- r.RDB$DEFAULT_VALUE AS field_default_value,
- r.RDB$NULL_FLAG AS field_not_null_constraint,
- f.RDB$FIELD_LENGTH AS field_length,
- f.RDB$FIELD_PRECISION AS field_precision,
- f.RDB$FIELD_SCALE AS field_scale,
- CASE f.RDB$FIELD_TYPE
- WHEN 261 THEN \'BLOB\'
- WHEN 14 THEN \'CHAR\'
- WHEN 40 THEN \'CSTRING\'
- WHEN 11 THEN \'D_FLOAT\'
- WHEN 27 THEN \'DOUBLE\'
- WHEN 10 THEN \'FLOAT\'
- WHEN 16 THEN \'INT64\'
- WHEN 8 THEN \'INTEGER\'
- WHEN 9 THEN \'QUAD\'
- WHEN 7 THEN \'SMALLINT\'
- WHEN 12 THEN \'DATE\'
- WHEN 13 THEN \'TIME\'
- WHEN 35 THEN \'TIMESTAMP\'
- WHEN 37 THEN \'VARCHAR\'
- ELSE \'UNKNOWN\'
- END AS field_type,
- f.RDB$FIELD_SUB_TYPE AS field_subtype,
- coll.RDB$COLLATION_NAME AS field_collation,
- cset.RDB$CHARACTER_SET_NAME AS field_charset
- FROM RDB$RELATION_FIELDS r
- LEFT JOIN RDB$FIELDS f ON r.RDB$FIELD_SOURCE = f.RDB$FIELD_NAME
- LEFT JOIN RDB$COLLATIONS coll ON f.RDB$COLLATION_ID = coll.RDB$COLLATION_ID
- LEFT JOIN RDB$CHARACTER_SETS cset ON f.RDB$CHARACTER_SET_ID = cset.RDB$CHARACTER_SET_ID
- WHERE r.RDB$RELATION_NAME = '.q($R).'
- 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
- indexes($R,$h=null){$I=array();return$I;}function
- foreign_keys($R){return
- array();}function
- collations(){return
- array();}function
- information_schema($l){return
- false;}function
- error(){global$g;return
- h($g->error);}function
- types(){return
- array();}function
- schemas(){return
- array();}function
- get_schema(){return"";}function
- set_schema($Ug){return
- true;}function
- support($Oc){return
- 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
- Min_DB{var$extension="SimpleXML",$server_info='2009-04-15',$error,$timeout,$next,$affected_rows,$_result;function
- select_db($j){return($j=="domain");}function
- 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
- as$Yd)$Eh+=$Yd->Attribute->Value;$H=array((object)array('Attribute'=>array((object)array('Name'=>'Count','Value'=>$Eh,))));}return
- new
- Min_Result($H);}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- false;}function
- quote($Q){return"'".str_replace("'","''",$Q)."'";}}class
- Min_Result{var$num_rows,$_rows=array(),$_offset=0;function
- __construct($H){foreach($H
- as$Yd){$J=array();if($Yd->Name!='')$J['itemName()']=(string)$Yd->Name;foreach($Yd->Attribute
- 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
- as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
- _processValue($oc){return(is_object($oc)&&$oc['encoding']=='base64'?base64_decode($oc):(string)$oc);}function
- 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
- fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
- array_values($I);}function
- fetch_field(){$ee=array_keys($this->_rows[0]);return(object)array('name'=>$ee[$this->_offset++]);}}}class
- Min_Driver
- extends
- Min_SQL{public$eg="itemName()";function
- _chunkRequest($Cd,$va,$If,$Dc=array()){global$g;foreach(array_chunk($Cd,25)as$hb){$Jf=$If;foreach($hb
- as$s=>$t){$Jf["Item.$s.ItemName"]=$t;foreach($Dc
- as$y=>$X)$Jf["Item.$s.$y"]=$X;}if(!sdb_request($va,$Jf))return
- false;}$g->affected_rows=count($Cd);return
- true;}function
- _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
- 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
- delete($R,$qg,$z=0){return$this->_chunkRequest($this->_extractIds($R,$qg,$z),'BatchDeleteAttributes',array('DomainName'=>$R));}function
- 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
- 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
- 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
- insert($R,$O){$If=array("DomainName"=>$R);$s=0;foreach($O
- as$C=>$Y){if($Y!="NULL"){$C=idf_unescape($C);if($C=="itemName()")$If["ItemName"]=idf_unescape($Y);else{foreach((array)$Y
- as$X){$If["Attribute.$s.Name"]=$C;$If["Attribute.$s.Value"]=(is_array($Y)?$X:idf_unescape($Y));$s++;}}}}return
- sdb_request('PutAttributes',$If);}function
- insertUpdate($R,$K,$eg){foreach($K
- as$O){if(!$this->update($R,$O,"WHERE `itemName()` = ".q($O["`itemName()`"])))return
- false;}return
- true;}function
- begin(){return
- false;}function
- commit(){return
- false;}function
- rollback(){return
- false;}function
- slowQuery($G,$Yh){$this->_conn->timeout=$Yh;return$G;}}function
- connect(){global$b;list(,,$F)=$b->credentials();if($F!="")return'Database does not support password.';return
- new
- Min_DB;}function
- support($Oc){return
- preg_match('~sql~',$Oc);}function
- logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
- get_databases(){return
- array("domain");}function
- collations(){return
- array();}function
- db_collation($l,$ob){}function
- 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
- 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
- explain($g,$G){}function
- error(){global$g;return
- h($g->error);}function
- information_schema(){}function
- is_view($S){}function
- indexes($R,$h=null){return
- array(array("type"=>"PRIMARY","columns"=>array("itemName()")),);}function
- fields($R){return
- fields_from_edit();}function
- foreign_keys($R){return
- array();}function
- table($u){return
- idf_escape($u);}function
- idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
- limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z":"");}function
- unconvert_field($o,$I){return$I;}function
- fk_support($S){}function
- engines(){return
- array();}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){return($R==""&&sdb_request('CreateDomain',array('DomainName'=>$C)));}function
- drop_tables($T){foreach($T
- as$R){if(!sdb_request('DeleteDomain',array('DomainName'=>$R)))return
- false;}return
- true;}function
- count_tables($k){foreach($k
- as$l)return
- array($l=>count(tables_list()));}function
- found_rows($S,$Z){return($Z?null:$S["Rows"]);}function
- last_id(){}function
- 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
- 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
- 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
- false;}libxml_use_internal_errors(true);$gj=simplexml_load_string($Sc);if(!$gj){$n=libxml_get_last_error();$g->error=$n->message;return
- false;}if($gj->Errors){$n=$gj->Errors->Error;$g->error="$n->Message ($n->Code)";return
- false;}$g->error='';$Ph=$va."Result";return($gj->$Ph?$gj->$Ph:true);}function
- 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
- as$oc)$I[]=$oc;if($z&&count($I)>=$z){$_GET["next"]=$gj->NextToken;break;}if($Yh&µtime(true)-$xh>$Yh)return
- 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
- Min_DB{var$extension="Mongo",$server_info=MongoClient::VERSION,$error,$last_id,$_link,$_db;function
- connect($Ei,$sf){return@new
- MongoClient($Ei,$sf);}function
- query($G){return
- false;}function
- select_db($j){try{$this->_db=$this->_link->selectDB($j);return
- true;}catch(Exception$_c){$this->error=$_c->getMessage();return
- false;}}function
- quote($Q){return$Q;}}class
- Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
- __construct($H){foreach($H
- as$Yd){$J=array();foreach($Yd
- 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
- as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
- 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
- fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
- array_values($I);}function
- fetch_field(){$ee=array_keys($this->_rows[0]);$C=$ee[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}class
- Min_Driver
- extends
- Min_SQL{public$eg="_id";function
- 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
- as$X){$X=preg_replace('~ DESC$~','',$X,1,$Cb);$oh[$X]=($Cb?-1:1);}return
- new
- Min_Result($this->_conn->_db->selectCollection($R)->find(array(),$L)->sort($oh)->limit($z!=""?+$z:0)->skip($E*$z));}function
- 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
- false;}}}function
- get_databases($Zc){global$g;$I=array();$Pb=$g->_link->listDBs();foreach($Pb['databases']as$l)$I[]=$l['name'];return$I;}function
- count_tables($k){global$g;$I=array();foreach($k
- as$l)$I[$l]=count($g->_link->selectDB($l)->getCollectionNames(true));return$I;}function
- tables_list(){global$g;return
- array_fill_keys($g->_db->getCollectionNames(true),'table');}function
- drop_databases($k){global$g;foreach($k
- as$l){$Gg=$g->_link->selectDB($l)->drop();if(!$Gg['ok'])return
- false;}return
- true;}function
- 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
- fields($R){return
- fields_from_edit();}function
- found_rows($S,$Z){global$g;return$g->_db->selectCollection($_GET["select"])->count($Z);}$pf=array("=");}elseif(class_exists('MongoDB\Driver\Manager')){class
- Min_DB{var$extension="MongoDB",$server_info=MONGODB_VERSION,$error,$last_id;var$_link;var$_db,$_db_name;function
- connect($Ei,$sf){$jb='MongoDB\Driver\Manager';return
- new$jb($Ei,$sf);}function
- query($G){return
- false;}function
- select_db($j){$this->_db_name=$j;return
- true;}function
- quote($Q){return$Q;}}class
- Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
- __construct($H){foreach($H
- as$Yd){$J=array();foreach($Yd
- 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
- as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=$H->count;}function
- 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
- fetch_row(){$I=$this->fetch_assoc();if(!$I)return$I;return
- array_values($I);}function
- fetch_field(){$ee=array_keys($this->_rows[0]);$C=$ee[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}class
- Min_Driver
- extends
- Min_SQL{public$eg="_id";function
- 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
- 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
- new
- Min_Result($Jg);}function
- 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
- 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
- true;}function
- 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
- true;}function
- 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
- true;}}function
- 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
- as$Pb){foreach($Pb->databases
- as$l)$I[]=$l->name;}return$I;}function
- count_tables($k){$I=array();return$I;}function
- 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
- as$H)$pb[$H->name]='table';return$pb;}function
- drop_databases($k){return
- false;}function
- 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
- 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
- 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
- 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
- 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
- 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
- as$bj)$Z[]=trim($bj);if(count($ej)==1)$ej=array();elseif(count($ej)>1)$Z=array();return
- where_to_query($Z,$ej);}function
- 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
- 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
- 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
- table($u){return$u;}function
- idf_escape($u){return$u;}function
- 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
- create_database($l,$d){return
- true;}function
- last_id(){global$g;return$g->last_id;}function
- error(){global$g;return
- h($g->error);}function
- collations(){return
- array();}function
- logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
- connect(){global$b;$g=new
- 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
- alter_indexes($R,$c){global$g;foreach($c
- as$X){list($U,$C,$O)=$X;if($O=="DROP")$I=$g->_db->command(array("deleteIndexes"=>$R,"index"=>$C));else{$f=array();foreach($O
- 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
- false;}}return
- true;}function
- support($Oc){return
- preg_match("~database|indexes~",$Oc);}function
- db_collation($l,$ob){}function
- information_schema(){}function
- is_view($S){}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- foreign_keys($R){return
- array();}function
- fk_support($S){}function
- engines(){return
- array();}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){global$g;if($R==""){$g->_db->createCollection($C);return
- true;}}function
- drop_tables($T){global$g;foreach($T
- as$R){$Gg=$g->_db->selectCollection($R)->drop();if(!$Gg['ok'])return
- false;}return
- true;}function
- truncate_tables($T){global$g;foreach($T
- as$R){$Gg=$g->_db->selectCollection($R)->remove();if(!$Gg['ok'])return
- false;}return
- 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
- Min_DB{var$extension="JSON",$server_info,$errno,$error,$_url;function
- 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
- 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
- query($Sf,$yb=array(),$Ne='GET'){return$this->rootQuery(($this->_db!=""?"$this->_db/":"/").ltrim($Sf,'/'),$yb,$Ne);}function
- 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
- select_db($j){$this->_db=$j;return
- true;}function
- quote($Q){return$Q;}}class
- Min_Result{var$num_rows,$_rows;function
- __construct($K){$this->num_rows=count($this->_rows);$this->_rows=$K;reset($this->_rows);}function
- fetch_assoc(){$I=current($this->_rows);next($this->_rows);return$I;}function
- fetch_row(){return
- array_values($this->fetch_assoc());}}}class
- Min_Driver
- extends
- Min_SQL{function
- 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
- 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
- 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
- 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
- as$y)$p[$y]=$zd['fields'][$y];}foreach($p
- as$y=>$X){if($Kb["fields"])$X=$X[0];$J[$y]=(is_array($X)?json_encode($X):$X);}$I[]=$J;}return
- new
- Min_Result($I);}function
- 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
- false;}function
- insert($U,$vg){$t="";$G="$U/$t";$Gg=$this->_conn->query($G,$vg,'POST');$this->_conn->last_id=$Gg['_id'];return$Gg['created'];}function
- 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
- 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
- connect(){global$b;$g=new
- 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
- support($Oc){return
- preg_match("~database|table|columns~",$Oc);}function
- logged_user(){global$b;$Fb=$b->credentials();return$Fb[1];}function
- get_databases(){global$g;$I=$g->rootQuery('_aliases');if($I){$I=array_keys($I);sort($I,SORT_STRING);}return$I;}function
- collations(){return
- array();}function
- db_collation($l,$ob){}function
- engines(){return
- array();}function
- count_tables($k){global$g;$I=array();$H=$g->query('_stats');if($H&&$H['indices']){$Jd=$H['indices'];foreach($Jd
- as$Id=>$yh){$Hd=$yh['total']['indexing'];$I[$Id]=$Hd['index_total'];}}return$I;}function
- tables_list(){global$g;$I=$g->query('_mapping');if($I)$I=array_fill_keys(array_keys($I[$g->_db]["mappings"]),'table');return$I;}function
- 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
- 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
- error(){global$g;return
- h($g->error);}function
- information_schema(){}function
- is_view($S){}function
- indexes($R,$h=null){return
- array(array("type"=>"PRIMARY","columns"=>array("_id")),);}function
- 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
- 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
- foreign_keys($R){return
- array();}function
- table($u){return$u;}function
- idf_escape($u){return$u;}function
- convert_field($o){}function
- unconvert_field($o,$I){return$I;}function
- fk_support($S){}function
- found_rows($S,$Z){return
- null;}function
- create_database($l){global$g;return$g->rootQuery(urlencode($l),null,'PUT');}function
- drop_databases($k){global$g;return$g->rootQuery(urlencode(implode(',',$k)),array(),'DELETE');}function
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){global$g;$mg=array();foreach($p
- 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
- drop_tables($T){global$g;$I=true;foreach($T
- as$R)$I=$I&&$g->query(urlencode($R),array(),'DELETE');return$I;}function
- 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
- Min_DB
- extends
- MySQLi{var$extension="MySQLi";function
- __construct(){parent::init();}function
- 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
- set_charset($bb){if(parent::set_charset($bb))return
- true;parent::set_charset('utf8');return$this->query("SET NAMES $bb");}function
- result($G,$o=0){$H=$this->query($G);if(!$H)return
- false;$J=$H->fetch_array();return$J[$o];}function
- 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
- Min_DB{var$extension="MySQL",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
- 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
- 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
- set_charset($bb){if(function_exists('mysql_set_charset')){if(mysql_set_charset($bb,$this->_link))return
- true;mysql_set_charset('utf8',$this->_link);}return$this->query("SET NAMES $bb");}function
- quote($Q){return"'".mysql_real_escape_string($Q,$this->_link)."'";}function
- select_db($j){return
- mysql_select_db($j,$this->_link);}function
- 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
- false;}if($H===true){$this->affected_rows=mysql_affected_rows($this->_link);$this->info=mysql_info($this->_link);return
- true;}return
- new
- Min_Result($H);}function
- multi_query($G){return$this->_result=$this->query($G);}function
- store_result(){return$this->_result;}function
- next_result(){return
- false;}function
- result($G,$o=0){$H=$this->query($G);if(!$H||!$H->num_rows)return
- false;return
- mysql_result($H->_result,0,$o);}}class
- Min_Result{var$num_rows,$_result,$_offset=0;function
- __construct($H){$this->_result=$H;$this->num_rows=mysql_num_rows($H);}function
- fetch_assoc(){return
- mysql_fetch_assoc($this->_result);}function
- fetch_row(){return
- mysql_fetch_row($this->_result);}function
- 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
- __destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
- Min_DB
- extends
- Min_PDO{var$extension="PDO_MySQL";function
- 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
- true;}function
- set_charset($bb){$this->query("SET NAMES $bb");}function
- select_db($j){return$this->query("USE ".idf_escape($j));}function
- query($G,$xi=false){$this->setAttribute(1000,!$xi);return
- parent::query($G,$xi);}}}class
- Min_Driver
- extends
- Min_SQL{function
- insert($R,$O){return($O?parent::insert($R,$O):queries("INSERT INTO ".table($R)." ()\nVALUES ()"));}function
- insertUpdate($R,$K,$eg){$f=array_keys(reset($K));$cg="INSERT INTO ".table($R)." (".implode(", ",$f).") VALUES\n";$Oi=array();foreach($f
- as$y)$Oi[$y]="$y = VALUES($y)";$Dh="\nON DUPLICATE KEY UPDATE ".implode(", ",$Oi);$Oi=array();$qe=0;foreach($K
- as$O){$Y="(".implode(", ",$O).")";if($Oi&&(strlen($cg)+$qe+strlen($Y)+strlen($Dh)>1e6)){if(!queries($cg.implode(",\n",$Oi).$Dh))return
- false;$Oi=array();$qe=0;}$Oi[]=$Y;$qe+=strlen($Y)+2;}return
- queries($cg.implode(",\n",$Oi).$Dh);}function
- 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
- 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
- warnings(){$H=$this->_conn->query("SHOW WARNINGS");if($H&&$H->num_rows){ob_start();select($H);return
- ob_get_clean();}}function
- tableHelp($C){$xe=preg_match('~MariaDB~',$this->_conn->server_info);if(information_schema(DB))return
- strtolower(($xe?"information-schema-$C-table/":str_replace("_","-",$C)."-table.html"));if(DB=="mysql")return($xe?"mysql$C-table/":"system-database.html");}}function
- idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
- table($u){return
- idf_escape($u);}function
- connect(){global$b,$wi,$Ah;$g=new
- 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
- 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
- limit($G,$Z,$z,$D=0,$M=" "){return" $G$Z".($z!==null?$M."LIMIT $z".($D?" OFFSET $D":""):"");}function
- limit1($R,$G,$Z,$M="\n"){return
- limit($G,$Z,1,0,$M);}function
- 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
- engines(){$I=array();foreach(get_rows("SHOW ENGINES")as$J){if(preg_match("~YES|DEFAULT~",$J["Support"]))$I[]=$J["Engine"];}return$I;}function
- logged_user(){global$g;return$g->result("SELECT USER()");}function
- tables_list(){return
- 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
- count_tables($k){$I=array();foreach($k
- as$l)$I[$l]=count(get_vals("SHOW TABLES IN ".idf_escape($l)));return$I;}function
- 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
- is_view($S){return$S["Engine"]===null;}function
- fk_support($S){return
- preg_match('~InnoDB|IBMDB2I~i',$S["Engine"])||(preg_match('~NDB~i',$S["Engine"])&&min_version(5.6));}function
- 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
- 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
- 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
- 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
- view($C){global$g;return
- array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)*\s+AS\s+~isU','',$g->result("SHOW CREATE VIEW ".table($C),1)));}function
- 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
- as$y=>$X)asort($I[$y]);return$I;}function
- information_schema($l){return(min_version(5)&&$l=="information_schema")||(min_version(5.5)&&$l=="performance_schema");}function
- error(){global$g;return
- h(preg_replace('~^You have an error.*syntax to use~U',"Syntax error",$g->error));}function
- create_database($l,$d){return
- queries("CREATE DATABASE ".idf_escape($l).($d?" COLLATE ".q($d):""));}function
- drop_databases($k){$I=apply_queries("DROP DATABASE",$k,'idf_escape');restart_session();set_session("dbs",null);return$I;}function
- 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
- 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
- alter_table($R,$C,$p,$bd,$tb,$tc,$d,$La,$Of){$c=array();foreach($p
- 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
- 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
- alter_indexes($R,$c){foreach($c
- 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
- queries("ALTER TABLE ".table($R).implode(",",$c));}function
- truncate_tables($T){return
- apply_queries("TRUNCATE TABLE",$T);}function
- drop_views($Ti){return
- queries("DROP VIEW ".implode(", ",array_map('table',$Ti)));}function
- drop_tables($T){return
- queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
- move_tables($T,$Ti,$Qh){$Eg=array();foreach(array_merge($T,$Ti)as$R)$Eg[]=table($R)." TO ".idf_escape($Qh).".".table($R);return
- queries("RENAME TABLE ".implode(", ",$Eg));}function
- copy_tables($T,$Ti,$Qh){queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");foreach($T
- 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
- 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
- false;}}foreach($Ti
- 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
- false;}return
- true;}function
- trigger($C){if($C=="")return
- array();$K=get_rows("SHOW TRIGGERS WHERE `Trigger` = ".q($C));return
- reset($K);}function
- 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
- trigger_options(){return
- array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
- 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
- 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
- array("fields"=>$p,"definition"=>$B[11]);return
- array("fields"=>$p,"returns"=>array("type"=>$B[12],"length"=>$B[13],"unsigned"=>$B[15],"collation"=>$B[16]),"definition"=>$B[17],"language"=>"SQL",);}function
- routines(){return
- get_rows("SELECT ROUTINE_NAME AS SPECIFIC_NAME, ROUTINE_NAME, ROUTINE_TYPE, DTD_IDENTIFIER FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".q(DB));}function
- routine_languages(){return
- array();}function
- routine_id($C,$J){return
- idf_escape($C);}function
- last_id(){global$g;return$g->result("SELECT LAST_INSERT_ID()");}function
- explain($g,$G){return$g->query("EXPLAIN ".(min_version(5.1)?"PARTITIONS ":"").$G);}function
- found_rows($S,$Z){return($Z||$S["Engine"]!="InnoDB"?null:$S["Rows"]);}function
- types(){return
- array();}function
- schemas(){return
- array();}function
- get_schema(){return"";}function
- set_schema($Ug){return
- true;}function
- 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
- truncate_sql($R){return"TRUNCATE ".table($R);}function
- use_sql($j){return"USE ".idf_escape($j);}function
- 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
- show_variables(){return
- get_key_vals("SHOW VARIABLES");}function
- process_list(){return
- get_rows("SHOW FULL PROCESSLIST");}function
- show_status(){return
- get_key_vals("SHOW STATUS");}function
- 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
- 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
- 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
- kill_process($X){return
- queries("KILL ".number($X));}function
- connection_id(){return"SELECT CONNECTION_ID()";}function
- 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
- Adminer{var$operators;function
- name(){return"<a href='https://www.adminer.org/'".target_blank()." id='h1'>Adminer</a>";}function
- credentials(){return
- array(SERVER,$_GET["username"],get_password());}function
- connectSsl(){}function
- permanentLogin($i=false){return
- password_file($i);}function
- bruteForceKey(){return$_SERVER["REMOTE_ADDR"];}function
- serverName($N){return
- h($N);}function
- database(){return
- DB;}function
- databases($Zc=true){return
- get_databases($Zc);}function
- schemas(){return
- schemas();}function
- queryTimeout(){return
- 2;}function
- headers(){}function
- csp(){return
- csp();}function
- head(){return
- true;}function
- css(){$I=array();$Tc="adminer.css";if(file_exists($Tc))$I[]=$Tc;return$I;}function
- 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
- loginFormField($C,$wd,$Y){return$wd.$Y;}function
- login($ue,$F){if($F=="")return
- 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
- true;}function
- tableName($Hh){return
- h($Hh["Name"]);}function
- fieldName($o,$uf=0){return'<span title="'.h($o["full_type"]).'">'.h($o["field"]).'</span>';}function
- 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
- as$y=>$X)echo" <a href='".h(ME)."$y=".urlencode($C).($y=="edit"?$O:"")."'".bold(isset($_GET[$y])).">$X</a>";echo
- doc_link(array($x=>$m->tableHelp($C)),"?"),"\n";}function
- foreignKeys($R){return
- foreign_keys($R);}function
- backwardKeys($R,$Gh){return
- array();}function
- backwardKeysPrint($Oa,$J){}function
- 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
- sqlCommandQuery($G){return
- shorten_utf8(trim($G),1000);}function
- rowDescription($R){return"";}function
- rowDescriptions($K,$cd){return$K;}function
- selectLink($X,$o){}function
- 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
- editVal($X,$o){return$X;}function
- tableStructurePrint($p){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr><th>".'Column'."<td>".'Type'.(support("comment")?"<td>".'Comment':"")."</thead>\n";foreach($p
- 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
- tableIndexesPrint($w){echo"<table cellspacing='0'>\n";foreach($w
- 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
- selectColumnsPrint($L,$f){global$jd,$pd;print_fieldset("select",'Select',$L);$s=0;$L[""]=array();foreach($L
- 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
- selectSearchPrint($Z,$f,$w){print_fieldset("search",'Search',$Z);foreach($w
- 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
- 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
- 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
- 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
- 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
- as$v){$Jb=reset($v["columns"]);if($v["type"]!="FULLTEXT"&&$Jb)$f[$Jb]=1;}$f[""]=1;foreach($f
- as$y=>$X)json_row($y);echo";\n","selectFieldChange.call(qs('#form')['select']);\n","</script>\n","</div></fieldset>\n";}function
- selectCommandPrint(){return!information_schema(DB);}function
- selectImportPrint(){return!information_schema(DB);}function
- selectEmailPrint($qc,$f){}function
- 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
- array($L,$md);}function
- selectSearchProcess($p,$w){global$g,$m;$I=array();foreach($w
- 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
- 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
- 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
- selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"50");}function
- selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
- selectEmailProcess($Z,$cd){return
- false;}function
- selectQueryBuild($L,$Z,$md,$uf,$z,$E){return"";}function
- 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
- editFunctions($o){global$lc;$I=($o["null"]?"NULL/":"");foreach($lc
- as$y=>$jd){if(!$y||(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET)))){foreach($jd
- 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
- explode("/",$I);}function
- 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
- editHint($R,$o,$Y){return"";}function
- 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
- unconvert_field($o,$I);}function
- dumpOutput(){$I=array('text'=>'open','file'=>'save');if(function_exists('gzencode'))$I['gz']='gzip';return$I;}function
- dumpFormat(){return
- array('sql'=>'SQL','csv'=>'CSV,','csv;'=>'CSV;','tsv'=>'TSV');}function
- dumpDatabase($l){}function
- 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
- dumpData($R,$Bh,$G){global$g,$x;$Be=($x=="sqlite"?0:1048576);if($Bh){if($_POST["format"]=="sql"){if($Bh=="TRUNCATE+INSERT")echo
- 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
- 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
- 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
- dumpFilename($Bd){return
- friendly_url($Bd!=""?$Bd:(SERVER!=""?SERVER:"localhost"));}function
- 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
- importServerPath(){return"adminer.sql";}function
- 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
- true;}function
- navigation($Pe){global$ia,$x,$dc,$g;echo'<h1>
- ',$this->name(),' <span class="version">',$ia,'</span>
- <a href="https://www.adminer.org/#download"',target_blank(),' id="version">',(version_compare($ia,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
- </h1>
- ';if($Pe=="auth"){$Vc=true;foreach((array)$_SESSION["pwds"]as$Qi=>$gh){foreach($gh
- as$N=>$Li){foreach($Li
- 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
- script_src(preg_replace("~\\?.*~","",ME)."?file=jush.js&version=4.6.3");if(support("sql")){echo'<script',nonce(),'>
- ';if($T){$te=array();foreach($T
- 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":""),');
- </script>
- ';}$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
- databasesPrint($Pe){global$b,$g;$k=$this->databases();if($k&&!in_array(DB,$k))array_unshift($k,DB);echo'<form action="">
- <p id="dbs">
- ';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
- tablesPrint($T){echo"<ul id='tables'>".script("mixin(qs('#tables'), {onmouseover: menuOver, onmouseout: menuOut});");foreach($T
- 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
- Adminer);if($b->operators===null)$b->operators=$pf;function
- 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>
- <html lang="en" dir="ltr">
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <meta name="robots" content="noindex">
- <title>',$di,'</title>
- <link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",ME)."?file=default.css&version=4.6.3"),'">
- ',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"),'">
- <link rel="apple-touch-icon" href="',h(preg_replace("~\\?.*~","",ME)."?file=favicon.ico&version=4.6.3"),'">
- ';foreach($b->css()as$Hb){echo'<link rel="stylesheet" type="text/css" href="',h($Hb),'">
- ';}}echo'
- <body class="ltr nojs">
- ';$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-----
- MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwqWOVuF5uw7/+Z70djoK
- RlHIZFZPO0uYRezq90+7Amk+FDNd7KkL5eDve+vHRJBLAszF/7XKXe11xwliIsFs
- DFWQlsABVZB3oisKCBEuI71J4kPH8dKGEWR9jDHFw3cWmoH3PmqImX6FISWbG3B8
- h7FIx3jEaw5ckVPVTeo5JRm/1DZzJxjyDenXvBQ/6o9DgZKeNDgxwKzH+sw9/YCO
- jHnq1cFpOIISzARlrHMa/43YfeNRAm/tsBXjSxembBPo7aQZLAWHmaj5+K19H10B
- nCpz9Y++cipkVEiKRGih4ZEvjoFysEOdRLj6WiD/uUNky4xGeA6LaJqh5XpkFkcQ
- fQIDAQAB
- -----END PUBLIC KEY-----
- ";if(openssl_verify($Ri["version"],base64_decode($Ri["signature"]),$ng)==1)$_COOKIE["adminer_version"]=$Ri["version"];}echo'<script',nonce(),'>
- mixin(document.body, {onkeydown: bodyKeydown, onclick: bodyClick',(isset($_COOKIE["adminer_version"])?"":", onload: partial(verifyVersion, '$ia', '".js_escape(ME)."', '".get_token()."')");?>});
- document.body.className = document.body.className.replace(/ nojs/, ' js');
- var offlineMessage = '<?php echo
- js_escape('You are offline.'),'\';
- var thousandsSeparator = \'',js_escape(','),'\';
- </script>
- <div id="help" class="jush-',$x,' jsonly hidden"></div>
- ',script("mixin(qs('#help'), {onmouseover: function () { helpOpen = 1; }, onmouseout: helpMouseout});"),'
- <div id="content">
- ';if($Wa!==null){$_=substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.h($_?$_:".").'">'.$dc[DRIVER].'</a> » ';$_=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> » ";if($_GET["ns"]!=""||(DB!=""&&is_array($Wa)))echo'<a href="'.h($_."&db=".urlencode(DB).(support("scheme")?"&ns=":"")).'">'.h(DB).'</a> » ';if(is_array($Wa)){if($_GET["ns"]!="")echo'<a href="'.h(substr(ME,0,-1)).'">'.h($_GET["ns"]).'</a> » ';foreach($Wa
- 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> » ";}}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
- 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
- as$y=>$X)$vd[]="$y $X";header("Content-Security-Policy: ".implode("; ",$vd));}$b->headers();}function
- csp(){return
- 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
- get_nonce(){static$Ze;if(!$Ze)$Ze=base64_encode(rand_string());return$Ze;}function
- 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
- page_footer($Pe=""){global$b,$hi;echo'</div>
- ';if($Pe!="auth"){echo'<form action="" method="post">
- <p class="logout">
- <input type="submit" name="logout" value="Logout" id="logout">
- <input type="hidden" name="token" value="',$hi,'">
- </p>
- </form>
- ';}echo'<div id="menu">
- ';$b->navigation($Pe);echo'</div>
- ',script("setupSubmitHighlight(document);");}function
- int32($Se){while($Se>=2147483648)$Se-=4294967296;while($Se<=-2147483649)$Se+=4294967296;return(int)$Se;}function
- long2str($W,$Vi){$Sg='';foreach($W
- as$X)$Sg.=pack('V',$X);if($Vi)return
- substr($Sg,0,end($W));return$Sg;}function
- 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
- xxtea_mx($ij,$hj,$Eh,$ae){return
- int32((($ij>>5&0x7FFFFFF)^$hj<<2)+(($hj>>3&0x1FFFFFFF)^$ij<<4))^int32(($Eh^$hj)+($ae^$ij));}function
- 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
- long2str($W,false);}function
- decrypt_string($_h,$y){if($_h=="")return"";if(!$y)return
- 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
- 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
- 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
- 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
- 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
- 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
- unset_permanent(){global$Vf;foreach($Vf
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- as$X)echo
- h($X[0])."\n\n\n";}else
- echo
- h($Y);echo"</textarea>";}function
- 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
- optionlist(array_merge($Kc,$Ah),$U),'</select>
- ',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
- 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
- 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
- process_field($o,$ui){return
- 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
- 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
- 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
- edit_fields($p,$ob,$U="TABLE",$dd=array(),$ub=false){global$Od;$p=array_values($p);echo'<thead><tr>
- ';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
- <td>','Options';if($U=="TABLE"){echo'<td id="label-null">NULL
- <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
- ',(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>
- <tbody>
- ',script("mixin(qsl('tbody'), {onclick: editingClick, onkeydown: editingKeydown, oninput: editingInput});");foreach($p
- 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;'"),'>
- ',($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),'">
- ';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
- process_fields(&$p){$D=0;if($_POST["up"]){$ke=0;foreach($p
- 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
- 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
- false;return
- true;}function
- 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
- grant($kd,$jg,$f,$jf){if(!$jg)return
- 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
- queries("$kd ".preg_replace('~(GRANT OPTION)\([^)]*\)~','\1',implode("$f, ",$jg).$f).$jf);}function
- 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
- queries_redirect($A,$Ie,queries($Uh)&&queries($hc)&&queries($ec)&&queries($i));}function
- 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
- create_routine($Og,$J){global$Od,$x;$O=array();$p=(array)$J["fields"];ksort($p);foreach($p
- 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
- remove_definer($G){return
- preg_replace('~^([A-Z =]+) DEFINER=`'.preg_replace('~@(.*)~','`@`(%|\1)',logged_user()).'`~','\1',$G);}function
- 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
- 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
- str_repeat("\0",511-($ei->size+511)%512);}function
- 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
- 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
- ob_gzencode($Q){return
- gzencode($Q);}function
- 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
- format_number($I);}function
- 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
- 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
- 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?"&ns=":"")."&database=' title='".'Alter database'."'>$d</a>":$d),"<td align='right'><a href='$Ng&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
- TmpFile{var$handler;var$size;function
- __construct(){$this->handler=tmpfile();}function
- write($zb){$this->size+=strlen($zb);fwrite($this->handler,$zb);}function
- 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
- 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
- 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
- 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;">
- <script',nonce(),'>
- qs(\'#schema\').onselectstart = function () { return false; };
- var tablePos = {',implode(",",$Lh)."\n",'};
- var em = qs(\'#schema\').offsetHeight / ',$ii,';
- document.onmousemove = schemaMousemove;
- document.onmouseup = partialArg(schemaMouseup, \'',js_escape(DB),'\');
- </script>
- ';foreach($Ug
- 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
- 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
- as$me=>$f){$ne=$me-$Kh[$C][1];$s=0;foreach($f
- 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
- as$C=>$R){foreach((array)$R["references"]as$Rh=>$Ag){foreach($Ag
- 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>
- <p class="links"><a href="',h(ME."schema=".urlencode($ea)),'" id="schema-link">Permanent link</a>
- ';}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;
- SET time_zone = '+00:00';
- ".($_POST["data_style"]?"SET foreign_key_checks = 0;
- SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';
- ":"")."
- ";$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
- 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
- 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
- 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
- as$Si)$b->dumpTable($Si,$_POST["table_style"],1);if($Hc=="tar")echo
- 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'
- <form action="" method="post">
- <table cellspacing="0">
- ';$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>
- <p><input type="submit" value="Export">
- <input type="hidden" name="token" value="',$hi,'">
- <table cellspacing="0">
- ',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
- 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
- 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
- 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
- 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
- echo"<tr><td><textarea name='databases' rows='10' cols='20'></textarea>";}echo'</table>
- </form>
- ';$Vc=true;foreach($dg
- 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
- 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
- echo"<p class='error'>".upload_error($G)."\n";}echo'
- <form action="" method="post" enctype="multipart/form-data" id="form">
- ';$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 (< ".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
- 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>
- ';}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
- 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
- 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
- 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
- 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
- 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
- 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
- as$tc){if(!strcasecmp($tc,$J["Engine"])){$J["Engine"]=$tc;break;}}echo'
- <form action="" method="post" id="form">
- <p>
- ';if(support("columns")||$a==""){echo'Table name: <input name="name" maxlength="64" value="',h($J["name"]),'" autocapitalize="off">
- ';if($a==""&&!$_POST)echo
- 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">
- ';}echo'
- ';if(support("columns")){echo'<table cellspacing="0" id="edit-fields" class="nowrap">
- ';$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>
- <p>
- Auto Increment: <input type="number" name="Auto_increment" size="6" value="',h($J["Auto_increment"]),'">
- ',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>
- <input type="submit" value="Save">
- ';}echo'
- ';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>
- ',"<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"]),'">)
- Partitions: <input type="number" name="partitions" class="size',($Nf||!$J["partition_by"]?" hidden":""),'" value="',h($J["partitions"]),'">
- <table cellspacing="0" id="partition-table"',($Nf?"":" class='hidden'"),'>
- <thead><tr><th>Partition name<th>Values</thead>
- ';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>
- </div></fieldset>
- ';}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ',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
- 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
- as$y=>$v){$w[$y]["name"]=$y;$w[$y]["columns"][]="";}$w[]=array("columns"=>array(1=>""));$J["indexes"]=$w;}echo'
- <form action="" method="post">
- <table cellspacing="0" class="nowrap">
- <thead><tr>
- <th id="label-type">Index Type
- <th><input type="submit" class="wayoff">Column (length)
- <th id="label-name">Name
- <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>
- </thead>
- ';if($eg){echo"<tr><td>PRIMARY<td>";foreach($eg["columns"]as$y=>$e){echo
- 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>
- <p>
- <input type="submit" value="Save">
- <input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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
- 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'
- <form action="" method="post">
- <p>
- ',($_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">
- ';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,'">
- </form>
- ';}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
- redirect($_);}}page_header($_GET["ns"]!=""?'Alter schema':'Create schema',$n);if(!$J)$J["name"]=$_GET["ns"];echo'
- <form action="" method="post">
- <p><input name="name" id="name" value="',h($J["name"]),'" autocapitalize="off">
- ',script("focus(qs('#name'));"),'<input type="submit" value="Save">
- ';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,'">
- </form>
- ';}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
- 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'
- <form action="" method="post">
- ';if($Ed){echo"<table cellspacing='0'>\n";foreach($Ed
- 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>
- <input type="submit" value="Call">
- <input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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'
- <form action="" method="post">
- <p>
- ';if($J["db"]==""&&$J["ns"]==""){echo'Target table:
- ',html_select("table",$yg,$J["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
- <noscript><p><input type="submit" name="change" value="Change"></noscript>
- <table cellspacing="0">
- <thead><tr><th id="label-source">Source<th id="label-target">Target</thead>
- ';$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>
- <p>
- 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>
- <input type="submit" value="Save">
- <noscript><p><input type="submit" name="add" value="Add column"></noscript>
- ';}if($C!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$C));}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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'
- <form action="" method="post">
- <p>Name: <input name="name" value="',h($J["name"]),'" maxlength="64" autocapitalize="off">
- ',(support("materializedview")?" ".checkbox("materialized",1,$J["materialized"],'Materialized view'):""),'<p>';textarea("select",$J["select"]);echo'<p>
- <input type="submit" value="Save">
- ';if($a!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$a));}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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'
- <form action="" method="post">
- <table cellspacing="0">
- <tr><th>Name<td><input name="EVENT_NAME" value="',h($J["EVENT_NAME"]),'" maxlength="64" autocapitalize="off">
- <tr><th title="datetime">Start<td><input name="STARTS" value="',h("$J[EXECUTE_AT]$J[STARTS]"),'">
- <tr><th title="datetime">End<td><input name="ENDS" value="',h($J["ENDS"]),'">
- <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">
- <tr><th><td>',checkbox("ON_COMPLETION","PRESERVE",$J["ON_COMPLETION"]=="PRESERVE",'On completion preserve'),'</table>
- <p>';textarea("EVENT_DEFINITION",$J["EVENT_DEFINITION"]);echo'<p>
- <input type="submit" value="Save">
- ';if($aa!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$aa));}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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'
- <form action="" method="post" id="form">
- <p>Name: <input name="name" value="',h($J["name"]),'" maxlength="64" autocapitalize="off">
- ',($Pg?'Language'.": ".html_select("language",$Pg,$J["language"])."\n":""),'<input type="submit" value="Save">
- <table cellspacing="0" class="nowrap">
- ';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>
- <p>';textarea("definition",$J["definition"]);echo'<p>
- <input type="submit" value="Save">
- ';if($da!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$da));}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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
- redirect($_);}page_header($fa!=""?'Alter sequence'.": ".h($fa):'Create sequence',$n);if(!$J)$J["name"]=$fa;echo'
- <form action="" method="post">
- <p><input name="name" value="',h($J["name"]),'" autocapitalize="off">
- <input type="submit" value="Save">
- ';if($fa!="")echo"<input type='submit' name='drop' value='".'Drop'."'>".confirm(sprintf('Drop %s?',$fa))."\n";echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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
- 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'
- <form action="" method="post">
- <p>
- ';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,'">
- </form>
- ';}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'
- <form action="" method="post" id="form">
- <table cellspacing="0">
- <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>
- <p>Name: <input name="Trigger" value="',h($J["Trigger"]),'" maxlength="64" autocapitalize="off">
- ',script("qs('#form')['Timing'].onchange();"),'<p>';textarea("Statement",$J["Statement"]);echo'<p>
- <input type="submit" value="Save">
- ';if($C!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$C));}echo'<input type="hidden" name="token" value="',$hi,'">
- </form>
- ';}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
- 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
- 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
- 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">
- <table cellspacing="0">
- <tr><th>Server<td><input name="host" maxlength="60" value="',h($J["host"]),'" autocapitalize="off">
- <tr><th>Username<td><input name="user" maxlength="16" value="',h($J["user"]),'" autocapitalize="off">
- <tr><th>Password<td><input name="pass" id="pass" value="',h($J["pass"]),'" autocomplete="new-password">
- ';if(!$J["hashed"])echo
- script("typePassword(qs('#pass'));");echo
- checkbox("hashed",1,$J["hashed"],'Hashed',"typePassword(this.form['pass'], this.checked);"),'</table>
- ';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".'Privileges'.doc_link(array('sql'=>"grant.html#priv_level"));$s=0;foreach($ld
- 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
- 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>
- <input type="submit" value="Save">
- ';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,'">
- </form>
- ';}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'
- <form action="" method="post">
- <table cellspacing="0" class="nowrap checkable">
- ',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
- 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
- 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>
- <p>
- ';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,'">
- </form>
- ',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
- 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
- reset($I->fetch_row());}exit;}$eg=$Bi=null;foreach($w
- as$v){if($v["type"]=="PRIMARY"){$eg=array_flip($v["columns"]);$Bi=($L?$eg:array());foreach($Bi
- 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
- 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
- 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
- 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
- as$y=>$X){$o=$p[idf_unescape($X)];if($o&&($Ga=convert_field($o)))$Yg[$y]="$Ga AS $X";}if(!$Vd&&$Bi){foreach($Bi
- 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
- 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
- as$J){foreach($J
- 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
- 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
- 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
- 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
- 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
- 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>
- <input type="submit" value="Save"',($_GET["modify"]?'':' title="'.'Ctrl+click on a value to modify it.'.'"'),'>
- </div></fieldset>
- <fieldset><legend>Selected <span id="selected"></span></legend><div>
- <input type="submit" name="edit" value="Edit">
- <input type="submit" name="clone" value="Clone">
- <input type="submit" name="delete" value="Delete">',confirm(),'</div></fieldset>
- ';}$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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- script("ajaxSetHtml('".js_escape(ME)."script=db');");}}}page_footer();
Add Comment
Please, Sign In to add comment