macspeedsolo

adminer

Feb 26th, 2018
437
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 219.83 KB | None | 0 0
  1. <?php
  2. /** Adminer - Compact database management
  3. * @link https://www.adminer.org/
  4. * @author Jakub Vrana, https://www.vrana.cz/
  5. * @copyright 2007 Jakub Vrana
  6. * @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
  7. * @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
  8. * @version 4.5.0
  9. */error_reporting(6135);$sc=!preg_match('~^(unsafe_raw)?$~',ini_get("filter.default"));if($sc||ini_get("filter.default_flags")){foreach(array('_GET','_POST','_COOKIE','_SERVER')as$X){$Lg=filter_input_array(constant("INPUT$X"),FILTER_UNSAFE_RAW);if($Lg)$$X=$Lg;}}if(function_exists("mb_internal_encoding"))mb_internal_encoding("8bit");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
  10. 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
  11. 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ߨŠÞ¨¨è-ŽƒÈà2‡¹pÂ3Œ¢îb–àÙ¥°¨çÞv>ñœp\\²ŒÃê6_HˆÛ»CxïW†1OjùAwH7q£ \\ÉŽ#¨ÒÉ®ýrŒ4v=ŸnòvÑO‰–÷6‡gWpß×ù'eÚy¯—ŸÝ÷¡pî0#z6=ÙÖ€u¡º\\_Ä.¬â£>H<rÞ+cz%}®w÷ÈVˆA*€¸Ã—B>dR:\rê‰\rœðl\rÕ9´jð43•¸ qm\rPN ðØAãþ`ÅûÁµxoèm\rÁì8?ÔüÃõ, E·,U茂âêìòŸ%z®Ê›¬5õ’ˆvÃìvE 86H0[C¼Lmj¨2D¨¢¦Á`pŠÑ1?ÁRÀQŽÊÛMæÅxšžbéu ±Å& ˜âI-\"¡Ê§žÛV\"ò ÍpG\"W†±èŽ\$¦Š“J\$6†PæPÜÄu\"ˆT7CHòÖ–{÷Æ HÙåÓô8FK•r#D@ÝYKKcp 1¼ˆè‘ˆY\rá‡D’^X#ª –€ÂYÀ5¹\ne̲Òö\$†\" SH\$°{ก.©%ÈXF³Ji@8L ¥if\riñgBstDŒ¤N‚SzmMÀË9'zm‹\rxµ¥éIüŽ¥Ðž-é ©Ð7:q\$3pÇ ÍQ—f¬,š¤Ø¡Hb2 ]…\n€à·'̹?PÆmCÖ‰¥rIù£4ƒ¢XAÝPn¨ö…ÅiCxp…ðL£¬éþŸÔ\nƒDô‚‘ªHé4.A”;·òŒäVqÁOf1À2\"OÉí>KÉ4­s+C˜qSFL«SPr ‰@€ôÕ\"æŸS*ëLµL‚ôKä«EE±\nÆÖk)À™j’˜4u\r©I7A±’†0ꏣa7p ì¹€ç !sòA˜4‡ƒ(yÑéï*o¥¨£fŒª.­ðØ2¥ZÇž[ VGî\$š×ê¬^n&1E™)Ê€-£\r%÷ZPÞȲúˆQR#xZc,Sô ïدҔïlÔH.!iÃ78…e…yr6„X‹€Zî\\†lYB)\$á(—\n“ ¥I\\Sx¸Ñ½Ð*up«û§/Á\0p€E¬ëxÊ4<ŒUGvxŽYí=ö…XŸ€ÇÊ¥ôœÐLÀ¾‚æ¨êÏ„˜\$2CöcÐf!Î\nµ¹‚HAÖwÎúÈèÓíf‰jláŒ4öé¾ ¶åBÔbL –\nO´°ì»7!À# Ët7DEzÚ&²×âîŸ&T‰¥R‰ji\\]gãv!Ã†qɬòCdÊ„k«é€“Êl™Ñ­î UP20åBq=«Œ8ª3>û¯ !’ȸÙuõ+-äÂÌmDó03s\"²÷†ý£{¹x‘*+E­0>‚3.`Q–,EÖ–ˆ^˜M”÷Â5 eÔ]+_•>Ÿ=Ì«¥CœÙ)™7Û \rŸu¿Êô8™²zÁk†@´Û#ªZY’q²áˆ5—]ˆQԾǟú€·‚=bnŠb¼Äª±Ž¬˜iž¡ËEäJ ‘u~°eÃkýu§îÍÄÖÈ0«Ã'̘n[wÞÄåŒó‚kÛ%Ý÷,Ý¢½göò)´LˆýèàW²e™i’Ô³ˆ>ÍÜ>){ ¨Pðt r°„1£ÑUaÊ–\$ò.I|ÿ#Z³š råy&ù¯2“²:H'ë¸Ý“{*ä<ëÛ—Ñ—®;P¦Î87ô>IêÜ·Wõ¤²ž€v²2p7{'ô.[́k]9»8] clóõüdúG•7~cÉu…ÄÝ›¦¾Ñeºÿ\$t®ùñ¾WÏÝovéO°†µ>Þ~2 gç=>ê^Žú»?JQ!FÍêMù!0>à¡¡éÂä¶Ú-1@à4°RûŒ °þ¦é_•´øsOlú,c¥r`È·?¤u½)”Ƀ0àe¯Ùº‹Â\"ÆÛì„üÚNÛ; m>³§+ÎåaퟷðýC\"u4ÙlºW¾ú¿?±æÿ¤þÏu¡÷ÊBm|I®Eø\nâùúøB¿ö¦ ÷=KZkozÍO üϦÿ萋e6œK]\0劐 d îµHص¤ÄAÖ6ƒlX)`+d šÐ.7 è\r ¾ ÀÚƒj6êËp-ÐE\"oPR7ݐ:\0Ð\0¾{@ÇPMmPt7x ðcàZƒp„4P ççô’BÐ/¨“°°“#Dð« ¾Ÿ¨V–\0fi,¬¼ÐÌ iw G‚\rð“\r°Þ ßð]\n@[ ÊG’SpÝŠ¢\r€¿“èÕ([j¤ ðáÑ%ô– &Ãð£pµ‰‚\0r—pÕ\npm\r ¾› 0m 9ÐÿâšÕMF.­Kpï¨ZWí1=‘EÀßQ)qRÔ@ò¨)Ž‰'u„0Ð\nâ+0D¬Èq'Äö ðB‘ðö=‘ªƒì- éPåñº iPM‘q³ƒqÑ@\rˆëHË ÀŒ«“Ѧ è7 ¯q±qý±û±ÍP‰Ò±±°“P–ƒqÞSQâŠá °Ñ\r\0ѧ ð\r±hê/p¡ ãÙ#’=2K\$’ÄrU1Ð@`诱œ,… 1½²m Òm¨êq ä_ÈK¯ø–}(]ÀÖ  ó 2‘)QÔ²²šlò…²z¯ò#qÃ&f a\$Q]0ÿ)ñiñ‡ RÇ,ðm'Qv ñ,É\r’ÍrЪHÕ.2×òÔ àà òÓ.‘;.rÛ/²ÿ-²Ù\rpl\r©ªRñ&ño1S 1Ï/c\\ i»/r£2S+2ó Ÿ ‘œpÌSIð:]ño5ˆÍbe“!3Y,nŽ©—Êí2É_4)„˜^ÇB­G\nLqŽ ªþ°#°r´(Ó5±M&ªœó¥²ß:Ы/Ó£ 3^ó0“3sµÆ]( +8I ©dÀ Ø©ò÷219&ìqóáòó\"­=-É‘§>rU@·3¯ÐÛ@S\r@‘o@ô >1S„–„)Š–Âo)~@P;-ò€©°¯ô:\nl\"›\nÌ#g7clÀC\0000CŠüöD|1hÔ.óôéQ‚A\$\rÆ.±š8.2t2#ô6o¢ACâËD åDtJHÔQ+KâÖ„î ");}elseif($_GET["file"]=="functions.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  12. lzw_decompress("f:›ŒgCI¼Ü\n8œÅ3)°Ë7œ…'³‘”èu9„CyŒêm2›Ž‚ã‰ÔÊr<”á°ó¤F+ˆD‡gØ\n „Í’øtÄXcƒ §ƒ¤Lìa9¡§1ì\$Ã<–DgôÐø|ŽG¤!Hî+Œˆ)eºXºn3\rщvg5Á`ôê„ú\"ªÄëñˆÕÞ…D’I¥©ì´äA6Ná˜Xvi¸Îˆ!†vf7Q©\0ªAž˜A9Œ'‘q„àp6Eã®\$YÈN‡1Hºti1™EíîÃp››…¨µðA˜Òéõ\"‹Q¤ç¯9g±Öü‡“9eMš8£1š¤çsú'QªÖk¶½ž÷‹¿êÜ…ØŸˆ¶0.sµï|kÓ<î`Ðç:’fê&ː6#ÀÒáŒê,cz0Ü¢c2\\£©#XÊ<Px\nÂã*'º(°·/ÌH971\\>·¬|œ2Êä!ƒæ…!©ü{‰Ã\n@\$#ć\"cHÌ!¨š rç\"¤ì§*ÇÒ¼Œ2…È«P0·!@¤2Œâ(ð88P/‚à¸Úá\\¹\"Ká\\Ý9càH„áHX„•Êt”‡á8A:Îòò@ô\ng2(:Z3ŒèpP4Œ”6)¨PNε»-ÊÒÀÊÊd©VËáèzÀc Ȑ„ôhOJW5ØÝK7Ïó,†AÈ \rãXÒÝK£HÎ7ƒ#FÚpàk(AèÜ2ŽàPˆ0¨NwnL`éqÜ·@\\3¢×ct…v°òÚ\\èëb‘Jƒ}›g¿Qý¤7OAÚÅ5(ª™:ÝK¬;\$òpò+\$ã›ä4-XŒ\rb[3#Ý™g7A8Â2A–øä/â–,ƒ¡€N7Ýµ'4Rʳ}¤c+r ¢*öM¹Ä¿KhÉmVã@è:˜t…㾬ÒåzN\"#8_–åãp^ãªE[ÎÈÆÌ:zLÀ3g#(„ˆ×c–c¶îø\\6³°x2ÚZvï·6ÙðÞÄÁã=n7\rá>ñ¸¶Ã ò‡ý@µVẇÇpƒŸ%Ê\r\0ÏÁáˆ\\£(ÛÎIü°ÜŽápà7óÂhËŒ7€Lu݆°2¸‚D&9ÊU&ï:W=ÉÌ#1<Z 2ñÙ?áž'<¤ójAÜ^›€ù ¾Ç‘({àåiAõµq§ê:ž««äùN·®Ð6Ë7¾ƒÐZû.JÀ°R ÁqC!ï Ùå¸JêNñÿ6F³ÓkõkL­°@4ë@[-¬Ð®†ÔCÀ(c‰è9³àÒ =ƒ¤ñ pÃØ}I¦§ LÇÉ hˆeKà̱Ñ13!)´Ã5†mP! \r†ÀȧÞLISXÅ’À¬e‰1u(¡î º@ͱ0(A\$ºò†q ŒäŒ£†ÂLLÖÔs ¡Ç6¹ s qú=FÈÜ rÅŠ=šVžúÃu(AÌGRLUáɵaÀ‡¤åžü…’±€2ƒ©D_Ê+AG8*;•bǝʢ\"«yp\0¤ÎšSZm É´¡΁H\$f`œ4¬Cú¨.’aÑX̧r«Œsã2E ÙJÓºeññTÝ×ved®›Å)*D¦v\rN\rê왬RÄ%Q8ˆíІ0Ö¬Uó³ ‘Mi^ çš–G\$%Ó˜”þ!èx234·=hdIéM\r Úîè¡\r¡m“Nh²¢´nŽ†Ê>×l7®r‚êGG µ& ´¡*ҵ̍f‘Ža\r %>\n™Œk¨\$@ÚNÕ\0,¡+en¯Tª”—•.ž‡Dô SeLi”…À„\nú° =ƒ0ú½ø/ ê\rG¯E JêÚ!ª–&*•BÞ'Ãú)(<8I\"˜]& n¯¡Ò‡+)ø'R»vSP‘X˜“EAC7p`ò¾WâÌHKHhm ®W¤C`¤=²¦Ì-†’Ý­Ê2q÷0êe„I¶€‘¼àæ¢ãÚ°©[³#bÚ\n¤qR…š´¾¨‰Xm)‡6JR8Ð͐svBÉÚ.L”,öfÍÙØ\$¢šTËV.ªAZ`]x4å¼––™Ð©ínnbT¢ìÏ;‰=¯ʽ–þàÏ+q}ç¼ù·þÛ¦Ô\"’Þ¢Õ_G°®ÝC6lž!×jÌ«ºùÁzoN&Ò÷»p\nš~€ó)ÛÌÌ\$íïb³K³B|²åJSè\0rfxžò…܆ÌØjná¨O<(Z0°j³ˆžz\\\\|ÃU3 Ì%ÏE@Ó©vL™:+_ËúAéU TBŸÜ…IÕ=vUjËÛ˜ŽEöˉFxåŠ5€#ܯ½\n‹2ÇË­\\šL£4Z纫£tñÅ{²wfËä 4rdI÷£9ëóo=Ǥ7®ógX-|Ã%œRó»:æЉÑå6|¬jšÏh-J§µºÕ¬«‚zÝŠð†–\"¯¬µ¢™8`¸çSÃiˆewÏ\0÷YJÔS35\\so'›©ÀçòAÆ5ÃE)ý¡8˜í\0·ð0‡ËF%DÔ ;R %7%'\n·Ã¡ˆ7‡‡ò±Ižëݺ†{%Jc+öL©Ô¡¬æukœç±–\"u†ZðR‰?ª_€Ò,¥•&QeÙN*†Jñ¾énu¼#2i€v”È6û¤4ÓUÓ|Õqs`}[IŠP»éNV]݁ãzO}òùÁ\rñÎ|*8“=ÊúCš ÁÐ%¡÷v\n,ΐ«ô­1¤RÈ=çW:i…aÓ¹t ë¿ˆçPu<É5qÁöÓc FÌì<þ¹Š×lfðë‰ã}n†h\0ådp}“´xþîh‹:Íí¥¢ì—²¼Z›ÑSº™ |ýÄ´[;|ºÈ=Ó¼žüZ3j<\n¶¹…^ÑÔîéü]q\$L13ð×¼}hêAÊ;Üš({óñòæ)~aQ*5H¨\r:£åêé˜AZª¯& {ÅH·hl¥¶ÇkÀÜÊ‚@T ¡1[‚`ܤØ;qÞ¼†´¦ƒþ‡ÒúŸ\"ó®Âƒ´\r'¼­§fS.¶ÌSÜ5ÙPìAC¨s\na¥%ú0öýí4©Üýí<2eàæ P\r* ÀY\0ÄLÚ­žH œ'w¯d#¥È.@]@Ê À{ÀÌQÝ bQ MÆчr ¢Ø%(RÊp†Â+`ê æZ‚¸³ÀÂØ‚,ØÍeIRµ\r®; ÂPmº“`‰çv &¸ ÀÌ]@™ê­ Àß\nÔ\nç.\r\0} Ϙట\n\"- @È-BؤN@i(yg(\ræZ ÀØÖnþæ,Á¶Êä\$0n’Hp¾0ØLÜ\$ðáFL’GÓÈæ%t\nM`‡´ÉböÔíâ’PäJ§¦±Ã¼Yì¡ åvÁ±8â.B\r–^ú@(©®\r ¡qX\\ÈòNÊM¨æfq,ìnî몺èæïŒ,ïÂ'ìRðñˆ¼ÍLDz«€¶ Z@º €¶¬`Vå€L%-êf¨ÚW`ðnîTìk«°qpÖvï\rºÀÒ²ŽÈЮúÑ.÷¥k±oQ”Lƒtñ›ñ£m3Å &ðm*V„²R¯ !\nfÜå^ÝNdݧó ÚêÍüàϸö2,”hìUò§B±fÖù±<L¢uî rš0hDhÔ%BΊ'`8NnÚ­òÄX§…vVÀbb¯'rzಀÒ9ÊP!’fêr‡\0úöÒ^ŽrdF\0Ñ*§ü‡ʾ)-ëã\$î\$É®*#\nq¾(qÅ€ŽÀÚ\rÀšB©rèò2`ÝДXf=\rQ×±ß/1€ÐñèIà_-b>lM™“\0Å%\"Å€÷1rÅejó\r-¤ë.S\$\$®R«øöòb ²š¸Ï³ÊæÌ\0GÀÈ]@[)’¬RÅY32@qÅ´yÀíÓh°²úï1Ü“i0,.³Óh³z𐈟Ói,.(Éê€ñoÀLŽh¿#àQ8ì–ân %lçoK4NF«PVÓ{BÔ\"s¨áòÇ+¥¼KåÎ\r í9 ¦‘H-æ‰EL kЀz@¶Ž º@ºfsh6¤4#Â=Èâ8èÓÍzžbw')'b@Ù&²†}\"@B2k9Î}\$s&­<ؤ\$ÙÌ烍'dPÖT* æF„ÏÂDÓÍØ €ó&²o@X’&ž Ĥ{\0¦%¤Øæñ(ÓôCÀé-J\$9”BÀÔÿ Ð\n‚ªÜDOHtN\"Ô™IÔ (ÄçÄŸAt%I(„?'Ò#(4R_’‹'àz2wiÂ;´ª…ŽmÁJ&~ÛËhÚ”âÄ–#Ì‚Tp%¦COj_P\" ½®J1–ö5£ClµëbäÔ—@oò\\ÉÝ#)Ú˜îÁ#NaF ór[TãH”DCeI-¬tIÎ\$n‚IΈCóOr µµ ý`OMЋIMŽPnÎ4¦Øê]QÕFà¾Ip–\rg]@¨\r\"@BÉ™)õ‚ÖU†Ï•Šû`Y)¤FâoÖq4hÖqDh%RyLrŒ h[\\õ?] fKÔ|ÌØõID4‘H0ê¥OU\\ÔÓ\"5ÖQ¥¾(öÿ¢ÐWàNìÿôÿ•ü å,Øt÷,Nv q+N¢`ØèôÞŸê\"®V\$´\r–1a\0ÎÆÕçWm¥d4ÂœÎ;9KOÎ ¯ÒbÏÙb®±ÀRÆÖ_d«åfN fŽ fõ¾†ôãgµ€ûÊD_T S4S\0úçôTèUb)¿SÕÂõÆcK!ƒ²Ú•/A0SOYS’^§1W>Q‹B¾*^ñ\$Áj¸ Ês “PechÅ:(¹––ó\"%¤\n‹W\" z %vÉe¾T(ȶ‡Õp·ðO\"Ûr àš…¦Ð×(’EÞ\"À‚‘ïø’FJàZo€ð»bÕKR\" Û7FžwJ\\ OuUu€Ñ ÷+rj\0*¯·QdCK·0}`ÏpÉ8ñ×AV«Ss7à×t3s`ñs«2ÆcyU]tWIGN\\‘w,+w`Yy·z—­<e. ËF\0÷N t´jÎgB\r€àG‡i>pðeœ\0ŸxÄ2Ñ6âeD3\rr†2¿a²á`ö#=Î*¯ RÈ%’̐ày:§<C Ý€ø& x+\rúÊU¶YSQmeám±+ðâ[ñ4í)\\ím§X‚ïl^h´ò’ZîÑØD.õ7u7ò;=C…Ôá\rNØ·\n±%(¦â²YKë\rJP󵤇-<„ÈP…T\$'êb DÈ\re«|\0X{ën^ d ¢JÄ¥`Õçb ¦¨¦ LøÎsÀ~[åÍ€™ÀáŽLÑÐ`ÔÀ‚.& \0ž @Ô%˜æ–¹ ™¹ dÚ £qÄ*è`]ŽÏ¢\n€ P u#8d‚B+Ž(Æ[X¬z\\ò÷àG”§=•õI8Å£ê„ùLB\".’À\$ï¢úeo7“Ø#?9b^\0DÈ>vøÆ ¤ô€_6™ŒyK”ùnÅDðK9£–Ïóš…%njµqú‚\$*ÔPpeQ`÷šù]›E\\eoœ@XO·”8ö\$`Þ“ƒ…:wÀQ   à¦\n–à‹ŸÅc”’ã‰”HÒ˜ôĦþdçºêx/D·ž˜d\0Õ6 À^\0ZjÀîªF¦8\$\"€Wj1Ùäĺ¡g=¡¦êM °ºX`[ WZPy0~f˜Ú ÆFYZ(Gýû’´IúRsʲdâS–ÖÃ\0¼H¼Z“UÙ°6ˆ-‹x»%˜ÍžuöÏ–™¥›9rYvúš¹¡‚ÿ ªª²“b !”²…)—À혭?\"OÀ嘤ë\nðàkGl|”ù™™Ê¬Z¯Ek§1±õ›±ø\0_ÅuœJ×3ˆŠ?šÔŠYðB:P˜ú«ŠºÄ\"ÊŠ¨ø°ùTH# C”»R’Ÿª¥Dà{à”\n`ž À¶ûs\$’ã­Ævrî ºçË€DÜN»€vû…®Bª˜,ÁÄ:Cë>[wÁ{L÷ PE˜¾B\$dE«%Õ¸3™hÊ4;Ê5Œ9‘´n’U¶wÀ ¶-Ìð)‹œ¹,ÿºXy7bˇñ…4–`Ư†VKЛ䦶ËqqÈ\$öìÙ HàÓ1)›\"œJrºŽjHËÁŠ—\"`ðƒDyÀÞ‹\\¶ÖŒ–IœÂ+ÄÜ×d@ø¡î³(oPÆBçeIŤ Ê\n ¤ *x\r»„6IšÎdômHà¼}È\0ßÈG¦§Ö>ÚSš”(Õoɺù@uÂÉI†K¶œp\r@ÞAäÚÖ&3f8ßµLƒ‚àà^ýàéÂ\$¹Ô.\r ×i|ÎcŠ²«qú €~ÀU …ªë|Ͼ2BÛ\\c›a¨Ûe1û³µM–š×oXq«ºU¸:㸂ò¯ÿI®‚\"}<\r:p*Tt`è é| džg4ÙYªêá[+»°˜hµ3à T°cª€î)\0ÜÿÕECH5GD\r_hË^•XÛÕvŽ#ƒ’ŠÕ|¶”ëKF~P/9ÙôC Äáv¦u½€ÿÝ!óÝÆñ¨ð3w3€%IÚœü/¦¾¢ªêBª*ê»1 ÅÝ¥ùXfð&v=„¨gâ…E¦ˆ•Ü=²R•r÷\rÄY&ú‹[”‘rß;jAç|ß4¹`ÑM@dü è­&¾F´:èÀLÙõUKîo{@„ŽÀä<ÖòËêâ:ˬà{߃,Rô‚ýä´}#E>@Ÿ -H3ÑÞ¥=är*ýà•\"x¬ÜpùâO®~tþr°¶·6-F÷Šýণe Ì h€e)ô\rܯ P–M`)€bíò?Ï9½²€¸lJ׊qrp‚7!ïà{ïþ;=n €ê\0`&d*ë\0˜¦<T3Ä\r5#êŸã¾EHÔ.Ie¨Ÿ6_ˆç†}4„\nQb7±Xoq\n€Þý\$TÅùì‚D v¿h€²ìQ+€eð¿V €ê5ph-÷ßXb]àɪ*£˜®þ†^\0e¡ Šuÿ`§ÀOú Éùg_X+¾ú ËúiQò¢gÞrü_3Þ•%~l]_†\nun€‘Ô‡ÄÊîµ5)iè\$•l' …µÈqF@܁ԐøN®IÛ’Ü‚ä2Ÿ? T.G!«ÅÊK5)Ó\rÃn*ãÏž†åµÂUzÈHÏ!Kž]r èJì N *ø¥ôae8vIö;H@Ì\rÏځ¹tˆ\$úí†óÅžpŒùÈ!ào¦+êØú¤ù?\$h#¯kPÃDÁã\0°¥©Jëå@V~ø( Áƒ¤Ì-û®XÀ7Œ-áAJ‹bÄ8ŒØA›AéíUD~°‡éÞ,º?PE¤3BmfTGœ‚¼ ˆ>¥Y]ˆÄfIÓ µDÆ#‹kYh€”º.ÐefÀè©è#i÷ t± òuäRШQ” Þuæºh(€;M1ÛH r)\$®€yRL.Ö‚Ea³>Tn?\\\"ÒÀ»@¤¬‚3g2 þ‚'¼6L«¦™p|&tbÁ} +{ªüÐœþ–^Kìo•³Õâ«T}€ ‰d@Gj*‡t<s\0b›³™BK\rÈ\0„Zó¬õ«û(äâgú?ÙÔÈ,X†M\0¡~Ä’Ð D(F¨ŠºñÛ  ˆ©YË<Ã@º7p°é¹GiuÎöþfÿ¿Â Ïó¨èÝJ4â6– SéIp<x•Ä\"% h‰x\"b‡ÃË @î%-‰·†ø/5ªf%‰šïW’Q]È…£þÆfZ6ó(„±QÄSI\$(5>Ád´o1ÄR_…§0 DoóaëÀˆð0†´Öoós”“Hb³œ\r‚:((Âÿ1A®..1{1šÙâÌÞ8±¼Ê-Qx!Šã\0Éò#ÅÊ ê‘\\^#X½”JшD`bá\$!â1ѐŒ\\âW“rŠÉÔ-sR’Ӂµ;&ã§V¨` ô“Áe{;#\rQÎI\"ÂÆÖ\$û‰3—Æ›óÀ\rså¤-2Cbœ‘æ?ÍW/+çÄÀ¤³â6à -ùR^=h©øH.j  âGsœJqàÀö‡Œr–Ç°6QîáÝãÈhó!.='m¾}Øõ<L€h 3\0NC@ÇÜZ‘çL9‹…“„«1YÀeV€wšŒR×ý”ÝÖFžDà \n~ÐÍ„5÷â¬ḊÕ6ûĘ0nÑ¿Sn¤̍ ¤s\n‘›µ!ØRÈ̍R5d\0t—àHÄÍ(4H¶¤„óµãHÈðúˆˆˆ¤„Ս8HE‰Î’wÌl2&Èä½’V’@´†…%b\"Ī2gë‰ÜOEc#âwHˆ&kì<\nSÕC å!¨™D*A]RúGþ§³YB=v«ßŠêHP»¢FdGq›Sˆ ×Ähc©-+£»“ªøÍÓ‘Ý©î «ºô£M 5N¦\r',‰\0”tmWN©9Ô\nN‚XÐ\0¾¯à5Œ,\n£±Äzñ\0 ®`\"c=cê!ÖJteÐC’cuDê p[Fd0e,'¸.\nà\n{!¤¬n”æ.Ña!–iŽ¥«&#ŠZâ,̶Äg\r®q™¡—Eî6\$\\`czÆø6!:‘86«tsܺÀç.!²†Ê]AY˜ åã)â\"'xu¯5‚•Î‚<Gˆ bX\n heN ùTËIÓ•HLå€ 8—?ÝÕ®L¡ÁFf­¥QåÏ\nM€ Žl¦ýA7d¾MóÜa¡9€¥Ô -ŠY£¦X˜Ä¹­,ýij–ÉŸ3rÓ)%aˆ“K\"Ú P\"¦VF‘R‰ôX‡;™IdËœßäÁÍD£hù:‰ÎÕ.Q£ÂDÙ%逗@î7BW¸ ÁDÊÓ TZÄé‡8· ^\0¥&#ù³É¤æñ\"VPƒ6ñºØpï}ŒZ‚—âe¼S™4(¦Qù•]¿±ÇoøXËÌrU“ì2€i`¦Å:Q\$ Å2y^ì\$Ep€²¬8”sÇw\ráoÓf'–“Âuðï*ÀzÅC˜ Io?È@ˆ®'ŠÎêv%¢œì]”\$ùÝNÐþépÚ܃ò¸’7.0ô\0{žKó<Ö( ?)\\%\$ƒ‚q<\$ø°œ|óÂPbRKš¬E!«Y>ÚÜÁsO¹ZÓé•Ìù\$;¹êÎÖy“Î7Jâ>5¥ÇOqóùž\\õçœ.p1O)aÓØJTö§ ¸º\0Ox§H¨ETøEæY⑝IŠ#‘¿\$,ñAQD€À²,F£‡9wÄžkÞ^\"9LS(°80 ‰%DÍI˜‘Ó9ÇmSb—’1¿&®¬ãõ¤xŽè³ *^ÕBR‹H  è–~¿T#qæ)“¸œdÑ\$C¿†lŽh§¢)á( *D萌R(!\0 vM°“‰€€ÉkàH@ 1‘Šì°›ëå‹<ÏZ.zŒE/!€º'¦z§üÆÏH ³š\n,º>…´OIü)< H\$–¶ê¼h(f¾¢‘ÑÀBð&\$ `Eà€ŠÐ\0,B†À(g«Œ)H÷Rf“qÓ#©|‚º0%\"Z\0%+…–Ï ÃØ/ ª€l\n¹e©Cå²;„‘tepâeRî@P„֍´oÁÈýC–¨ÌÀgán­M`AáåÄ,\0/…Þ\0¡V]PRâ@“”ikZ]7¨›C¸Ý€(Ž´y•¦µHŠ:ÑøOIk¤’i|2*(¥´IkÚZå¡Mb¨\ný?Šk½#Ç;·\rÐ\$ô£¦yÕ!KºH’’•ZX³hœ{\0™§l )ݦ;€áä^ÀpíÕ¦0¶ËQRHæ•K½GiRà¸Y¡3H¹péÆTÈft¤X¯…(·SÄzŹ8 ‘Òržºi/Ü1tP’°Ž¡¯Q¼mÎð|p0‰è âu/i\n Õ””ó«@©\\rf%\"q U…ÀŽÄ|/:´ª<ûó\rÛ—`*\0003…¡¦\rж ÜIIz6P \0dso-®a5ŵyìêuU|‚^è7¥Ý\0´ò(U©HæžEhºÏžjEèÔóWŸù3Ô6gR\\9Â])ÇèT@¤#»Ø¡ÙªÖÊe -hÅEL@S É 53\\*¹làä <]n…Цá[W ò -îêÙ]Ž¾·aB)œk@€Ö-œ‰Î<8­ÖóGãw»‚¤IÝ™ @ißJ•%°\rÀ=£è «ð“7ÈÄä°0D¸ú8j¦rÀƒ”¯8íì·¹˜äÇf=0ùŒ„YӝHÀfH[å[)Vc㘜*õU¢U겺­Ø˜Î0±!lBOU€:Õh2ÁS¯Õ‚ËÒmZð8]·›åx…ÐZ ×̈´®°ÐO[ToòVE\n}kj‹'ÐH)CܐÑDFݽZ,õr©SÐ.\0ºËà?®uVå\"„pÑô?ˆ¯è@T³ˆÖlîöm|ª ,àVäm)3šYÚ˜ŒÃ=Á÷ò8DÓfBèß\"݇ N´8ß~X E\"æGÓU™\\Ȩ°¥0Ï\0ÉÂYšLÑ’Ù\$f\0À 9uÑ­¢úÌŠÓEæ²K-;6…\rüó\"ñÙí‹«TÚfÖ¬7´”Š;2ËMâÂ1%G|Ë-.m[W×µ¡-ý6×`*pŽ6À®‹æ\0ñk›G&1# d¶¤× a2+M³qÏM”@}íGjZ怲Õ F•)”HÓUÉ¡ì\nÄgâöb2ñ[&¢Öݯ))3L\"®m\">ü`¢åoˆ¦[èñV˜¶É¥m·S€>ÌÜ? Q<\rdGYJ z`©`zØ\0è\$„D7V’µ¹yªÀÃÑ°AiËÚ¸¤r®-Y1/ÖVÒ uœØq™\\jªU4ÒØêqY *\$Lð‚j#NvˆôPÒ\rµ§\"¼ü€ÛYâJZ~Ühþò4¨ÿ\\ÂÍLê…ÓI1ÇU –&&¡ü³ðb9æ8yâ=ˆ Ç-ñÇ\\øß÷@VøZÞ1 ,ÍÄ\"PDC“+RvÃ)\$\"mX(˜+”,\$DI-¥±ëQr’Bt¡‚ã¡'¸ýÈ`Ø‹‘jŒ%­·ž°ïk5Œ… W¼-çï{ÍŽÆô°¦½Ê.LKÓ^„ ÷£¸ÚÎÐÀô³Š¨Ã+d9X”Š»áÇ]ÒʫϬ¬Z•k`ÍÀž¶¦Œ³•,F=|ºÐ/Œ 6­#½h'\n[8–Å­«}ïY2Ù\"È…Ý÷ÝTs~Dà(ÔÀ½;\"y8×u[\n‹Û’\nÀ|\0BQN§ ±yéÎ0Íüïê(«û¸=ÂOq¥1†Pô×Zÿâ¿Ó‹ê (à\$(¸·È^U€RÖ!/VRl<{EÃTr’ `4µ‚· ÷Ä\"ä(é‰N½µ¬¿j)\0çp[{Ñ?õÁ)‰DŒ8Š´È¡eù+W~À-Ü/u°¢Üduʏ›þý8+ÂZÄzøPe6“8RõIw…!ÚáVÀ>°pœ <wBµOHH+Z‹ LxQ”_D€mœ+ Ï Ø€Þcgظ¢!VákÂoP1«82Ø_™¶i…†9®á\0 À_~º0ÙÈÍáUâ¼e%ðjÊ×!`h5¥0ÄàL2`° x‹ª¨E€ËˆøÍaS“¸ ë€<Cõ~«÷CŠ\\[Ä,«—žN×ÅŒÆ\$\n Ãy \$xr IŸ+QadWô¿´/0)Ëë­ýŠ ¼íéØœ¬ š{2vŠÊ¥IòìBJ\$œ¯\rfÕˆDÅ9VŒNðšVzëÜcbgR!²£*°Úȹ”)4óÆ)Á«#„QX82©¢zÆy£©|úVß6\"Ô­­ \0, ÙBa³ŒO{¼í@ÑJäHùÕ/žnh\\±2²!]Côu®ÔI»¶Jî²¥Ú([aè\nÜAêþ¦K(ƒsK)cm|qd;»n’•ûÛ+\$V­í’•\\‘§¡²€^¿mÕ@ÝGñBR äuÈèe‡w+€\0®•µç{Ø\nì‘k©€Ÿ#YËÞ]ó‘¡AäTyXE\$r\\<Ûµ†&@nÉ ã²Kvœ˜d¦íÃÓ>ÙÌ)Œ7:Yhζ4L9‹fG”ÓVE¤¡e} Ì\"2ëcáK\rΪ¡´#\ncPn˜À]q*ilœÝ-õÜi\"ä Sjµ•ìÀhMäÉËkšëÏŽÁ‰ÍXDÓLR1@”sA³)9Æ•1—üÀ‡x‰\0,CE”ƒ± ¹ Sô‹VqÖŽâVÄàRš\0ÊL³ö¢˜ê¾Â_K†ÙBPnl œÝmÊ?™ÜV£<¡rÎŽÀøs–(Z´ìÐÏA“Mœàà€¶Ùèl¾óñžÂÜwkøŲsÖkŒ>¦ï€w<”–X[vFÙýd!½˜.PÝ¢ždåd!—~a„-²@’¦&0ä¾8- Ò£4ЊŒÊ÷yŸ2|‰¢k@è2Ð’Ð愯\"„_Ú&ˆö·Ìrnè¯B¶ìQvÛÔôŽe§›#u:eŠ (ØFÚ- SŸ\$p—Xº5»6‡ŸÛ¢'!â¦C·ÑZ#t[eShÀ[V{ј®âM]éWFêüE¦Žƒ Tý¢ù–ÇFåú´ëu,³in^éFª5Ò Ý:éAQÉ+õ®ÑÑ£ËíP¡å¶=îèä=‡º4‘¨Dl#iðT./6Bg¥@ç›iзg³Ó”ÄÛ\\ikR“Å µFÃ…43%Çh³Åè\nc|ï´Kè‰'2ˆñ¡\$GLéSDZ’ùºb.•ZO§wÔ·Q©„F•Ki–á*–Û‡xû·ö4Cu­ •áÂà{Õ£ŽNƒUó°‘â9â¤:ܵ%F×?\$ ©öýl-úùX4zÝs˜•Xø³ê®Êú®šTÿõet„Hå·Z#SrÜRôÔjG+…3sø õÖ‘\rw„jµŽ¬åX\\î„Ž`)7H€’à\" \0\"ÞÄÒÊHdp\0ðÕ²\$\r][Xl (hÙY–ßRî°¤ÓA²%Ó6ÂRO£6ÚCGv+ÔM´ç¤\r—„³HŽ¨¨–v›n,³Q·RÉÓö¦€w²f\nlËJ!oI˜_œæi겺®@jÄkèÞ¾E†ûD´¤qu´BÅ\"Ð.<9ᴏµ€ê_j£H¡jò×Pw\$VvþI”õˆ‰´H±¤úÕ5j6ٵݛYE ´áA3˜bq3ØÙ¶& ÁF¤ ¤J{½û#Ø(ü/Kp&w8çŒ\n‹ÆŒµÞv”“ubÒÝm#mübz±&_ZÔ÷:³FR±#U¾–l)w…W`N&\r\0w(%]Êo™(Íî‰è¹çÆzw6QiË@\n P @¨P<È2U)ä€æªmã!hèFù;Ã`Ï'*åIÙ³üýúˆ ÎYK“°¦´4‹“`@;G\n„\nT&˜èèÃÙB Ç£Àag„ˆ 9úbƒ`˜Ï[)o´u@aß…×Æ!±'…¨\\†é |ÿ×* ‡ Và@ c´ñÕ;\næ}ÏáyÃ\0006©7±¾Mº^ÅÉ\"Œš¨†4T©M±í~\nMÅ6³8M€ûFÜ)³Oe£Óê*ü¦]Áˆ —ë„“†^aU\n5e\r§Åò™Š‚¯S«@\r\nÜŸì}\0)b°1:Íð‚žÃHCˆ!Önã¨í8ïIJóqëà:ãûôÒÁÁd³×‡\nÙ¤ÊШ…±†d|ãA¯#^p/ ,×Xiu1µhñàÅ)'7Jm9\r”𤜐zû¨†S|äÑø¼ªO\$¹*õ¾U\0÷•@1Ðê‡ÉV3†Ggw]º{'S’aË!”ü³ä/GV¤U>ÿ•£{sgyTÞX…·–¯uå6[Ë/®hó;—üU IÂSÌ16¦Ü“\\Èzï3†.qFψ\"*•ÎV5£ß–”’¸¯(¸ÁÉ|‹å,ÝäÝ29;•ä‚ ,\r€\$ÔО¸áZFzòAGÜýäLù¤^EpÅTLõ}ÿDù»Ñw×`ã†<¡è­ä p^Ró“gëïèã;9bŒýpc&œå抹ÓÌnuݤt/÷zð¹D\$ …(ø=1„\09âÞ™òá\n‡WB \nùvVî_\0ï©9&Q÷O^ÁÊþ¡ {£Pæ<ÀéÏ©íÒܸ\"jµÚysÊ®xõ“›ÝUè˜ ú£8epk}ép+ðÔm;¡óõ“„“þž•\0KqÇnµh[æPìÃóp.pH¼7QR»F˜ð¼uAnë' zú¯ÇÌÊôD\"ãè¶\0+z±€¬E‚z \nù§DÈ*vvJÁ÷è\n”ØøĤ\0¿µïŒÑ»»MÓá0”öé½ãô·(ýÚîØvǶzR3Ð@œ”ãø¹=1\\k«äëy¡1UuÉÒ¨´ª þ]LCºàfÔ–@{Gü¯€¬ºD)†Tþé\0´a€b€§x€X5mÔ[X³{=£ÌÐ8\$Zw\"ßX²±gÁÔ@Üß1SÅ‘>Yçc ý_J@JØ^@÷ <Z¯éxD• Ði-‹>ý0\"¯NCQºV’>ú3Ú¡óïÃ*±f)lY¹ýD¨ÜÅæŽêwTotƒÞA±gŸÆxH \"¡°Ò°d75Å\$Ô!²;\$\$Q\n ;6¬_§~:×Ã5OfÈpàlé\nüv5\0´!b (ÐäýþùúR_˜GD4â€È^)ó3ýÕ€ö×·ø§©\\*G”H[›06!Lè~V g7Àéå¯ywÍœ ÍX¼¾¿d0¡e ~dVEójø\0¹íÈw9‡úé!Tœø„ˆ%ÖðÇ~ÉgZ“t»!//Úºä'!V)‘—ÓC!ð‚þJnC§µ÷ÇÒ½øÐ%ükäÓxœP[ÕÏìauÂÐ");}elseif($_GET["file"]=="jush.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  13. lzw_decompress("v0œF£©ÌÐ==˜ÎFS ÐÊ_6MƳ˜èèr:™E‡CI´Êo:C„”Xc‚\ræØ„J(:=ŸE†¦a28¡xð¸?Ä'ƒi°SANN‘ùðxs…NBáÌVl0›ŒçS œËUl(D|Ò„çÊP¦À>šE†ã©¶yH chäÂ-3Eb“å ¸b½ßpEÁpÿ9.Š˜Ì~\nŽ?Kb±iw|È`Ç÷d.¼x8EN¦ã!”Í2™‡3©ˆá\r‡ÑYŽÌèy6GFmYŽ8o7\n\r³0¤÷\0DbcÓ!¾Q7Шd8‹Áì~‘¬N)ùEг`ôNsßð`ÆS)ÐOé— ·ç/º<xÆ9Žo»ÔåµÁì3n«®2»!r¼:;ã+Â9ˆCȨ®‰Ã\n<ñ`Èó¯bè\\š?`†4\r#`È<¯Be ãB#¤N Üã\r.D`¬«jê4ÿŽŽpéar°ø 㢺÷>ò8Ó\$Éc ¾1Écœ ¡c êÝê{n7ÀáƒAðNÊRLi\r1À¾ø!£(æ j´®+Âê62ÀXÊ8+Êâàä.\rÍÎôƒÎ!x¼åƒhù' ãâˆ6Sð\0RïÔôñOÒ\n¼…1(W0…ãœÇ7qœë:NÃE:68n+ŽäÕ´5_(®s \rã”ê‰ /m6PÔ@ÃEQàÄ9\n¨V-‹Áó\"¦.:åJÏ8weÎq½|؇³XÐ]µÝY XÁeåzWâü Ž7âûZ1íhQfÙãu£jÑ4Z{p\\AUËJ<õ†káÁ@¼ÉÃà@„}&„ˆL7 U°wuYhÔ2¸È@ûu  Pà7ËA†hèÌò°Þ3 ÛêçXEÍ…Zˆ]­lá@MplvÂ)æ ÁÁHW‘‘Ôy>Y-øYŸè/«›ªÁî hC [*‹ûFã­#~†!Ð`ô\r#0PïC˝—f ·¶ ¡îÃ\\‡É^Ã%B<\\½fˆÞ±ÅáÐÝã&/¦O‚ðL\\jF¨jZ£1«\\:Æ´>N¹¯XaFÃAÀ³²ðÃØÍf…h{\"s\n×64‡ÜøÒ…¼?Ä8Ü^p\"띰ñȸ\\Úe(¸PƒNµìq[g¸Árÿ&Â}PhÊà¡ÀWÙí*Þír_sËP‡hà¼àÐ\nÛËÃomõ¿¥Ãê—Ó#§¡.Á\0@épdW ² \$Òº°QÛ½Tl0† ¾ÃHdHë)š‡ۏÙ À)PÓÜØHgàýUþ„ªBèe\r†t:‡Õ\0)\"Åtô,´œ’ÛÇ[(DøO\nR8!†Æ¬ÖšðÜlAüV…¨4 hà£Sq<žà@}ÃëÊgK±]®àè]â=90°'€åâøwA<‚ƒÐÑaÁ~€òWšæƒD|A´††2ÓXÙU2àéyÅŠŠ=¡p)«\0P ˜s€µn…3îr„f\0¢F…·ºvÒÌG ®ÁI@é%¤”Ÿ+Àö_I`¶ ÌôÅ\r.ƒ N²ºËKI…[”Ê–SJò©¾aUf›Szûƒ«M§ô„ %¬·\"Q|9€¨Bc§aÁq\0©8Ÿ#Ò<a„³:z1Ufª·>îZ¹l‰‰¹ÓÀe5#U@iUG‚™©n¨%Ò°s¦„Ë;gxL´pPš?BçŒÊQ\\—b „ÿé¾’Q„=7:¸¯Ý¡Qº\r:ƒtì¥:y(Å ×\nÛd)¹ÐÒ\nÁX; ‹ìŽêCaA¬\ráÝñŸP¨GHù!¡ ¢@È9\n\nAl~H úªV\nsªÉÕ«Æ¯ÕbBr£ªö„’­²ßû3ƒ\ržP¿% ¢Ñ„\r}b/‰Î‘\$“5§PëCä\"wÌB_çŽÉUÕgAtë¤ô…夅é^QÄåUÉÄÖj™Áí Bvhì¡„4‡)¹ã +ª)<–j^<Lóà4U* õBg ëÐæè*nÊ–è-ÿÜõÓ 9 O\$´‰Ø·zyM™3„\\9Üè˜.oŠ¶šÌë¸E(iåàž œÄÓ7 tßšé-&¢\nj!\rÀyœyàD1gðÒö]«ÜyRÔ7\"ð槷ƒˆ~ÀíàÜ)TZ0E9MåYZt Xe!Ýf†@ç{Ȭyl 8‡;¦ƒR{„ë8‡Ä®ÁeØ+ULñ'‚F²1ýøæ8PE5- Ð_!Ô7…ó [2‰JËÁ;‡HR²éǹ€8p痲݇@™£0,Õ®psK0\r¿4”¢\$sJ¾Ã4ÉDZ©ÕI¢™'\$cL”R–MpY&ü½Íiçz3GÍzÒšJ%ÁÌPÜ-„[É/xç³T¾{p¶§z‹CÖvµ¥Ó:ƒV'\\–’KJa¨ÃMƒ&º°£Ó¾\"à²eo^Q+h^âÐiTð1ªORäl«,5[ݘ\$¹·)¬ôjLƁU`£SË`Z ^ð|€‡r½=Ð÷nç™»–˜TU 1Hyk›Çt+\0váD¿\r <œàÆ™ìñjG”ž­tÆ*3%k›Y ܲT*Ý|\"CŠülhE§(È\rÃ8r‡×{Üñ0å²×þÙDÜ_Œ‡.6иè;ãü‡„rBjƒO'Ûœ¥¥Ï>\$¤Ô`^6™Ì9‘#¸¨§æ4Xþ¥mh8:êûc‹þ0ø×;Ø/Ô‰·¿¹Ø;ä\\'( î„tú'+ ™òý¯Ì·°^ ]­±NÑv¹ç#Ç,ëvð×ÃOÏiÏ–©>·Þ<SïA\\€\\îµü!Ø3*tl`÷u\0p'è7…Pà9·bsœ{Àv®{·ü7ˆ\"{ÛÆrîaÖ(¿^æ¼ÝE÷úÿë¹gÒÜ/¡øžUÄ9g¶î÷/ÈÔ`Ä\nL\n)À†‚(Aúað\" žçØ Á&„PøÂ@O\n師0†(M&©FJ'Ú! …0Š<ïHëîÂçÆù¥*Ì|ìÆ*çOZím*n/bî/ö®Ô ˆ¹.ìâ©o\0ÎÊdnÎ)ùŽi:RŽÎëP2êmµ\0/vìOX÷ðøFʳψîŒè®\"ñ®êöî¸÷0õ0ö‚¬©í0bËÐgjðð\$ñné0}° î@ø =MÆ‚ 0nîPŸ/pæotì€÷°¨ð.Ì̽ g\0Ð)o—\n0È÷‰\rF¶é € b¾i¶Ão}\n°̯… NQ °' ðxòFaÐJîÎôLõéðÐàÆ\rÀÍ\r€Öö‘0Åñ' ð¬Éd oepÝ°4DÐÜʐ¦q(~ÀÌ ê\r‚E°ÛprùQVFHœl£‚Kj¦¿äN&­j!ÍH`‚_bh\r1Ž  º n!ÍÉŽ­ z™°¡ð¥ Í\\«¬\rŠíŠÃ`V_kÚÃ\"\\ׂ'Vˆ«\0ʾ`ACúÀ±Ï…¦VÆ`\r%¢’ÂÅì¦\rñ⃂k@NÀ°üBñíš™¯ ·!È\n’\0Z™ 6°\$d Œ,%à%laíH×\n‹#¢S\$ !\$@¶Ý2±„I\$r€{!±°J‡2HàZM\\ÉÇhb,‡ '||cj~gÐr…`¼Ä¼º\$ºÄ +êA1ðœE€ÇÀÙ <ÊL¨Ñ\$âY%-FDªŠd€L焳 ª\n@’bVfè¾;2_(ëôLÄп ²<%@Úœ,\"êdÄÀN‚erô\0æƒ`ĤZ €¾4Å'ld9-ò#`äóÅ–…à¶Öãj6ëÆ£ãv ¶àNÕ͐f Ö@܆“&’B\$ å¶ (ðZ&„ßó278I à¿àP\rk\\§—2`¶\rdLb@Eöƒ2`P( B'ã €¶€º0²& ô{•“§:®ªdBå1ò^؉*\r\0c<K|Ý5sZ¾`ºÀÀO3ê5=@å5ÀC>@ÂW* =\0N<g¿6s67Sm7u? {<&LÂ.3~DÄê\rÅš ¯x¹í),rîinÅ/ åO\0o{0kÎ]3>m‹”1\0”I@Ô9T34+Ô™@e”GFMCÉ\rE3ËEtm!Û#1ÁD @‚H(‘Ón ÃÆ<g,V`R]@úÂÇÉ3Cr7s~ÅGIói@\0vÂÓ5\rVß'¬ ¤  Î£PÀÔ\râ\$<bÐ%(‡Ddƒ‹PWÄîÐÌbØ fO æx\0è} Ü â”lb &‰vj4µLS¼¨Ö´Ô¶5&dsF Mó4ÌÓ\".HËM0ó1uL³\"ÂÂ/J`ò{Çþ§€ÊxǐYu*\"U.I53Q­3Qô»J„”g ’5…sàúŽ&jÑŒ’Õu‚٭ЪGQ MTmGBƒt l-cù*±þ\rŠ«Z7Ôõó*hs/RUV·ðôªBŸNˈ¸ÃóãêÔŠài¨Lk÷.©´Ätì é¾©…rYi”Õé-Sµƒ3Í\\šTëOM^­G>‘ZQjÔ‡™\"¤Ž¬i”ÖMsSãS\$Ib f²âÑu榴™å:êSB|i¢ Y¦ƒà8 vÊ#é”Dª4`‡†.€Ë^óHÅM‰_Õ¼ŠuÀ™UÊz`ZJ eçºÝ@Ceíëa‰\"mób„6Ô¯JRÂÖ ‘T?Ô£XMZÜÍІÍòpèÒ¶ªQv¯jÿjV¶{¶¼ÅCœ\rµÕ7‰TÊžª úí5{Pö¿]’\rÓ?QàAAÀ莋’Í2ñ¾ “V)Ji£Ü-N 99f–l JmÍò;u¨@‚<FþÑ ¾e†j €ÒĦI‰<+CW@ðçÀ¿Z‘lÑ1É<2ÅiFý7`KG˜~L&+NàYtWH飑w Ö•ƒòl€Òs'gÉãq+Lézbiz«ÆÊÅ¢Ð.ЊÇzW²Ç ùzd•W¦Û÷¹(y)vÝE4,\0Ô \"d¢¤\$Bã{²Ž!)1U†5b p#Å}m=×È@ˆwÄ P\0ä\rì ¢·‘€`O|ëÆö œÉüÅõûYôæJÕ‚öE×ÙOuž_§\n`F`È}MÂ.#1Ⴌfì*´Õ¡µ§ ¿zàucû€—³ xfÓ8kZR¯s2Ê‚-†’§Z2­+ŽÊ·¯(åsUõcDòÑ·Ê ì˜ÝX!àÍuø&-vPÐر\0'LïŒX øLùŒˆo Ý ô>¸ÕŽÓ\r@ÙPõ\rxF×üE€ÌÈ­ ï%À ãì®ü=5NÖœƒ¸?„7ùNËÃ…©wŠ`ØhX«98 ́ø¯q¬£zãÏd%6Ì‚tÍ/…•˜ä ¬ëLúÍl¾Ê,ÜKa•N~Ï ÀÛìú ,ÿ'íÇ€M\rf9£w˜!x÷x[ˆÏ‘ØG’8;„xA˜ù-IÌ&5\$–D\$ö¼³%…ØxѬÁ”È´À Œ]›¤õ‡&o‰-39ÖLù½zü§y6 ¹;u¹zZ èÑ8ÿ_•Éx\0D?šX7†™«’y±OY.#3Ÿ8 ™Ç€˜e”Q¨=Ø€*˜™GŒwm ³Ú„Y‘ù  ÀÚ]YOY¨F¨íšÙ)„z#\$eŠš)†/Œz?£z;™—Ù¬^ÛúFÒZg¤ù• Ì÷¥™§ƒš`^Úe¡­¦º#§“Øñ” ©Žú?œ¸e£€M£Ú3uÌ偃0¹>Ê\"?Ÿö@×—Xv•\"甌¹¬¦*Ô¢\r6v~‡ÃOV~&ר^gü šÄ‘Ùž‡'΀f6:-Z~ ¹šO6;zx²;&!Û+{9M³Ù³d¬ \r,9Öí°ä·W ÆÝ­:ê\rúÙœùã@睂+¢·]œÌ-ž[gž™Û‡[s¶[ižÙiÈq››y›éxé+“|7Í{7Ë|w³}„¢›£E– ûW°€Wk¸|J؁¶å‰xmˆ¸q xwyjŸ»˜#³˜e¼ø(²©‰¸Àßžþ™†ò³ {èßڏ y“ »M»¸´@«æÉ‚“°Y(gÍš-ÿ©º©äí¡š¡ØJ(¥ü@ó… ;…yÂ#S¼‡µY„Èp@Ï%èsžúoŸ9;°ê¿ôõ¤¹+¯Ú ¥;«ÁúˆZNٯº§„š k¼V§·u‰[ñ¼x…|q’¤ON?€ÉÕ …`uœ¡6|­|X ¹¤­—س|Oìx!ë:¨œÏ—Y]–¬¹Ž™c•¬À\r¹hÍ9nÎ Á¬¬ë€Ï8'—ù‚ê à Æ\rS.1¿¢USȸ…¼X‰É+ËÉz]ɵʤ?œ©ÊÀCË\r×Ë\\ º­¹ø\$Ï`ùÌ)UÌ|ˤ|Ѩx'ÕœØÌäÊ<àÌ™eÎ|êÍ³ç— â’Ìé—LïÏÝMÎy€(Û§ÐlÐº¤O]{Ѿ×FD®ÕÙ}¡yu‹ÑÄ’ß,XL\\ÆxÆÈ;U×ÉWt€vŸÄ\\OxWJ9È’×R5·WiMi[‡Kˆ€f(\0æ¾dÄšÒè¿©´\rìMÄáÈÙ7¿;ÈÃÆóÒñçÓ6‰KʦIª\rÄÜÃxv\r²V3ÕÛßɱ.ÌàRùÂþɍá|Ÿá¾^2‰^0ß¾\$ QÍä[ã¿D÷áÜ£å>1'^X ~t1\"6Lþ›+þ¾Aàžeá“æÞåI‘ç~Ÿåâ³â³@ßÕ­õ pM>Óm<´ÒSKÊç-HÉÀ¼T76ÙSMfg¨=»ÅGPÊ°›PÖ\r¸é>Íö¾¡¥2Sb\$•C[Ø×ï(Ä)žÞ%Q#G`uð°ÇGwp\rkÞKe—zhjÓ“zi(ôèrO«óÄÞÓþØT=·7³òî~ ÿ4\"ef›~ íd™ôíVÿZ‰š÷U•-ëb'VµJ¹Z7ÛöÂ)T‘£8.<¿RMÿ\$‰žôÛØ'ßbyï\n5øƒÝõ_Ž àwñΰíUð’`eiÞ¿J”b©gðuSÍë?Íå`öážì+¾Ïï Mïgè7`ùïí\0¢_Ô-ûŸõ _÷–?õF°\0“õ¸X‚å´’[²¯Jœ8&~D#Áö{P•Øô4Ü—½ù\"›\0ÌÀ€‹ý§ý@Ò“–¥\0F ?* ^ñå¯wëО:ð¾uàÏ3xKÍ^ów“¼¨ß¯‰y[Ôž(žæ–µ#¦/zr_”g·æ?¾\0?€1wMR&M¿†ù?¬St€T]Ý´Gõ:I·à¢÷ˆ)‡©B vô§’½1ç<ôtÈâ6½:W{ÀŠôx:=ÈŒÞšóø:Â!!\0x›Õ˜£÷q&áè0}z\"]ÄÞo•z¥™ÒjÃw×ßÊÚÁ6¸ÒJ¢PÛž[\\ }ûª`S™\0à¤qHMë/7B’€P°ÂÄ]FTã•8S5± /IÑ\rŒ\n îO¯0aQ\n >Ã2­j…;=Ú¬ÛdA=­p£VL)Xõ\n¦`e\$˜TƦQJÍó®ælJïŠÔîÑy„IÞ ä:ƒÑ ÄÄBùbPÀ†ûZ͸n«ª°ÕU;>_Ñ\n ¾õëÐÌ `–ÔuMòŒ‚‚Â֍m³ÕóÂLwúB\0\\b8¢Mܐ[z‘&©1ý\0ô ¡\r˜TÖ×› €+\\»3ÀPlb4-)%Wd#\nÈår ÞåMX\"Ï¡ä(Ei11(b`@fÒ´­ƒSÒóˆjåD†bf£}€rムýD‘R1…´bÓ˜AÛïIy\"µWvàÁgC¸IÄJ8z\"P\\i¥\\m~ZR¹¢vî1ZB5IŠÃi@x”†·°-‰uM\njKÕU°h\$o—ˆJϤ!ÈL\"#p7\0´ P€\0ŠD÷\$  GK4eÔÐ\$\nGä?ù3£EAJ F4àIp\0«×FŽ4±²<f@ž %q¸<kãw€ àLOp\0‰xÓÇ( €G>ð@¡ØçÆÆ9\0TÀˆ˜ìGB7 - €žøâG:<Q™ #èÓÇ´û1Ï&tz£á0*J=à'‹J>ØßÇ8q¡Ð¥ªà €OÀ¢XôF´àQ,ÀÊÐ\"9‘®pä*ð6 6A'ý,y€IF€Rˆ³TˆÏý\"”÷HÀR‚!´j#kyFÀ™àe‘¬z£ëéÈðG\0Žp£‰aJ` C÷iù@œT÷|\n€Ix£K\"­´*¨Tk\$c³òÆ”aAh€“! \"úE\0OdÄSxò \0T ö\0‚žà!FÜ\n’U“|™#S& IvL\"”“…ä\$hÐÈÞEAïN\$—%%ù/\nP†1š“²{¤ï) <‡ð L å-R1¤â6‘¶’<@O*\0J@q¹‘Ôª#É@ǵ0\$tƒ|’]ã`»¡ÄŠA]èÍìPá‘€˜CÀp\\pÒ¤\0™ÒÅ7°ÄÖ@9©bmˆr¶oÛC+Ù]¥JrÔfü¶\rì)d¤ ’Ñœ­^hßI\\Î. g–Ê>¥Í×8ŒÞÀ'–HÀf™rJÒ[rço㥯.¹v„½ï#„#yR·+©yËÖ^òù›†F\0᱁™]!É•ÒÞ”++Ù_Ë,©\0<@€M-¤2WòâÙR ,c•Œœe2Ä*@\0êP €Âc°a0Ç\\PÁŠˆO  ø`I_2Qs\$´w£¿=:Îz\0)Ì` Ì hŠÂ–Áƒˆç¢\nJ@@Ê«–\0šø 6qT¯å‡4J%•N-ºm¤Äåã.É‹%*cnäËNç6\"\rÍ‘¸òè—ûŠfÒAµÁ„ põM Û€I7\0™MÈ>lO›4ÅS 7™cÍì €\"ìߧ\0å“6îps…–ÄÝåy.´ã ò¦ñRKð•PAo1FÂtIÄb*ÉÁ<‡©ý@¾7ÐË‚p,ï0NÅ÷: ¨N²m ,xO%è!‚Úv³¨˜ gz(ÐM´óÀIÃà à~yËö›h\0U:éØOZyA8<2§²ð¸ÊusÞ~lòÆÎEð˜O”0±Ÿ0]'…>¡ÝɍŒ:ÜêÅ;°/€ÂwÒôäì'~3GΖ~Ó­äþ§c. þ„òvT\0cØt'Ó;P²\$À\$ ø€‚Ð-‚s³òe|º!•@dÐObwÓæc¢õ'Ó@`P\"xô µèÀ0O™5´/|ãU{:b©R\"û0…шk˜Ðâ`BD\nk€Pãc©á4ä^ p6S`Ü\$ëf;Î7µ?lsÅÀ߆gDÊ'4Xja A‡…E%™ 86b¡:qr \r±]C8ÊcÀF\n'ÑŒf_9Ã%(¦š*”~ŠãiSèÛ É@(85 T”Ë[þ†Jڍ4I…l=°ŽQÜ\$dÀ®hä@D -Ù!ü_]ÉÚH–ÆŠ”k6:·Úò\\M-ÌØðò£\r‘FJ>\n.‘ ”qeGú5QZ´†‹' É¢ž½ہ0ŸîzP–à#ŤøöÖéràÒít½’ÒÏËŽþŠ<QˆT¸£3D\\¹„ÄÓpOE¦%)77–Wt[ºô@¼›Žš\$F)½5qG0«-ÑW´v¢`è°*)RrÕ¨=9qE*K\$g ‚íA!åPjBT:—Kû§!×÷H“ R0?„6¤yA)B@:Q„8B+J5U]`„Ò¬€:£ðå*%Ip9ŒÌ€ÿ` KcQúQ.B”±Ltbª–yJñEê›Té¥õ7•ÎöAmÓ䢕Ku:ŽðSji— 5.q%LiFºšTr¦Ài©ÕKˆÒ¨z—55T%U•‰UÚIÕ‚¦µÕY\"\nSÕm†ÑÄx¨½Ch÷NZ¶UZ”Ä( Bêô\$YËV²ã€u@è”»’¯ ¢ª| ‚\$\0ÿ\0 oZw2Ò€x2‘ûk\$Á*I6IÒn• •¡ƒI,€ÆQU4ü\n„¢). øQôÖaIá]™À èLâh\"øf¢ÓŠ>˜:Z¥>L¡`n˜Ø¶Õì7”VLZu”…e¨ëXú膺B¿¬¥B‰º’¡Z`;®ø•J‡]òÑ€žäS8¼«f \nÚ¶ˆ#\$ùjM(¹‘Þ¡”„¬a­Gí§Ì+Aý!èxL/\0) Cö\nñW@é4€º áÛ©• ŠÔRZƒ®â =˜Çî8“`²8~â†hÀìP °\r– °žìD-FyX°+Êf°QSj+Xó|•È9-’øs¬xØü†ê+‰VÉcbpì¿”o6HÐq °³ªÈ@.€˜l 8g½YMŸÖWMPÀªU¡·YLß3PaèH2Ð9©„:¶a²` ¬Æd\0à&ê²YìÞY0Ù˜¡¶SŒ-—’%;/‡TÝBS³PÔ%fØÚý• @ßFí¬(´Ö*Ñq +[ƒZ:ÒQY\0Þ´ëJUYÖ“/ý¦†pkzȈò€,´ðª‡ƒjÚꀥW°×´e©JµFèýVBIµ\r£ÆpF›NÙ‚Ö¶™*Õ¨Í3kÚ0§D€{™Ôø`q™•Ò²Bqµe¥D‰ cÚÚÔVÃE©‚¬nñ×äFG E›>jîèÐú0g´a|¡Shì7uÂÝ„\$•†ì;aô—7&¡ë°R[WX„ÊØ(qÖ#Œ¬P¹Æä×–Ýc8!°H¸àØVX§ÄŽ­jøÊZŽô‘¡¥°Q,DUaQ±X0‘ÕÕ¨ÀÝËGbÁÜlŠBŠt9-oZü”L÷£¥Â­åpˇ‘x6&¯¯MyÔÏsҐ¿–èð\"ÕÍ€èR‚IWU`c÷°à}l<|Â~Äw\"·ðvI%r+‹Rà¶\n\\ØùÃÑ][‹Ñ6&Á¸ÝÈ­Ãa”ÓºìÅj¹(Ú“ðTÑ“À·C'Š…´ '%de,È\n–FCÅэe9C¹NäЍ‚-6”UeȵŒýCX¶ÐV±ƒ¹ýÜ+ÔR+ºØ”Ë•3B܁ڌJð¢è™œ±æT2 ]ì\0PèaÇt29Ï×(i‹#€aÆ®1\"S…:ö· ˆÖoF)kÙ fôòÄЪ\0ÎÓ¿þÕ,ËÕwêƒJ@ìÖVò„Žµéq.e}KmZúÛïå¹XnZ{G-»÷ÕZQº¯Ç}‘Å׶û6ɸðµÄ_žØÕ‰à\nÖ@7ß` ÕC\0]_ ©Êµù¬«ï»}ûGÁWW: fCYk+éÚbÛ¶·¦µ2S, Ú‹Þ9™\0﯁+þWÄZ!¯eþ°2ûôà›—í²k.OcƒÖ(vÌ®8œDeG`ۇŒöL±õ“,ƒdË\"CÊÈÖB-”Ä°(þ„ „„p÷íÓp±=àÙü¶!ýk’ØÒļï}(ýÑÊB–kr_Rî—ܼ0Œ8a%Û˜L \0é†Àñ‰b¥²šñÅþ@×\"ÑÏr,µ0TÛrV>ˆ…ÚÈQŸÐ\"•rÞ÷P‰&3báP²æ- x‚Ò±uW~\"ÿ*舞ŒNâh—%7²µþK¡Y€€^A÷®úÊC‚èþ»p£áîˆ\0ð ..`cÅæ+ÏŠâGJ£¤¸H¿À®E‚…¤¾l@|I#AcâÿD…|+<[c2Ü+*WS<ˆràãg¸ÛÅ}‰Š>iÝ€!`f8ñ€(c¦èÉQý=fñ\nç2Ñc£h4–+q8\na·RãBÜ|°R“×ê¿Ým µŠ\\qÚõgXÀ –ÏŽ0äXä«`nîF€îìŒO pÈîHòCƒ”jd¡fµßEuDV˜bJɦ¿å:±ï€\\¤!mɱ?,TIa˜†ØaT.L€]“,JŒ?™?Ï”FMct!aÙ§RêF„Gð!¹Aõ“»rrŒ-pŽXŸ·\r»òC^À7áð&ãRé\0ÎÑf² *àA\nõÕ›Háã¤yîY=Çúè…l€<‡¹AÄ_¹è +‘ÎtAú\0B•<Ay…(fy‹1Îc§O;p èÅᦝ`ç’4СMìà*œîf†ê 5fvy {?©àË:yøÑ^câÍuœ'‡™€8\0±¼Ó±?«ŠgšÓ‡ 8BÎ&p9ÖO\"zÇõžrs–0ºæB‘!uÍ3™f{×\0£:Á\n@\0ÜÀ£pÙÆ6þv.;àú©„Êb«Æ«:J>Ë‚‰é-ÃBÏhkR`-ÜñÎðawæxEj©…÷Árž8¸\0\\Áïô€\\¸Uhm› ý(mÕH3Ì´í§S™“Áæq\0ùŸNVh³Hy —»5ãMÍŽe\\g½\nçIP:Sj¦Û¡Ù¶è<Ž¯Ñxó&ŒLÚ¿;nfͶcóq›¦\$fð&lïÍþi³…œàç0%yΞ¾tì/¹÷gU̳¬dï\0e:ÃÌhïZ Ð^ƒ@ç ý1€Ïm#ÑNów@ŒßOððzGÎ\$ò¨¦m6é6}ÙÒÒ‹šX'¥I×i\\QºY€¸4k-.è:yzÑÈÝH¿¦] ææxåGÏÖ3ü¿M\0€£@z7¢„³6¦-DO34Þ‹\0ΚÄùΰ t\"Î\"vC\"JfÏRÊžÔúku3™MÎæ~ú¤ÓŽ5V à„j/3úƒÓ@gG›}D龺BÓNq´Ù=]\$é¿I‡õÓž”3¨x=_j‹XÙ¨fk(C]^jÙMÁÍF«ÕÕ¡ŒàÏ£CzÈÒVœÁ=]&ž\r´A< æµÂÀÜãç6ÙÔ®¶×´Ý`jk7:gÍî‘4Õ®áë“YZqÖftu|hÈZÒÒ6µ­i〰0 ?éõ骭{-7_:°×ސtѯíck‹`YÍØ&“´éIõlP `:íô j­{hì=Ðf à Ã[byž¢Ê€oЋB°RS—€¼B6°À^@'4æø1UÛDq}ìÃNÚ(Xô6j}¬cà{@8 ãòð,À ÏPFCàð‰Bà\$m v˜¨Pæ\"ºÛLöÕCS³]›ÝàEÙÞÏlU†Ñfíwh{o(—ä)è\0@*a1GÄ ( D4-cØóP8£N|R›†âVM¸°×n8G`e}„!}¥€Çp»‡Üòý@_¸ÍÑnCtÂ9ŽÑ\0]»u±î¯s»ŠÝ~èr§»#Cn p;·%‹>wu¸ÞnÃwû¤Ýžê.âà[ÇÝhT÷{¸Ý值 ç¨Ë‡·JðÔÆ—iJÊ6æ€O¾=¡€‡ûæßE”÷Ù´‘ImÛïÚV'É¿@â&‚{ª‘›òö¯µ;íop;^–Ø6Ŷ@2ç¯lûÔÞNï·ºMÉ¿r€_Ü°ËÍ´` ì( yß6ç7‘¹ýëîÇ‚“7/Ápðe>|ßà ø=½]Ðocû‘á&åxNm£‰çƒ»¬ào ·GÃN p—‚»˜x¨•Ã½Ýðƒy\\3àø‡Â€'ÖI`râG÷]ľñ7ˆ\\7Ú49¡]Å^p‡{<Zá·¸q4™uÎ|ÕÛQÛ™àõp™ýši\$¶@oxñ_<Àæ9p BU\"\0005— iäׂ»¸Cûp´\nôi@‚[ãœÆ4¼jЁ„6bæP„\0Ÿ&F2~ŽÀù£¼ïU&š}¾½¿É˜ ™ÌDa<€æzx¶k£ˆ‹=ùñ°r3éË(l_”…FeF›ž4ä1“K \\ÓŽldî ä1H\r½€ùp!†%bGæXfÌÀ'\0ÈœØ '6Àžps_›á\$?0\0’~p(H\n€1…W:9ÕÍ¢¯˜`‹æ:hÇB–èg›BŠk©ÆpÄƁót¼ìˆEBI@<ò%øÀù` êŠyd\\Y@D–P?Š|+!„áWÀø.:ŸLe€v,Ð>qóAÈçº:ž–îbYéˆ@8Ÿd>r/)ÂBç4ÀÐÎ(·Š`|é¸:t±!«‹Á¨?<¯@ø«’/¥ S’¯P\0Âà>\\æâ |é3ï:VÑuw¥ëçx°(®²Ÿœ4€ÇZjD^´¥¦Lý'¼ìÄC[×'ú°§®éjº[ E¸ó uã°{KZ[s„ž€6ˆ‚S1Ìz%1õc™£B4ˆB\n3M`0§;çòÌÂ3Ð.”&?¡ê!YAÀI,)ðå•l†W['ÆÊI‡Tjƒè>F©¼÷S§‡ BбPá»caþÇŒuï¢NÝÏÀøHÔ LSôî0”ÕY`ÂÆÈ\"il‘\rçB²ëã/Œôãø%P€ÏÝN”Gô 0JÆX\n?aë!Ï3@MæF&óÖþ¿,°\"î€èlbô:KJ\rï`k_êb÷üAáÙįÌü1Ñ I,ÅÝîüˆ;B,×:ó¾ìY%¼J ŽŠ#v”€'†{ßÑÀã „ž wx:\ni°¶³’} cÀ°eN®Ñï`!wÆ\0ÄBRU#ØSý!à<`–&v¬<¾&íqOÒ+Σ¥sfL9QÒBʇ„ÉóäbÓà_+ï«*€Su>%0€Ž™©…8@l±?’L1po.ÄC&½íÉ BÀÊqh˜¦ó­’Ážz\0±`1á_ 9ð\"–€è!\$øŒ¶~~-±.¼*3r?øòÀd™s\0ÌõÈ>z\nÈ\0Š0 1Ä~‘ô˜Jð³ðú”|SÞœô k7gé\0ŒúKÔ d¶ÙaÉîPgº%ãw“DôêzmÒûÈõ·)¿‘ñŠœj‹Û×Âÿ`k»ÒQà^ÃÎ1üŒº+Îåœ>/wbüGwOkÃÞÓ_Ù'ƒ¬-CJ¸å7&¨¢ºðEñ\0L\r>™!Ïq́îÒ7ÝÁ­õoŠ™`9O`ˆàƒ”ö+!}÷P~EåNÈc”öQŸ)ìá#ûï#åò‡€ì‡ÌÑøÀ‘¡¯èJñÄz_u{³ÛK%‘\0=óáOŽX«ß¶Cù>\n²€…|wá?ÆF€Åê„Õa–Ï©UÙåÖb N¥YïÉhŠ½»é‘/úû)ÞGÎŒ2ü™¢K|ã±y/Ÿ\0éä¿Z”{éßP÷YG¤;õ?Z}T!Þ0ŸÕ=mN¯«úÃfØ\"%4™aö\"!–ÞŸúºµ\0çõï©}»î[òçܾ³ëbU}»Ú•mõÖ2±• …ö/tþî‘%#.ÑØ–Äÿse€Bÿp&}[ËŸŽÇ7ã<aùKýïñ8æúP\0™ó¡g¼ò?šù,Ö\0ß߈r, >¿ŒýWÓþïù/Öþ[™qýk~®CÓ‹4ÛûGŠ¯:„€X÷˜Gúr\0ÉéŸâ¯÷ŸL%VFLUc¯Þä‘¢þŽHÿybP‚Ú'#ÿ× \0пýÏì¹`9Ø9¿~ïò—_¼¬0qä5K-ÙE0àbôÏ­üš¡Žœt`lmêíËÿbŒàƘ; ,=˜  'S‚.bÊçS„¾øCc—ƒêëʍAR,„ƒíÆXŠ@à'…œ8Z0„&ìXnc<<È£ð3\0(ü+*À3·@&\r¸+Ð@h, öò\$O’¸„\0Å’ƒèt+>¬¢‹œbª€Ê°€\r£><]#õ%ƒ;Nìsó®ÅŽ€¢Êð*»ïcû0-@®ªLì >½Yp#Ð-†f0îÃʱaª,>»Ü`ÆÅàPà:9ŒŒo·ð °ov¹R)e\0Ú¢\\²°Áµ\nr{îX™ÒøÎ:A*ÛÇ.Dõº7Ž»¼ò#,ûN¸\rŽE™Ô÷hQK2»Ý©¥½zÀ>P@°° ¦ T<ÒÊ=¡:òÀ °XÁGJ<°GAfõ &×A^pã`©ÀÐ{ûÔ0`¼:ûð€);U !Ðe\0Ïc†p\r‹³ ‹¾:(ø•@…%2 S¯\$Y«Ý3é¯hCÖì™:O˜#ÏÁLóï/šé‚ç¬k,†¯Kåoo7¥BD0{ƒ¡jó ìj &X2Ú«{¯}„RÏx¤ÂvÁä÷Ø£À9Aë¸ ¶¾ 0‰;0õá‘à-€5„ˆ/”<Üç° ¾NÜ8E¯‘—Ç +ãÐ…ÂPd¡‚;ªÃÀ*nŸ¼&²8/jX°\rš> PϐW>Kà•O’¢VÄ/”¬U\n<°¥\0Ù\nIk@Šº㦃[àÈϦ²œ#Ž?€Ùã%ñƒ‚èË.\0001\0ø¡kè`1T · ©„¾ë‚ɐl¼šÀ£îÅp®¢°Á¤³¬³…< .£>íØ5ŽÐ\0ä» O¬>k@Bn¾Š<\"i%•>œºzÄ– ç“ñá ºÇ3ÙPƒ! ð\rÀ\"¬ã¬\r ‰>šadàöó¢U?ÚÇ”3P×Áj3£ä°‘>; Óä¡ ¿>žt6Ë2ä[ÂðÞ¾M\r >°º\0äìP®‚·Bè«Oe*R n¬§œy;« 8\0ÈËÕoæ½0ýÓøiÂøþ3Ê€2@Êýà£î¯?xô[÷€ÛÃLÿaŽ¯ƒw\ns÷ˆ‡ŒA²¿x\r[Ñaª6Âclc=¶Ê¼X0§z/> +šª‰ øW[´o2ÂøŒ)eî2þHQPéDY“zG4#YD…ö…ºp) ºHúpŽ˜&â4*@†/:˜ á‰T˜ ­Ÿ¦aH5‘ƒëh.ƒA>œï`;.Ÿ­îY“Áa Âòút/ =3…°BnhD?(\n€!ÄBúsš\0ØÌDÑ&D“J‘)\0‡jÅQÄyŽhDh(ôK‘/!Ð>®h,=Ûõ±†ãtJ€+¡Sõ±,\"M¸Ä¿´NÑ1¿[;øТŠ¼+õ±#<ìŒI¤ZÄŸŒP‘)ÄáLJñDéìP1\$Äîõ¼Q‘>dO‘¼vé#˜/mh8881N:øZ0ZŠÁèT •BóCÇq3%°¤@¡\0Øï\"ñXD à3\0•!\\ì8#h¼vìibÏ‚T€!dª—ˆÎüV\\2óÀSëÅÅ’\nA+ͽpšxÈiD(ìº(à<* öÚ+ÅÕE·ÌT®¾ BèS·CÈ¿T ´æÙÄ e„Aï’\"á|©u¼v8ÄT\0002‘@8D^ooƒ‚ø÷‘|”Nù˜ô¥ÊJ8[¬Ï3ÄÂõîJz׳WL\0¶\0ž€È†8×:y,Ï6&@”À E£Ê¯Ý‘h;¼!f˜¼.Bþ;:ÃÊÎ[Z3¥™Â«‚ðn»ìëÈ‘­éA¨’ÓqP4,„óºXc8^»Ä`׃‚ôl.®üº¢S±hÞ”°‚O+ª%P#Ρ\n?ÛÜIB½ÊeË‘O\\]ÎÂ6ö#û¦۽؁(!c) Nõ¸ºÑ?EØ”B##D íDdo½åPAª\0€:ÜnÂÆŸ€` Úè Q„³>!\r6¨\0€‰V%cbHF×)¤m&\0B ¨2Ií5’Ù#]ú˜ØD>¬ì3<\n:MLðÉ9CñÊ˜0ãë\0“¨(ᏩH\nþ€¦ºM€\"GR\n@éø`[Ã󀊘\ni*\0œð)ˆü€‚ìu©)¤«Hp\0€Nˆ À\"€®N:9qÛ.\r!´JÖÔ{,Û'æفŠ4… B†úÇ lqŨŸXc«Â4ß‹N1ɨ5«WmÇ3\nÁF€„`­'‘ˆÒŠxàƒ&>z>N¬\$4?ó›ÃïÂ(\n쀨>à ëϵPÔ!CqÍŒ¼Œp­qGLqqöG²yÍH.«^àž\0zÕ\$€AT9Fs†Ð…¢D{ía§øcc_€GÈz†)ó³‡ Ü}QÆÅhóÌHBÖ¸<‚y!L­“€Û!\\‚²ˆî ø'’H(‚ä-µ\"ƒin]Äžˆ³­\\¨!Ú`M˜H,gÈŽí»*ÒKfë*\0ò>€6¶ˆà6ÈÖ2óhJæ7Ù{nqÂ8àßôÉHÕ#cHã#˜\r’:¶–7Ê8àÜ€Z²˜ZrD£þß²`rG\0äl\n®Iˆi\0<±äãô\0Lg…~¨ÃE¬Û\$¹ÒP“\$Š@ÒPƼT03ÉHGH±lÉQ%*\"N?ë%œ– €Î\nñCrWÉC\$¬–pñ%‰uR`ÀË%³òR\$–<‘`ÖIfxª¯÷\$/\$„”¥\$œš’O…(‹Ë\0æË\0RY‚ *Ù/ ê\rÜœC9€ï&hhá=IÓ'\$–RRIÇ'\\•a=EÔ„òu·'Ì™wIå'T’€€‘üÿ©¾ãK9%˜d¢´·‚!ü”ÀÊÊÀÒj…ì¡íÓÊ&Ðæ„vÌŸ²\\=<,œEùŒ`ÛYÁò\\Ÿ²‚¤*b0>²r®à,d–pdŒŒÌ0DD Ì–`â,T ­1Ý% P‘ž¤/ø\ròb¹(Œ£õJÑèÍîT0ò``ƾÞè íóJ”t©’©ÊŸ((dÇʪáh+ <Ɉ+H%i ‡Èô‹²•#´`­ ÚÊÑ'ô£B>t˜¯J€Z\\‘`<Jç+h R·ÊÔ8 àh R±,J]gò¨Iä•è0\n%J¹*ÐY²¯£JwDœ°&Ê–D±®•ÉÐœªR§K\"ß1Qò¨Ë ”²AJKC,ä´mV’»Ž²›ÊÙ-±òÏKI*±r¨ƒ\0ÇL³\"ÆKb(üªóJ:qKr·dùÊŸ-)ÁžË†#Ô¸²Þ¸[ºA»@•.[–Ҩʼß4º¡¯.™1ò®J½.Ì®¦u#J“‡Ág\0Æãò‘§£<Ë&”’ðK¤+½ M?Í/d£Ê%'/›¿2YÈä>­\$ͬlº\0†©+ø—Á‰}-tº’Í…*ê‰Rä\$ß” òÌK».´Á­óJHûʉ ‡2\r„¿B‚½(PÍÓÌ6\"ü–nf†\0#Ї ®Í%\$ÄÊ[€\nÐnoLJ°ŒÅÓÂe'<¯ó…‡1KíÁyÌY1¤Çs¥0À&zLf#üƳ/%y-²Ë£3-„Â’ÍK£L¶ÎÉ×0œ³’ë¸[,¤Ë̵,œ±’«„§0”±Ó(‹.DÀ¡ @ÏÁ2ïL+.|£’÷¤É2è(³L¥*´¹S:\0Ù3´ÌíóG3lÌÁaːl³@L³3z4­Ç½%Ì’ÍLÝ3»…³¼!0Š33=Lù4|È—¡à+\"°Êé4´Ëå7Ë,\$¬SPM‘\\±Î?JŠY“Ì¡¹½+(Âa=K¨ì4œ¤³C̤<Ё…=\$,»³UJ]5h³W &tÖI%€é5¬Ò³\\M38g¢́5HŠN?W1Hš±^ÊÙÔ¸“YÍ—Ø Í.‚N3MŸ4Ã…³`„Ži/P‰7 ÖdM>šd¯/LRÎÜâ=K‘60>¯I\0[ðõ\0ßÍ\r2ôÔòZ@Ï1„Û2ÿ°7È9äFG+ä¯ÒœÅ\r)àhQtL}8\$ÊBeC#Á“r*HÈÛ«Ž-›Hý/ØËÒ6Èß\$øRC9Âب!‚€Å7ük/PË0Xr5ƒ¡3D„¼<TÁÔ’q¯Kô©³nÎH§<µFÿ:1SLÎrÀ%(ÿu)¸Xr—1Ñ€nJÃIÌ´S£ \$\$é.·9Ôé²IΟÒ3 ¨L Ãl”“¯Î™9äÅC•N #Ô¡ó\$µ/ÔésÉ9«@6Êt“²®Nñ9¼´·NÉ: ¹’¡7ó Ó¬Í:DáÓÁM)<#–ÓÃM}+ñ2ÎNþ ñ²›O&„ð¢JNy*ŒòòÙ¸[;ñóÎO\"mÚÄóÅMõ<c Â´‚°±8¬K²,´ÓÇN£=07s×JE=Tá³ÆO<Ôô³£Jé=D“Ó:ÏC<Ì“àˉ=äèó®KÊ»Ì³ÈL3¬÷­„LTЀ3ÊS,œ.¨ÿÏq-Œñsç7Í>‚?ó¼7O;Ü `ùOA9´óñÏ»\$œüÁ OÑ;ìý`9ÎnÇIAŒxpÜöE=O¹<ü²5Ï΄ý2¸O?d´Ž„´Œ`NòiOÿ>Œþ3½P ?¤òÔOžmœúSðMôˬ·†=¹(ãdã¤AÈ­9“‘\0í#üä²@ƒ­9DŽÁÉ&ÜýòŠ‚ ?œ “Ð i9»\nà/€ñAÝóòÈ­A¤ýSËPo?kuN5¨~4ÜãÆ6††Ø=ò–Œ“*@(®N\0\\Û”d Gåüp#è¤> 0À«\$2“4z )À `ÂW˜ð +\0Š‘80£è¦•  ¤ª”äz\"TÐä0Ô:\0Š\ne \$€ŽrM”=¡r\n²N‰P÷Cm t80ðú #¤ØJ= &ÐÆ 3\0*€Bú6€\"€ˆéèú€#Ì>˜  (Q\nŒðê´8Ñ1C\rt2ƒECˆ\n`(Çx?j8N¹\0¨È[À¤QN>£©à'\0¬x cêªð\nÉ3×Chü`&\0²Ð´8Ñ\0ø\n䵦úO`/€„¢A`#ÐìXcèÐÏD ÿtR\n>¼ÔdÑBòD´LÐÄÌõ ‰äÐÍDt4ÐÖ j”pµGAoQoG8,-sÑÖðÔK#‡);§E5´TQÑGÐ4Ao\0 >ðtMÓD8yRG@'PõC° ô<PõCå\"”K\0’xüÔ~\0ªe i9Ðìœv))ѵGb6‰ €±H\r48Ñ@‚M‰:€³FØtQÒ!H•”{R } ôURpÍÔO\0¥I…t8¤ØðûÎÇ[D4FÑD#ÊÑ+D½'ôMÊ•À>RgIÕ´ŠQïJ¨””UÒ)EmàüTZ­Eµ'ãê£iEÝ´£ÒqF zAªº>ý)T‹Q3HÅ#TLÒqIjNT½¼…&CøÒhX\nT›ÑÙK\0000´5€ˆ¢JHÑ\0“FE@'Ñ™Fp´hS5F\"ÎoÑ®e%aoS E)  €“DU «Q—FmÎÑ£M´ÑѲe(tnÒ “U1Ü£~>\$ñßÇ‚’­(hÕÇ‘Güy`«\0’ê  ƒíG„ò3Ô5Sp (ýõPãGí\$”œ#¤¨ ©†©N¨\nôV\$ö]ÔœPÖ=\"RÓ¨?Lzt·ƒ1L\$\0ÔøG~å ,‰KNý=”ëÒGMÅ”…¤NS€)ÑáO]:ÔŠS}Ý81àRGe@Cí\0«OPðSõNÍ1ôÝT!P•@ÑÝS€ðÿÕS‰G`\nÉ:€“P°j”7R€ @3üÑ\n‘ üã÷â £”DÓ æúLÈϼŽ  èë\0ùQ5ôµ©CPúµSMP´v4†º?h hëT‡D0úÑ֏àõ>&ÒITxôO¼?•@U¤÷R8@%Ô–ŒõK‰€§NåKãóRyE­E#ýù @ýÃøä %Là«Q«Q¨µ£ª?N5\0¥R\0úԁTëFåÔ”RŸSí!oTEÂC(϶Èýĵ\0„?3iîSS@U÷QeMµƒ KØ\n4PÕCeS”‘\0NC«P‚­Oõ! \"RTûõ€S¥NՏÁU5OU>UiIÕPU#UnKPô£UYTè*ÕC«U¥/\0+º¸Å)ÈÚ:ReAà\$\0øŽ¤xòÇWDº3Ãêà`üÚüçU5ÒIHUY”ô:°P õe\0–MJi€ƒµ ÃýQø>õ@«T±C{›ÕuÑì?Õ^µv\0WR]U}Cöê1-5+Uä?í\rõW<¸?5•JU-SXüÕLÔß \\tÕ?ÒsMÕb„ÕƒV܁t§TŒ>ÂMU+Ö EÅcˆÏÔ9Nm\rRǃCý8ŽSÇX•'RÒéXjCI#G|¥!QÙGh•tðQ¸ý )<¹YÐ*ÔÐRmX0üôö½M£›õOQßYýhÀ«ßduÕ¤ÕZ(ýAo#¥NlyN¬V€Z9IՍºM•¦V«ZuOÕ…TÕTÅEÕ‡Ö·SÍeµµÖÊ\nµXµªSÛQERµ³ÔÙ[MF±VçO=/õ­¨>õgÕ¹TíVoUT³Z’N€*T\\*ÃïÐ×S-pµSÕÃVÕq€ÒM(ÏQ=\\-UUUV­C•Ä×ZØ\nu’V\$?M@UÎWJ\r\rUÐÔ\\å'U×W]…W”£W8ºN '#h=oCóÐýF(üé:9ÕYu•†¤÷V-UÓ9Ÿ]ÒC©:U¿\\\nµqW—™à(TT?5Páª\$ R3Õ⺟C}`>\0®E]ˆ#Rêà ƒÿ#R¥)²W–’:`#óGõ)4ŠRÀý;õáViD%8À)Ç“^¥Qõé#”h ´HÂŽX ƒþ\$Nýx´š#i xûÔ’XRõ€'Ô9`m\\©†¨\nEÀ¦Q±`¥bu@×ñN¥dT×#YYý„µ®GV]j5#?L¤xt/#¬”å#é…½O­PÕëQæ¢6•££Ï^í† €šŽðüÖØM\\R5t´Óšpà*€ƒXˆV\"WÅD€ oRALm\rdGN ÕÖÀú6”p\$P废E5Ôý†©Tx\n€+€‹C[¨ôVŽŒýÖ8U•Du}Ø»F\$.ªËQ-;4È€±NX\n.Xñb͐•\0¯b¥)–#­NýG4KØÐZS”^×´M¶8Øód­\"C‚¬>ÅÕdHe\nöY8¥Ñ.ê ú°ˆÒFúD”½W1cZ6”›QâKHü@*\0¿^¸úÖ\\QßF‚4U3Y|‘=˜Ó¤éE ›ÔÛ¤¦?-™47YƒPm™hYw_\ršVe×±M˜±ßُe(0¶ÔFÕ\r !ÒPUI•uÑ7Qå•CèÑŽ?0ÿµÝgu\rqधY-Qèó°èú=g\0…\0M#÷U×S5Zt®ÖŸae^•\$>²ArV¯_\r;t’¨”HW©Zí@HÕØhzDèÚ\0«S2Jµ HIåO 'ǁeígÉ6¹[µR”<¸?È /ÒKM¤ö–Ø\n>½¤HáZ!iˆ ö¤ŸTX6–Ò×iºC !Ó›g½ à ÒG }Q6žÑ4>äwà!Ú™C}§VBÖ>åªUQÚ‘jª8cïUTàû–'<‚>ÈýõôHC]¨VšÑ7jj3v¥¤å`0ÃèÈ23ö°Ðòxû@U—k \n€:Si5žÕ#Yì-wî”ÕàéM?céÒMQÅGQÕуb`•ò\0Ž@ õËÒ§\0M¥à)ZrKXûÖŸÙWl­²öÍlå³TM×D\r4—QsS¥40ÑsQ́õmYãh•d¶ÂC`{›V€gEÈ\n–»XkՁà'Óè,4ú¼¹^í¢6Æ#<4éNX nM):¹·OM_6d€–æõ¸Ãõ[\"KU²nžÖ?l´x\0&\0¿R56ŸT~>  ô†Õ¸?”Jnž€’ ˆÏZ/iÒ6ôÎÚglͦÖUÛáF}´.ž£¼JLöCTbMŽ4ÍÓcLõTjSD’}JtŒ€Z›ªµÇ:±L­€´d:‰Ez”ʤª>ÖV\$2>­µŽ¢[ãpâ6öÔRŽ9uêW.?•1®£RHužèÛR¸?58Ô®¤íDÝÆuƒ£çpûcìZà?œr×» Eaf°}5wY´ëå‚Ï’ÒêÅW‚wT[Sp7'Ô_aEk \"[/i¥¿#ÿ\$;m…fØ£WOüô”ÔFò\r%\$Íju-t#<Å!·\n:«KEA£íÒÑ]À\nUæQ­KEÀ #€¿Xå¨÷5[Ê>ˆ`/£ÍDµÊÖ­VEp à)åI%ÏqßÜûníx):¤§le¢´Õ[eÕ\\•eV[j…–£éÑ7 -+ÖßGWEwt¯WkEÅ~uìQ/mõ#ԐW—`ýyu“Ç£DÝAö'×±\r±•Õ™OD )ZM^€³u-|v8]‹g½‘hö×ÅLà–W\0øÈû6ËX†‘=YÔd½Q­7 Ï“”Ï9£çͲr <Ã֏êD³ºB`c 9¿ ’È`D ¬=wx©I%ä,ᄬ†è²àêƒj[ÑšÖíßOÿ‹´ ``ŽÅ|¸òòÆÞø¤Œ˜¼í.Ì AOŠÀÄ ·‰@å@ 0h2í\\âЀM{eã€9^>ô•â@7\0òôË‚W’€ò\$,íÉÅš¡@Ø€Òâ•å×w^fmå‰,\0ÏyD,ם^X€.¯Ö†©7ã·›Ã×2ÝÅf;¥€6«\n”¤Ž…^ŸzC©×§mz…én–^ˆô”&LFFê ,°ö[€¥eÈ õaXy9h€!:zÍ9còQ9bÅ !€¦µGw_WÉg¥9©ÓS+t®ÚápÝtɃ\nm+–œÞÙ_𠡪\\¼’k5£ÒÜ]Æ4ˆ_h•9 Ù÷N…—Å]%|¥ˆ7ËÖœŽ];”ï |ñµ ßXýÍ9Õ|åñ×ÌG¢“¨[×Ô\0‘}Uñ”çßMCI:ÒqO¨VÔƒa\0\rñRÍ6Ï€Ã\0ø@H ¢ÅP+rìS¤Wãè€øp7äI~p/ø HÏ^Ýê²ü¤¬E§-%û¥Ì»Í&.ÎÄ+¸JÑ’;:³¶«!“ýÐNð Æ~öª‰€/“WÄ !„BèL+Â\$ðíq§=ü¿+Ñ`/Æ„e„\\±ÒÏxÀpE‘lpSÂJ SÝ¢½ö6à‡_¹(ů©Äéb\\OÆÊ&ì¼\\Ð59\0û€9nñøD¸{¡\$ḋK‘v2 d]èv…CÕþÅÕ?tf|WÜ:£Ô¨ p&¿àLn„Î賞î{;ˆçÚGR9øT.y¹üïI8€¹´\rl° ú Tè  n”3¼öðT.ƒ9´è3› š¼Zès¡¯ÑÒGñþŽˆ: 0£¦£zè­Ý.Œ]ÀçÄ£Q›?àgT»%ñ™ÕxŒÕŒ.„šÔÇn<ì£-â8B˳,Bòì˜rgQþ¢íßó„ÉŽ`Úá2é„:îµ½{…gëÄs„øgóZ¿•… ׌<æ×w{¦˜ƒbU9ˆ `5`4„\0BxMpð‘8qnahé†@ؼí†-â(—>S|0®…¾¥…3á8h\0Ñ«µCÔzLQž@¶\n?†¸`AÀ >2šÂ,÷á˜ñN&Œ«xˆl8sah1è|˜B‡É‡DxBÞ#V—‹V–׊`Wâa'@›‡¬ X_?\nì¾ •_â. ØP¼r2®bUarÀI¸~áñ…S“àú\0×…\" 2€ÖþÀ>b;…vPh{[ °7a`Ë\0ê˲j—oŒ~·ûþvÍÙ|fv†4[½\$¶« {ó¯P\rvæBKGbpëÈÅø™–OŠ5Ý 2\0j÷Ù„LŽ€î)ÇmáÈV¡ejBB.'R{C¤ïV'`Ø‚ ‰Ž%­Ç€Ð\$ Oå\0˜`‚’«4 ÌNò>;4£³¢/ÌÏ€´À*Âø\\5„ÅÁ!†û`X*Þ%îÄNÍ3SõAMôþËÆ”,þ1¬²®í\\¯²caϧ ³ù@ج˃¸B/„¬Íø0` óv2ï¡„§Œ`hDÅJO\$ç…@p!9˜ !¥\n1ø7pB,>8F4¯åf Ï€:“ñ7„î3›£3…¿à°T8—=+~Øn«Îâ\\Äe¸<br·þ øFز°  ¹C¡N‹:c€:Ôl–<\r›ã\\3à>ñ˜‡À6ONnŠä!;áñ@›twë^Fé€Là;€× º,^aÈ\ra\"ÞÀÚ®'ú:„vàJe4Ãא;•ñ_d\r4\rÌ:ÛüÀ¬S˜à2€[c€„XÿʦPl˜\$¹Þ£i“wåd#ŽB šb›Îפõ’™`:†€Ï~ <\0Ñ2Ù·—‘RŒÂÆPÈ\r¸J8D¡t@ìEŽè\0\rÍœ6öóäÞ7•½ä˜YÏ£ú\"åäÀš\rüƒ¦Àš3ƒ¡.˜+«z3±;_ÊŸvLÝäÓwJ¿94ÀIJa,A¦ñˆ¯;ƒs?ÖN\nR‡!Ž§Ý†Om…sÈ_æà-zÛ­w„€ÛzÜ­7¡ÍÅzî÷–M”ˆ€o¿”¥æ\0¢ƒa”Åݹ4å8èPfñYå?”òi—–eBÎSà1\0ÉjDTeK”®UYSå?66R ¦cõ 6Ry[c÷”°5Ù]BÍ”ÖRù_eA)&ù[凕XYRW–6VYaeU•fYeåw•ŽU¹båw”Eë°Ê†;z¤^W«9–äקäÝ–õë\0<Þ˜èeê9SåΤdaª ”_-îá‰L×8Ç…ÍQöèTH[!<p\0£”Py5ˆ|—#ê‘P³ ×9vàš2Â|Ǹáfa o†á,j8×\$A@kñƒ¿ŽaË‘½bócñÈf4!4¨‘¶cr,;™‘æ‘öbÆ=€Â;\0°øź…˜†cdÃæX¾bìx™a™Rx0Aãh£+wðxN[˜ÜB·pÚƒ¿w™TÀ8T%™šMšl2à‡½¡šð—}¡Ès.kY„˜0\$/èfU€=þØs„gKáˆM› õ?ÿ›ç`4c.Ôø!¡&€åˆ†g°ûfà/þf1=¯›V AE<#̹¡f\n») Šë›Npò“ã`.\"\"»A眤ã—ü q¸X“ Ù¬: aÉ8™¹f¯™Vsó‹G™ÞrŽ:æVÞÆcÔgVl™g=`ã“WŽËýyÒgUÀË™ªáº¼îeT=  ã€á€Æx 0â M¼@ˆ»šÂ%κb½œþw™ÆfÛÙOøç­˜Ü*0¯…®|tá°%±™PÈÍpæúgKžù¬?pô@JÀ<BÙŸ#­`1„î9þ2çg¶!3~ØÜçînläÅfŠØVhù¬Ž.Ñ€à…aCÑù•?³Šû-à1œ68>A¤ˆaÈ\r—¦ y‹0 Öi‘J«} à ¹© Ð z:\r¡)‘Sþ‚¡@ ¢åh@äöƒY¹ã´mCEg¡cyφ‚<õàÍh@¼@«zh<WÙÄ`•¨±:zOãÎÖ\rÍêW«“°V08Ùf7™(Gyƒ²`St#ï„f†#ƒ²œC(9Ș؀dùææ8T:¯»Œ0ºè qµ  79· á£phAgÜ6Š.ãæ7 Fr™bä ÈjšèA5î…†ƒá¡a1ú Úh•ZCh:–%¹ÎgU¢ðD9ÖÅɈ„×¹Ïé0~vTi;VvSš„wœØ\r΃?àÇf²£…ÿ¥nŠÏ›iY™ìaº¬3 Î‡9Õ,\n™Ãr‘‰,/,@.:èY>&…šFÑ)ú™¶}šb£€èiOÝiæš:dèAŒn˜šc=¤L9O’h{¦ 8hY.’ÙÀ®¾‡®‡…œüÇ\r¬Ö‡£À›Šé1Q¯U ”C‘hô†eÿO‰›°+2oÌÎìÞN‹˜÷§øzpè¢(þ]Óh€å¢Z|¬O¡cÑzDáþ;õT\0j¡\0…8#>ÎŽÁ=bZ8Fjóìé;íÞºTé…¡w®Í)¦ýøN`æë¨ ¤Ã…B{ûƒz\ró¡c“Óè|dTG“iœ/ûú !i†Ê0±¼ø'`Z:ŠCHï(8ê`V¥™Úãöª\0Üꧩ†£WïßǪ˜ÕzgG¾‘…ƒ½²-[ÃÐ iœêN\rqºé«n„„“o Æ¥fEJý¡apb¹ê}6£…Õ=o¤–„,tèY+ö®EC\rÖPx4=¼¾™Ù@‡‰¦.†‘F£[¡zqçÜèX6:FG¨ #°û\$@&­ab¤þhE:²ƒå¬ä`¶S­1—1g1©þ„2uhY‹¬_:Bß¡dcï–*ÿ­†\0úÆ—FYFœ:Ë£ªn„ØÌ=Û¨H*Z¼Mhk/ëƒ¡žzٹ]šÁh@ôæ©Øã1\0˜øZKùž¢ëÎÆè^+º,vfós®š>ˆ¤’Oã|èÀÊsÃ\0Öœ5öX é‹îѯF„÷n¿Aˆr]|ÏIi4è…þ ØÂC° h@ع´Ÿž–cߥ¨6smOÃ前™›gX¬V2¦6g?~ÖÃYÕÑ°†súcl \\RŠ\0Œ¨cœA+Œ1°„›ùÌé\n(ÑúÃÌ^368cz:=z÷‚(äø ;裨ñsüF¶@`;ì€,>yTßï&–•d½Lןœÿ%Òƒ -ëCHL8\r‡Çbû°°£úMj]4Ym9üÛüÐZÚBøïP}<ŸûàX²¯‰Ì¥á+gÅ^ØMÞ + B_Fd¬X„ø‹lówÈ~î\r⽋è\":ÔêqA1X¾ìæ²Ðø¯3ÖΓEáh±4ßZZÂó¸& …ææ1~!Nfã´öo—ˆ™\nMeÜ଄îëXI΄íG@V*X¯†;µY5{Vˆ\nè»ÏTéz\rF 3}m ¶Ôp1í[€>©tèe¶w™Ÿæë@VÖz#‚2Äï iôôÎ{ã9ƒ‚p̝»gh‘Šæ+[elU‰¦ÛAßÙ¶Ó¼i1Ä!Œ¾ommµ*Kà‡ê}¶°!íÆ³í¡®Ý{me·f`“—mè˜CÛz=žnÞ:}g° T›mLu1FÜÚ}=8¸ZáíèOžÛmFFMf¤…OO€ðîáÀ‹ƒèøß/¼éõ¸Þ“šå€þV™oqj³²èn!+½òµüZ¨ËI¹.Ì9!nG¹\\„›3a¹~…O+Îå::îK@Œ\nÚ@ƒ‘¤Hph‘´\\BÄõdmfvCèžÓPÛ\" æ½Û.nW&–ên¢øHYþ+\r¶“Äz÷i>MfqۤùÝQc‚[­H+æÀo¤Ñ*ú1'¤÷#āEw€D_Xí)>Ðs£„-~\rT=½£žà÷ˆà- íy§m§¹æð{„hóŸÌjÚMè)€^ž¹ïÀ'@Vå¡+iÈîÎò›Ÿåµ†É;F“ D[Îb!¼¾´B ¦¤:MP‹îóÛ­oC¼vAE?éC²IiYÍ„#þp¶P\$kâJÞq½.É07œþöxˆl¦sC|ï½¾bo–2äXª>Mô\rl&»Ç:2ã~ÛÑcQ²îò²æoÑÞdá‚-þèUÜRo‚YšnM;’n©#–ß\0–P¾fðÚPo׿(CÚv<ʬø[òoÛ¸”šû×fÑ¿ÖüÁ;ßẖõ[úYŸ.o®Up¿®pUŒø”.ž ©B!'\0‹òã<Tñ:1±À¾ šã¤î<„›ðnˆîF³ðƒI¢Ç”´‚V0ÊǁRO8‰wøÎ,aFú¼É¥¹[´ÎŸ…ñYOù«‰€/\0™Ùox÷ÇQð?§°:Ù‹ëÆè`h@:ƒ«¿öÑ/Mím¼x:Û°c1¤Öàû¯ív² ;„‚è^æØÆ@®õ@£úð½ÂÇ\n{¯¼Âî‹à;ç‘´B¼í¸8‘º g坒ä\\*gåyC)Û„E^ýOÄh ¡³¦Aƒu>Æèü@àD̆Yæ¼í›â`o»<>Àƒp‰™ŠÄ·’q,Y1Q¨Á߸†/qgŒ\0+\0âæå‡Dÿƒç?¶þ î©Úßîk:ù\$©û¬í×¥6~I¥…=@ŽíÑ!¾ùvÚzOñš²â+ÍõÆ9Çi³–›¼aïð†êû…gòðô —¹ÿ?š0Gn˜q²]{Ò¸,FáÃøO¡â„Þ <_>f+¢,ñÌ »Ôñ±&ôœ†ðí·¼yêÇ©Oü:¬U¯ˆLÆ\nÃúI:2³¿-;_Ä¢È|%éå´¿!Îõfž\$¦ˆ†Xr\"Kniîñ—ÀÐ\$8#›g¤t-›€r@LÓ圏è@S£<‘rN\nD/rLdQk࣓”ªõÄîeðåäãЭåø\n=4)ƒ B˜”Ëךô");}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;}function
  14. connection(){global$e;return$e;}function
  15. adminer(){global$b;return$b;}function
  16. idf_unescape($Pc){$md=substr($Pc,-1);return
  17. str_replace($md.$md,$md,substr($Pc,1,-1));}function
  18. escape_string($X){return
  19. substr(q($X),1,-1);}function
  20. number($X){return
  21. preg_replace('~[^0-9]+~','',$X);}function
  22. remove_slashes($Ue,$sc=false){if(get_magic_quotes_gpc()){while(list($y,$X)=each($Ue)){foreach($X
  23. as$fd=>$W){unset($Ue[$y][$fd]);if(is_array($W)){$Ue[$y][stripslashes($fd)]=$W;$Ue[]=&$Ue[$y][stripslashes($fd)];}else$Ue[$y][stripslashes($fd)]=($sc?$W:stripslashes($W));}}}}function
  24. bracket_escape($Pc,$_a=false){static$_g=array(':'=>':1',']'=>':2','['=>':3','"'=>':4');return
  25. strtr($Pc,($_a?array_flip($_g):$_g));}function
  26. charset($e){return(version_compare($e->server_info,"5.5.3")>=0?"utf8mb4":"utf8");}function
  27. script($Jf,$zg="\n"){return"<script".nonce().">$Jf</script>$zg";}function
  28. script_src($Qg){return"<script src='".h($Qg)."'".nonce()."></script>\n";}function
  29. nonce(){return' nonce="'.get_nonce().'"';}function
  30. target_blank(){return' target="_blank" rel="noopener"';}function
  31. h($Sf){return
  32. str_replace("\0","&#0;",htmlspecialchars($Sf,ENT_QUOTES,'utf-8'));}function
  33. nbsp($Sf){return(trim($Sf)!=""?h($Sf):"&nbsp;");}function
  34. nl_br($Sf){return
  35. str_replace("\n","<br>",$Sf);}function
  36. checkbox($E,$Y,$Na,$jd="",$fe="",$Ra="",$kd=""){$K="<input type='checkbox' name='$E' value='".h($Y)."'".($Na?" checked":"").($kd?" aria-labelledby='$kd'":"").">".($fe?script("qsl('input').onclick = function () { $fe };",""):"");return($jd!=""||$Ra?"<label".($Ra?" class='$Ra'":"").">$K".h($jd)."</label>":$K);}function
  37. optionlist($je,$zf=null,$Tg=false){$K="";foreach($je
  38. as$fd=>$W){$ke=array($fd=>$W);if(is_array($W)){$K.='<optgroup label="'.h($fd).'">';$ke=$W;}foreach($ke
  39. as$y=>$X)$K.='<option'.($Tg||is_string($y)?' value="'.h($y).'"':'').(($Tg||is_string($y)?(string)$y:$X)===$zf?' selected':'').'>'.h($X);if(is_array($W))$K.='</optgroup>';}return$K;}function
  40. html_select($E,$je,$Y="",$ee=true,$kd=""){if($ee)return"<select name='".h($E)."'".($kd?" aria-labelledby='$kd'":"").">".optionlist($je,$Y)."</select>".(is_string($ee)?script("qsl('select').onchange = function () { $ee };",""):"");$K="";foreach($je
  41. as$y=>$X)$K.="<label><input type='radio' name='".h($E)."' value='".h($y)."'".($y==$Y?" checked":"").">".h($X)."</label>";return$K;}function
  42. select_input($wa,$je,$Y="",$ee="",$He=""){$hg=($je?"select":"input");return"<$hg$wa".($je?"><option value=''>$He".optionlist($je,$Y,true)."</select>":" size='10' value='".h($Y)."' placeholder='$He'>").($ee?script("qsl('$hg').onchange = $ee;",""):"");}function
  43. confirm($C="",$_f="qsl('input')"){return
  44. script("$_f.onclick = function () { return confirm('".($C?js_escape($C):'Are you sure?')."'); };","");}function
  45. print_fieldset($t,$rd,$ch=false){echo"<fieldset><legend>","<a href='#fieldset-$t'>$rd</a>",script("qsl('a').onclick = partial(toggle, 'fieldset-$t');",""),"</legend>","<div id='fieldset-$t'".($ch?"":" class='hidden'").">\n";}function
  46. bold($Ga,$Ra=""){return($Ga?" class='active $Ra'":($Ra?" class='$Ra'":""));}function
  47. odd($K=' class="odd"'){static$s=0;if(!$K)$s=-1;return($s++%2?$K:'');}function
  48. js_escape($Sf){return
  49. addcslashes($Sf,"\r\n'\\/");}function
  50. json_row($y,$X=null){static$tc=true;if($tc)echo"{";if($y!=""){echo($tc?"":",")."\n\t\"".addcslashes($y,"\r\n\t\"\\/").'": '.($X!==null?'"'.addcslashes($X,"\r\n\"\\/").'"':'null');$tc=false;}else{echo"\n}\n";$tc=true;}}function
  51. ini_bool($Tc){$X=ini_get($Tc);return(preg_match('~^(on|true|yes)$~i',$X)||(int)$X);}function
  52. sid(){static$K;if($K===null)$K=(SID&&!($_COOKIE&&ini_bool("session.use_cookies")));return$K;}function
  53. set_password($Yg,$O,$V,$G){$_SESSION["pwds"][$Yg][$O][$V]=($_COOKIE["adminer_key"]&&is_string($G)?array(encrypt_string($G,$_COOKIE["adminer_key"])):$G);}function
  54. get_password(){$K=get_session("pwds");if(is_array($K))$K=($_COOKIE["adminer_key"]?decrypt_string($K[0],$_COOKIE["adminer_key"]):false);return$K;}function
  55. q($Sf){global$e;return$e->quote($Sf);}function
  56. get_vals($I,$c=0){global$e;$K=array();$J=$e->query($I);if(is_object($J)){while($L=$J->fetch_row())$K[]=$L[$c];}return$K;}function
  57. get_key_vals($I,$f=null,$pg=0,$Ff=true){global$e;if(!is_object($f))$f=$e;$K=array();$f->timeout=$pg;$J=$f->query($I);$f->timeout=0;if(is_object($J)){while($L=$J->fetch_row()){if($Ff)$K[$L[0]]=$L[1];else$K[]=$L[0];}}return$K;}function
  58. get_rows($I,$f=null,$j="<p class='error'>"){global$e;$eb=(is_object($f)?$f:$e);$K=array();$J=$eb->query($I);if(is_object($J)){while($L=$J->fetch_assoc())$K[]=$L;}elseif(!$J&&!is_object($f)&&$j&&defined("PAGE_HEADER"))echo$j.error()."\n";return$K;}function
  59. unique_array($L,$v){foreach($v
  60. as$u){if(preg_match("~PRIMARY|UNIQUE~",$u["type"])){$K=array();foreach($u["columns"]as$y){if(!isset($L[$y]))continue
  61. 2;$K[$y]=$L[$y];}return$K;}}}function
  62. 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
  63. idf_escape($y);}function
  64. where($Z,$l=array()){global$e,$x;$K=array();foreach((array)$Z["where"]as$y=>$X){$y=bracket_escape($y,1);$c=escape_key($y);$K[]=$c.($x=="sql"&&preg_match('~^[0-9]*\\.[0-9]*$~',$X)?" LIKE ".q(addcslashes($X,"%_\\")):($x=="mssql"?" LIKE ".q(preg_replace('~[_%[]~','[\0]',$X)):" = ".unconvert_field($l[$y],q($X))));if($x=="sql"&&preg_match('~char|text~',$l[$y]["type"])&&preg_match("~[^ -@]~",$X))$K[]="$c = ".q($X)." COLLATE ".charset($e)."_bin";}foreach((array)$Z["null"]as$y)$K[]=escape_key($y)." IS NULL";return
  65. implode(" AND ",$K);}function
  66. where_check($X,$l=array()){parse_str($X,$Ma);remove_slashes(array(&$Ma));return
  67. where($Ma,$l);}function
  68. where_link($s,$c,$Y,$ge="="){return"&where%5B$s%5D%5Bcol%5D=".urlencode($c)."&where%5B$s%5D%5Bop%5D=".urlencode(($Y!==null?$ge:"IS NULL"))."&where%5B$s%5D%5Bval%5D=".urlencode($Y);}function
  69. convert_fields($d,$l,$N=array()){$K="";foreach($d
  70. as$y=>$X){if($N&&!in_array(idf_escape($y),$N))continue;$ua=convert_field($l[$y]);if($ua)$K.=", $ua AS ".idf_escape($y);}return$K;}function
  71. cookie($E,$Y,$ud=2592000){global$ba;return
  72. header("Set-Cookie: $E=".urlencode($Y).($ud?"; expires=".gmdate("D, d M Y H:i:s",time()+$ud)." GMT":"")."; path=".preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]).($ba?"; secure":"")."; HttpOnly; SameSite=lax",false);}function
  73. restart_session(){if(!ini_bool("session.use_cookies"))session_start();}function
  74. stop_session(){if(!ini_bool("session.use_cookies"))session_write_close();}function&get_session($y){return$_SESSION[$y][DRIVER][SERVER][$_GET["username"]];}function
  75. set_session($y,$X){$_SESSION[$y][DRIVER][SERVER][$_GET["username"]]=$X;}function
  76. auth_url($Yg,$O,$V,$i=null){global$Ib;preg_match('~([^?]*)\\??(.*)~',remove_from_uri(implode("|",array_keys($Ib))."|username|".($i!==null?"db|":"").session_name()),$B);return"$B[1]?".(sid()?SID."&":"").($Yg!="server"||$O!=""?urlencode($Yg)."=".urlencode($O)."&":"")."username=".urlencode($V).($i!=""?"&db=".urlencode($i):"").($B[2]?"&$B[2]":"");}function
  77. is_ajax(){return($_SERVER["HTTP_X_REQUESTED_WITH"]=="XMLHttpRequest");}function
  78. redirect($A,$C=null){if($C!==null){restart_session();$_SESSION["messages"][preg_replace('~^[^?]*~','',($A!==null?$A:$_SERVER["REQUEST_URI"]))][]=$C;}if($A!==null){if($A=="")$A=".";header("Location: $A");exit;}}function
  79. query_redirect($I,$A,$C,$df=true,$gc=true,$mc=false,$og=""){global$e,$j,$b;if($gc){$Of=microtime(true);$mc=!$e->query($I);$og=format_time($Of);}$Mf="";if($I)$Mf=$b->messageQuery($I,$og);if($mc){$j=error().$Mf.script("messagesPrint();");return
  80. false;}if($df)redirect($A,$C.$Mf);return
  81. true;}function
  82. queries($I){global$e;static$Ye=array();static$Of;if(!$Of)$Of=microtime(true);if($I===null)return
  83. array(implode("\n",$Ye),format_time($Of));$Ye[]=(preg_match('~;$~',$I)?"DELIMITER ;;\n$I;\nDELIMITER ":$I).";";return$e->query($I);}function
  84. apply_queries($I,$S,$cc='table'){foreach($S
  85. as$Q){if(!queries("$I ".$cc($Q)))return
  86. false;}return
  87. true;}function
  88. queries_redirect($A,$C,$df){list($Ye,$og)=queries(null);return
  89. query_redirect($Ye,$A,$C,$df,false,!$df,$og);}function
  90. format_time($Of){return
  91. sprintf('%.3f s',max(0,microtime(true)-$Of));}function
  92. remove_from_uri($xe=""){return
  93. substr(preg_replace("~(?<=[?&])($xe".(SID?"":"|".session_name()).")=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
  94. pagination($F,$pb){return" ".($F==$pb?$F+1:'<a href="'.h(remove_from_uri("page").($F?"&page=$F".($_GET["next"]?"&next=".urlencode($_GET["next"]):""):"")).'">'.($F+1)."</a>");}function
  95. get_file($y,$xb=false){$qc=$_FILES[$y];if(!$qc)return
  96. null;foreach($qc
  97. as$y=>$X)$qc[$y]=(array)$X;$K='';foreach($qc["error"]as$y=>$j){if($j)return$j;$E=$qc["name"][$y];$wg=$qc["tmp_name"][$y];$fb=file_get_contents($xb&&preg_match('~\\.gz$~',$E)?"compress.zlib://$wg":$wg);if($xb){$Of=substr($fb,0,3);if(function_exists("iconv")&&preg_match("~^\xFE\xFF|^\xFF\xFE~",$Of,$jf))$fb=iconv("utf-16","utf-8",$fb);elseif($Of=="\xEF\xBB\xBF")$fb=substr($fb,3);$K.=$fb."\n\n";}else$K.=$fb;}return$K;}function
  98. upload_error($j){$Cd=($j==UPLOAD_ERR_INI_SIZE?ini_get("upload_max_filesize"):0);return($j?'Unable to upload a file.'.($Cd?" ".sprintf('Maximum allowed file size is %sB.',$Cd):""):'File does not exist.');}function
  99. repeat_pattern($Fe,$sd){return
  100. str_repeat("$Fe{0,65535}",$sd/65535)."$Fe{0,".($sd%65535)."}";}function
  101. is_utf8($X){return(preg_match('~~u',$X)&&!preg_match('~[\\0-\\x8\\xB\\xC\\xE-\\x1F]~',$X));}function
  102. shorten_utf8($Sf,$sd=80,$Wf=""){if(!preg_match("(^(".repeat_pattern("[\t\r\n -\x{10FFFF}]",$sd).")($)?)u",$Sf,$B))preg_match("(^(".repeat_pattern("[\t\r\n -~]",$sd).")($)?)",$Sf,$B);return
  103. h($B[1]).$Wf.(isset($B[2])?"":"<i>...</i>");}function
  104. format_number($X){return
  105. strtr(number_format($X,0,".",','),preg_split('~~u','0123456789',-1,PREG_SPLIT_NO_EMPTY));}function
  106. friendly_url($X){return
  107. preg_replace('~[^a-z0-9_]~i','-',$X);}function
  108. hidden_fields($Ue,$Qc=array()){while(list($y,$X)=each($Ue)){if(!in_array($y,$Qc)){if(is_array($X)){foreach($X
  109. as$fd=>$W)$Ue[$y."[$fd]"]=$W;}else
  110. echo'<input type="hidden" name="'.h($y).'" value="'.h($X).'">';}}}function
  111. 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
  112. table_status1($Q,$nc=false){$K=table_status($Q,$nc);return($K?$K:array("Name"=>$Q));}function
  113. column_foreign_keys($Q){global$b;$K=array();foreach($b->foreignKeys($Q)as$m){foreach($m["source"]as$X)$K[$X][]=$m;}return$K;}function
  114. enum_input($U,$wa,$k,$Y,$Wb=null){global$b;preg_match_all("~'((?:[^']|'')*)'~",$k["length"],$yd);$K=($Wb!==null?"<label><input type='$U'$wa value='$Wb'".((is_array($Y)?in_array($Wb,$Y):$Y===0)?" checked":"")."><i>".'empty'."</i></label>":"");foreach($yd[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$Na=(is_int($Y)?$Y==$s+1:(is_array($Y)?in_array($s+1,$Y):$Y===$X));$K.=" <label><input type='$U'$wa value='".($s+1)."'".($Na?' checked':'').'>'.h($b->editVal($X,$k)).'</label>';}return$K;}function
  115. input($k,$Y,$p){global$e,$Gg,$b,$x;$E=h(bracket_escape($k["field"]));echo"<td class='function'>";if(is_array($Y)&&!$p){$ta=array($Y);if(version_compare(PHP_VERSION,5.4)>=0)$ta[]=JSON_PRETTY_PRINT;$Y=call_user_func_array('json_encode',$ta);$p="json";}$lf=($x=="mssql"&&$k["auto_increment"]);if($lf&&!$_POST["save"])$p=null;$Bc=(isset($_GET["select"])||$lf?array("orig"=>'original'):array())+$b->editFunctions($k);$wa=" name='fields[$E]'";if($k["type"]=="enum")echo
  116. nbsp($Bc[""])."<td>".$b->editInput($_GET["edit"],$k,$wa,$Y);else{$Hc=(in_array($p,$Bc)||isset($Bc[$p]));echo(count($Bc)>1?"<select name='function[$E]'>".optionlist($Bc,$p===null||$Hc?$p:"")."</select>".on_help("getTarget(event).value.replace(/^SQL\$/, '')",1).script("qsl('select').onchange = functionChange;",""):nbsp(reset($Bc))).'<td>';$Vc=$b->editInput($_GET["edit"],$k,$wa,$Y);if($Vc!="")echo$Vc;elseif(preg_match('~bool~',$k["type"]))echo"<input type='hidden'$wa value='0'>"."<input type='checkbox'".(preg_match('~^(1|t|true|y|yes|on)$~i',$Y)?" checked='checked'":"")."$wa value='1'>";elseif($k["type"]=="set"){preg_match_all("~'((?:[^']|'')*)'~",$k["length"],$yd);foreach($yd[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$Na=(is_int($Y)?($Y>>$s)&1:in_array($X,explode(",",$Y),true));echo" <label><input type='checkbox' name='fields[$E][$s]' value='".(1<<$s)."'".($Na?' checked':'').">".h($b->editVal($X,$k)).'</label>';}}elseif(preg_match('~blob|bytea|raw|file~',$k["type"])&&ini_bool("file_uploads"))echo"<input type='file' name='fields-$E'>";elseif(($mg=preg_match('~text|lob~',$k["type"]))||preg_match("~\n~",$Y)){if($mg&&$x!="sqlite")$wa.=" cols='50' rows='12'";else{$M=min(12,substr_count($Y,"\n")+1);$wa.=" cols='30' rows='$M'".($M==1?" style='height: 1.2em;'":"");}echo"<textarea$wa>".h($Y).'</textarea>';}elseif($p=="json"||preg_match('~^jsonb?$~',$k["type"]))echo"<textarea$wa cols='50' rows='12' class='jush-js'>".h($Y).'</textarea>';else{$Ed=(!preg_match('~int~',$k["type"])&&preg_match('~^(\\d+)(,(\\d+))?$~',$k["length"],$B)?((preg_match("~binary~",$k["type"])?2:1)*$B[1]+($B[3]?1:0)+($B[2]&&!$k["unsigned"]?1:0)):($Gg[$k["type"]]?$Gg[$k["type"]]+($k["unsigned"]?0:1):0));if($x=='sql'&&$e->server_info>=5.6&&preg_match('~time~',$k["type"]))$Ed+=7;echo"<input".((!$Hc||$p==="")&&preg_match('~(?<!o)int~',$k["type"])&&!preg_match('~\[\]~',$k["full_type"])?" type='number'":"")." value='".h($Y)."'".($Ed?" data-maxlength='$Ed'":"").(preg_match('~char|binary~',$k["type"])&&$Ed>20?" size='40'":"")."$wa>";}echo$b->editHint($_GET["edit"],$k,$Y);$tc=0;foreach($Bc
  117. as$y=>$X){if($y===""||!$X)break;$tc++;}if($tc)echo
  118. script("mixin(qsl('td'), {onchange: partial(skipOriginal, $tc), oninput: function () { this.onchange(); }});");}}function
  119. process_input($k){global$b;$Pc=bracket_escape($k["field"]);$p=$_POST["function"][$Pc];$Y=$_POST["fields"][$Pc];if($k["type"]=="enum"){if($Y==-1)return
  120. false;if($Y=="")return"NULL";return+$Y;}if($k["auto_increment"]&&$Y=="")return
  121. null;if($p=="orig")return($k["on_update"]=="CURRENT_TIMESTAMP"?idf_escape($k["field"]):false);if($p=="NULL")return"NULL";if($k["type"]=="set")return
  122. array_sum((array)$Y);if($p=="json"){$p="";$Y=json_decode($Y,true);if(!is_array($Y))return
  123. false;return$Y;}if(preg_match('~blob|bytea|raw|file~',$k["type"])&&ini_bool("file_uploads")){$qc=get_file("fields-$Pc");if(!is_string($qc))return
  124. false;return
  125. q($qc);}return$b->processInput($k,$Y,$p);}function
  126. fields_from_edit(){global$Hb;$K=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){$E=bracket_escape($y,1);$K[$E]=array("field"=>$E,"privileges"=>array("insert"=>1,"update"=>1),"null"=>1,"auto_increment"=>($y==$Hb->primary),);}return$K;}function
  127. search_tables(){global$b,$e;$_GET["where"][0]["val"]=$_POST["query"];$yc=false;foreach(table_status('',true)as$Q=>$R){$E=$b->tableName($R);if(isset($R["Engine"])&&$E!=""&&(!$_POST["tables"]||in_array($Q,$_POST["tables"]))){$J=$e->query("SELECT".limit("1 FROM ".table($Q)," WHERE ".implode(" AND ",$b->selectSearchProcess(fields($Q),array())),1));if(!$J||$J->fetch_row()){if(!$yc){echo"<ul>\n";$yc=true;}echo"<li>".($J?"<a href='".h(ME."select=".urlencode($Q)."&where[0][op]=".urlencode($_GET["where"][0]["op"])."&where[0][val]=".urlencode($_GET["where"][0]["val"]))."'>$E</a>\n":"$E: <span class='error'>".error()."</span>\n");}}}echo($yc?"</ul>":"<p class='message'>".'No tables.')."\n";}function
  128. dump_headers($Oc,$Ld=false){global$b;$K=$b->dumpHeaders($Oc,$Ld);$ve=$_POST["output"];if($ve!="text")header("Content-Disposition: attachment; filename=".$b->dumpFilename($Oc).".$K".($ve!="file"&&!preg_match('~[^0-9a-z]~',$ve)?".$ve":""));session_write_close();ob_flush();flush();return$K;}function
  129. dump_csv($L){foreach($L
  130. as$y=>$X){if(preg_match("~[\"\n,;\t]~",$X)||$X==="")$L[$y]='"'.str_replace('"','""',$X).'"';}echo
  131. implode(($_POST["format"]=="csv"?",":($_POST["format"]=="tsv"?"\t":";")),$L)."\r\n";}function
  132. apply_sql_function($p,$c){return($p?($p=="unixepoch"?"DATETIME($c, '$p')":($p=="count distinct"?"COUNT(DISTINCT ":strtoupper("$p("))."$c)"):$c);}function
  133. get_temp_dir(){$K=ini_get("upload_tmp_dir");if(!$K){if(function_exists('sys_get_temp_dir'))$K=sys_get_temp_dir();else{$rc=@tempnam("","");if(!$rc)return
  134. false;$K=dirname($rc);unlink($rc);}}return$K;}function
  135. file_open_lock($rc){$o=@fopen($rc,"r+");if(!$o){$o=@fopen($rc,"w");if(!$o)return;chmod($rc,0660);}flock($o,LOCK_EX);return$o;}function
  136. file_write_unlock($o,$rb){rewind($o);fwrite($o,$rb);ftruncate($o,strlen($rb));flock($o,LOCK_UN);fclose($o);}function
  137. password_file($g){$rc=get_temp_dir()."/adminer.key";$K=@file_get_contents($rc);if($K||!$g)return$K;$o=@fopen($rc,"w");if($o){chmod($rc,0660);$K=rand_string();fwrite($o,$K);fclose($o);}return$K;}function
  138. rand_string(){return
  139. md5(uniqid(mt_rand(),true));}function
  140. select_value($X,$_,$k,$ng){global$b,$ba;if(is_array($X)){$K="";foreach($X
  141. as$fd=>$W)$K.="<tr>".($X!=array_values($X)?"<th>".h($fd):"")."<td>".select_value($W,$_,$k,$ng);return"<table cellspacing='0'>$K</table>";}if(!$_)$_=$b->selectLink($X,$k);if($_===null){if(is_mail($X))$_="mailto:$X";if($We=is_url($X))$_=(($We=="http"&&$ba)||preg_match('~WebKit|Firefox~i',$_SERVER["HTTP_USER_AGENT"])?$X:"https://www.adminer.org/redirect/?url=".urlencode($X));}$K=$b->editVal($X,$k);if($K!==null){if($K==="")$K="&nbsp;";elseif(!is_utf8($K))$K="\0";elseif($ng!=""&&is_shortable($k))$K=shorten_utf8($K,max(0,+$ng));else$K=h($K);}return$b->selectVal($K,$_,$k,$X);}function
  142. is_mail($Tb){$va='[-a-z0-9!#$%&\'*+/=?^_`{|}~]';$Gb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';$Fe="$va+(\\.$va+)*@($Gb?\\.)+$Gb";return
  143. is_string($Tb)&&preg_match("(^$Fe(,\\s*$Fe)*\$)i",$Tb);}function
  144. is_url($Sf){$Gb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return(preg_match("~^(https?)://($Gb?\\.)+$Gb(:\\d+)?(/.*)?(\\?.*)?(#.*)?\$~i",$Sf,$B)?strtolower($B[1]):"");}function
  145. is_shortable($k){return
  146. preg_match('~char|text|lob|geometry|point|linestring|polygon|string|bytea~',$k["type"]);}function
  147. count_rows($Q,$Z,$bd,$r){global$x;$I=" FROM ".table($Q).($Z?" WHERE ".implode(" AND ",$Z):"");return($bd&&($x=="sql"||count($r)==1)?"SELECT COUNT(DISTINCT ".implode(", ",$r).")$I":"SELECT COUNT(*)".($bd?" FROM (SELECT 1$I$Dc) x":$I));}function
  148. slow_query($I){global$b,$T;$i=$b->database();$pg=$b->queryTimeout();if(support("kill")&&is_object($f=connect())&&($i==""||$f->select_db($i))){$hd=$f->result(connection_id());echo'<script',nonce(),'>
  149. var timeout = setTimeout(function () {
  150. ajax(\'',js_escape(ME),'script=kill\', function () {
  151. }, \'kill=',$hd,'&token=',$T,'\');
  152. }, ',1000*$pg,');
  153. </script>
  154. ';}else$f=null;ob_flush();flush();$K=@get_key_vals($I,$f,$pg,false);if($f){echo
  155. script("clearTimeout(timeout);");ob_flush();flush();}return$K;}function
  156. get_token(){$bf=rand(1,1e6);return($bf^$_SESSION["token"]).":$bf";}function
  157. verify_token(){list($T,$bf)=explode(":",$_POST["token"]);return($bf^$_SESSION["token"])==$T;}function
  158. lzw_decompress($Da){$Cb=256;$Ea=8;$Ta=array();$mf=0;$nf=0;for($s=0;$s<strlen($Da);$s++){$mf=($mf<<8)+ord($Da[$s]);$nf+=8;if($nf>=$Ea){$nf-=$Ea;$Ta[]=$mf>>$nf;$mf&=(1<<$nf)-1;$Cb++;if($Cb>>$Ea)$Ea++;}}$Bb=range("\0","\xFF");$K="";foreach($Ta
  159. as$s=>$Sa){$Sb=$Bb[$Sa];if(!isset($Sb))$Sb=$gh.$gh[0];$K.=$Sb;if($s)$Bb[]=$gh.$Sb[0];$gh=$Sb;}return$K;}function
  160. on_help($Za,$Gf=0){return
  161. script("mixin(qsl('select, input'), {onmouseover: function (event) { helpMouseover.call(this, event, $Za, $Gf) }, onmouseout: helpMouseout});","");}function
  162. edit_form($a,$l,$L,$Og){global$b,$x,$T,$j;$bg=$b->tableName(table_status1($a,true));page_header(($Og?'Edit':'Insert'),$j,array("select"=>array($a,$bg)),$bg);if($L===false)echo"<p class='error'>".'No rows.'."\n";echo'<form action="" method="post" enctype="multipart/form-data" id="form">
  163. ';if(!$l)echo"<p class='error'>".'You have no privileges to update this table.'."\n";else{echo"<table cellspacing='0'>".script("qsl('table').onkeydown = editingKeydown;");foreach($l
  164. as$E=>$k){echo"<tr><th>".$b->fieldName($k);$yb=$_GET["set"][bracket_escape($E)];if($yb===null){$yb=$k["default"];if($k["type"]=="bit"&&preg_match("~^b'([01]*)'\$~",$yb,$jf))$yb=$jf[1];}$Y=($L!==null?($L[$E]!=""&&$x=="sql"&&preg_match("~enum|set~",$k["type"])?(is_array($L[$E])?array_sum($L[$E]):+$L[$E]):$L[$E]):(!$Og&&$k["auto_increment"]?"":(isset($_GET["select"])?false:$yb)));if(!$_POST["save"]&&is_string($Y))$Y=$b->editVal($Y,$k);$p=($_POST["save"]?(string)$_POST["function"][$E]:($Og&&$k["on_update"]=="CURRENT_TIMESTAMP"?"now":($Y===false?null:($Y!==null?'':'NULL'))));if(preg_match("~time~",$k["type"])&&$Y=="CURRENT_TIMESTAMP"){$Y="";$p="now";}input($k,$Y,$p);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($l){echo"<input type='submit' value='".'Save'."'>\n";if(!isset($_GET["select"])){echo"<input type='submit' name='insert' value='".($Og?'Save and continue edit':'Save and insert next')."' title='Ctrl+Shift+Enter'>\n",($Og?script("qsl('input').onclick = function () { return !ajaxForm(this.form, '".'Saving'."...', this); };"):"");}}echo($Og?"<input type='submit' name='delete' value='".'Delete'."'>".confirm()."\n":($_POST||!$l?"":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"]),'">
  165. <input type="hidden" name="save" value="1">
  166. <input type="hidden" name="token" value="',$T,'">
  167. </form>
  168. ';}global$b,$e,$Ib,$Pb,$Zb,$j,$Bc,$Ec,$ba,$Uc,$x,$ca,$ld,$de,$Ge,$Tf,$Ic,$T,$Bg,$Gg,$Ng,$ga;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]";$ba=$_SERVER["HTTPS"]&&strcasecmp($_SERVER["HTTPS"],"off");@ini_set("session.use_trans_sid",false);if(!defined("SID")){session_cache_limiter("");session_name("adminer_sid");$ye=array(0,preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]),"",$ba);if(version_compare(PHP_VERSION,'5.2.0')>=0)$ye[]=true;call_user_func_array('session_set_cookie_params',$ye);session_start();}remove_slashes(array(&$_GET,&$_POST,&$_COOKIE),$sc);if(get_magic_quotes_runtime())set_magic_quotes_runtime(false);@set_time_limit(0);@ini_set("zend.ze1_compatibility_mode",false);@ini_set("precision",17);function
  169. get_lang(){return'en';}function
  170. lang($Ag,$Ud=null){if(is_array($Ag)){$Je=($Ud==1?0:1);$Ag=$Ag[$Je];}$Ag=str_replace("%d","%s",$Ag);$Ud=format_number($Ud);return
  171. sprintf($Ag,$Ud);}if(extension_loaded('pdo')){class
  172. Min_PDO
  173. extends
  174. PDO{var$_result,$server_info,$affected_rows,$errno,$error;function
  175. __construct(){global$b;$Je=array_search("SQL",$b->operators);if($Je!==false)unset($b->operators[$Je]);}function
  176. dsn($Mb,$V,$G){try{parent::__construct($Mb,$V,$G);}catch(Exception$ec){auth_error(h($ec->getMessage()));}$this->setAttribute(13,array('Min_PDOStatement'));$this->server_info=@$this->getAttribute(4);}function
  177. query($I,$Hg=false){$J=parent::query($I);$this->error="";if(!$J){list(,$this->errno,$this->error)=$this->errorInfo();return
  178. false;}$this->store_result($J);return$J;}function
  179. multi_query($I){return$this->_result=$this->query($I);}function
  180. store_result($J=null){if(!$J){$J=$this->_result;if(!$J)return
  181. false;}if($J->columnCount()){$J->num_rows=$J->rowCount();return$J;}$this->affected_rows=$J->rowCount();return
  182. true;}function
  183. next_result(){if(!$this->_result)return
  184. false;$this->_result->_offset=0;return@$this->_result->nextRowset();}function
  185. result($I,$k=0){$J=$this->query($I);if(!$J)return
  186. false;$L=$J->fetch();return$L[$k];}}class
  187. Min_PDOStatement
  188. extends
  189. PDOStatement{var$_offset=0,$num_rows;function
  190. fetch_assoc(){return$this->fetch(2);}function
  191. fetch_row(){return$this->fetch(3);}function
  192. fetch_field(){$L=(object)$this->getColumnMeta($this->_offset++);$L->orgtable=$L->table;$L->orgname=$L->name;$L->charsetnr=(in_array("blob",(array)$L->flags)?63:0);return$L;}}}$Ib=array();class
  193. Min_SQL{var$_conn;function
  194. __construct($e){$this->_conn=$e;}function
  195. select($Q,$N,$Z,$r,$le=array(),$z=1,$F=0,$Qe=false){global$b,$x;$bd=(count($r)<count($N));$I=$b->selectQueryBuild($N,$Z,$r,$le,$z,$F);if(!$I)$I="SELECT".limit(($_GET["page"]!="last"&&$z!=""&&$r&&$bd&&$x=="sql"?"SQL_CALC_FOUND_ROWS ":"").implode(", ",$N)."\nFROM ".table($Q),($Z?"\nWHERE ".implode(" AND ",$Z):"").($r&&$bd?"\nGROUP BY ".implode(", ",$r):"").($le?"\nORDER BY ".implode(", ",$le):""),($z!=""?+$z:null),($F?$z*$F:0),"\n");$Of=microtime(true);$K=$this->_conn->query($I);if($Qe)echo$b->selectQuery($I,format_time($Of));return$K;}function
  196. delete($Q,$Ze,$z=0){$I="FROM ".table($Q);return
  197. queries("DELETE".($z?limit1($I,$Ze):" $I$Ze"));}function
  198. update($Q,$P,$Ze,$z=0,$Bf="\n"){$Wg=array();foreach($P
  199. as$y=>$X)$Wg[]="$y = $X";$I=table($Q)." SET$Bf".implode(",$Bf",$Wg);return
  200. queries("UPDATE".($z?limit1($I,$Ze):" $I$Ze"));}function
  201. insert($Q,$P){return
  202. queries("INSERT INTO ".table($Q).($P?" (".implode(", ",array_keys($P)).")\nVALUES (".implode(", ",$P).")":" DEFAULT VALUES"));}function
  203. insertUpdate($Q,$M,$Pe){return
  204. false;}function
  205. begin(){return
  206. queries("BEGIN");}function
  207. commit(){return
  208. queries("COMMIT");}function
  209. rollback(){return
  210. queries("ROLLBACK");}}$Ib=array("server"=>"MySQL")+$Ib;if(!defined("DRIVER")){$Me=array("MySQLi","MySQL","PDO_MySQL");define("DRIVER","server");if(extension_loaded("mysqli")){class
  211. Min_DB
  212. extends
  213. MySQLi{var$extension="MySQLi";function
  214. __construct(){parent::init();}function
  215. connect($O="",$V="",$G="",$tb=null,$Ie=null,$If=null){mysqli_report(MYSQLI_REPORT_OFF);list($Mc,$Ie)=explode(":",$O,2);$K=@$this->real_connect(($O!=""?$Mc:ini_get("mysqli.default_host")),($O.$V!=""?$V:ini_get("mysqli.default_user")),($O.$V.$G!=""?$G:ini_get("mysqli.default_pw")),$tb,(is_numeric($Ie)?$Ie:ini_get("mysqli.default_port")),(!is_numeric($Ie)?$Ie:$If));return$K;}function
  216. set_charset($La){if(parent::set_charset($La))return
  217. true;parent::set_charset('utf8');return$this->query("SET NAMES $La");}function
  218. result($I,$k=0){$J=$this->query($I);if(!$J)return
  219. false;$L=$J->fetch_array();return$L[$k];}function
  220. quote($Sf){return"'".$this->escape_string($Sf)."'";}}}elseif(extension_loaded("mysql")&&!(ini_get("sql.safe_mode")&&extension_loaded("pdo_mysql"))){class
  221. Min_DB{var$extension="MySQL",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
  222. connect($O,$V,$G){$this->_link=@mysql_connect(($O!=""?$O:ini_get("mysql.default_host")),("$O$V"!=""?$V:ini_get("mysql.default_user")),("$O$V$G"!=""?$G: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
  223. set_charset($La){if(function_exists('mysql_set_charset')){if(mysql_set_charset($La,$this->_link))return
  224. true;mysql_set_charset('utf8',$this->_link);}return$this->query("SET NAMES $La");}function
  225. quote($Sf){return"'".mysql_real_escape_string($Sf,$this->_link)."'";}function
  226. select_db($tb){return
  227. mysql_select_db($tb,$this->_link);}function
  228. query($I,$Hg=false){$J=@($Hg?mysql_unbuffered_query($I,$this->_link):mysql_query($I,$this->_link));$this->error="";if(!$J){$this->errno=mysql_errno($this->_link);$this->error=mysql_error($this->_link);return
  229. false;}if($J===true){$this->affected_rows=mysql_affected_rows($this->_link);$this->info=mysql_info($this->_link);return
  230. true;}return
  231. new
  232. Min_Result($J);}function
  233. multi_query($I){return$this->_result=$this->query($I);}function
  234. store_result(){return$this->_result;}function
  235. next_result(){return
  236. false;}function
  237. result($I,$k=0){$J=$this->query($I);if(!$J||!$J->num_rows)return
  238. false;return
  239. mysql_result($J->_result,0,$k);}}class
  240. Min_Result{var$num_rows,$_result,$_offset=0;function
  241. __construct($J){$this->_result=$J;$this->num_rows=mysql_num_rows($J);}function
  242. fetch_assoc(){return
  243. mysql_fetch_assoc($this->_result);}function
  244. fetch_row(){return
  245. mysql_fetch_row($this->_result);}function
  246. fetch_field(){$K=mysql_fetch_field($this->_result,$this->_offset++);$K->orgtable=$K->table;$K->orgname=$K->name;$K->charsetnr=($K->blob?63:0);return$K;}function
  247. __destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
  248. Min_DB
  249. extends
  250. Min_PDO{var$extension="PDO_MySQL";function
  251. connect($O,$V,$G){$this->dsn("mysql:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\\d)~',';port=\\1',$O)),$V,$G);return
  252. true;}function
  253. set_charset($La){$this->query("SET NAMES $La");}function
  254. select_db($tb){return$this->query("USE ".idf_escape($tb));}function
  255. query($I,$Hg=false){$this->setAttribute(1000,!$Hg);return
  256. parent::query($I,$Hg);}}}class
  257. Min_Driver
  258. extends
  259. Min_SQL{function
  260. insert($Q,$P){return($P?parent::insert($Q,$P):queries("INSERT INTO ".table($Q)." ()\nVALUES ()"));}function
  261. insertUpdate($Q,$M,$Pe){$d=array_keys(reset($M));$Ne="INSERT INTO ".table($Q)." (".implode(", ",$d).") VALUES\n";$Wg=array();foreach($d
  262. as$y)$Wg[$y]="$y = VALUES($y)";$Wf="\nON DUPLICATE KEY UPDATE ".implode(", ",$Wg);$Wg=array();$sd=0;foreach($M
  263. as$P){$Y="(".implode(", ",$P).")";if($Wg&&(strlen($Ne)+$sd+strlen($Y)+strlen($Wf)>1e6)){if(!queries($Ne.implode(",\n",$Wg).$Wf))return
  264. false;$Wg=array();$sd=0;}$Wg[]=$Y;$sd+=strlen($Y)+2;}return
  265. queries($Ne.implode(",\n",$Wg).$Wf);}}function
  266. idf_escape($Pc){return"`".str_replace("`","``",$Pc)."`";}function
  267. table($Pc){return
  268. idf_escape($Pc);}function
  269. connect(){global$b,$Gg,$Tf;$e=new
  270. Min_DB;$mb=$b->credentials();if($e->connect($mb[0],$mb[1],$mb[2])){$e->set_charset(charset($e));$e->query("SET sql_quote_show_create = 1, autocommit = 1");if(version_compare($e->server_info,'5.7.8')>=0){$Tf['Strings'][]="json";$Gg["json"]=4294967295;}return$e;}$K=$e->error;if(function_exists('iconv')&&!is_utf8($K)&&strlen($uf=iconv("windows-1250","utf-8",$K))>strlen($K))$K=$uf;return$K;}function
  271. get_databases($uc){global$e;$K=get_session("dbs");if($K===null){$I=($e->server_info>=5?"SELECT SCHEMA_NAME FROM information_schema.SCHEMATA":"SHOW DATABASES");$K=($uc?slow_query($I):get_vals($I));restart_session();set_session("dbs",$K);stop_session();}return$K;}function
  272. limit($I,$Z,$z,$Wd=0,$Bf=" "){return" $I$Z".($z!==null?$Bf."LIMIT $z".($Wd?" OFFSET $Wd":""):"");}function
  273. limit1($I,$Z){return
  274. limit($I,$Z,1);}function
  275. db_collation($i,$Xa){global$e;$K=null;$g=$e->result("SHOW CREATE DATABASE ".idf_escape($i),1);if(preg_match('~ COLLATE ([^ ]+)~',$g,$B))$K=$B[1];elseif(preg_match('~ CHARACTER SET ([^ ]+)~',$g,$B))$K=$Xa[$B[1]][-1];return$K;}function
  276. engines(){$K=array();foreach(get_rows("SHOW ENGINES")as$L){if(preg_match("~YES|DEFAULT~",$L["Support"]))$K[]=$L["Engine"];}return$K;}function
  277. logged_user(){global$e;return$e->result("SELECT USER()");}function
  278. tables_list(){global$e;return
  279. get_key_vals($e->server_info>=5?"SELECT TABLE_NAME, TABLE_TYPE FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ORDER BY TABLE_NAME":"SHOW TABLES");}function
  280. count_tables($h){$K=array();foreach($h
  281. as$i)$K[$i]=count(get_vals("SHOW TABLES IN ".idf_escape($i)));return$K;}function
  282. table_status($E="",$nc=false){global$e;$K=array();foreach(get_rows($nc&&$e->server_info>=5?"SELECT TABLE_NAME AS Name, ENGINE AS Engine, TABLE_COMMENT AS Comment FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ".($E!=""?"AND TABLE_NAME = ".q($E):"ORDER BY Name"):"SHOW TABLE STATUS".($E!=""?" LIKE ".q(addcslashes($E,"%_\\")):""))as$L){if($L["Engine"]=="InnoDB")$L["Comment"]=preg_replace('~(?:(.+); )?InnoDB free: .*~','\\1',$L["Comment"]);if(!isset($L["Engine"]))$L["Comment"]="";if($E!="")return$L;$K[$L["Name"]]=$L;}return$K;}function
  283. is_view($R){return$R["Engine"]===null;}function
  284. fk_support($R){global$e;return
  285. preg_match('~InnoDB|IBMDB2I~i',$R["Engine"])||(preg_match('~NDB~i',$R["Engine"])&&version_compare($e->server_info,'5.6')>=0);}function
  286. fields($Q){$K=array();foreach(get_rows("SHOW FULL COLUMNS FROM ".table($Q))as$L){preg_match('~^([^( ]+)(?:\\((.+)\\))?( unsigned)?( zerofill)?$~',$L["Type"],$B);$K[$L["Field"]]=array("field"=>$L["Field"],"full_type"=>$L["Type"],"type"=>$B[1],"length"=>$B[2],"unsigned"=>ltrim($B[3].$B[4]),"default"=>($L["Default"]!=""||preg_match("~char|set~",$B[1])?$L["Default"]:null),"null"=>($L["Null"]=="YES"),"auto_increment"=>($L["Extra"]=="auto_increment"),"on_update"=>(preg_match('~^on update (.+)~i',$L["Extra"],$B)?$B[1]:""),"collation"=>$L["Collation"],"privileges"=>array_flip(preg_split('~, *~',$L["Privileges"])),"comment"=>$L["Comment"],"primary"=>($L["Key"]=="PRI"),);}return$K;}function
  287. indexes($Q,$f=null){$K=array();foreach(get_rows("SHOW INDEX FROM ".table($Q),$f)as$L){$E=$L["Key_name"];$K[$E]["type"]=($E=="PRIMARY"?"PRIMARY":($L["Index_type"]=="FULLTEXT"?"FULLTEXT":($L["Non_unique"]?($L["Index_type"]=="SPATIAL"?"SPATIAL":"INDEX"):"UNIQUE")));$K[$E]["columns"][]=$L["Column_name"];$K[$E]["lengths"][]=($L["Index_type"]=="SPATIAL"?null:$L["Sub_part"]);$K[$E]["descs"][]=null;}return$K;}function
  288. foreign_keys($Q){global$e,$de;static$Fe='`(?:[^`]|``)+`';$K=array();$kb=$e->result("SHOW CREATE TABLE ".table($Q),1);if($kb){preg_match_all("~CONSTRAINT ($Fe) FOREIGN KEY ?\\(((?:$Fe,? ?)+)\\) REFERENCES ($Fe)(?:\\.($Fe))? \\(((?:$Fe,? ?)+)\\)(?: ON DELETE ($de))?(?: ON UPDATE ($de))?~",$kb,$yd,PREG_SET_ORDER);foreach($yd
  289. as$B){preg_match_all("~$Fe~",$B[2],$Jf);preg_match_all("~$Fe~",$B[5],$ig);$K[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',$Jf[0]),"target"=>array_map('idf_unescape',$ig[0]),"on_delete"=>($B[6]?$B[6]:"RESTRICT"),"on_update"=>($B[7]?$B[7]:"RESTRICT"),);}}return$K;}function
  290. view($E){global$e;return
  291. array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)*\\s+AS\\s+~isU','',$e->result("SHOW CREATE VIEW ".table($E),1)));}function
  292. collations(){$K=array();foreach(get_rows("SHOW COLLATION")as$L){if($L["Default"])$K[$L["Charset"]][-1]=$L["Collation"];else$K[$L["Charset"]][]=$L["Collation"];}ksort($K);foreach($K
  293. as$y=>$X)asort($K[$y]);return$K;}function
  294. information_schema($i){global$e;return($e->server_info>=5&&$i=="information_schema")||($e->server_info>=5.5&&$i=="performance_schema");}function
  295. error(){global$e;return
  296. h(preg_replace('~^You have an error.*syntax to use~U',"Syntax error",$e->error));}function
  297. create_database($i,$Wa){return
  298. queries("CREATE DATABASE ".idf_escape($i).($Wa?" COLLATE ".q($Wa):""));}function
  299. drop_databases($h){$K=apply_queries("DROP DATABASE",$h,'idf_escape');restart_session();set_session("dbs",null);return$K;}function
  300. rename_database($E,$Wa){$K=false;if(create_database($E,$Wa)){$kf=array();foreach(tables_list()as$Q=>$U)$kf[]=table($Q)." TO ".idf_escape($E).".".table($Q);$K=(!$kf||queries("RENAME TABLE ".implode(", ",$kf)));if($K)queries("DROP DATABASE ".idf_escape(DB));restart_session();set_session("dbs",null);}return$K;}function
  301. auto_increment(){$za=" PRIMARY KEY";if($_GET["create"]!=""&&$_POST["auto_increment_col"]){foreach(indexes($_GET["create"])as$u){if(in_array($_POST["fields"][$_POST["auto_increment_col"]]["orig"],$u["columns"],true)){$za="";break;}if($u["type"]=="PRIMARY")$za=" UNIQUE";}}return" AUTO_INCREMENT$za";}function
  302. alter_table($Q,$E,$l,$vc,$bb,$Xb,$Wa,$ya,$Be){$sa=array();foreach($l
  303. as$k)$sa[]=($k[1]?($Q!=""?($k[0]!=""?"CHANGE ".idf_escape($k[0]):"ADD"):" ")." ".implode($k[1]).($Q!=""?$k[2]:""):"DROP ".idf_escape($k[0]));$sa=array_merge($sa,$vc);$Pf=($bb!==null?" COMMENT=".q($bb):"").($Xb?" ENGINE=".q($Xb):"").($Wa?" COLLATE ".q($Wa):"").($ya!=""?" AUTO_INCREMENT=$ya":"");if($Q=="")return
  304. queries("CREATE TABLE ".table($E)." (\n".implode(",\n",$sa)."\n)$Pf$Be");if($Q!=$E)$sa[]="RENAME TO ".table($E);if($Pf)$sa[]=ltrim($Pf);return($sa||$Be?queries("ALTER TABLE ".table($Q)."\n".implode(",\n",$sa).$Be):true);}function
  305. alter_indexes($Q,$sa){foreach($sa
  306. as$y=>$X)$sa[$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
  307. queries("ALTER TABLE ".table($Q).implode(",",$sa));}function
  308. truncate_tables($S){return
  309. apply_queries("TRUNCATE TABLE",$S);}function
  310. drop_views($bh){return
  311. queries("DROP VIEW ".implode(", ",array_map('table',$bh)));}function
  312. drop_tables($S){return
  313. queries("DROP TABLE ".implode(", ",array_map('table',$S)));}function
  314. move_tables($S,$bh,$ig){$kf=array();foreach(array_merge($S,$bh)as$Q)$kf[]=table($Q)." TO ".idf_escape($ig).".".table($Q);return
  315. queries("RENAME TABLE ".implode(", ",$kf));}function
  316. copy_tables($S,$bh,$ig){queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");foreach($S
  317. as$Q){$E=($ig==DB?table("copy_$Q"):idf_escape($ig).".".table($Q));if(!queries("\nDROP TABLE IF EXISTS $E")||!queries("CREATE TABLE $E LIKE ".table($Q))||!queries("INSERT INTO $E SELECT * FROM ".table($Q)))return
  318. false;}foreach($bh
  319. as$Q){$E=($ig==DB?table("copy_$Q"):idf_escape($ig).".".table($Q));$ah=view($Q);if(!queries("DROP VIEW IF EXISTS $E")||!queries("CREATE VIEW $E AS $ah[select]"))return
  320. false;}return
  321. true;}function
  322. trigger($E){if($E=="")return
  323. array();$M=get_rows("SHOW TRIGGERS WHERE `Trigger` = ".q($E));return
  324. reset($M);}function
  325. triggers($Q){$K=array();foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($Q,"%_\\")))as$L)$K[$L["Trigger"]]=array($L["Timing"],$L["Event"]);return$K;}function
  326. trigger_options(){return
  327. array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
  328. routine($E,$U){global$e,$Zb,$Uc,$Gg;$qa=array("bool","boolean","integer","double precision","real","dec","numeric","fixed","national char","national varchar");$Kf="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$Fg="((".implode("|",array_merge(array_keys($Gg),$qa)).")\\b(?:\\s*\\(((?:[^'\")]|$Zb)++)\\))?\\s*(zerofill\\s*)?(unsigned(?:\\s+zerofill)?)?)(?:\\s*(?:CHARSET|CHARACTER\\s+SET)\\s*['\"]?([^'\"\\s,]+)['\"]?)?";$Fe="$Kf*(".($U=="FUNCTION"?"":$Uc).")?\\s*(?:`((?:[^`]|``)*)`\\s*|\\b(\\S+)\\s+)$Fg";$g=$e->result("SHOW CREATE $U ".idf_escape($E),2);preg_match("~\\(((?:$Fe\\s*,?)*)\\)\\s*".($U=="FUNCTION"?"RETURNS\\s+$Fg\\s+":"")."(.*)~is",$g,$B);$l=array();preg_match_all("~$Fe\\s*,?~is",$B[1],$yd,PREG_SET_ORDER);foreach($yd
  329. as$xe){$E=str_replace("``","`",$xe[2]).$xe[3];$l[]=array("field"=>$E,"type"=>strtolower($xe[5]),"length"=>preg_replace_callback("~$Zb~s",'normalize_enum',$xe[6]),"unsigned"=>strtolower(preg_replace('~\\s+~',' ',trim("$xe[8] $xe[7]"))),"null"=>1,"full_type"=>$xe[4],"inout"=>strtoupper($xe[1]),"collation"=>strtolower($xe[9]),);}if($U!="FUNCTION")return
  330. array("fields"=>$l,"definition"=>$B[11]);return
  331. array("fields"=>$l,"returns"=>array("type"=>$B[12],"length"=>$B[13],"unsigned"=>$B[15],"collation"=>$B[16]),"definition"=>$B[17],"language"=>"SQL",);}function
  332. routines(){return
  333. get_rows("SELECT ROUTINE_NAME, ROUTINE_TYPE, DTD_IDENTIFIER FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".q(DB));}function
  334. routine_languages(){return
  335. array();}function
  336. last_id(){global$e;return$e->result("SELECT LAST_INSERT_ID()");}function
  337. explain($e,$I){return$e->query("EXPLAIN ".($e->server_info>=5.1?"PARTITIONS ":"").$I);}function
  338. found_rows($R,$Z){return($Z||$R["Engine"]!="InnoDB"?null:$R["Rows"]);}function
  339. types(){return
  340. array();}function
  341. schemas(){return
  342. array();}function
  343. get_schema(){return"";}function
  344. set_schema($wf){return
  345. true;}function
  346. create_sql($Q,$ya,$Uf){global$e;$K=$e->result("SHOW CREATE TABLE ".table($Q),1);if(!$ya)$K=preg_replace('~ AUTO_INCREMENT=\\d+~','',$K);return$K;}function
  347. truncate_sql($Q){return"TRUNCATE ".table($Q);}function
  348. use_sql($tb){return"USE ".idf_escape($tb);}function
  349. trigger_sql($Q){$K="";foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($Q,"%_\\")),null,"-- ")as$L)$K.="\nCREATE TRIGGER ".idf_escape($L["Trigger"])." $L[Timing] $L[Event] ON ".table($L["Table"])." FOR EACH ROW\n$L[Statement];;\n";return$K;}function
  350. show_variables(){return
  351. get_key_vals("SHOW VARIABLES");}function
  352. process_list(){return
  353. get_rows("SHOW FULL PROCESSLIST");}function
  354. show_status(){return
  355. get_key_vals("SHOW STATUS");}function
  356. convert_field($k){global$e;if(preg_match("~binary~",$k["type"]))return"HEX(".idf_escape($k["field"]).")";if($k["type"]=="bit")return"BIN(".idf_escape($k["field"])." + 0)";if(preg_match("~geometry|point|linestring|polygon~",$k["type"]))return($e->server_info>=8?"ST_":"")."AsWKT(".idf_escape($k["field"]).")";}function
  357. unconvert_field($k,$K){if(preg_match("~binary~",$k["type"]))$K="UNHEX($K)";if($k["type"]=="bit")$K="CONV($K, 2, 10) + 0";if(preg_match("~geometry|point|linestring|polygon~",$k["type"]))$K="GeomFromText($K)";return$K;}function
  358. support($oc){global$e;return!preg_match("~scheme|sequence|type|view_trigger|materializedview".($e->server_info<5.1?"|event|partitioning".($e->server_info<5?"|routine|trigger|view":""):"")."~",$oc);}function
  359. kill_process($X){return
  360. queries("KILL ".number($X));}function
  361. connection_id(){return"SELECT CONNECTION_ID()";}function
  362. max_connections(){global$e;return$e->result("SELECT @@max_connections");}$x="sql";$Gg=array();$Tf=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){$Gg+=$X;$Tf[$y]=array_keys($X);}$Ng=array("unsigned","zerofill","unsigned zerofill");$he=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","REGEXP","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$Bc=array("char_length","date","from_unixtime","lower","round","sec_to_time","time_to_sec","upper");$Ec=array("avg","count","count distinct","group_concat","max","min","sum");$Pb=array(array("char"=>"md5/sha1/password/encrypt/uuid","binary"=>"md5/sha1","date|time"=>"now",),array("(^|[^o])int|float|double|decimal"=>"+/-","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"])."&":""):''));$ga="4.5.0";class
  363. Adminer{var$operators;function
  364. name(){return"<a href='https://www.adminer.org/'".target_blank()." id='h1'>Adminer</a>";}function
  365. credentials(){return
  366. array(SERVER,$_GET["username"],get_password());}function
  367. permanentLogin($g=false){return
  368. password_file($g);}function
  369. bruteForceKey(){return$_SERVER["REMOTE_ADDR"];}function
  370. database(){return
  371. DB;}function
  372. databases($uc=true){return
  373. get_databases($uc);}function
  374. schemas(){return
  375. schemas();}function
  376. queryTimeout(){return
  377. 5;}function
  378. headers(){}function
  379. csp(){return
  380. csp();}function
  381. head(){return
  382. true;}function
  383. css(){$K=array();$rc="adminer.css";if(file_exists($rc))$K[]=$rc;return$K;}function
  384. loginForm(){global$Ib;?>
  385. <table cellspacing="0">
  386. <tr><th>System<td><input type='hidden' name='auth[driver]' value='server'>MySQL
  387. <tr><th>Server<td><input name="auth[server]" value="<?php echo
  388. h(SERVER),'" title="hostname[:port]" placeholder="localhost" autocapitalize="off">
  389. <tr><th>Username<td><input name="auth[username]" id="username" value="',h($_GET["username"]),'" autocapitalize="off">
  390. <tr><th>Password<td><input type="password" name="auth[password]">
  391. <tr><th>Database<td><input name="auth[db]" value="',h($_GET["db"]),'" autocapitalize="off">
  392. </table>
  393. ',script("focus(qs('#username'));"),"<p><input type='submit' value='".'Login'."'>\n",checkbox("auth[permanent]",1,$_COOKIE["adminer_permanent"],'Permanent login')."\n";}function
  394. login($wd,$G){global$x;if($x=="sqlite")return
  395. sprintf('<a href="https://www.adminer.org/en/extension/"%s>Implement</a> %s method to use SQLite.',target_blank(),'<code>login()</code>');return
  396. true;}function
  397. tableName($ag){return
  398. h($ag["Name"]);}function
  399. fieldName($k,$le=0){return'<span title="'.h($k["full_type"]).'">'.h($k["field"]).'</span>';}function
  400. selectLinks($ag,$P=""){echo'<p class="links">';$vd=array("select"=>'Select data');if(support("table")||support("indexes"))$vd["table"]='Show structure';if(support("table")){if(is_view($ag))$vd["view"]='Alter view';else$vd["create"]='Alter table';}if($P!==null)$vd["edit"]='New item';foreach($vd
  401. as$y=>$X)echo" <a href='".h(ME)."$y=".urlencode($ag["Name"]).($y=="edit"?$P:"")."'".bold(isset($_GET[$y])).">$X</a>";echo"\n";}function
  402. foreignKeys($Q){return
  403. foreign_keys($Q);}function
  404. backwardKeys($Q,$Zf){return
  405. array();}function
  406. backwardKeysPrint($Aa,$L){}function
  407. selectQuery($I,$og){global$x;return"<p><code class='jush-$x'>".h(str_replace("\n"," ",$I))."</code> <span class='time'>($og)</span>".(support("sql")?" <a href='".h(ME)."sql=".urlencode($I)."'>".'Edit'."</a>":"")."</p>";}function
  408. sqlCommandQuery($I){return
  409. shorten_utf8(trim($I),1000);}function
  410. rowDescription($Q){return"";}function
  411. rowDescriptions($M,$wc){return$M;}function
  412. selectLink($X,$k){}function
  413. selectVal($X,$_,$k,$te){$K=($X===null?"<i>NULL</i>":(preg_match("~char|binary|boolean~",$k["type"])&&!preg_match("~var~",$k["type"])?"<code>$X</code>":$X));if(preg_match('~blob|bytea|raw|file~',$k["type"])&&!is_utf8($X))$K="<i>".lang(array('%d byte','%d bytes'),strlen($te))."</i>";if(preg_match('~json~',$k["type"]))$K="<code class='jush-js'>$K</code>";return($_?"<a href='".h($_)."'".(is_url($_)?" rel='noreferrer'":"").">$K</a>":$K);}function
  414. editVal($X,$k){return$X;}function
  415. tableStructurePrint($l){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr><th>".'Column'."<td>".'Type'.(support("comment")?"<td>".'Comment':"")."</thead>\n";foreach($l
  416. as$k){echo"<tr".odd()."><th>".h($k["field"]),"<td><span title='".h($k["collation"])."'>".h($k["full_type"])."</span>",($k["null"]?" <i>NULL</i>":""),($k["auto_increment"]?" <i>".'Auto Increment'."</i>":""),(isset($k["default"])?" <span title='".'Default value'."'>[<b>".h($k["default"])."</b>]</span>":""),(support("comment")?"<td>".nbsp($k["comment"]):""),"\n";}echo"</table>\n";}function
  417. tableIndexesPrint($v){echo"<table cellspacing='0'>\n";foreach($v
  418. as$E=>$u){ksort($u["columns"]);$Qe=array();foreach($u["columns"]as$y=>$X)$Qe[]="<i>".h($X)."</i>".($u["lengths"][$y]?"(".$u["lengths"][$y].")":"").($u["descs"][$y]?" DESC":"");echo"<tr title='".h($E)."'><th>$u[type]<td>".implode(", ",$Qe)."\n";}echo"</table>\n";}function
  419. selectColumnsPrint($N,$d){global$Bc,$Ec;print_fieldset("select",'Select',$N);$s=0;$N[""]=array();foreach($N
  420. as$y=>$X){$X=$_GET["columns"][$y];$c=select_input(" name='columns[$s][col]'",$d,$X["col"],($y!==""?"selectFieldChange":"selectAddRow"));echo"<div>".($Bc||$Ec?"<select name='columns[$s][fun]'>".optionlist(array(-1=>"")+array_filter(array('Functions'=>$Bc,'Aggregation'=>$Ec)),$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();")." };","")."($c)":$c)."</div>\n";$s++;}echo"</div></fieldset>\n";}function
  421. selectSearchPrint($Z,$d,$v){print_fieldset("search",'Search',$Z);foreach($v
  422. as$s=>$u){if($u["type"]=="FULLTEXT"){echo"<div>(<i>".implode("</i>, <i>",array_map('h',$u["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";}}$_GET["where"]=(array)$_GET["where"];reset($_GET["where"]);$Ka="this.parentNode.firstChild.onchange();";for($s=0;$s<=count($_GET["where"]);$s++){list(,$X)=each($_GET["where"]);if(!$X||("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators))){echo"<div>".select_input(" name='where[$s][col]'",$d,$X["col"],($X?"selectFieldChange":"selectAddRow"),"(".'anywhere'.")"),html_select("where[$s][op]",$this->operators,$X["op"],$Ka),"<input type='search' name='where[$s][val]' value='".h($X["val"])."'>",script("mixin(qsl('input'), {oninput: function () { $Ka }, onkeydown: selectSearchKeydown, onsearch: selectSearchSearch});",""),"</div>\n";}}echo"</div></fieldset>\n";}function
  423. selectOrderPrint($le,$d,$v){print_fieldset("sort",'Sort',$le);$s=0;foreach((array)$_GET["order"]as$y=>$X){if($X!=""){echo"<div>".select_input(" name='order[$s]'",$d,$X,"selectFieldChange"),checkbox("desc[$s]",1,isset($_GET["desc"][$y]),'descending')."</div>\n";$s++;}}echo"<div>".select_input(" name='order[$s]'",$d,"","selectAddRow"),checkbox("desc[$s]",1,false,'descending')."</div>\n","</div></fieldset>\n";}function
  424. 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
  425. selectLengthPrint($ng){if($ng!==null){echo"<fieldset><legend>".'Text length'."</legend><div>","<input type='number' name='text_length' class='size' value='".h($ng)."'>","</div></fieldset>\n";}}function
  426. selectActionPrint($v){echo"<fieldset><legend>".'Action'."</legend><div>","<input type='submit' value='".'Select'."'>"," <span id='noindex' title='".'Full table scan'."'></span>","<script".nonce().">\n","var indexColumns = ";$d=array();foreach($v
  427. as$u){$qb=reset($u["columns"]);if($u["type"]!="FULLTEXT"&&$qb)$d[$qb]=1;}$d[""]=1;foreach($d
  428. as$y=>$X)json_row($y);echo";\n","selectFieldChange.call(qs('#form')['select']);\n","</script>\n","</div></fieldset>\n";}function
  429. selectCommandPrint(){return!information_schema(DB);}function
  430. selectImportPrint(){return!information_schema(DB);}function
  431. selectEmailPrint($Ub,$d){}function
  432. selectColumnsProcess($d,$v){global$Bc,$Ec;$N=array();$r=array();foreach((array)$_GET["columns"]as$y=>$X){if($X["fun"]=="count"||($X["col"]!=""&&(!$X["fun"]||in_array($X["fun"],$Bc)||in_array($X["fun"],$Ec)))){$N[$y]=apply_sql_function($X["fun"],($X["col"]!=""?idf_escape($X["col"]):"*"));if(!in_array($X["fun"],$Ec))$r[]=$N[$y];}}return
  433. array($N,$r);}function
  434. selectSearchProcess($l,$v){global$e,$x;$K=array();foreach($v
  435. as$s=>$u){if($u["type"]=="FULLTEXT"&&$_GET["fulltext"][$s]!="")$K[]="MATCH (".implode(", ",array_map('idf_escape',$u["columns"])).") AGAINST (".q($_GET["fulltext"][$s]).(isset($_GET["boolean"][$s])?" IN BOOLEAN MODE":"").")";}foreach((array)$_GET["where"]as$X){if($X["op"]=="")$X["op"]="LIKE %%";if("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators)){$db=" $X[op]";if(preg_match('~IN$~',$X["op"])){$Rc=process_length($X["val"]);$db.=" ".($Rc!=""?$Rc:"(NULL)");}elseif($X["op"]=="SQL")$db=" $X[val]";elseif($X["op"]=="LIKE %%")$db=" LIKE ".$this->processInput($l[$X["col"]],"%$X[val]%");elseif($X["op"]=="ILIKE %%")$db=" ILIKE ".$this->processInput($l[$X["col"]],"%$X[val]%");elseif(!preg_match('~NULL$~',$X["op"]))$db.=" ".$this->processInput($l[$X["col"]],$X["val"]);if($X["col"]!="")$K[]=idf_escape($X["col"]).$db;else{$Ya=array();foreach($l
  436. as$E=>$k){$dd=preg_match('~char|text|enum|set~',$k["type"]);if((is_numeric($X["val"])||!preg_match('~(^|[^o])int|float|double|decimal|bit~',$k["type"]))&&(!preg_match("~[\x80-\xFF]~",$X["val"])||$dd)){$E=idf_escape($E);$Ya[]=($x=="sql"&&$dd&&!preg_match("~^utf8~",$k["collation"])?"CONVERT($E USING ".charset($e).")":$E);}}$K[]=($Ya?"(".implode("$db OR ",$Ya)."$db)":"0");}}}return$K;}function
  437. selectOrderProcess($l,$v){$K=array();foreach((array)$_GET["order"]as$y=>$X){if($X!="")$K[]=(preg_match('~^((COUNT\\(DISTINCT |[A-Z0-9_]+\\()(`(?:[^`]|``)+`|"(?:[^"]|"")+")\\)|COUNT\\(\\*\\))$~',$X)?$X:idf_escape($X)).(isset($_GET["desc"][$y])?" DESC":"");}return$K;}function
  438. selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"50");}function
  439. selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
  440. selectEmailProcess($Z,$wc){return
  441. false;}function
  442. selectQueryBuild($N,$Z,$r,$le,$z,$F){return"";}function
  443. messageQuery($I,$og){global$x;restart_session();$Kc=&get_session("queries");if(!$Kc[$_GET["db"]])$Kc[$_GET["db"]]=array();$t="sql-".count($Kc[$_GET["db"]]);if(strlen($I)>1e6)$I=preg_replace('~[\x80-\xFF]+$~','',substr($I,0,1e6))."\n...";$Kc[$_GET["db"]][]=array($I,time(),$og);return" <span class='time'>".@date("H:i:s")."</span>"." <a href='#$t' class='toggle'>".'SQL command'."</a>"."<div id='$t' class='hidden'><pre><code class='jush-$x'>".shorten_utf8($I,1000).'</code></pre>'.($og?" <span class='time'>($og)</span>":'').(support("sql")?'<p><a href="'.h(str_replace("db=".urlencode(DB),"db=".urlencode($_GET["db"]),ME).'sql=&history='.(count($Kc[$_GET["db"]])-1)).'">'.'Edit'.'</a>':'').'</div>';}function
  444. editFunctions($k){global$Pb;$K=($k["null"]?"NULL/":"");foreach($Pb
  445. as$y=>$Bc){if(!$y||(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET)))){foreach($Bc
  446. as$Fe=>$X){if(!$Fe||preg_match("~$Fe~",$k["type"]))$K.="/$X";}if($y&&!preg_match('~set|blob|bytea|raw|file~',$k["type"]))$K.="/SQL";}}if($k["auto_increment"]&&!isset($_GET["select"])&&!where($_GET))$K='Auto Increment';return
  447. explode("/",$K);}function
  448. editInput($Q,$k,$wa,$Y){if($k["type"]=="enum")return(isset($_GET["select"])?"<label><input type='radio'$wa value='-1' checked><i>".'original'."</i></label> ":"").($k["null"]?"<label><input type='radio'$wa value=''".($Y!==null||isset($_GET["select"])?"":" checked")."><i>NULL</i></label> ":"").enum_input("radio",$wa,$k,$Y,0);return"";}function
  449. editHint($Q,$k,$Y){return"";}function
  450. processInput($k,$Y,$p=""){if($p=="SQL")return$Y;$E=$k["field"];$K=q($Y);if(preg_match('~^(now|getdate|uuid)$~',$p))$K="$p()";elseif(preg_match('~^current_(date|timestamp)$~',$p))$K=$p;elseif(preg_match('~^([+-]|\\|\\|)$~',$p))$K=idf_escape($E)." $p $K";elseif(preg_match('~^[+-] interval$~',$p))$K=idf_escape($E)." $p ".(preg_match("~^(\\d+|'[0-9.: -]') [A-Z_]+\$~i",$Y)?$Y:$K);elseif(preg_match('~^(addtime|subtime|concat)$~',$p))$K="$p(".idf_escape($E).", $K)";elseif(preg_match('~^(md5|sha1|password|encrypt)$~',$p))$K="$p($K)";return
  451. unconvert_field($k,$K);}function
  452. dumpOutput(){$K=array('text'=>'open','file'=>'save');if(function_exists('gzencode'))$K['gz']='gzip';return$K;}function
  453. dumpFormat(){return
  454. array('sql'=>'SQL','csv'=>'CSV,','csv;'=>'CSV;','tsv'=>'TSV');}function
  455. dumpDatabase($i){}function
  456. dumpTable($Q,$Uf,$ed=0){if($_POST["format"]!="sql"){echo"\xef\xbb\xbf";if($Uf)dump_csv(array_keys(fields($Q)));}else{if($ed==2){$l=array();foreach(fields($Q)as$E=>$k)$l[]=idf_escape($E)." $k[full_type]";$g="CREATE TABLE ".table($Q)." (".implode(", ",$l).")";}else$g=create_sql($Q,$_POST["auto_increment"],$Uf);set_utf8mb4($g);if($Uf&&$g){if($Uf=="DROP+CREATE"||$ed==1)echo"DROP ".($ed==2?"VIEW":"TABLE")." IF EXISTS ".table($Q).";\n";if($ed==1)$g=remove_definer($g);echo"$g;\n\n";}}}function
  457. dumpData($Q,$Uf,$I){global$e,$x;$_d=($x=="sqlite"?0:1048576);if($Uf){if($_POST["format"]=="sql"){if($Uf=="TRUNCATE+INSERT")echo
  458. truncate_sql($Q).";\n";$l=fields($Q);}$J=$e->query($I,1);if($J){$Wc="";$Ia="";$gd=array();$Wf="";$pc=($Q!=''?'fetch_assoc':'fetch_row');while($L=$J->$pc()){if(!$gd){$Wg=array();foreach($L
  459. as$X){$k=$J->fetch_field();$gd[]=$k->name;$y=idf_escape($k->name);$Wg[]="$y = VALUES($y)";}$Wf=($Uf=="INSERT+UPDATE"?"\nON DUPLICATE KEY UPDATE ".implode(", ",$Wg):"").";\n";}if($_POST["format"]!="sql"){if($Uf=="table"){dump_csv($gd);$Uf="INSERT";}dump_csv($L);}else{if(!$Wc)$Wc="INSERT INTO ".table($Q)." (".implode(", ",array_map('idf_escape',$gd)).") VALUES";foreach($L
  460. as$y=>$X){$k=$l[$y];$L[$y]=($X!==null?unconvert_field($k,preg_match('~(^|[^o])int|float|double|decimal~',$k["type"])&&$X!=''?$X:q($X)):"NULL");}$uf=($_d?"\n":" ")."(".implode(",\t",$L).")";if(!$Ia)$Ia=$Wc.$uf;elseif(strlen($Ia)+4+strlen($uf)+strlen($Wf)<$_d)$Ia.=",$uf";else{echo$Ia.$Wf;$Ia=$Wc.$uf;}}}if($Ia)echo$Ia.$Wf;}elseif($_POST["format"]=="sql")echo"-- ".str_replace("\n"," ",$e->error)."\n";}}function
  461. dumpFilename($Oc){return
  462. friendly_url($Oc!=""?$Oc:(SERVER!=""?SERVER:"localhost"));}function
  463. dumpHeaders($Oc,$Ld=false){$ve=$_POST["output"];$kc=(preg_match('~sql~',$_POST["format"])?"sql":($Ld?"tar":"csv"));header("Content-Type: ".($ve=="gz"?"application/x-gzip":($kc=="tar"?"application/x-tar":($kc=="sql"||$ve!="file"?"text/plain":"text/csv")."; charset=utf-8")));if($ve=="gz")ob_start('ob_gzencode',1e6);return$kc;}function
  464. importServerPath(){return"adminer.sql";}function
  465. 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
  466. true;}function
  467. navigation($Kd){global$ga,$x,$Ib,$e;echo'<h1>
  468. ',$this->name(),' <span class="version">',$ga,'</span>
  469. <a href="https://www.adminer.org/#download"',target_blank(),' id="version">',(version_compare($ga,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
  470. </h1>
  471. ';if($Kd=="auth"){$tc=true;foreach((array)$_SESSION["pwds"]as$Yg=>$Df){foreach($Df
  472. as$O=>$Ug){foreach($Ug
  473. as$V=>$G){if($G!==null){if($tc){echo"<p id='logins'>".script("mixin(qs('#logins'), {onmouseover: menuOver, onmouseout: menuOut});");$tc=false;}$wb=$_SESSION["db"][$Yg][$O][$V];foreach(($wb?array_keys($wb):array(""))as$i)echo"<a href='".h(auth_url($Yg,$O,$V,$i))."'>($Ib[$Yg]) ".h($V.($O!=""?"@$O":"").($i!=""?" - $i":""))."</a><br>\n";}}}}}else{if($_GET["ns"]!==""&&!$Kd&&DB!=""){$e->select_db(DB);$S=table_status('',true);}echo
  474. script_src(preg_replace("~\\?.*~","",ME)."?file=jush.js&version=4.5.0&driver=mysql");if(support("sql")){echo'<script',nonce(),'>
  475. ';if($S){$vd=array();foreach($S
  476. as$Q=>$U)$vd[]=preg_quote($Q,'/');echo"var jushLinks = { $x: [ '".js_escape(ME).(support("table")?"table=":"select=")."\$&', /\\b(".implode("|",$vd).")\\b/g ] };\n";foreach(array("bac","bra","sqlite_quo","mssql_bra")as$X)echo"jushLinks.$X = jushLinks.$x;\n";}echo'bodyLoad(\'',(is_object($e)?substr($e->server_info,0,3):""),'\');
  477. </script>
  478. ';}$this->databasesPrint($Kd);if(DB==""||!$Kd){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"]!==""&&!$Kd&&DB!=""){echo'<a href="'.h(ME).'create="'.bold($_GET["create"]==="").">".'Create table'."</a>\n";if(!$S)echo"<p class='message'>".'No tables.'."\n";else$this->tablesPrint($S);}}}function
  479. databasesPrint($Kd){global$b,$e;$h=$this->databases();echo'<form action="">
  480. <p id="dbs">
  481. ';hidden_fields_get();$ub=script("mixin(qsl('select'), {onmousedown: dbMouseDown, onchange: dbChange});","");echo"<span title='".'database'."'>DB</span>: ".($h?"<select name='db'>".optionlist(array(""=>"")+$h,DB)."</select>$ub":'<input name="db" value="'.h(DB).'" autocapitalize="off">'),"<input type='submit' value='".'Use'."'".($h?" class='hidden'":"").">\n";if($Kd!="db"&&DB!=""&&$e->select_db(DB)){}echo(isset($_GET["sql"])?'<input type="hidden" name="sql" value="">':(isset($_GET["schema"])?'<input type="hidden" name="schema" value="">':(isset($_GET["dump"])?'<input type="hidden" name="dump" value="">':(isset($_GET["privileges"])?'<input type="hidden" name="privileges" value="">':"")))),"</p></form>\n";}function
  482. tablesPrint($S){echo"<ul id='tables'>".script("mixin(qs('#tables'), {onmouseover: menuOver, onmouseout: menuOut});");foreach($S
  483. as$Q=>$Pf){echo'<li><a href="'.h(ME).'select='.urlencode($Q).'"'.bold($_GET["select"]==$Q||$_GET["edit"]==$Q,"select").">".'select'."</a> ";$E=$this->tableName($Pf);echo(support("table")||support("indexes")?'<a href="'.h(ME).'table='.urlencode($Q).'"'.bold(in_array($Q,array($_GET["table"],$_GET["create"],$_GET["indexes"],$_GET["foreign"],$_GET["trigger"])),(is_view($Pf)?"view":"structure"))." title='".'Show structure'."'>$E</a>":"<span>$E</span>")."\n";}echo"</ul>\n";}}$b=(function_exists('adminer_object')?adminer_object():new
  484. Adminer);if($b->operators===null)$b->operators=$he;function
  485. page_header($rg,$j="",$Ha=array(),$sg=""){global$ca,$ga,$b,$Ib,$x;page_headers();if(is_ajax()&&$j){page_messages($j);exit;}$tg=$rg.($sg!=""?": $sg":"");$ug=strip_tags($tg.(SERVER!=""&&SERVER!="localhost"?h(" - ".SERVER):"")." - ".$b->name());echo'<!DOCTYPE html>
  486. <html lang="en" dir="ltr">
  487. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  488. <meta name="robots" content="noindex">
  489. <title>',$ug,'</title>
  490. <link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",ME)."?file=default.css&version=4.5.0&driver=mysql"),'">
  491. ',script_src(preg_replace("~\\?.*~","",ME)."?file=functions.js&version=4.5.0&driver=mysql");if($b->head()){echo'<link rel="shortcut icon" type="image/x-icon" href="',h(preg_replace("~\\?.*~","",ME)."?file=favicon.ico&version=4.5.0&driver=mysql"),'">
  492. <link rel="apple-touch-icon" href="',h(preg_replace("~\\?.*~","",ME)."?file=favicon.ico&version=4.5.0&driver=mysql"),'">
  493. ';foreach($b->css()as$ob){echo'<link rel="stylesheet" type="text/css" href="',h($ob),'">
  494. ';}}echo'
  495. <body class="ltr nojs">
  496. ';$rc=get_temp_dir()."/adminer.version";if(!$_COOKIE["adminer_version"]&&function_exists('openssl_verify')&&file_exists($rc)&&filemtime($rc)+86400>time()){$Zg=unserialize(file_get_contents($rc));$Xe="-----BEGIN PUBLIC KEY-----
  497. MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwqWOVuF5uw7/+Z70djoK
  498. RlHIZFZPO0uYRezq90+7Amk+FDNd7KkL5eDve+vHRJBLAszF/7XKXe11xwliIsFs
  499. DFWQlsABVZB3oisKCBEuI71J4kPH8dKGEWR9jDHFw3cWmoH3PmqImX6FISWbG3B8
  500. h7FIx3jEaw5ckVPVTeo5JRm/1DZzJxjyDenXvBQ/6o9DgZKeNDgxwKzH+sw9/YCO
  501. jHnq1cFpOIISzARlrHMa/43YfeNRAm/tsBXjSxembBPo7aQZLAWHmaj5+K19H10B
  502. nCpz9Y++cipkVEiKRGih4ZEvjoFysEOdRLj6WiD/uUNky4xGeA6LaJqh5XpkFkcQ
  503. fQIDAQAB
  504. -----END PUBLIC KEY-----
  505. ";if(openssl_verify($Zg["version"],base64_decode($Zg["signature"]),$Xe)==1)$_COOKIE["adminer_version"]=$Zg["version"];}echo'<script',nonce(),'>
  506. mixin(document.body, {onkeydown: bodyKeydown, onclick: bodyClick',(isset($_COOKIE["adminer_version"])?"":", onload: partial(verifyVersion, '$ga', '".js_escape(ME)."', '".get_token()."')");?>});
  507. document.body.className = document.body.className.replace(/ nojs/, ' js');
  508. var offlineMessage = '<?php echo
  509. js_escape('You are offline.'),'\';
  510. </script>
  511.  
  512. <div id="help" class="jush-',$x,' jsonly hidden"></div>
  513. ',script("mixin(qs('#help'), {onmouseover: function () { helpOpen = 1; }, onmouseout: helpMouseout});"),'
  514. <div id="content">
  515. ';if($Ha!==null){$_=substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.h($_?$_:".").'">'.$Ib[DRIVER].'</a> &raquo; ';$_=substr(preg_replace('~\b(db|ns)=[^&]*&~','',ME),0,-1);$O=(SERVER!=""?h(SERVER):'Server');if($Ha===false)echo"$O\n";else{echo"<a href='".($_?h($_):".")."' accesskey='1' title='Alt+Shift+1'>$O</a> &raquo; ";if($_GET["ns"]!=""||(DB!=""&&is_array($Ha)))echo'<a href="'.h($_."&db=".urlencode(DB).(support("scheme")?"&ns=":"")).'">'.h(DB).'</a> &raquo; ';if(is_array($Ha)){if($_GET["ns"]!="")echo'<a href="'.h(substr(ME,0,-1)).'">'.h($_GET["ns"]).'</a> &raquo; ';foreach($Ha
  516. as$y=>$X){$_b=(is_array($X)?$X[1]:h($X));if($_b!="")echo"<a href='".h(ME."$y=").urlencode(is_array($X)?$X[0]:$X)."'>$_b</a> &raquo; ";}}echo"$rg\n";}}echo"<h2>$tg</h2>\n","<div id='ajaxstatus' class='jsonly hidden'></div>\n";restart_session();page_messages($j);$h=&get_session("dbs");if(DB!=""&&$h&&!in_array(DB,$h,true))$h=null;stop_session();define("PAGE_HEADER",1);}function
  517. 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$nb){$Jc=array();foreach($nb
  518. as$y=>$X)$Jc[]="$y $X";header("Content-Security-Policy: ".implode("; ",$Jc));}$b->headers();}function
  519. csp(){return
  520. 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
  521. get_nonce(){static$Sd;if(!$Sd)$Sd=base64_encode(rand_string());return$Sd;}function
  522. page_messages($j){$Pg=preg_replace('~^[^?]*~','',$_SERVER["REQUEST_URI"]);$Id=$_SESSION["messages"][$Pg];if($Id){echo"<div class='message'>".implode("</div>\n<div class='message'>",$Id)."</div>".script("messagesPrint();");unset($_SESSION["messages"][$Pg]);}if($j)echo"<div class='error'>$j</div>\n";}function
  523. page_footer($Kd=""){global$b,$T;echo'</div>
  524.  
  525. ';if($Kd!="auth"){echo'<form action="" method="post">
  526. <p class="logout">
  527. <input type="submit" name="logout" value="Logout" id="logout">
  528. <input type="hidden" name="token" value="',$T,'">
  529. </p>
  530. </form>
  531. ';}echo'<div id="menu">
  532. ';$b->navigation($Kd);echo'</div>
  533. ',script("setupSubmitHighlight(document);");}function
  534. int32($D){while($D>=2147483648)$D-=4294967296;while($D<=-2147483649)$D+=4294967296;return(int)$D;}function
  535. long2str($W,$dh){$uf='';foreach($W
  536. as$X)$uf.=pack('V',$X);if($dh)return
  537. substr($uf,0,end($W));return$uf;}function
  538. str2long($uf,$dh){$W=array_values(unpack('V*',str_pad($uf,4*ceil(strlen($uf)/4),"\0")));if($dh)$W[]=strlen($uf);return$W;}function
  539. xxtea_mx($ih,$hh,$Xf,$fd){return
  540. int32((($ih>>5&0x7FFFFFF)^$hh<<2)+(($hh>>3&0x1FFFFFFF)^$ih<<4))^int32(($Xf^$hh)+($fd^$ih));}function
  541. encrypt_string($Rf,$y){if($Rf=="")return"";$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($Rf,true);$D=count($W)-1;$ih=$W[$D];$hh=$W[0];$H=floor(6+52/($D+1));$Xf=0;while($H-->0){$Xf=int32($Xf+0x9E3779B9);$Ob=$Xf>>2&3;for($we=0;$we<$D;$we++){$hh=$W[$we+1];$Md=xxtea_mx($ih,$hh,$Xf,$y[$we&3^$Ob]);$ih=int32($W[$we]+$Md);$W[$we]=$ih;}$hh=$W[0];$Md=xxtea_mx($ih,$hh,$Xf,$y[$we&3^$Ob]);$ih=int32($W[$D]+$Md);$W[$D]=$ih;}return
  542. long2str($W,false);}function
  543. decrypt_string($Rf,$y){if($Rf=="")return"";if(!$y)return
  544. false;$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($Rf,false);$D=count($W)-1;$ih=$W[$D];$hh=$W[0];$H=floor(6+52/($D+1));$Xf=int32($H*0x9E3779B9);while($Xf){$Ob=$Xf>>2&3;for($we=$D;$we>0;$we--){$ih=$W[$we-1];$Md=xxtea_mx($ih,$hh,$Xf,$y[$we&3^$Ob]);$hh=int32($W[$we]-$Md);$W[$we]=$hh;}$ih=$W[$D];$Md=xxtea_mx($ih,$hh,$Xf,$y[$we&3^$Ob]);$hh=int32($W[0]-$Md);$W[0]=$hh;$Xf=int32($Xf-0x9E3779B9);}return
  545. long2str($W,true);}$e='';$Ic=$_SESSION["token"];if(!$Ic)$_SESSION["token"]=rand(1,1e6);$T=get_token();$Ge=array();if($_COOKIE["adminer_permanent"]){foreach(explode(" ",$_COOKIE["adminer_permanent"])as$X){list($y)=explode(":",$X);$Ge[$y]=$X;}}function
  546. add_invalid_login(){global$b;$o=file_open_lock(get_temp_dir()."/adminer.invalid");if(!$o)return;$Zc=unserialize(stream_get_contents($o));$og=time();if($Zc){foreach($Zc
  547. as$ad=>$X){if($X[0]<$og)unset($Zc[$ad]);}}$Yc=&$Zc[$b->bruteForceKey()];if(!$Yc)$Yc=array($og+30*60,0);$Yc[1]++;file_write_unlock($o,serialize($Zc));}function
  548. check_invalid_login(){global$b;$Zc=unserialize(@file_get_contents(get_temp_dir()."/adminer.invalid"));$Yc=$Zc[$b->bruteForceKey()];$Rd=($Yc[1]>29?$Yc[0]-time():0);if($Rd>0)auth_error(lang(array('Too many unsuccessful logins, try again in %d minute.','Too many unsuccessful logins, try again in %d minutes.'),ceil($Rd/60)));}$xa=$_POST["auth"];if($xa){session_regenerate_id();$Yg=$xa["driver"];$O=$xa["server"];$V=$xa["username"];$G=(string)$xa["password"];$i=$xa["db"];set_password($Yg,$O,$V,$G);$_SESSION["db"][$Yg][$O][$V][$i]=true;if($xa["permanent"]){$y=base64_encode($Yg)."-".base64_encode($O)."-".base64_encode($V)."-".base64_encode($i);$Re=$b->permanentLogin(true);$Ge[$y]="$y:".base64_encode($Re?encrypt_string($G,$Re):"");cookie("adminer_permanent",implode(" ",$Ge));}if(count($_POST)==1||DRIVER!=$Yg||SERVER!=$O||$_GET["username"]!==$V||DB!=$i)redirect(auth_url($Yg,$O,$V,$i));}elseif($_POST["logout"]){if($Ic&&!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($Ge&&!$_SESSION["pwds"]){session_regenerate_id();$Re=$b->permanentLogin();foreach($Ge
  549. as$y=>$X){list(,$Qa)=explode(":",$X);list($Yg,$O,$V,$i)=array_map('base64_decode',explode("-",$y));set_password($Yg,$O,$V,decrypt_string(base64_decode($Qa),$Re));$_SESSION["db"][$Yg][$O][$V][$i]=true;}}function
  550. unset_permanent(){global$Ge;foreach($Ge
  551. as$y=>$X){list($Yg,$O,$V,$i)=array_map('base64_decode',explode("-",$y));if($Yg==DRIVER&&$O==SERVER&&$V==$_GET["username"]&&$i==DB)unset($Ge[$y]);}cookie("adminer_permanent",implode(" ",$Ge));}function
  552. auth_error($j){global$b,$Ic;$Ef=session_name();if(isset($_GET["username"])){header("HTTP/1.1 403 Forbidden");if(($_COOKIE[$Ef]||$_GET[$Ef])&&!$Ic)$j='Session expired, please login again.';else{add_invalid_login();$G=get_password();if($G!==null){if($G===false)$j.='<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[$Ef]&&$_GET[$Ef]&&ini_bool("session.use_only_cookies"))$j='Session support must be enabled.';$ye=session_get_cookie_params();cookie("adminer_key",($_COOKIE["adminer_key"]?$_COOKIE["adminer_key"]:rand_string()),$ye["lifetime"]);page_header('Login',$j,null);echo"<form action='' method='post'>\n";$b->loginForm();echo"<div>";hidden_fields($_POST,array("auth"));echo"</div>\n","</form>\n";page_footer("auth");exit;}if(isset($_GET["username"])){if(!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(", ",$Me)),false);page_footer("auth");exit;}list($Mc,$Ie)=explode(":",SERVER,2);if(is_numeric($Ie)&&$Ie<1024)auth_error('Connecting to privileged ports is not allowed.');check_invalid_login();$e=connect();$Hb=new
  553. Min_Driver($e);}if(!is_object($e)||($wd=$b->login($_GET["username"],get_password()))!==true)auth_error((is_string($e)?h($e):(is_string($wd)?$wd:'Invalid credentials.')));if($xa&&$_POST["token"])$_POST["token"]=$T;$j='';if($_POST){if(!verify_token()){$Tc="max_input_vars";$Dd=ini_get($Tc);if(extension_loaded("suhosin")){foreach(array("suhosin.request.max_vars","suhosin.post.max_vars")as$y){$X=ini_get($y);if($X&&(!$Dd||$X<$Dd)){$Tc=$y;$Dd=$X;}}}$j=(!$_POST["token"]&&$Dd?sprintf('Maximum number of allowed fields exceeded. Please increase %s.',"'$Tc'"):'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"){$j=sprintf('Too big POST data. Reduce the data or increase the %s configuration directive.',"'post_max_size'");if(isset($_GET["sql"]))$j.=' '.'You can upload a big SQL file via FTP and import it from server.';}if(!ini_bool("session.use_cookies")||@ini_set("session.use_cookies",false)!==false)session_write_close();function
  554. select($J,$f=null,$oe=array(),$z=0){global$x;$vd=array();$v=array();$d=array();$Fa=array();$Gg=array();$K=array();odd('');for($s=0;(!$z||$s<$z)&&($L=$J->fetch_row());$s++){if(!$s){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr>";for($w=0;$w<count($L);$w++){$k=$J->fetch_field();$E=$k->name;$ne=$k->orgtable;$me=$k->orgname;$K[$k->table]=$ne;if($oe&&$x=="sql")$vd[$w]=($E=="table"?"table=":($E=="possible_keys"?"indexes=":null));elseif($ne!=""){if(!isset($v[$ne])){$v[$ne]=array();foreach(indexes($ne,$f)as$u){if($u["type"]=="PRIMARY"){$v[$ne]=array_flip($u["columns"]);break;}}$d[$ne]=$v[$ne];}if(isset($d[$ne][$me])){unset($d[$ne][$me]);$v[$ne][$me]=$w;$vd[$w]=$ne;}}if($k->charsetnr==63)$Fa[$w]=true;$Gg[$w]=$k->type;echo"<th".($ne!=""||$k->name!=$me?" title='".h(($ne!=""?"$ne.":"").$me)."'":"").">".h($E).($oe?doc_link(array('sql'=>"explain-output.html#explain_".strtolower($E))):"");}echo"</thead>\n";}echo"<tr".odd().">";foreach($L
  555. as$y=>$X){if($X===null)$X="<i>NULL</i>";elseif($Fa[$y]&&!is_utf8($X))$X="<i>".lang(array('%d byte','%d bytes'),strlen($X))."</i>";elseif(!strlen($X))$X="&nbsp;";else{$X=h($X);if($Gg[$y]==254)$X="<code>$X</code>";}if(isset($vd[$y])&&!$d[$vd[$y]]){if($oe&&$x=="sql"){$Q=$L[array_search("table=",$vd)];$_=$vd[$y].urlencode($oe[$Q]!=""?$oe[$Q]:$Q);}else{$_="edit=".urlencode($vd[$y]);foreach($v[$vd[$y]]as$Ua=>$w)$_.="&where".urlencode("[".bracket_escape($Ua)."]")."=".urlencode($L[$w]);}$X="<a href='".h(ME.$_)."'>$X</a>";}echo"<td>$X";}}echo($s?"</table>":"<p class='message'>".'No rows.')."\n";return$K;}function
  556. referencable_primary($Af){$K=array();foreach(table_status('',true)as$bg=>$Q){if($bg!=$Af&&fk_support($Q)){foreach(fields($bg)as$k){if($k["primary"]){if($K[$bg]){unset($K[$bg]);break;}$K[$bg]=$k;}}}}return$K;}function
  557. textarea($E,$Y,$M=10,$Ya=80){global$x;echo"<textarea name='$E' rows='$M' cols='$Ya' class='sqlarea jush-$x' spellcheck='false' wrap='off'>";if(is_array($Y)){foreach($Y
  558. as$X)echo
  559. h($X[0])."\n\n\n";}else
  560. echo
  561. h($Y);echo"</textarea>";}function
  562. edit_type($y,$k,$Xa,$n=array()){global$Tf,$Gg,$Ng,$de;$U=$k["type"];echo'<td><select name="',h($y),'[type]" class="type" aria-labelledby="label-type">';if($U&&!isset($Gg[$U])&&!isset($n[$U]))array_unshift($Tf,$U);if($n)$Tf['Foreign keys']=$n;echo
  563. optionlist($Tf,$U),'</select>
  564. ',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($k["length"]),'" size="3"',(!$k["length"]&&preg_match('~var(char|binary)$~',$U)?" class='required'":""),' aria-labelledby="label-length">',script("mixin(qsl('input'), {onfocus: editingLengthFocus, oninput: editingLengthChange});",""),'<td class="options">';echo"<select name='".h($y)."[collation]'".(preg_match('~(char|text|enum|set)$~',$U)?"":" class='hidden'").'><option value="">('.'collation'.')'.optionlist($Xa,$k["collation"]).'</select>',($Ng?"<select name='".h($y)."[unsigned]'".(!$U||preg_match('~((^|[^o])int|float|double|decimal)$~',$U)?"":" class='hidden'").'><option>'.optionlist($Ng,$k["unsigned"]).'</select>':''),(isset($k['on_update'])?"<select name='".h($y)."[on_update]'".(preg_match('~timestamp|datetime~',$U)?"":" class='hidden'").'>'.optionlist(array(""=>"(".'ON UPDATE'.")","CURRENT_TIMESTAMP"),$k["on_update"]).'</select>':''),($n?"<select name='".h($y)."[on_delete]'".(preg_match("~`~",$U)?"":" class='hidden'")."><option value=''>(".'ON DELETE'.")".optionlist(explode("|",$de),$k["on_delete"])."</select> ":" ");}function
  565. process_length($sd){global$Zb;return(preg_match("~^\\s*\\(?\\s*$Zb(?:\\s*,\\s*$Zb)*+\\s*\\)?\\s*\$~",$sd)&&preg_match_all("~$Zb~",$sd,$yd)?"(".implode(",",$yd[0]).")":preg_replace('~^[0-9].*~','(\0)',preg_replace('~[^-0-9,+()[\]]~','',$sd)));}function
  566. process_type($k,$Va="COLLATE"){global$Ng;return" $k[type]".process_length($k["length"]).(preg_match('~(^|[^o])int|float|double|decimal~',$k["type"])&&in_array($k["unsigned"],$Ng)?" $k[unsigned]":"").(preg_match('~char|text|enum|set~',$k["type"])&&$k["collation"]?" $Va ".q($k["collation"]):"");}function
  567. process_field($k,$Eg){global$x;$yb=$k["default"];return
  568. array(idf_escape(trim($k["field"])),process_type($Eg),($k["null"]?" NULL":" NOT NULL"),(isset($yb)?" DEFAULT ".((preg_match('~time~',$k["type"])&&preg_match('~^CURRENT_TIMESTAMP(\(\))?$~i',$yb))||($x=="sqlite"&&preg_match('~^CURRENT_(TIME|TIMESTAMP|DATE)$~i',$yb))||($k["type"]=="bit"&&preg_match("~^([0-9]+|b'[0-1]+')\$~",$yb))||($x=="pgsql"&&preg_match("~^[a-z]+\\(('[^']*')+\\)\$~",$yb))?$yb:q($yb)):""),(preg_match('~timestamp|datetime~',$k["type"])&&$k["on_update"]?" ON UPDATE $k[on_update]":""),(support("comment")&&$k["comment"]!=""?" COMMENT ".q($k["comment"]):""),($k["auto_increment"]?auto_increment():null),);}function
  569. 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
  570. edit_fields($l,$Xa,$U="TABLE",$n=array(),$cb=false){global$e,$Uc;$l=array_values($l);echo'<thead><tr class="wrap">
  571. ';if($U=="PROCEDURE"){echo'<td>&nbsp;';}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
  572. <td>','Options';if($U=="TABLE"){echo'<td id="label-null">NULL
  573. <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",'sqlite'=>"autoinc.html",'pgsql'=>"datatype.html#DATATYPE-SERIAL",'mssql'=>"ms186775.aspx",)),'<td id="label-default">Default value
  574. ',(support("comment")?"<td id='label-comment'".($cb?"":" class='hidden'").">".'Comment':"");}echo'<td>',"<input type='image' class='icon' name='add[".(support("move_col")?0:count($l))."]' src='".h(preg_replace("~\\?.*~","",ME)."?file=plus.gif&version=4.5.0&driver=mysql")."' alt='+' title='".'Add next'."'>".script("row_count = ".count($l).";"),'</thead>
  575. <tbody>
  576. ',script("qsl('tbody').onkeydown = editingKeydown;");foreach($l
  577. as$s=>$k){$s++;$pe=$k[($_POST?"orig":"field")];$Db=(isset($_POST["add"][$s-1])||(isset($k["field"])&&!$_POST["drop_col"][$s]))&&(support("drop_col")||$pe=="");echo'<tr',($Db?"":" style='display: none;'"),'>
  578. ',($U=="PROCEDURE"?"<td>".html_select("fields[$s][inout]",explode("|",$Uc),$k["inout"]):""),'<th>';if($Db){echo'<input name="fields[',$s,'][field]" value="',h($k["field"]),'" maxlength="64" autocapitalize="off" aria-labelledby="label-name">',script("qsl('input').oninput = function () { editingNameChange.call(this);".($k["field"]!=""||count($l)>1?"":" editingAddRow.call(this);")." };","");}echo'<input type="hidden" name="fields[',$s,'][orig]" value="',h($pe),'">
  579. ';edit_type("fields[$s]",$k,$Xa,$n);if($U=="TABLE"){echo'<td>',checkbox("fields[$s][null]",1,$k["null"],"","","block","label-null"),'<td><label class="block"><input type="radio" name="auto_increment_col" value="',$s,'"';if($k["auto_increment"]){echo' checked';}echo' aria-labelledby="label-ai">',script("qsl('input').onclick = function () { var field = this.form['fields[' + this.value + '][field]']; if (!field.value) { field.value = 'id'; field.oninput(); } }"),'</label><td>',checkbox("fields[$s][has_default]",1,$k["has_default"],"","","","label-default"),'<input name="fields[',$s,'][default]" value="',h($k["default"]),'" aria-labelledby="label-default">',script("qsl('input').oninput = function () { this.previousSibling.checked = true; }",""),(support("comment")?"<td".($cb?"":" class='hidden'")."><input name='fields[$s][comment]' value='".h($k["comment"])."' maxlength='".($e->server_info>=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.5.0&driver=mysql")."' alt='+' title='".'Add next'."'>&nbsp;".script("qsl('input').onclick = partial(editingAddRow, 1);","")."<input type='image' class='icon' name='up[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=up.gif&version=4.5.0&driver=mysql")."' alt='^' title='".'Move up'."'>&nbsp;".script("qsl('input').onclick = partial(editingMoveRow, 1);","")."<input type='image' class='icon' name='down[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=down.gif&version=4.5.0&driver=mysql")."' alt='v' title='".'Move down'."'>&nbsp;".script("qsl('input').onclick = partial(editingMoveRow, 0);",""):""),($pe==""||support("drop_col")?"<input type='image' class='icon' name='drop_col[$s]' src='".h(preg_replace("~\\?.*~","",ME)."?file=cross.gif&version=4.5.0&driver=mysql")."' alt='x' title='".'Remove'."'>".script("qsl('input').onclick = partial(editingRemoveRow, 'fields\$1[field]');"):"");}}function
  580. process_fields(&$l){$Wd=0;if($_POST["up"]){$md=0;foreach($l
  581. as$y=>$k){if(key($_POST["up"])==$y){unset($l[$y]);array_splice($l,$md,0,array($k));break;}if(isset($k["field"]))$md=$Wd;$Wd++;}}elseif($_POST["down"]){$yc=false;foreach($l
  582. as$y=>$k){if(isset($k["field"])&&$yc){unset($l[key($_POST["down"])]);array_splice($l,$Wd,0,array($yc));break;}if(key($_POST["down"])==$y)$yc=$k;$Wd++;}}elseif($_POST["add"]){$l=array_values($l);array_splice($l,key($_POST["add"]),0,array(array()));}elseif(!$_POST["drop_col"])return
  583. false;return
  584. true;}function
  585. 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
  586. grant($q,$Te,$d,$ce){if(!$Te)return
  587. true;if($Te==array("ALL PRIVILEGES","GRANT OPTION"))return($q=="GRANT"?queries("$q ALL PRIVILEGES$ce WITH GRANT OPTION"):queries("$q ALL PRIVILEGES$ce")&&queries("$q GRANT OPTION$ce"));return
  588. queries("$q ".preg_replace('~(GRANT OPTION)\\([^)]*\\)~','\\1',implode("$d, ",$Te).$d).$ce);}function
  589. drop_create($Jb,$g,$Kb,$lg,$Lb,$A,$Hd,$Fd,$Gd,$Zd,$Pd){if($_POST["drop"])query_redirect($Jb,$A,$Hd);elseif($Zd=="")query_redirect($g,$A,$Gd);elseif($Zd!=$Pd){$lb=queries($g);queries_redirect($A,$Fd,$lb&&queries($Jb));if($lb)queries($Kb);}else
  590. queries_redirect($A,$Fd,queries($lg)&&queries($Lb)&&queries($Jb)&&queries($g));}function
  591. create_trigger($ce,$L){global$x;$qg=" $L[Timing] $L[Event]".($L["Event"]=="UPDATE OF"?" ".idf_escape($L["Of"]):"");return"CREATE TRIGGER ".idf_escape($L["Trigger"]).($x=="mssql"?$ce.$qg:$qg.$ce).rtrim(" $L[Type]\n$L[Statement]",";").";";}function
  592. create_routine($rf,$L){global$Uc;$P=array();$l=(array)$L["fields"];ksort($l);foreach($l
  593. as$k){if($k["field"]!="")$P[]=(preg_match("~^($Uc)\$~",$k["inout"])?"$k[inout] ":"").idf_escape($k["field"]).process_type($k,"CHARACTER SET");}return"CREATE $rf ".idf_escape(trim($L["name"]))." (".implode(", ",$P).")".(isset($_GET["function"])?" RETURNS".process_type($L["returns"],"CHARACTER SET"):"").($L["language"]?" LANGUAGE $L[language]":"").rtrim("\n$L[definition]",";").";";}function
  594. remove_definer($I){return
  595. preg_replace('~^([A-Z =]+) DEFINER=`'.preg_replace('~@(.*)~','`@`(%|\\1)',logged_user()).'`~','\\1',$I);}function
  596. format_foreign_key($m){global$de;return" FOREIGN KEY (".implode(", ",array_map('idf_escape',$m["source"])).") REFERENCES ".table($m["table"])." (".implode(", ",array_map('idf_escape',$m["target"])).")".(preg_match("~^($de)\$~",$m["on_delete"])?" ON DELETE $m[on_delete]":"").(preg_match("~^($de)\$~",$m["on_update"])?" ON UPDATE $m[on_update]":"");}function
  597. tar_file($rc,$vg){$K=pack("a100a8a8a8a12a12",$rc,644,0,0,decoct($vg->size),decoct(time()));$Pa=8*32;for($s=0;$s<strlen($K);$s++)$Pa+=ord($K[$s]);$K.=sprintf("%06o",$Pa)."\0 ";echo$K,str_repeat("\0",512-strlen($K));$vg->send();echo
  598. str_repeat("\0",511-($vg->size+511)%512);}function
  599. ini_bytes($Tc){$X=ini_get($Tc);switch(strtolower(substr($X,-1))){case'g':$X*=1024;case'm':$X*=1024;case'k':$X*=1024;}return$X;}function
  600. doc_link($Ee){global$x,$e;$Rg=array('sql'=>"https://dev.mysql.com/doc/refman/".substr($e->server_info,0,3)."/en/",'sqlite'=>"https://www.sqlite.org/",'pgsql'=>"https://www.postgresql.org/docs/".substr($e->server_info,0,3)."/static/",'mssql'=>"https://msdn.microsoft.com/library/",'oracle'=>"https://download.oracle.com/docs/cd/B19306_01/server.102/b14200/",);return($Ee[$x]?"<a href='$Rg[$x]$Ee[$x]'".target_blank()."><sup>?</sup></a>":"");}function
  601. ob_gzencode($Sf){return
  602. gzencode($Sf);}function
  603. db_size($i){global$e;if(!$e->select_db($i))return"?";$K=0;foreach(table_status()as$R)$K+=$R["Data_length"]+$R["Index_length"];return
  604. format_number($K);}function
  605. set_utf8mb4($g){global$e;static$P=false;if(!$P&&preg_match('~\butf8mb4~i',$g)){$P=true;echo"SET NAMES ".charset($e).";\n\n";}}function
  606. connect_error(){global$b,$e,$T,$j,$Ib;if(DB!=""){header("HTTP/1.1 404 Not Found");page_header('Database'.": ".h(DB),'Invalid database.',true);}else{if($_POST["db"]&&!$j)queries_redirect(substr(ME,0,-1),'Databases have been dropped.',drop_databases($_POST["db"]));page_header('Select database',$j,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',$Ib[DRIVER],"<b>".h($e->server_info)."</b>","<b>$e->extension</b>")."\n","<p>".sprintf('Logged as: %s',"<b>".h(logged_user())."</b>")."\n";$h=$b->databases();if($h){$xf=support("scheme");$Xa=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>&nbsp;":"")."<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";$h=($_GET["dbsize"]?count_tables($h):array_flip($h));foreach($h
  607. as$i=>$S){$qf=h(ME)."db=".urlencode($i);$t=h("Db-".$i);echo"<tr".odd().">".(support("database")?"<td>".checkbox("db[]",$i,in_array($i,(array)$_POST["db"]),"","","",$t):""),"<th><a href='$qf' id='$i'>".h($i)."</a>";$Wa=nbsp(db_collation($i,$Xa));echo"<td>".(support("database")?"<a href='$qf".($xf?"&amp;ns=":"")."&amp;database=' title='".'Alter database'."'>$Wa</a>":$Wa),"<td align='right'><a href='$qf&amp;schema=' id='tables-".h($i)."' title='".'Database schema'."'>".($_GET["dbsize"]?$S:"?")."</a>","<td align='right' id='size-".h($i)."'>".($_GET["dbsize"]?db_size($i):"?"),"\n";}echo"</table>\n",(support("database")?"<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":""),script("tableCheck();"),"<input type='hidden' name='token' value='$T'>\n","</form>\n";}}page_footer("db");}if(isset($_GET["status"]))$_GET["variables"]=$_GET["status"];if(isset($_GET["import"]))$_GET["sql"]=$_GET["import"];if(!(DB!=""?$e->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;}$de="RESTRICT|NO ACTION|CASCADE|SET NULL|SET DEFAULT";class
  608. TmpFile{var$handler;var$size;function
  609. __construct(){$this->handler=tmpfile();}function
  610. write($gb){$this->size+=strlen($gb);fwrite($this->handler,$gb);}function
  611. send(){fseek($this->handler,0);fpassthru($this->handler);fclose($this->handler);}}$Zb="'(?:''|[^'\\\\]|\\\\.)*'";$Uc="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"];$l=fields($a);header("Content-Type: application/octet-stream");header("Content-Disposition: attachment; filename=".friendly_url("$a-".implode("_",$_GET["where"])).".".friendly_url($_GET["field"]));$N=array(idf_escape($_GET["field"]));$J=$Hb->select($a,$N,array(where($_GET,$l)),$N);$L=($J?$J->fetch_row():array());echo$L[0];exit;}elseif(isset($_GET["table"])){$a=$_GET["table"];$l=fields($a);if(!$l)$j=error();$R=table_status1($a,true);page_header(($l&&is_view($R)?$R['Engine']=='materialized view'?'Materialized view':'View':'Table').": ".h($a),$j);$b->selectLinks($R);$bb=$R["Comment"];if($bb!="")echo"<p class='nowrap'>".'Comment'.": ".h($bb)."\n";if($l)$b->tableStructurePrint($l);if(!is_view($R)){if(support("indexes")){echo"<h3 id='indexes'>".'Indexes'."</h3>\n";$v=indexes($a);if($v)$b->tableIndexesPrint($v);echo'<p class="links"><a href="'.h(ME).'indexes='.urlencode($a).'">'.'Alter indexes'."</a>\n";}if(fk_support($R)){echo"<h3 id='foreign-keys'>".'Foreign keys'."</h3>\n";$n=foreign_keys($a);if($n){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Source'."<td>".'Target'."<td>".'ON DELETE'."<td>".'ON UPDATE'."<td>&nbsp;</thead>\n";foreach($n
  612. as$E=>$m){echo"<tr title='".h($E)."'>","<th><i>".implode("</i>, <i>",array_map('h',$m["source"]))."</i>","<td><a href='".h($m["db"]!=""?preg_replace('~db=[^&]*~',"db=".urlencode($m["db"]),ME):($m["ns"]!=""?preg_replace('~ns=[^&]*~',"ns=".urlencode($m["ns"]),ME):ME))."table=".urlencode($m["table"])."'>".($m["db"]!=""?"<b>".h($m["db"])."</b>.":"").($m["ns"]!=""?"<b>".h($m["ns"])."</b>.":"").h($m["table"])."</a>","(<i>".implode("</i>, <i>",array_map('h',$m["target"]))."</i>)","<td>".nbsp($m["on_delete"])."\n","<td>".nbsp($m["on_update"])."\n",'<td><a href="'.h(ME.'foreign='.urlencode($a).'&name='.urlencode($E)).'">'.'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($R)?"view_trigger":"trigger")){echo"<h3 id='triggers'>".'Triggers'."</h3>\n";$Dg=triggers($a);if($Dg){echo"<table cellspacing='0'>\n";foreach($Dg
  613. 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]":"")));$cg=array();$dg=array();$ea=($_GET["schema"]?$_GET["schema"]:$_COOKIE["adminer_schema-".str_replace(".","_",DB)]);preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~',$ea,$yd,PREG_SET_ORDER);foreach($yd
  614. as$s=>$B){$cg[$B[1]]=array($B[2],$B[3]);$dg[]="\n\t'".js_escape($B[1])."': [ $B[2], $B[3] ]";}$xg=0;$Ca=-1;$wf=array();$hf=array();$qd=array();foreach(table_status('',true)as$Q=>$R){if(is_view($R))continue;$Je=0;$wf[$Q]["fields"]=array();foreach(fields($Q)as$E=>$k){$Je+=1.25;$k["pos"]=$Je;$wf[$Q]["fields"][$E]=$k;}$wf[$Q]["pos"]=($cg[$Q]?$cg[$Q]:array($xg,0));foreach($b->foreignKeys($Q)as$X){if(!$X["db"]){$od=$Ca;if($cg[$Q][1]||$cg[$X["table"]][1])$od=min(floatval($cg[$Q][1]),floatval($cg[$X["table"]][1]))-1;else$Ca-=.1;while($qd[(string)$od])$od-=.0001;$wf[$Q]["references"][$X["table"]][(string)$od]=array($X["source"],$X["target"]);$hf[$X["table"]][$Q][(string)$od]=$X["target"];$qd[(string)$od]=true;}}$xg=max($xg,$wf[$Q]["pos"][0]+2.5+$Je);}echo'<div id="schema" style="height: ',$xg,'em;">
  615. <script',nonce(),'>
  616. qs(\'#schema\').onselectstart = function () { return false; };
  617. var tablePos = {',implode(",",$dg)."\n",'};
  618. var em = qs(\'#schema\').offsetHeight / ',$xg,';
  619. document.onmousemove = schemaMousemove;
  620. document.onmouseup = partialArg(schemaMouseup, \'',js_escape(DB),'\');
  621. </script>
  622. ';foreach($wf
  623. as$E=>$Q){echo"<div class='table' style='top: ".$Q["pos"][0]."em; left: ".$Q["pos"][1]."em;'>",'<a href="'.h(ME).'table='.urlencode($E).'"><b>'.h($E)."</b></a>",script("qsl('div').onmousedown = schemaMousedown;");foreach($Q["fields"]as$k){$X='<span'.type_class($k["type"]).' title="'.h($k["full_type"].($k["null"]?" NULL":'')).'">'.h($k["field"]).'</span>';echo"<br>".($k["primary"]?"<i>$X</i>":$X);}foreach((array)$Q["references"]as$jg=>$if){foreach($if
  624. as$od=>$ef){$pd=$od-$cg[$E][1];$s=0;foreach($ef[0]as$Jf)echo"\n<div class='references' title='".h($jg)."' id='refs$od-".($s++)."' style='left: $pd"."em; top: ".$Q["fields"][$Jf]["pos"]."em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: ".(-$pd)."em;'></div></div>";}}foreach((array)$hf[$E]as$jg=>$if){foreach($if
  625. as$od=>$d){$pd=$od-$cg[$E][1];$s=0;foreach($d
  626. as$ig)echo"\n<div class='references' title='".h($jg)."' id='refd$od-".($s++)."' style='left: $pd"."em; top: ".$Q["fields"][$ig]["pos"]."em; height: 1.25em; background: url(".h(preg_replace("~\\?.*~","",ME)."?file=arrow.gif) no-repeat right center;&version=4.5.0&driver=mysql")."'><div style='height: .5em; border-bottom: 1px solid Gray; width: ".(-$pd)."em;'></div></div>";}}echo"\n</div>\n";}foreach($wf
  627. as$E=>$Q){foreach((array)$Q["references"]as$jg=>$if){foreach($if
  628. as$od=>$ef){$Jd=$xg;$Bd=-10;foreach($ef[0]as$y=>$Jf){$Ke=$Q["pos"][0]+$Q["fields"][$Jf]["pos"];$Le=$wf[$jg]["pos"][0]+$wf[$jg]["fields"][$ef[1][$y]]["pos"];$Jd=min($Jd,$Ke,$Le);$Bd=max($Bd,$Ke,$Le);}echo"<div class='references' id='refl$od' style='left: $od"."em; top: $Jd"."em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: ".($Bd-$Jd)."em;'></div></div>\n";}}}echo'</div>
  629. <p class="links"><a href="',h(ME."schema=".urlencode($ea)),'" id="schema-link">Permanent link</a>
  630. ';}elseif(isset($_GET["dump"])){$a=$_GET["dump"];if($_POST&&!$j){$jb="";foreach(array("output","format","db_style","routines","events","table_style","auto_increment","triggers","data_style")as$y)$jb.="&$y=".urlencode($_POST[$y]);cookie("adminer_export",substr($jb,1));$S=array_flip((array)$_POST["tables"])+array_flip((array)$_POST["data"]);$kc=dump_headers((count($S)==1?key($S):DB),(DB==""||count($S)>1));$cd=preg_match('~sql~',$_POST["format"]);if($cd){echo"-- Adminer $ga ".$Ib[DRIVER]." dump\n\n";if($x=="sql"){echo"SET NAMES utf8;
  631. SET time_zone = '+00:00';
  632. ".($_POST["data_style"]?"SET foreign_key_checks = 0;
  633. SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';
  634. ":"")."
  635. ";$e->query("SET time_zone = '+00:00';");}}$Uf=$_POST["db_style"];$h=array(DB);if(DB==""){$h=$_POST["databases"];if(is_string($h))$h=explode("\n",rtrim(str_replace("\r","",$h),"\n"));}foreach((array)$h
  636. as$i){$b->dumpDatabase($i);if($e->select_db($i)){if($cd&&preg_match('~CREATE~',$Uf)&&($g=$e->result("SHOW CREATE DATABASE ".idf_escape($i),1))){set_utf8mb4($g);if($Uf=="DROP+CREATE")echo"DROP DATABASE IF EXISTS ".idf_escape($i).";\n";echo"$g;\n";}if($cd){if($Uf)echo
  637. use_sql($i).";\n\n";$ue="";if($_POST["routines"]){foreach(array("FUNCTION","PROCEDURE")as$rf){foreach(get_rows("SHOW $rf STATUS WHERE Db = ".q($i),null,"-- ")as$L){$g=remove_definer($e->result("SHOW CREATE $rf ".idf_escape($L["Name"]),2));set_utf8mb4($g);$ue.=($Uf!='DROP+CREATE'?"DROP $rf IF EXISTS ".idf_escape($L["Name"]).";;\n":"")."$g;;\n\n";}}}if($_POST["events"]){foreach(get_rows("SHOW EVENTS",null,"-- ")as$L){$g=remove_definer($e->result("SHOW CREATE EVENT ".idf_escape($L["Name"]),3));set_utf8mb4($g);$ue.=($Uf!='DROP+CREATE'?"DROP EVENT IF EXISTS ".idf_escape($L["Name"]).";;\n":"")."$g;;\n\n";}}if($ue)echo"DELIMITER ;;\n\n$ue"."DELIMITER ;\n\n";}if($_POST["table_style"]||$_POST["data_style"]){$bh=array();foreach(table_status('',true)as$E=>$R){$Q=(DB==""||in_array($E,(array)$_POST["tables"]));$rb=(DB==""||in_array($E,(array)$_POST["data"]));if($Q||$rb){if($kc=="tar"){$vg=new
  638. TmpFile;ob_start(array($vg,'write'),1e5);}$b->dumpTable($E,($Q?$_POST["table_style"]:""),(is_view($R)?2:0));if(is_view($R))$bh[]=$E;elseif($rb){$l=fields($E);$b->dumpData($E,$_POST["data_style"],"SELECT *".convert_fields($l,$l)." FROM ".table($E));}if($cd&&$_POST["triggers"]&&$Q&&($Dg=trigger_sql($E)))echo"\nDELIMITER ;;\n$Dg\nDELIMITER ;\n";if($kc=="tar"){ob_end_flush();tar_file((DB!=""?"":"$i/")."$E.csv",$vg);}elseif($cd)echo"\n";}}foreach($bh
  639. as$ah)$b->dumpTable($ah,$_POST["table_style"],1);if($kc=="tar")echo
  640. pack("x512");}}}if($cd)echo"-- ".$e->result("SELECT NOW()")."\n";exit;}page_header('Export',$j,($_GET["export"]!=""?array("table"=>$_GET["export"]):array()),h(DB));echo'
  641. <form action="" method="post">
  642. <table cellspacing="0">
  643. ';$vb=array('','USE','DROP+CREATE','CREATE');$eg=array('','DROP+CREATE','CREATE');$sb=array('','TRUNCATE+INSERT','INSERT');if($x=="sql")$sb[]='INSERT+UPDATE';parse_str($_COOKIE["adminer_export"],$L);if(!$L)$L=array("output"=>"text","format"=>"sql","db_style"=>(DB!=""?"":"CREATE"),"table_style"=>"DROP+CREATE","data_style"=>"INSERT");if(!isset($L["events"])){$L["routines"]=$L["events"]=($_GET["dump"]=="");$L["triggers"]=$L["table_style"];}echo"<tr><th>".'Output'."<td>".html_select("output",$b->dumpOutput(),$L["output"],0)."\n";echo"<tr><th>".'Format'."<td>".html_select("format",$b->dumpFormat(),$L["format"],0)."\n";echo($x=="sqlite"?"":"<tr><th>".'Database'."<td>".html_select('db_style',$vb,$L["db_style"]).(support("routine")?checkbox("routines",1,$L["routines"],'Routines'):"").(support("event")?checkbox("events",1,$L["events"],'Events'):"")),"<tr><th>".'Tables'."<td>".html_select('table_style',$eg,$L["table_style"]).checkbox("auto_increment",1,$L["auto_increment"],'Auto Increment').(support("trigger")?checkbox("triggers",1,$L["triggers"],'Triggers'):""),"<tr><th>".'Data'."<td>".html_select('data_style',$sb,$L["data_style"]),'</table>
  644. <p><input type="submit" value="Export">
  645. <input type="hidden" name="token" value="',$T,'">
  646.  
  647. <table cellspacing="0">
  648. ';$Oe=array();if(DB!=""){$Na=($a!=""?"":" checked");echo"<thead><tr>","<th style='text-align: left;'><label class='block'><input type='checkbox' id='check-tables'$Na>".'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'$Na></label>".script("qs('#check-data').onclick = partial(formCheck, /^data\\[/);",""),"</thead>\n";$bh="";$fg=tables_list();foreach($fg
  649. as$E=>$U){$Ne=preg_replace('~_.*~','',$E);$Na=($a==""||$a==(substr($a,-1)=="%"?"$Ne%":$E));$Qe="<tr><td>".checkbox("tables[]",$E,$Na,$E,"checkboxClick.call(this, event); formUncheck('check-tables');","block");if($U!==null&&!preg_match('~table~i',$U))$bh.="$Qe\n";else
  650. echo"$Qe<td align='right'><label class='block'><span id='Rows-".h($E)."'></span>".checkbox("data[]",$E,$Na,"","checkboxClick.call(this, event); formUncheck('check-data');")."</label>\n";$Oe[$Ne]++;}echo$bh;if($fg)echo
  651. 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";$h=$b->databases();if($h){foreach($h
  652. as$i){if(!information_schema($i)){$Ne=preg_replace('~_.*~','',$i);echo"<tr><td>".checkbox("databases[]",$i,$a==""||$a=="$Ne%",$i,"formUncheck('check-databases');","block")."\n";$Oe[$Ne]++;}}}else
  653. echo"<tr><td><textarea name='databases' rows='10' cols='20'></textarea>";}echo'</table>
  654. </form>
  655. ';$tc=true;foreach($Oe
  656. as$y=>$X){if($y!=""&&$X>1){echo($tc?"<p>":" ")."<a href='".h(ME)."dump=".urlencode("$y%")."'>".h($y)."</a>";$tc=false;}}}elseif(isset($_GET["privileges"])){page_header('Privileges');echo'<p class="links"><a href="'.h(ME).'user=">'.'Create user'."</a>";$J=$e->query("SELECT User, Host FROM mysql.".(DB==""?"user":"db WHERE ".q(DB)." LIKE Db")." ORDER BY Host, User");$q=$J;if(!$J)$J=$e->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",($q?"":"<input type='hidden' name='grant' value=''>\n"),"<table cellspacing='0'>\n","<thead><tr><th>".'Username'."<th>".'Server'."<th>&nbsp;</thead>\n";while($L=$J->fetch_assoc())echo'<tr'.odd().'><td>'.h($L["User"])."<td>".h($L["Host"]).'<td><a href="'.h(ME.'user='.urlencode($L["User"]).'&host='.urlencode($L["Host"])).'">'.'Edit'."</a>\n";if(!$q||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(!$j&&$_POST["export"]){dump_headers("sql");$b->dumpTable("","");$b->dumpData("","table",$_POST["query"]);exit;}restart_session();$Lc=&get_session("queries");$Kc=&$Lc[DB];if(!$j&&$_POST["clear"]){$Kc=array();redirect(remove_from_uri("history"));}page_header((isset($_GET["import"])?'Import':'SQL command'),$j);if(!$j&&$_POST){$o=false;if(!isset($_GET["import"]))$I=$_POST["query"];elseif($_POST["webfile"]){$Nf=$b->importServerPath();$o=@fopen((file_exists($Nf)?$Nf:"compress.zlib://$Nf.gz"),"rb");$I=($o?fread($o,1e6):false);}else$I=get_file("sql_file",true);if(is_string($I)){if(function_exists('memory_get_usage'))@ini_set("memory_limit",max(ini_bytes("memory_limit"),2*strlen($I)+memory_get_usage()+8e6));if($I!=""&&strlen($I)<1e6){$H=$I.(preg_match("~;[ \t\r\n]*\$~",$I)?"":";");if(!$Kc||reset(end($Kc))!=$H){restart_session();$Kc[]=array($H,time());set_session("queries",$Lc);stop_session();}}$Kf="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$zb=";";$Wd=0;$Wb=true;$f=connect();if(is_object($f)&&DB!="")$f->select_db(DB);$ab=0;$bc=array();$ze='[\'"'.($x=="sql"?'`#':($x=="sqlite"?'`[':($x=="mssql"?'[':''))).']|/\\*|-- |$'.($x=="pgsql"?'|\\$[^$]*\\$':'');$yg=microtime(true);parse_str($_COOKIE["adminer_export"],$la);$Nb=$b->dumpFormat();unset($Nb["sql"]);while($I!=""){if(!$Wd&&preg_match("~^$Kf*+DELIMITER\\s+(\\S+)~i",$I,$B)){$zb=$B[1];$I=substr($I,strlen($B[0]));}else{preg_match('('.preg_quote($zb)."\\s*|$ze)",$I,$B,PREG_OFFSET_CAPTURE,$Wd);list($yc,$Je)=$B[0];if(!$yc&&$o&&!feof($o))$I.=fread($o,1e5);else{if(!$yc&&rtrim($I)=="")break;$Wd=$Je+strlen($yc);if($yc&&rtrim($yc)!=$zb){while(preg_match('('.($yc=='/*'?'\\*/':($yc=='['?']':(preg_match('~^-- |^#~',$yc)?"\n":preg_quote($yc)."|\\\\."))).'|$)s',$I,$B,PREG_OFFSET_CAPTURE,$Wd)){$uf=$B[0][0];if(!$uf&&$o&&!feof($o))$I.=fread($o,1e5);else{$Wd=$B[0][1]+strlen($uf);if($uf[0]!="\\")break;}}}else{$Wb=false;$H=substr($I,0,$Je);$ab++;$Qe="<pre id='sql-$ab'><code class='jush-$x'>".$b->sqlCommandQuery($H)."</code></pre>\n";if($x=="sqlite"&&preg_match("~^$Kf*+ATTACH\\b~i",$H,$B)){echo$Qe,"<p class='error'>".'ATTACH queries are not supported.'."\n";$bc[]=" <a href='#sql-$ab'>$ab</a>";if($_POST["error_stops"])break;}else{if(!$_POST["only_errors"]){echo$Qe;ob_flush();flush();}$Of=microtime(true);if($e->multi_query($H)&&is_object($f)&&preg_match("~^$Kf*+USE\\b~i",$H))$f->query($H);do{$J=$e->store_result();$og=" <span class='time'>(".format_time($Of).")</span>".(strlen($H)<1000?" <a href='".h(ME)."sql=".urlencode(trim($H))."'>".'Edit'."</a>":"");if($e->error){echo($_POST["only_errors"]?$Qe:""),"<p class='error'>".'Error in query'.($e->errno?" ($e->errno)":"").": ".error()."\n";$bc[]=" <a href='#sql-$ab'>$ab</a>";if($_POST["error_stops"])break
  657. 2;}elseif(is_object($J)){$z=$_POST["limit"];$oe=select($J,$f,array(),$z);if(!$_POST["only_errors"]){echo"<form action='' method='post'>\n";$Td=$J->num_rows;echo"<p>".($Td?($z&&$Td>$z?sprintf('%d / ',$z):"").lang(array('%d row','%d rows'),$Td):""),$og;$t="export-$ab";$jc=", <a href='#$t'>".'Export'."</a>".script("qsl('a').onclick = partial(toggle, '$t');","")."<span id='$t' class='hidden'>: ".html_select("output",$b->dumpOutput(),$la["output"])." ".html_select("format",$Nb,$la["format"])."<input type='hidden' name='query' value='".h($H)."'>"." <input type='submit' name='export' value='".'Export'."'><input type='hidden' name='token' value='$T'></span>\n";if($f&&preg_match("~^($Kf|\\()*+SELECT\\b~i",$H)&&($ic=explain($f,$H))){$t="explain-$ab";echo", <a href='#$t'>EXPLAIN</a>".script("qsl('a').onclick = partial(toggle, '$t');","").$jc,"<div id='$t' class='hidden'>\n";select($ic,$f,$oe);echo"</div>\n";}else
  658. echo$jc;echo"</form>\n";}}else{if(preg_match("~^$Kf*+(CREATE|DROP|ALTER)$Kf++(DATABASE|SCHEMA)\\b~i",$H)){restart_session();set_session("dbs",null);stop_session();}if(!$_POST["only_errors"])echo"<p class='message' title='".h($e->info)."'>".lang(array('Query executed OK, %d row affected.','Query executed OK, %d rows affected.'),$e->affected_rows)."$og\n";}$Of=microtime(true);}while($e->next_result());}$I=substr($I,$Wd);$Wd=0;}}}}if($Wb)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.'),$ab-count($bc))," <span class='time'>(".format_time($yg).")</span>\n";}elseif($bc&&$ab>1)echo"<p class='error'>".'Error in query'.": ".implode("",$bc)."\n";}else
  659. echo"<p class='error'>".upload_error($I)."\n";}echo'
  660. <form action="" method="post" enctype="multipart/form-data" id="form">
  661. ';$gc="<input type='submit' value='".'Execute'."' title='Ctrl+Enter'>";if(!isset($_GET["import"])){$H=$_GET["sql"];if($_POST)$H=$_POST["query"];elseif($_GET["history"]=="all")$H=$Kc;elseif($_GET["history"]!="")$H=$Kc[$_GET["history"]][0];echo"<p>";textarea("query",$H,20);echo($_POST?"":script("qs('textarea').focus();")),"<p>$gc\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>",(ini_bool("file_uploads")?"SQL (&lt; ".ini_get("upload_max_filesize")."B): <input type='file' name='sql_file[]' multiple>\n$gc":'File uploads are disabled.'),"</div></fieldset>\n","<fieldset><legend>".'From server'."</legend><div>",sprintf('Webserver file %s',"<code>".h($b->importServerPath()).(extension_loaded("zlib")?"[.gz]":"")."</code>"),' <input type="submit" name="webfile" value="'.'Run file'.'">',"</div></fieldset>\n","<p>";}echo
  662. 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='$T'>\n";if(!isset($_GET["import"])&&$Kc){print_fieldset("history",'History',$_GET["history"]!="");for($X=end($Kc);$X;$X=prev($Kc)){$y=key($Kc);list($H,$og,$Rb)=$X;echo'<a href="'.h(ME."sql=&history=$y").'">'.'Edit'."</a>"." <span class='time' title='".@date('Y-m-d',$og)."'>".@date("H:i:s",$og)."</span>"." <code class='jush-$x'>".shorten_utf8(ltrim(str_replace("\n"," ",str_replace("\r","",preg_replace('~^(#|-- ).*~m','',$H)))),80,"</code>").($Rb?" <span class='time'>($Rb)</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>
  663. ';}elseif(isset($_GET["edit"])){$a=$_GET["edit"];$l=fields($a);$Z=(isset($_GET["select"])?($_POST["check"]&&count($_POST["check"])==1?where_check($_POST["check"][0],$l):""):where($_GET,$l));$Og=(isset($_GET["select"])?$_POST["edit"]:$Z);foreach($l
  664. as$E=>$k){if(!isset($k["privileges"][$Og?"update":"insert"])||$b->fieldName($k)=="")unset($l[$E]);}if($_POST&&!$j&&!isset($_GET["select"])){$A=$_POST["referer"];if($_POST["insert"])$A=($Og?null:$_SERVER["REQUEST_URI"]);elseif(!preg_match('~^.+&select=.+$~',$A))$A=ME."select=".urlencode($a);$v=indexes($a);$Jg=unique_array($_GET["where"],$v);$af="\nWHERE $Z";if(isset($_POST["delete"]))queries_redirect($A,'Item has been deleted.',$Hb->delete($a,$af,!$Jg));else{$P=array();foreach($l
  665. as$E=>$k){$X=process_input($k);if($X!==false&&$X!==null)$P[idf_escape($E)]=$X;}if($Og){if(!$P)redirect($A);queries_redirect($A,'Item has been updated.',$Hb->update($a,$P,$af,!$Jg));if(is_ajax()){page_headers();page_messages($j);exit;}}else{$J=$Hb->insert($a,$P);$nd=($J?last_id():0);queries_redirect($A,sprintf('Item%s has been inserted.',($nd?" $nd":"")),$J);}}}$L=null;if($_POST["save"])$L=(array)$_POST["fields"];elseif($Z){$N=array();foreach($l
  666. as$E=>$k){if(isset($k["privileges"]["select"])){$ua=convert_field($k);if($_POST["clone"]&&$k["auto_increment"])$ua="''";if($x=="sql"&&preg_match("~enum|set~",$k["type"]))$ua="1*".idf_escape($E);$N[]=($ua?"$ua AS ":"").idf_escape($E);}}$L=array();if(!support("table"))$N=array("*");if($N){$J=$Hb->select($a,$N,array($Z),$N,array(),(isset($_GET["select"])?2:1));if(!$J)$j=error();else{$L=$J->fetch_assoc();if(!$L)$L=false;}if(isset($_GET["select"])&&(!$L||$J->fetch_assoc()))$L=null;}}if(!support("table")&&!$l){if(!$Z){$J=$Hb->select($a,array("*"),$Z,array("*"));$L=($J?$J->fetch_assoc():false);if(!$L)$L=array($Hb->primary=>"");}if($L){foreach($L
  667. as$y=>$X){if(!$Z)$L[$y]=null;$l[$y]=array("field"=>$y,"null"=>($y!=$Hb->primary),"auto_increment"=>($y==$Hb->primary));}}}edit_form($a,$l,$L,$Og);}elseif(isset($_GET["create"])){$a=$_GET["create"];$_e=array();foreach(array('HASH','LINEAR HASH','KEY','LINEAR KEY','RANGE','LIST')as$y)$_e[$y]=$y;$gf=referencable_primary($a);$n=array();foreach($gf
  668. as$bg=>$k)$n[str_replace("`","``",$bg)."`".str_replace("`","``",$k["field"])]=$bg;$re=array();$R=array();if($a!=""){$re=fields($a);$R=table_status($a);if(!$R)$j='No tables.';}$L=$_POST;$L["fields"]=(array)$L["fields"];if($L["auto_increment_col"])$L["fields"][$L["auto_increment_col"]]["auto_increment"]=true;if($_POST&&!process_fields($L["fields"])&&!$j){if($_POST["drop"])queries_redirect(substr(ME,0,-1),'Table has been dropped.',drop_tables(array($a)));else{$l=array();$ra=array();$Sg=false;$vc=array();$qe=reset($re);$pa=" FIRST";foreach($L["fields"]as$y=>$k){$m=$n[$k["type"]];$Eg=($m!==null?$gf[$m]:$k);if($k["field"]!=""){if(!$k["has_default"])$k["default"]=null;if($y==$L["auto_increment_col"])$k["auto_increment"]=true;$Ve=process_field($k,$Eg);$ra[]=array($k["orig"],$Ve,$pa);if($Ve!=process_field($qe,$qe)){$l[]=array($k["orig"],$Ve,$pa);if($k["orig"]!=""||$pa)$Sg=true;}if($m!==null)$vc[idf_escape($k["field"])]=($a!=""&&$x!="sqlite"?"ADD":" ").format_foreign_key(array('table'=>$n[$k["type"]],'source'=>array($k["field"]),'target'=>array($Eg["field"]),'on_delete'=>$k["on_delete"],));$pa=" AFTER ".idf_escape($k["field"]);}elseif($k["orig"]!=""){$Sg=true;$l[]=array($k["orig"]);}if($k["orig"]!=""){$qe=next($re);if(!$qe)$pa="";}}$Be="";if($_e[$L["partition_by"]]){$Ce=array();if($L["partition_by"]=='RANGE'||$L["partition_by"]=='LIST'){foreach(array_filter($L["partition_names"])as$y=>$X){$Y=$L["partition_values"][$y];$Ce[]="\n PARTITION ".idf_escape($X)." VALUES ".($L["partition_by"]=='RANGE'?"LESS THAN":"IN").($Y!=""?" ($Y)":" MAXVALUE");}}$Be.="\nPARTITION BY $L[partition_by]($L[partition])".($Ce?" (".implode(",",$Ce)."\n)":($L["partitions"]?" PARTITIONS ".(+$L["partitions"]):""));}elseif(support("partitioning")&&preg_match("~partitioned~",$R["Create_options"]))$Be.="\nREMOVE PARTITIONING";$C='Table has been altered.';if($a==""){cookie("adminer_engine",$L["Engine"]);$C='Table has been created.';}$E=trim($L["name"]);queries_redirect(ME.(support("table")?"table=":"select=").urlencode($E),$C,alter_table($a,$E,($x=="sqlite"&&($Sg||$vc)?$ra:$l),$vc,($L["Comment"]!=$R["Comment"]?$L["Comment"]:null),($L["Engine"]&&$L["Engine"]!=$R["Engine"]?$L["Engine"]:""),($L["Collation"]&&$L["Collation"]!=$R["Collation"]?$L["Collation"]:""),($L["Auto_increment"]!=""?number($L["Auto_increment"]):""),$Be));}}page_header(($a!=""?'Alter table':'Create table'),$j,array("table"=>$a),h($a));if(!$_POST){$L=array("Engine"=>$_COOKIE["adminer_engine"],"fields"=>array(array("field"=>"","type"=>(isset($Gg["int"])?"int":(isset($Gg["integer"])?"integer":"")))),"partition_names"=>array(""),);if($a!=""){$L=$R;$L["name"]=$a;$L["fields"]=array();if(!$_GET["auto_increment"])$L["Auto_increment"]="";foreach($re
  669. as$k){$k["has_default"]=isset($k["default"]);$L["fields"][]=$k;}if(support("partitioning")){$_c="FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA = ".q(DB)." AND TABLE_NAME = ".q($a);$J=$e->query("SELECT PARTITION_METHOD, PARTITION_ORDINAL_POSITION, PARTITION_EXPRESSION $_c ORDER BY PARTITION_ORDINAL_POSITION DESC LIMIT 1");list($L["partition_by"],$L["partitions"],$L["partition"])=$J->fetch_row();$Ce=get_key_vals("SELECT PARTITION_NAME, PARTITION_DESCRIPTION $_c AND PARTITION_NAME != '' ORDER BY PARTITION_ORDINAL_POSITION");$Ce[""]="";$L["partition_names"]=array_keys($Ce);$L["partition_values"]=array_values($Ce);}}}$Xa=collations();$Yb=engines();foreach($Yb
  670. as$Xb){if(!strcasecmp($Xb,$L["Engine"])){$L["Engine"]=$Xb;break;}}echo'
  671. <form action="" method="post" id="form">
  672. <p>
  673. ';if(support("columns")||$a==""){echo'Table name: <input name="name" maxlength="64" value="',h($L["name"]),'" autocapitalize="off">
  674. ';if($a==""&&!$_POST)echo
  675. script("focus(qs('#form')['name']);");echo($Yb?"<select name='Engine'>".optionlist(array(""=>"(".'engine'.")")+$Yb,$L["Engine"])."</select>".on_help("getTarget(event).value",1).script("qsl('select').onchange = helpClose;"):""),' ',($Xa&&!preg_match("~sqlite|mssql~",$x)?html_select("Collation",array(""=>"(".'collation'.")")+$Xa,$L["Collation"]):""),' <input type="submit" value="Save">
  676. ';}echo'
  677. ';if(support("columns")){echo'<table cellspacing="0" id="edit-fields" class="nowrap">
  678. ';$cb=($_POST?$_POST["comments"]:$L["Comment"]!="");if(!$_POST&&!$cb){foreach($L["fields"]as$k){if($k["comment"]!=""){$cb=true;break;}}}edit_fields($L["fields"],$Xa,"TABLE",$n,$cb);echo'</table>
  679. <p>
  680. Auto Increment: <input type="number" name="Auto_increment" size="6" value="',h($L["Auto_increment"]),'">
  681. ',checkbox("defaults",1,true,'Default values',"columnShow(this.checked, 5)","jsonly");if(!$_POST["defaults"])echo
  682. script("editingHideDefaults();");echo(support("comment")?"<label><input type='checkbox' name='comments' value='1' class='jsonly'".($cb?" checked":"").">".'Comment'."</label>".script("qsl('input').onclick = function () { columnShow(this.checked, 6); toggle('Comment'); if (this.checked) this.form['Comment'].focus(); };").' <input name="Comment" id="Comment" value="'.h($L["Comment"]).'" maxlength="'.($e->server_info>=5.5?2048:60).'"'.($cb?'':' class="hidden"').'>':''),'<p>
  683. <input type="submit" value="Save">
  684. ';}echo'
  685. ';if($a!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$a));}if(support("partitioning")){$Ae=preg_match('~RANGE|LIST~',$L["partition_by"]);print_fieldset("partition",'Partition by',$L["partition_by"]);echo'<p>
  686. ',"<select name='partition_by'>".optionlist(array(""=>"")+$_e,$L["partition_by"])."</select>".on_help("getTarget(event).value.replace(/./, 'PARTITION BY \$&')",1).script("qsl('select').onchange = partitionByChange;"),'(<input name="partition" value="',h($L["partition"]),'">)
  687. Partitions: <input type="number" name="partitions" class="size',($Ae||!$L["partition_by"]?" hidden":""),'" value="',h($L["partitions"]),'">
  688. <table cellspacing="0" id="partition-table"',($Ae?"":" class='hidden'"),'>
  689. <thead><tr><th>Partition name<th>Values</thead>
  690. ';foreach($L["partition_names"]as$y=>$X){echo'<tr>','<td><input name="partition_names[]" value="'.h($X).'" autocapitalize="off">',($y==count($L["partition_names"])-1?script("qsl('input').oninput = partitionNameChange;"):''),'<td><input name="partition_values[]" value="'.h($L["partition_values"][$y]).'">';}echo'</table>
  691. </div></fieldset>
  692. ';}echo'<input type="hidden" name="token" value="',$T,'">
  693. </form>
  694. ';}elseif(isset($_GET["indexes"])){$a=$_GET["indexes"];$Sc=array("PRIMARY","UNIQUE","INDEX");$R=table_status($a,true);$Cf=$e->server_info;$Ac=($Cf>=5.6);$Lf=($Cf>=5.7);if(preg_match('~([\d.]+)-MariaDB~',$Cf,$B)){$Cf=$B[1];$Ac=(version_compare($Cf,'10.0.5')>=0);$Lf=(version_compare($Cf,'10.2.2')>=0);}if(preg_match('~MyISAM|M?aria'.($Ac?'|InnoDB':'').'~i',$R["Engine"]))$Sc[]="FULLTEXT";if(preg_match('~MyISAM|M?aria'.($Lf?'|InnoDB':'').'~i',$R["Engine"]))$Sc[]="SPATIAL";$v=indexes($a);$Pe=array();if($x=="mongo"){$Pe=$v["_id_"];unset($Sc[0]);unset($v["_id_"]);}$L=$_POST;if($_POST&&!$j&&!$_POST["add"]&&!$_POST["drop_col"]){$sa=array();foreach($L["indexes"]as$u){$E=$u["name"];if(in_array($u["type"],$Sc)){$d=array();$td=array();$Ab=array();$P=array();ksort($u["columns"]);foreach($u["columns"]as$y=>$c){if($c!=""){$sd=$u["lengths"][$y];$_b=$u["descs"][$y];$P[]=idf_escape($c).($sd?"(".(+$sd).")":"").($_b?" DESC":"");$d[]=$c;$td[]=($sd?$sd:null);$Ab[]=$_b;}}if($d){$hc=$v[$E];if($hc){ksort($hc["columns"]);ksort($hc["lengths"]);ksort($hc["descs"]);if($u["type"]==$hc["type"]&&array_values($hc["columns"])===$d&&(!$hc["lengths"]||array_values($hc["lengths"])===$td)&&array_values($hc["descs"])===$Ab){unset($v[$E]);continue;}}$sa[]=array($u["type"],$E,$P);}}}foreach($v
  695. as$E=>$hc)$sa[]=array($hc["type"],$E,"DROP");if(!$sa)redirect(ME."table=".urlencode($a));queries_redirect(ME."table=".urlencode($a),'Indexes have been altered.',alter_indexes($a,$sa));}page_header('Indexes',$j,array("table"=>$a),h($a));$l=array_keys(fields($a));if($_POST["add"]){foreach($L["indexes"]as$y=>$u){if($u["columns"][count($u["columns"])]!="")$L["indexes"][$y]["columns"][]="";}$u=end($L["indexes"]);if($u["type"]||array_filter($u["columns"],'strlen'))$L["indexes"][]=array("columns"=>array(1=>""));}if(!$L){foreach($v
  696. as$y=>$u){$v[$y]["name"]=$y;$v[$y]["columns"][]="";}$v[]=array("columns"=>array(1=>""));$L["indexes"]=$v;}?>
  697.  
  698. <form action="" method="post">
  699. <table cellspacing="0" class="nowrap">
  700. <thead><tr>
  701. <th id="label-type">Index Type
  702. <th><input type="submit" class="wayoff">Column (length)
  703. <th id="label-name">Name
  704. <th><noscript><input type='image' class='icon' name='add[0]' src='" . h(preg_replace("~\\?.*~", "", ME) . "?file=plus.gif&version=4.5.0&driver=mysql") . "' alt='+' title='Add next'></noscript>&nbsp;
  705. </thead>
  706. <?php
  707. if($Pe){echo"<tr><td>PRIMARY<td>";foreach($Pe["columns"]as$y=>$c){echo
  708. select_input(" disabled",$l,$c),"<label><input disabled type='checkbox'>".'descending'."</label> ";}echo"<td><td>\n";}$w=1;foreach($L["indexes"]as$u){if(!$_POST["drop_col"]||$w!=key($_POST["drop_col"])){echo"<tr><td>".html_select("indexes[$w][type]",array(-1=>"")+$Sc,$u["type"],($w==count($L["indexes"])?"indexesAddRow.call(this);":1),"label-type"),"<td>";ksort($u["columns"]);$s=1;foreach($u["columns"]as$y=>$c){echo"<span>".select_input(" name='indexes[$w][columns][$s]' title='".'Column'."'",($l?array_combine($l,$l):$l),$c,"partial(".($s==count($u["columns"])?"indexesAddColumn":"indexesChangeColumn").", '".js_escape($x=="sql"?"":$_GET["indexes"]."_")."')"),($x=="sql"||$x=="mssql"?"<input type='number' name='indexes[$w][lengths][$s]' class='size' value='".h($u["lengths"][$y])."' title='".'Length'."'>":""),($x!="sql"?checkbox("indexes[$w][descs][$s]",1,$u["descs"][$y],'descending'):"")," </span>";$s++;}echo"<td><input name='indexes[$w][name]' value='".h($u["name"])."' autocapitalize='off' aria-labelledby='label-name'>\n","<td><input type='image' class='icon' name='drop_col[$w]' src='".h(preg_replace("~\\?.*~","",ME)."?file=cross.gif&version=4.5.0&driver=mysql")."' alt='x' title='".'Remove'."'>".script("qsl('input').onclick = partial(editingRemoveRow, 'indexes\$1[type]');");}$w++;}echo'</table>
  709. <p>
  710. <input type="submit" value="Save">
  711. <input type="hidden" name="token" value="',$T,'">
  712. </form>
  713. ';}elseif(isset($_GET["database"])){$L=$_POST;if($_POST&&!$j&&!isset($_POST["add_x"])){$E=trim($L["name"]);if($_POST["drop"]){$_GET["db"]="";queries_redirect(remove_from_uri("db|database"),'Database has been dropped.',drop_databases(array(DB)));}elseif(DB!==$E){if(DB!=""){$_GET["db"]=$E;queries_redirect(preg_replace('~\bdb=[^&]*&~','',ME)."db=".urlencode($E),'Database has been renamed.',rename_database($E,$L["collation"]));}else{$h=explode("\n",str_replace("\r","",$E));$Vf=true;$md="";foreach($h
  714. as$i){if(count($h)==1||$i!=""){if(!create_database($i,$L["collation"]))$Vf=false;$md=$i;}}restart_session();set_session("dbs",null);queries_redirect(ME."db=".urlencode($md),'Database has been created.',$Vf);}}else{if(!$L["collation"])redirect(substr(ME,0,-1));query_redirect("ALTER DATABASE ".idf_escape($E).(preg_match('~^[a-z0-9_]+$~i',$L["collation"])?" COLLATE $L[collation]":""),substr(ME,0,-1),'Database has been altered.');}}page_header(DB!=""?'Alter database':'Create database',$j,array(),h(DB));$Xa=collations();$E=DB;if($_POST)$E=$L["name"];elseif(DB!="")$L["collation"]=db_collation(DB,$Xa);elseif($x=="sql"){foreach(get_vals("SHOW GRANTS")as$q){if(preg_match('~ ON (`(([^\\\\`]|``|\\\\.)*)%`\\.\\*)?~',$q,$B)&&$B[1]){$E=stripcslashes(idf_unescape("`$B[2]`"));break;}}}echo'
  715. <form action="" method="post">
  716. <p>
  717. ',($_POST["add_x"]||strpos($E,"\n")?'<textarea id="name" name="name" rows="10" cols="40">'.h($E).'</textarea><br>':'<input name="name" id="name" value="'.h($E).'" maxlength="64" autocapitalize="off">')."\n".($Xa?html_select("collation",array(""=>"(".'collation'.")")+$Xa,$L["collation"]).doc_link(array('sql'=>"charset-charsets.html",'mssql'=>"ms187963.aspx",)):""),script("focus(qs('#name'));"),'<input type="submit" value="Save">
  718. ';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.5.0&driver=mysql")."' alt='+' title='".'Add next'."'>\n";echo'<input type="hidden" name="token" value="',$T,'">
  719. </form>
  720. ';}elseif(isset($_GET["call"])){$da=$_GET["call"];page_header('Call'.": ".h($da),$j);$rf=routine($da,(isset($_GET["callf"])?"FUNCTION":"PROCEDURE"));$Rc=array();$ue=array();foreach($rf["fields"]as$s=>$k){if(substr($k["inout"],-3)=="OUT")$ue[$s]="@".idf_escape($k["field"])." AS ".idf_escape($k["field"]);if(!$k["inout"]||substr($k["inout"],0,2)=="IN")$Rc[]=$s;}if(!$j&&$_POST){$Ja=array();foreach($rf["fields"]as$y=>$k){if(in_array($y,$Rc)){$X=process_input($k);if($X===false)$X="''";if(isset($ue[$y]))$e->query("SET @".idf_escape($k["field"])." = $X");}$Ja[]=(isset($ue[$y])?"@".idf_escape($k["field"]):$X);}$I=(isset($_GET["callf"])?"SELECT":"CALL")." ".table($da)."(".implode(", ",$Ja).")";echo"<p><code class='jush-$x'>".h($I)."</code> <a href='".h(ME)."sql=".urlencode($I)."'>".'Edit'."</a>\n";if(!$e->multi_query($I))echo"<p class='error'>".error()."\n";else{$f=connect();if(is_object($f))$f->select_db(DB);do{$J=$e->store_result();if(is_object($J))select($J,$f);else
  721. echo"<p class='message'>".lang(array('Routine has been called, %d row affected.','Routine has been called, %d rows affected.'),$e->affected_rows)."\n";}while($e->next_result());if($ue)select($e->query("SELECT ".implode(", ",$ue)));}}echo'
  722. <form action="" method="post">
  723. ';if($Rc){echo"<table cellspacing='0'>\n";foreach($Rc
  724. as$y){$k=$rf["fields"][$y];$E=$k["field"];echo"<tr><th>".$b->fieldName($k);$Y=$_POST["fields"][$E];if($Y!=""){if($k["type"]=="enum")$Y=+$Y;if($k["type"]=="set")$Y=array_sum($Y);}input($k,$Y,(string)$_POST["function"][$E]);echo"\n";}echo"</table>\n";}echo'<p>
  725. <input type="submit" value="Call">
  726. <input type="hidden" name="token" value="',$T,'">
  727. </form>
  728. ';}elseif(isset($_GET["foreign"])){$a=$_GET["foreign"];$E=$_GET["name"];$L=$_POST;if($_POST&&!$j&&!$_POST["add"]&&!$_POST["change"]&&!$_POST["change-js"]){$C=($_POST["drop"]?'Foreign key has been dropped.':($E!=""?'Foreign key has been altered.':'Foreign key has been created.'));$A=ME."table=".urlencode($a);if(!$_POST["drop"]){$L["source"]=array_filter($L["source"],'strlen');ksort($L["source"]);$ig=array();foreach($L["source"]as$y=>$X)$ig[$y]=$L["target"][$y];$L["target"]=$ig;}if($x=="sqlite")queries_redirect($A,$C,recreate_table($a,$a,array(),array(),array(" $E"=>($_POST["drop"]?"":" ".format_foreign_key($L)))));else{$sa="ALTER TABLE ".table($a);$Jb="\nDROP ".($x=="sql"?"FOREIGN KEY ":"CONSTRAINT ").idf_escape($E);if($_POST["drop"])query_redirect($sa.$Jb,$A,$C);else{query_redirect($sa.($E!=""?"$Jb,":"")."\nADD".format_foreign_key($L),$A,$C);$j='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>$j";}}}page_header('Foreign key',$j,array("table"=>$a),h($a));if($_POST){ksort($L["source"]);if($_POST["add"])$L["source"][]="";elseif($_POST["change"]||$_POST["change-js"])$L["target"]=array();}elseif($E!=""){$n=foreign_keys($a);$L=$n[$E];$L["source"][]="";}else{$L["table"]=$a;$L["source"]=array("");}$Jf=array_keys(fields($a));$ig=($a===$L["table"]?$Jf:array_keys(fields($L["table"])));$ff=array_keys(array_filter(table_status('',true),'fk_support'));echo'
  729. <form action="" method="post">
  730. <p>
  731. ';if($L["db"]==""&&$L["ns"]==""){echo'Target table:
  732. ',html_select("table",$ff,$L["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
  733. <noscript><p><input type="submit" name="change" value="Change"></noscript>
  734. <table cellspacing="0">
  735. <thead><tr><th id="label-source">Source<th id="label-target">Target</thead>
  736. ';$w=0;foreach($L["source"]as$y=>$X){echo"<tr>","<td>".html_select("source[".(+$y)."]",array(-1=>"")+$Jf,$X,($w==count($L["source"])-1?"foreignAddRow.call(this);":1),"label-source"),"<td>".html_select("target[".(+$y)."]",$ig,$L["target"][$y],1,"label-target");$w++;}echo'</table>
  737. <p>
  738. ON DELETE: ',html_select("on_delete",array(-1=>"")+explode("|",$de),$L["on_delete"]),' ON UPDATE: ',html_select("on_update",array(-1=>"")+explode("|",$de),$L["on_update"]),doc_link(array('sql'=>"innodb-foreign-key-constraints.html",'pgsql'=>"sql-createtable.html#SQL-CREATETABLE-REFERENCES",'mssql'=>"ms174979.aspx",'oracle'=>"clauses002.htm#sthref2903",)),'<p>
  739. <input type="submit" value="Save">
  740. <noscript><p><input type="submit" name="add" value="Add column"></noscript>
  741. ';}if($E!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$E));}echo'<input type="hidden" name="token" value="',$T,'">
  742. </form>
  743. ';}elseif(isset($_GET["view"])){$a=$_GET["view"];$L=$_POST;$se="VIEW";if($x=="pgsql"&&$a!=""){$Pf=table_status($a);$se=strtoupper($Pf["Engine"]);}if($_POST&&!$j){$E=trim($L["name"]);$ua=" AS\n$L[select]";$A=ME."table=".urlencode($E);$C='View has been altered.';$U=($_POST["materialized"]?"MATERIALIZED VIEW":"VIEW");if(!$_POST["drop"]&&$a==$E&&$x!="sqlite"&&$U=="VIEW"&&$se=="VIEW")query_redirect(($x=="mssql"?"ALTER":"CREATE OR REPLACE")." VIEW ".table($E).$ua,$A,$C);else{$kg=$E."_adminer_".uniqid();drop_create("DROP $se ".table($a),"CREATE $U ".table($E).$ua,"DROP $U ".table($E),"CREATE $U ".table($kg).$ua,"DROP $U ".table($kg),($_POST["drop"]?substr(ME,0,-1):$A),'View has been dropped.',$C,'View has been created.',$a,$E);}}if(!$_POST&&$a!=""){$L=view($a);$L["name"]=$a;$L["materialized"]=($se!="VIEW");if(!$j)$j=error();}page_header(($a!=""?'Alter view':'Create view'),$j,array("table"=>$a),h($a));echo'
  744. <form action="" method="post">
  745. <p>Name: <input name="name" value="',h($L["name"]),'" maxlength="64" autocapitalize="off">
  746. ',(support("materializedview")?" ".checkbox("materialized",1,$L["materialized"],'Materialized view'):""),'<p>';textarea("select",$L["select"]);echo'<p>
  747. <input type="submit" value="Save">
  748. ';if($a!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$a));}echo'<input type="hidden" name="token" value="',$T,'">
  749. </form>
  750. ';}elseif(isset($_GET["event"])){$aa=$_GET["event"];$Xc=array("YEAR","QUARTER","MONTH","DAY","HOUR","MINUTE","WEEK","SECOND","YEAR_MONTH","DAY_HOUR","DAY_MINUTE","DAY_SECOND","HOUR_MINUTE","HOUR_SECOND","MINUTE_SECOND");$Qf=array("ENABLED"=>"ENABLE","DISABLED"=>"DISABLE","SLAVESIDE_DISABLED"=>"DISABLE ON SLAVE");$L=$_POST;if($_POST&&!$j){if($_POST["drop"])query_redirect("DROP EVENT ".idf_escape($aa),substr(ME,0,-1),'Event has been dropped.');elseif(in_array($L["INTERVAL_FIELD"],$Xc)&&isset($Qf[$L["STATUS"]])){$vf="\nON SCHEDULE ".($L["INTERVAL_VALUE"]?"EVERY ".q($L["INTERVAL_VALUE"])." $L[INTERVAL_FIELD]".($L["STARTS"]?" STARTS ".q($L["STARTS"]):"").($L["ENDS"]?" ENDS ".q($L["ENDS"]):""):"AT ".q($L["STARTS"]))." ON COMPLETION".($L["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).$vf.($aa!=$L["EVENT_NAME"]?"\nRENAME TO ".idf_escape($L["EVENT_NAME"]):""):"CREATE EVENT ".idf_escape($L["EVENT_NAME"]).$vf)."\n".$Qf[$L["STATUS"]]." COMMENT ".q($L["EVENT_COMMENT"]).rtrim(" DO\n$L[EVENT_DEFINITION]",";").";"));}}page_header(($aa!=""?'Alter event'.": ".h($aa):'Create event'),$j);if(!$L&&$aa!=""){$M=get_rows("SELECT * FROM information_schema.EVENTS WHERE EVENT_SCHEMA = ".q(DB)." AND EVENT_NAME = ".q($aa));$L=reset($M);}echo'
  751. <form action="" method="post">
  752. <table cellspacing="0">
  753. <tr><th>Name<td><input name="EVENT_NAME" value="',h($L["EVENT_NAME"]),'" maxlength="64" autocapitalize="off">
  754. <tr><th title="datetime">Start<td><input name="STARTS" value="',h("$L[EXECUTE_AT]$L[STARTS]"),'">
  755. <tr><th title="datetime">End<td><input name="ENDS" value="',h($L["ENDS"]),'">
  756. <tr><th>Every<td><input type="number" name="INTERVAL_VALUE" value="',h($L["INTERVAL_VALUE"]),'" class="size"> ',html_select("INTERVAL_FIELD",$Xc,$L["INTERVAL_FIELD"]),'<tr><th>Status<td>',html_select("STATUS",$Qf,$L["STATUS"]),'<tr><th>Comment<td><input name="EVENT_COMMENT" value="',h($L["EVENT_COMMENT"]),'" maxlength="64">
  757. <tr><th>&nbsp;<td>',checkbox("ON_COMPLETION","PRESERVE",$L["ON_COMPLETION"]=="PRESERVE",'On completion preserve'),'</table>
  758. <p>';textarea("EVENT_DEFINITION",$L["EVENT_DEFINITION"]);echo'<p>
  759. <input type="submit" value="Save">
  760. ';if($aa!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$aa));}echo'<input type="hidden" name="token" value="',$T,'">
  761. </form>
  762. ';}elseif(isset($_GET["procedure"])){$da=$_GET["procedure"];$rf=(isset($_GET["function"])?"FUNCTION":"PROCEDURE");$L=$_POST;$L["fields"]=(array)$L["fields"];if($_POST&&!process_fields($L["fields"])&&!$j){$kg="$L[name]_adminer_".uniqid();drop_create("DROP $rf ".idf_escape($da),create_routine($rf,$L),"DROP $rf ".idf_escape($L["name"]),create_routine($rf,array("name"=>$kg)+$L),"DROP $rf ".idf_escape($kg),substr(ME,0,-1),'Routine has been dropped.','Routine has been altered.','Routine has been created.',$da,$L["name"]);}page_header(($da!=""?(isset($_GET["function"])?'Alter function':'Alter procedure').": ".h($da):(isset($_GET["function"])?'Create function':'Create procedure')),$j);if(!$_POST&&$da!=""){$L=routine($da,$rf);$L["name"]=$da;}$Xa=get_vals("SHOW CHARACTER SET");sort($Xa);$sf=routine_languages();echo'
  763. <form action="" method="post" id="form">
  764. <p>Name: <input name="name" value="',h($L["name"]),'" maxlength="64" autocapitalize="off">
  765. ',($sf?'Language'.": ".html_select("language",$sf,$L["language"]):""),'<input type="submit" value="Save">
  766. <table cellspacing="0" class="nowrap">
  767. ';edit_fields($L["fields"],$Xa,$rf);if(isset($_GET["function"])){echo"<tr><td>".'Return type';edit_type("returns",$L["returns"],$Xa);}echo'</table>
  768. <p>';textarea("definition",$L["definition"]);echo'<p>
  769. <input type="submit" value="Save">
  770. ';if($da!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$da));}echo'<input type="hidden" name="token" value="',$T,'">
  771. </form>
  772. ';}elseif(isset($_GET["trigger"])){$a=$_GET["trigger"];$E=$_GET["name"];$Cg=trigger_options();$L=(array)trigger($E)+array("Trigger"=>$a."_bi");if($_POST){if(!$j&&in_array($_POST["Timing"],$Cg["Timing"])&&in_array($_POST["Event"],$Cg["Event"])&&in_array($_POST["Type"],$Cg["Type"])){$ce=" ON ".table($a);$Jb="DROP TRIGGER ".idf_escape($E).($x=="pgsql"?$ce:"");$A=ME."table=".urlencode($a);if($_POST["drop"])query_redirect($Jb,$A,'Trigger has been dropped.');else{if($E!="")queries($Jb);queries_redirect($A,($E!=""?'Trigger has been altered.':'Trigger has been created.'),queries(create_trigger($ce,$_POST)));if($E!="")queries(create_trigger($ce,$L+array("Type"=>reset($Cg["Type"]))));}}$L=$_POST;}page_header(($E!=""?'Alter trigger'.": ".h($E):'Create trigger'),$j,array("table"=>$a));echo'
  773. <form action="" method="post" id="form">
  774. <table cellspacing="0">
  775. <tr><th>Time<td>',html_select("Timing",$Cg["Timing"],$L["Timing"],"triggerChange(/^".preg_quote($a,"/")."_[ba][iud]$/, '".js_escape($a)."', this.form);"),'<tr><th>Event<td>',html_select("Event",$Cg["Event"],$L["Event"],"this.form['Timing'].onchange();"),(in_array("UPDATE OF",$Cg["Event"])?" <input name='Of' value='".h($L["Of"])."' class='hidden'>":""),'<tr><th>Type<td>',html_select("Type",$Cg["Type"],$L["Type"]),'</table>
  776. <p>Name: <input name="Trigger" value="',h($L["Trigger"]),'" maxlength="64" autocapitalize="off">
  777. ',script("qs('#form')['Timing'].onchange();"),'<p>';textarea("Statement",$L["Statement"]);echo'<p>
  778. <input type="submit" value="Save">
  779. ';if($E!=""){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',$E));}echo'<input type="hidden" name="token" value="',$T,'">
  780. </form>
  781. ';}elseif(isset($_GET["user"])){$fa=$_GET["user"];$Te=array(""=>array("All privileges"=>""));foreach(get_rows("SHOW PRIVILEGES")as$L){foreach(explode(",",($L["Privilege"]=="Grant option"?"":$L["Context"]))as$hb)$Te[$hb][$L["Privilege"]]=$L["Comment"];}$Te["Server Admin"]+=$Te["File access on server"];$Te["Databases"]["Create routine"]=$Te["Procedures"]["Create routine"];unset($Te["Procedures"]["Create routine"]);$Te["Columns"]=array();foreach(array("Select","Insert","Update","References")as$X)$Te["Columns"][$X]=$Te["Tables"][$X];unset($Te["Server Admin"]["Usage"]);foreach($Te["Tables"]as$y=>$X)unset($Te["Databases"][$y]);$Od=array();if($_POST){foreach($_POST["objects"]as$y=>$X)$Od[$X]=(array)$Od[$X]+(array)$_POST["grants"][$y];}$Cc=array();$ae="";if(isset($_GET["host"])&&($J=$e->query("SHOW GRANTS FOR ".q($fa)."@".q($_GET["host"])))){while($L=$J->fetch_row()){if(preg_match('~GRANT (.*) ON (.*) TO ~',$L[0],$B)&&preg_match_all('~ *([^(,]*[^ ,(])( *\\([^)]+\\))?~',$B[1],$yd,PREG_SET_ORDER)){foreach($yd
  782. as$X){if($X[1]!="USAGE")$Cc["$B[2]$X[2]"][$X[1]]=true;if(preg_match('~ WITH GRANT OPTION~',$L[0]))$Cc["$B[2]$X[2]"]["GRANT OPTION"]=true;}}if(preg_match("~ IDENTIFIED BY PASSWORD '([^']+)~",$L[0],$B))$ae=$B[1];}}if($_POST&&!$j){$be=(isset($_GET["host"])?q($fa)."@".q($_GET["host"]):"''");if($_POST["drop"])query_redirect("DROP USER $be",ME."privileges=",'User has been dropped.');else{$Qd=q($_POST["user"])."@".q($_POST["host"]);$De=$_POST["pass"];if($De!=''&&!$_POST["hashed"]){$De=$e->result("SELECT PASSWORD(".q($De).")");$j=!$De;}$lb=false;if(!$j){if($be!=$Qd){$lb=queries(($e->server_info<5?"GRANT USAGE ON *.* TO":"CREATE USER")." $Qd IDENTIFIED BY PASSWORD ".q($De));$j=!$lb;}elseif($De!=$ae)queries("SET PASSWORD FOR $Qd = ".q($De));}if(!$j){$of=array();foreach($Od
  783. as$Vd=>$q){if(isset($_GET["grant"]))$q=array_filter($q);$q=array_keys($q);if(isset($_GET["grant"]))$of=array_diff(array_keys(array_filter($Od[$Vd],'strlen')),$q);elseif($be==$Qd){$Yd=array_keys((array)$Cc[$Vd]);$of=array_diff($Yd,$q);$q=array_diff($q,$Yd);unset($Cc[$Vd]);}if(preg_match('~^(.+)\\s*(\\(.*\\))?$~U',$Vd,$B)&&(!grant("REVOKE",$of,$B[2]," ON $B[1] FROM $Qd")||!grant("GRANT",$q,$B[2]," ON $B[1] TO $Qd"))){$j=true;break;}}}if(!$j&&isset($_GET["host"])){if($be!=$Qd)queries("DROP USER $be");elseif(!isset($_GET["grant"])){foreach($Cc
  784. as$Vd=>$of){if(preg_match('~^(.+)(\\(.*\\))?$~U',$Vd,$B))grant("REVOKE",array_keys($of),$B[2]," ON $B[1] FROM $Qd");}}}queries_redirect(ME."privileges=",(isset($_GET["host"])?'User has been altered.':'User has been created.'),!$j);if($lb)$e->query("DROP USER $Qd");}}page_header((isset($_GET["host"])?'Username'.": ".h("$fa@$_GET[host]"):'Create user'),$j,array("privileges"=>array('','Privileges')));if($_POST){$L=$_POST;$Cc=$Od;}else{$L=$_GET+array("host"=>$e->result("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', -1)"));$L["pass"]=$ae;if($ae!="")$L["hashed"]=true;$Cc[(DB==""||$Cc?"":idf_escape(addcslashes(DB,"%_\\"))).".*"]=array();}echo'<form action="" method="post">
  785. <table cellspacing="0">
  786. <tr><th>Server<td><input name="host" maxlength="60" value="',h($L["host"]),'" autocapitalize="off">
  787. <tr><th>Username<td><input name="user" maxlength="16" value="',h($L["user"]),'" autocapitalize="off">
  788. <tr><th>Password<td><input name="pass" id="pass" value="',h($L["pass"]),'">
  789. ';if(!$L["hashed"])echo
  790. script("typePassword(qs('#pass'));");echo
  791. checkbox("hashed",1,$L["hashed"],'Hashed',"typePassword(this.form['pass'], this.checked);"),'</table>
  792.  
  793. ';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".'Privileges'.doc_link(array('sql'=>"grant.html#priv_level"));$s=0;foreach($Cc
  794. as$Vd=>$q){echo'<th>'.($Vd!="*.*"?"<input name='objects[$s]' value='".h($Vd)."' 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$hb=>$_b){foreach((array)$Te[$hb]as$Se=>$bb){echo"<tr".odd()."><td".($_b?">$_b<td":" colspan='2'").' lang="en" title="'.h($bb).'">'.h($Se);$s=0;foreach($Cc
  795. as$Vd=>$q){$E="'grants[$s][".h(strtoupper($Se))."]'";$Y=$q[strtoupper($Se)];if($hb=="Server Admin"&&$Vd!=(isset($Cc["*.*"])?"*.*":".*"))echo"<td>&nbsp;";elseif(isset($_GET["grant"]))echo"<td><select name=$E><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=$E value='1'".($Y?" checked":"").($Se=="All privileges"?" id='grants-$s-all'>":">".($Se=="Grant option"?"":script("qsl('input').onclick = function () { if (this.checked) formUncheck('grants-$s-all'); };"))),"</label>";}$s++;}}}echo"</table>\n",'<p>
  796. <input type="submit" value="Save">
  797. ';if(isset($_GET["host"])){echo'<input type="submit" name="drop" value="Drop">',confirm(sprintf('Drop %s?',"$fa@$_GET[host]"));}echo'<input type="hidden" name="token" value="',$T,'">
  798. </form>
  799. ';}elseif(isset($_GET["processlist"])){if(support("kill")&&$_POST&&!$j){$id=0;foreach((array)$_POST["kill"]as$X){if(kill_process($X))$id++;}queries_redirect(ME."processlist=",lang(array('%d process has been killed.','%d processes have been killed.'),$id),$id||!$_POST["kill"]);}page_header('Process list',$j);echo'
  800. <form action="" method="post">
  801. <table cellspacing="0" class="nowrap checkable">
  802. ',script("mixin(qsl('table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true)});");$s=-1;foreach(process_list()as$s=>$L){if(!$s){echo"<thead><tr lang='en'>".(support("kill")?"<th>&nbsp;":"");foreach($L
  803. 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[]",$L[$x=="sql"?"Id":"pid"],0):"");foreach($L
  804. as$y=>$X)echo"<td>".(($x=="sql"&&$y=="Info"&&preg_match("~Query|Killed~",$L["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.($L["db"]!=""?"db=".urlencode($L["db"])."&":"")."sql=".urlencode($X)).'">'.'Clone'.'</a>':nbsp($X));echo"\n";}echo'</table>
  805. ',script("tableCheck();"),'<p>
  806. ';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="',$T,'">
  807. </form>
  808. ';}elseif(isset($_GET["select"])){$a=$_GET["select"];$R=table_status1($a);$v=indexes($a);$l=fields($a);$n=column_foreign_keys($a);$Xd="";if($R["Oid"]){$Xd=($x=="sqlite"?"rowid":"oid");$v[]=array("type"=>"PRIMARY","columns"=>array($Xd));}parse_str($_COOKIE["adminer_import"],$ma);$pf=array();$d=array();$ng=null;foreach($l
  809. as$y=>$k){$E=$b->fieldName($k);if(isset($k["privileges"]["select"])&&$E!=""){$d[$y]=html_entity_decode(strip_tags($E),ENT_QUOTES);if(is_shortable($k))$ng=$b->selectLengthProcess();}$pf+=$k["privileges"];}list($N,$r)=$b->selectColumnsProcess($d,$v);$bd=count($r)<count($N);$Z=$b->selectSearchProcess($l,$v);$le=$b->selectOrderProcess($l,$v);$z=$b->selectLimitProcess();$_c=($N?implode(", ",$N):"*".($Xd?", $Xd":"")).convert_fields($d,$l,$N)."\nFROM ".table($a);$Dc=($r&&$bd?"\nGROUP BY ".implode(", ",$r):"").($le?"\nORDER BY ".implode(", ",$le):"");if($_GET["val"]&&is_ajax()){header("Content-Type: text/plain; charset=utf-8");foreach($_GET["val"]as$Kg=>$L){$ua=convert_field($l[key($L)]);$N=array($ua?$ua:idf_escape(key($L)));$Z[]=where_check($Kg,$l);$K=$Hb->select($a,$N,$Z,$N);if($K)echo
  810. reset($K->fetch_row());}exit;}if($_POST&&!$j){$fh=$Z;if(!$_POST["all"]&&is_array($_POST["check"])){$Oa=array();foreach($_POST["check"]as$Ma)$Oa[]=where_check($Ma,$l);$fh[]="((".implode(") OR (",$Oa)."))";}$fh=($fh?"\nWHERE ".implode(" AND ",$fh):"");$Pe=$Mg=null;foreach($v
  811. as$u){if($u["type"]=="PRIMARY"){$Pe=array_flip($u["columns"]);$Mg=($N?$Pe:array());break;}}foreach((array)$Mg
  812. as$y=>$X){if(in_array(idf_escape($y),$N))unset($Mg[$y]);}if($_POST["export"]){cookie("adminer_import","output=".urlencode($_POST["output"])."&format=".urlencode($_POST["format"]));dump_headers($a);$b->dumpTable($a,"");if(!is_array($_POST["check"])||$Mg===array())$I="SELECT $_c$fh$Dc";else{$Ig=array();foreach($_POST["check"]as$X)$Ig[]="(SELECT".limit($_c,"\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$l).$Dc,1).")";$I=implode(" UNION ALL ",$Ig);}$b->dumpData($a,"table",$I);exit;}if(!$b->selectEmailProcess($Z,$n)){if($_POST["save"]||$_POST["delete"]){$J=true;$na=0;$P=array();if(!$_POST["delete"]){foreach($d
  813. as$E=>$X){$X=process_input($l[$E]);if($X!==null&&($_POST["clone"]||$X!==false))$P[idf_escape($E)]=($X!==false?$X:idf_escape($E));}}if($_POST["delete"]||$P){if($_POST["clone"])$I="INTO ".table($a)." (".implode(", ",array_keys($P)).")\nSELECT ".implode(", ",$P)."\nFROM ".table($a);if($_POST["all"]||($Mg===array()&&is_array($_POST["check"]))||$bd){$J=($_POST["delete"]?$Hb->delete($a,$fh):($_POST["clone"]?queries("INSERT $I$fh"):$Hb->update($a,$P,$fh)));$na=$e->affected_rows;}else{foreach((array)$_POST["check"]as$X){$eh="\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$l);$J=($_POST["delete"]?$Hb->delete($a,$eh,1):($_POST["clone"]?queries("INSERT".limit1($I,$eh)):$Hb->update($a,$P,$eh)));if(!$J)break;$na+=$e->affected_rows;}}}$C=lang(array('%d item has been affected.','%d items have been affected.'),$na);if($_POST["clone"]&&$J&&$na==1){$nd=last_id();if($nd)$C=sprintf('Item%s has been inserted.'," $nd");}queries_redirect(remove_from_uri($_POST["all"]&&$_POST["delete"]?"page":""),$C,$J);if(!$_POST["delete"]){edit_form($a,$l,(array)$_POST["fields"],!$_POST["clone"]);page_footer();exit;}}elseif(!$_POST["import"]){if(!$_POST["val"])$j='Ctrl+click on a value to modify it.';else{$J=true;$na=0;foreach($_POST["val"]as$Kg=>$L){$P=array();foreach($L
  814. as$y=>$X){$y=bracket_escape($y,1);$P[idf_escape($y)]=(preg_match('~char|text~',$l[$y]["type"])||$X!=""?$b->processInput($l[$y],$X):"NULL");}$J=$Hb->update($a,$P," WHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($Kg,$l),!($bd||$Mg===array())," ");if(!$J)break;$na+=$e->affected_rows;}queries_redirect(remove_from_uri(),lang(array('%d item has been affected.','%d items have been affected.'),$na),$J);}}elseif(!is_string($qc=get_file("csv_file",true)))$j=upload_error($qc);elseif(!preg_match('~~u',$qc))$j='File must be in UTF-8 encoding.';else{cookie("adminer_import","output=".urlencode($ma["output"])."&format=".urlencode($_POST["separator"]));$J=true;$Ya=array_keys($l);preg_match_all('~(?>"[^"]*"|[^"\\r\\n]+)+~',$qc,$yd);$na=count($yd[0]);$Hb->begin();$Bf=($_POST["separator"]=="csv"?",":($_POST["separator"]=="tsv"?"\t":";"));$M=array();foreach($yd[0]as$y=>$X){preg_match_all("~((?>\"[^\"]*\")+|[^$Bf]*)$Bf~",$X.$Bf,$zd);if(!$y&&!array_diff($zd[1],$Ya)){$Ya=$zd[1];$na--;}else{$P=array();foreach($zd[1]as$s=>$Ua)$P[idf_escape($Ya[$s])]=($Ua==""&&$l[$Ya[$s]]["null"]?"NULL":q(str_replace('""','"',preg_replace('~^"|"$~','',$Ua))));$M[]=$P;}}$J=(!$M||$Hb->insertUpdate($a,$M,$Pe));if($J)$J=$Hb->commit();queries_redirect(remove_from_uri("page"),lang(array('%d row has been imported.','%d rows have been imported.'),$na),$J);$Hb->rollback();}}}$bg=$b->tableName($R);if(is_ajax()){page_headers();ob_start();}else
  815. page_header('Select'.": $bg",$j);$P=null;if(isset($pf["insert"])||!support("table")){$P="";foreach((array)$_GET["where"]as$X){if($n[$X["col"]]&&count($n[$X["col"]])==1&&($X["op"]=="="||(!$X["op"]&&!preg_match('~[_%]~',$X["val"]))))$P.="&set".urlencode("[".bracket_escape($X["col"])."]")."=".urlencode($X["val"]);}}$b->selectLinks($R,$P);if(!$d&&support("table"))echo"<p class='error'>".'Unable to select the table'.($l?".":": ".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($N,$d);$b->selectSearchPrint($Z,$d,$v);$b->selectOrderPrint($le,$d,$v);$b->selectLimitPrint($z);$b->selectLengthPrint($ng);$b->selectActionPrint($v);echo"</form>\n";$F=$_GET["page"];if($F=="last"){$zc=$e->result(count_rows($a,$Z,$bd,$r));$F=floor(max(0,$zc-1)/$z);}$yf=$N;if(!$yf){$yf[]="*";if($Xd)$yf[]=$Xd;}$ib=convert_fields($d,$l,$N);if($ib)$yf[]=substr($ib,2);$J=$Hb->select($a,$yf,$Z,$r,$le,$z,$F,true);if(!$J)echo"<p class='error'>".error()."\n";else{if($x=="mssql"&&$F)$J->seek($z*$F);$Vb=array();echo"<form action='' method='post' enctype='multipart/form-data'>\n";$M=array();while($L=$J->fetch_assoc()){if($F&&$x=="oracle")unset($L["RNUM"]);$M[]=$L;}if($_GET["page"]!="last"&&$z!=""&&$r&&$bd&&$x=="sql")$zc=$e->result(" SELECT FOUND_ROWS()");if(!$M)echo"<p class='message'>".'No rows.'."\n";else{$Ba=$b->backwardKeys($a,$bg);echo"<table id='table' cellspacing='0' class='nowrap checkable'>",script("mixin(qs('#table'), {onclick: tableClick, ondblclick: partialArg(tableClick, true), onkeydown: editingKeydown});"),"<thead><tr>".(!$r&&$N?"":"<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>");$Nd=array();$Bc=array();reset($N);$cf=1;foreach($M[0]as$y=>$X){if($y!=$Xd){$X=$_GET["columns"][key($N)];$k=$l[$N?($X?$X["col"]:current($N)):$y];$E=($k?$b->fieldName($k,$cf):($X["fun"]?"*":$y));if($E!=""){$cf++;$Nd[$y]=$E;$c=idf_escape($y);$Nc=remove_from_uri('(order|desc)[^=]*|page').'&order%5B0%5D='.urlencode($y);$_b="&desc%5B0%5D=1";echo"<th>".script("mixin(qsl('th'), {onmouseover: partial(columnMouse), onmouseout: partial(columnMouse, ' hidden')});",""),'<a href="'.h($Nc.($le[0]==$c||$le[0]==$y||(!$le&&$bd&&$r[0]==$c)?$_b:'')).'">';echo
  816. apply_sql_function($X["fun"],$E)."</a>";echo"<span class='column hidden'>","<a href='".h($Nc.$_b)."' 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>";}$Bc[$y]=$X["fun"];next($N);}}$td=array();if($_GET["modify"]){foreach($M
  817. as$L){foreach($L
  818. as$y=>$X)$td[$y]=max($td[$y],min(40,strlen(utf8_decode($X))));}}echo($Ba?"<th>".'Relations':"")."</thead>\n";if(is_ajax()){if($z%2==1&&$F%2==1)odd();ob_end_clean();}foreach($b->rowDescriptions($M,$n)as$D=>$L){$Jg=unique_array($M[$D],$v);if(!$Jg){$Jg=array();foreach($M[$D]as$y=>$X){if(!preg_match('~^(COUNT\\((\\*|(DISTINCT )?`(?:[^`]|``)+`)\\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\\(`(?:[^`]|``)+`\\))$~',$y))$Jg[$y]=$X;}}$Kg="";foreach($Jg
  819. as$y=>$X){if(($x=="sql"||$x=="pgsql")&&preg_match('~char|text|enum|set~',$l[$y]["type"])&&strlen($X)>64){$y=(strpos($y,'(')?$y:idf_escape($y));$y="MD5(".($x!='sql'||preg_match("~^utf8~",$l[$y]["collation"])?$y:"CONVERT($y USING ".charset($e).")").")";$X=md5($X);}$Kg.="&".($X!==null?urlencode("where[".bracket_escape($y)."]")."=".urlencode($X):"null%5B%5D=".urlencode($y));}echo"<tr".odd().">".(!$r&&$N?"":"<td>".checkbox("check[]",substr($Kg,1),in_array(substr($Kg,1),(array)$_POST["check"]),"","this.form['all'].checked = false; formUncheck('all-page');").($bd||information_schema(DB)?"":" <a href='".h(ME."edit=".urlencode($a).$Kg)."'>".'edit'."</a>"));foreach($L
  820. as$y=>$X){if(isset($Nd[$y])){$k=$l[$y];if($X!=""&&(!isset($Vb[$y])||$Vb[$y]!=""))$Vb[$y]=(is_mail($X)?$Nd[$y]:"");$_="";if(preg_match('~blob|bytea|raw|file~',$k["type"])&&$X!="")$_=ME.'download='.urlencode($a).'&field='.urlencode($y).$Kg;if(!$_&&$X!==null){foreach((array)$n[$y]as$m){if(count($n[$y])==1||end($m["source"])==$y){$_="";foreach($m["source"]as$s=>$Jf)$_.=where_link($s,$m["target"][$s],$M[$D][$Jf]);$_=($m["db"]!=""?preg_replace('~([?&]db=)[^&]+~','\\1'.urlencode($m["db"]),ME):ME).'select='.urlencode($m["table"]).$_;if($m["ns"])$_=preg_replace('~([?&]ns=)[^&]+~','\\1'.urlencode($m["ns"]),$_);if(count($m["source"])==1)break;}}}if($y=="COUNT(*)"){$_=ME."select=".urlencode($a);$s=0;foreach((array)$_GET["where"]as$W){if(!array_key_exists($W["col"],$Jg))$_.=where_link($s++,$W["col"],$W["val"],$W["op"]);}foreach($Jg
  821. as$fd=>$W)$_.=where_link($s++,$fd,$W);}$X=select_value($X,$_,$k,$ng);$t=h("val[$Kg][".bracket_escape($y)."]");$Y=$_POST["val"][$Kg][bracket_escape($y)];$Qb=!is_array($L[$y])&&is_utf8($X)&&$M[$D][$y]==$L[$y]&&!$Bc[$y];$mg=preg_match('~text|lob~',$k["type"]);if(($_GET["modify"]&&$Qb)||$Y!==null){$Fc=h($Y!==null?$Y:$L[$y]);echo"<td>".($mg?"<textarea name='$t' cols='30' rows='".(substr_count($L[$y],"\n")+1)."'>$Fc</textarea>":"<input name='$t' value='$Fc' size='$td[$y]'>");}else{$xd=strpos($X,"<i>...</i>");echo"<td id='$t'>$X</td>",script("qsl('td').onclick = partialArg(selectClick, ".($xd?2:($mg?1:0)).($Qb?"":", '".h('Use edit link to modify this value.')."'").");","");}}}if($Ba)echo"<td>";$b->backwardKeysPrint($Ba,$M[$D]);echo"</tr>\n";}if(is_ajax())exit;echo"</table>\n";}if(($M||$F)&&!is_ajax()){$fc=true;if($_GET["page"]!="last"){if($z=="")$zc=count($M);elseif($x!="sql"||!$bd){$zc=($bd?false:found_rows($R,$Z));if($zc<max(1e4,2*($F+1)*$z))$zc=reset(slow_query(count_rows($a,$Z,$bd,$r)));else$fc=false;}}if($z!=""&&($zc===false||$zc>$z||$F)){echo"<p class='pages'>";$Ad=($zc===false?$F+(count($M)>=$z?2:1):floor(($zc-1)/$z));if($x!="simpledb"){echo'<a href="'.h(remove_from_uri("page")).'">'.'Page'."</a>:",script("qsl('a').onclick = function () { pageClick(this.href, +prompt('".'Page'."', '".($F+1)."')); return false; };"),pagination(0,$F).($F>5?" ...":"");for($s=max(1,$F-4);$s<min($Ad,$F+5);$s++)echo
  822. pagination($s,$F);if($Ad>0){echo($F+5<$Ad?" ...":""),($fc&&$zc!==false?pagination($Ad,$F):" <a href='".h(remove_from_uri("page")."&page=last")."' title='~$Ad'>".'last'."</a>");}echo(($zc===false?count($M)+1:$zc-$F*$z)>$z?' <a href="'.h(remove_from_uri("page")."&page=".($F+1)).'" class="loadmore">'.'Load more data'.'</a>'.script("qsl('a').onclick = partial(selectLoadMore, ".(+$z).", '".'Loading'."...');",""):'');}else{echo'Page'.":",pagination(0,$F).($F>1?" ...":""),($F?pagination($F,$F):""),($Ad>$F?pagination($F+1,$F).($Ad>$F+1?" ...":""):"");}}echo"<p class='count'>\n",($zc!==false?"(".($fc?"":"~ ").lang(array('%d row','%d rows'),$zc).") ":"");$Eb=($fc?"":"~ ").$zc;echo
  823. checkbox("all",1,0,'whole result',"var checked = formChecked(this, /check/); selectCount('selected', this.checked ? '$Eb' : checked); selectCount('selected2', this.checked || !checked ? '$Eb' : checked);")."\n";if($b->selectCommandPrint()){echo'<fieldset',($_GET["modify"]?'':' class="jsonly"'),'><legend>Modify</legend><div>
  824. <input type="submit" value="Save"',($_GET["modify"]?'':' title="'.'Ctrl+click on a value to modify it.'.'"'),'>
  825. </div></fieldset>
  826. <fieldset><legend>Selected <span id="selected"></span></legend><div>
  827. <input type="submit" name="edit" value="Edit">
  828. <input type="submit" name="clone" value="Clone">
  829. <input type="submit" name="delete" value="Delete">',confirm(),'</div></fieldset>
  830. ';}$xc=$b->dumpFormat();foreach((array)$_GET["columns"]as$c){if($c["fun"]){unset($xc['sql']);break;}}if($xc){print_fieldset("export",'Export'." <span id='selected2'></span>");$ve=$b->dumpOutput();echo($ve?html_select("output",$ve,$ma["output"])." ":""),html_select("format",$xc,$ma["format"])," <input type='submit' name='export' value='".'Export'."'>\n","</div></fieldset>\n";}echo(!$r&&$N?"":script("tableCheck();"));}if($b->selectImportPrint()){print_fieldset("import",'Import',!$M);echo"<input type='file' name='csv_file'> ",html_select("separator",array("csv"=>"CSV,","csv;"=>"CSV;","tsv"=>"TSV"),$ma["format"],1);echo" <input type='submit' name='import' value='".'Import'."'>","</div></fieldset>\n";}$b->selectEmailPrint(array_filter($Vb,'strlen'),$d);echo"<p><input type='hidden' name='token' value='$T'></p>\n","</form>\n";}}if(is_ajax()){ob_end_clean();exit;}}elseif(isset($_GET["variables"])){$Pf=isset($_GET["status"]);page_header($Pf?'Status':'Variables');$Xg=($Pf?show_status():show_variables());if(!$Xg)echo"<p class='message'>".'No rows.'."\n";else{echo"<table cellspacing='0'>\n";foreach($Xg
  831. as$y=>$X){echo"<tr>","<th><code class='jush-".$x.($Pf?"status":"set")."'>".h($y)."</code>","<td>".nbsp($X);}echo"</table>\n";}}elseif(isset($_GET["script"])){header("Content-Type: text/javascript; charset=utf-8");if($_GET["script"]=="db"){$Yf=array("Data_length"=>0,"Index_length"=>0,"Data_free"=>0);foreach(table_status()as$E=>$R){json_row("Comment-$E",nbsp($R["Comment"]));if(!is_view($R)){foreach(array("Engine","Collation")as$y)json_row("$y-$E",nbsp($R[$y]));foreach($Yf+array("Auto_increment"=>0,"Rows"=>0)as$y=>$X){if($R[$y]!=""){$X=format_number($R[$y]);json_row("$y-$E",($y=="Rows"&&$X&&$R["Engine"]==($Mf=="pgsql"?"table":"InnoDB")?"~ $X":$X));if(isset($Yf[$y]))$Yf[$y]+=($R["Engine"]!="InnoDB"||$y!="Data_free"?$R[$y]:0);}elseif(array_key_exists($y,$R))json_row("$y-$E");}}}foreach($Yf
  832. as$y=>$X)json_row("sum-$y",format_number($X));json_row("");}elseif($_GET["script"]=="kill")$e->query("KILL ".number($_POST["kill"]));elseif($_GET["script"]=="version"){$o=file_open_lock(get_temp_dir()."/adminer.version");if($o)file_write_unlock($o,serialize(array("signature"=>$_POST["signature"],"version"=>$_POST["version"])));}else{foreach(count_tables($b->databases())as$i=>$X){json_row("tables-$i",$X);json_row("size-$i",db_size($i));}json_row("");}exit;}else{$gg=array_merge((array)$_POST["tables"],(array)$_POST["views"]);if($gg&&!$j&&!$_POST["search"]){$J=true;$C="";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"])$J=truncate_tables($_POST["tables"]);$C='Tables have been truncated.';}elseif($_POST["move"]){$J=move_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$C='Tables have been moved.';}elseif($_POST["copy"]){$J=copy_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$C='Tables have been copied.';}elseif($_POST["drop"]){if($_POST["views"])$J=drop_views($_POST["views"]);if($J&&$_POST["tables"])$J=drop_tables($_POST["tables"]);$C='Tables have been dropped.';}elseif($x!="sql"){$J=($x=="sqlite"?queries("VACUUM"):apply_queries("VACUUM".($_POST["optimize"]?"":" ANALYZE"),$_POST["tables"]));$C='Tables have been optimized.';}elseif(!$_POST["tables"])$C='No tables.';elseif($J=queries(($_POST["optimize"]?"OPTIMIZE":($_POST["check"]?"CHECK":($_POST["repair"]?"REPAIR":"ANALYZE")))." TABLE ".implode(", ",array_map('idf_escape',$_POST["tables"])))){while($L=$J->fetch_assoc())$C.="<b>".h($L["Table"])."</b>: ".h($L["Msg_text"])."<br>";}queries_redirect(substr(ME,0,-1),$C,$J);}page_header(($_GET["ns"]==""?'Database'.": ".h(DB):'Schema'.": ".h($_GET["ns"])),$j,true);if($b->homepage()){if($_GET["ns"]!==""){echo"<h3 id='tables-views'>".'Tables and views'."</h3>\n";$fg=tables_list();if(!$fg)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"]!="")search_tables();}$Fb=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-mysql.html')),'<td>'.'Data Length'.$Fb,'<td>'.'Index Length'.$Fb,'<td>'.'Data Free'.$Fb,'<td>'.'Auto Increment'.doc_link(array('sql'=>'example-auto-increment.html')),'<td>'.'Rows'.$Fb,(support("comment")?'<td>'.'Comment'.$Fb:''),"</thead>\n";$S=0;foreach($fg
  833. as$E=>$U){$ah=($U!==null&&!preg_match('~table~i',$U));$t=h("Table-".$E);echo'<tr'.odd().'><td>'.checkbox(($ah?"views[]":"tables[]"),$E,in_array($E,$gg,true),"","formUncheck('check-all');","",$t),'<th>'.(support("table")||support("indexes")?"<a href='".h(ME)."table=".urlencode($E)."' title='".'Show structure'."' id='$t'>".h($E).'</a>':h($E));if($ah){echo'<td colspan="6"><a href="'.h(ME)."view=".urlencode($E).'" title="'.'Alter view'.'">'.(preg_match('~materialized~i',$U)?'Materialized view':'View').'</a>','<td align="right"><a href="'.h(ME)."select=".urlencode($E).'" 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($E)."'";echo($_?"<td align='right'>".(support("table")||$y=="Rows"||(support("indexes")&&$y!="Data_length")?"<a href='".h(ME."$_[0]=").urlencode($E)."'$t title='$_[1]'>?</a>":"<span$t>?</span>"):"<td id='$y-".h($E)."'>&nbsp;");}$S++;}echo(support("comment")?"<td id='Comment-".h($E)."'>&nbsp;":"");}echo"<tr><td>&nbsp;<th>".sprintf('%d in total',count($fg)),"<td>".nbsp($x=="sql"?$e->result("SELECT @@storage_engine"):""),"<td>".nbsp(db_collation(DB,collations()));foreach(array("Data_length","Index_length","Data_free")as$y)echo"<td align='right' id='sum-$y'>&nbsp;";echo"</table>\n";if(!information_schema(DB)){$Vg="<input type='submit' value='".'Vacuum'."'> ".on_help("'VACUUM'");$ie="<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"?$Vg:($x=="pgsql"?$Vg.$ie:($x=="sql"?"<input type='submit' value='".'Analyze'."'> ".on_help("'ANALYZE TABLE'").$ie."<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";$h=(support("scheme")?$b->schemas():$b->databases());if(count($h)!=1&&$x!="sqlite"){$i=(isset($_POST["target"])?$_POST["target"]:(support("scheme")?$_GET["ns"]:DB));echo"<p>".'Move to other database'.": ",($h?html_select("target",$h,$i):'<input name="target" value="'.h($i).'" 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
  834. script("qsl('input').onclick = function () { selectCount('selected', formChecked(this, /^(tables|views)\[/));".(support("table")?" selectCount('selected2', formChecked(this, /^tables\[/) || $S);":"")." }"),"<input type='hidden' name='token' value='$T'>\n","</div></fieldset>\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";$tf=routines();if($tf){echo"<table cellspacing='0'>\n",'<thead><tr><th>'.'Name'.'<td>'.'Type'.'<td>'.'Return type'."<td>&nbsp;</thead>\n";odd('');foreach($tf
  835. as$L){echo'<tr'.odd().'>','<th><a href="'.h(ME).($L["ROUTINE_TYPE"]!="PROCEDURE"?'callf=':'call=').urlencode($L["ROUTINE_NAME"]).'">'.h($L["ROUTINE_NAME"]).'</a>','<td>'.h($L["ROUTINE_TYPE"]),'<td>'.h($L["DTD_IDENTIFIER"]),'<td><a href="'.h(ME).($L["ROUTINE_TYPE"]!="PROCEDURE"?'function=':'procedure=').urlencode($L["ROUTINE_NAME"]).'">'.'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("event")){echo"<h3 id='events'>".'Events'."</h3>\n";$M=get_rows("SHOW EVENTS");if($M){echo"<table cellspacing='0'>\n","<thead><tr><th>".'Name'."<td>".'Schedule'."<td>".'Start'."<td>".'End'."<td></thead>\n";foreach($M
  836. as$L){echo"<tr>","<th>".h($L["Name"]),"<td>".($L["Execute at"]?'At given time'."<td>".$L["Execute at"]:'Every'." ".$L["Interval value"]." ".$L["Interval field"]."<td>$L[Starts]"),"<td>$L[Ends]",'<td><a href="'.h(ME).'event='.urlencode($L["Name"]).'">'.'Alter'.'</a>';}echo"</table>\n";$dc=$e->result("SELECT @@event_scheduler");if($dc&&$dc!="ON")echo"<p class='error'><code class='jush-sqlset'>event_scheduler</code>: ".h($dc)."\n";}echo'<p class="links"><a href="'.h(ME).'event=">'.'Create event'."</a>\n";}if($fg)echo
  837. script("ajaxSetHtml('".js_escape(ME)."script=db');");}}}page_footer();
Add Comment
Please, Sign In to add comment