SHARE
TWEET

Adminer

a guest Aug 12th, 2016 2,056 Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. <?php
  2. /** Adminer - Compact database management
  3. * @link https://www.adminer.org/
  4. * @author Jakub Vrana, http://www.vrana.cz/
  5. * @copyright 2007 Jakub Vrana
  6. * @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
  7. * @license http://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
  8. * @version 4.2.5
  9. */error_reporting(6135);$Jc=!preg_match('~^(unsafe_raw)?$~',ini_get("filter.default"));if($Jc||ini_get("filter.default_flags")){foreach(array('_GET','_POST','_COOKIE','_SERVER')as$X){$Gh=filter_input_array(constant("INPUT$X"),FILTER_UNSAFE_RAW);if($Gh)$$X=$Gh;}}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");if($_GET["file"]=="favicon.ico"){header("Content-Type: image/x-icon");echo
  10. 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
  11. lzw_decompress("\n1ٌ̇l7B14vb0fsn2Bѱ٘n:#(b.\rDc)a7El ñi1̎s-4f   i7 Fé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\"(#[@g ozn9k8n1I* =n0c(;à!*c>ΎE7DLJ1J=1L?s=#`3\$4uȱzGC YAt?;Qk&YPuǯ}UaHV%G;s<A\0\\P\\&ªV\nSUtr2 l^Z6ejA d[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_މb/HB%0>hoWnxl֍浃CQ^\r4lK{Z:Ã.pĂJB-+B(T%J0lT`+-@BۄV\0C,0tF?Ġ\na@Ɍ>ZECO-^Q&)I)R]\r97_\rF80Ob    >\nR_8٫ ov0bCAF!tă%0/zAYO(4  '] I8hH053@x&n|T)`.s6eYDzJѓ.{GEbӋ2{\$**@C-:zYHZI5F]YCOA`x'.*9t'{(wP=**xwr*cc|DV\rV.0 Vd?Ҁ,E͝`T6ۈ-ڎT[ѐz.Ar̀Pnc= a9Fn!u A0iPJ6e T]V[\rXav k\n+Eܕ*\0~@g\"NCI\$Ɍx@Wy*vuD\0v댆V\0V`GuE֕flh@)0@T7§RAٷ3ۘ/Q],s{VRFA<vץ%@9F5t%+ /8;WJo:N`  h{ܣ Ԑ8Eu&W|ɆU&\r\"|-udžN:ncfV# U20>\">`k]-xS͇ТcB}&`r+E\$yNb,Wx -9r,`+ˊC)7x\rWfMSR \\zQ̓u A24L&Hi µS\$)eg rȌ\$]ZiYskWn>7E1k8drkEwwcmTya\$tx\rB=*<l fKN/    lkH8.?f6ч{gi/\"@ K@2a|#,Z wd6w^&tP].Tkro\ro=%h`:\0᱂ |ꊣa Ԯ6*:*rO-^nM}Aya\nu^rnO\r`T~</wy}:|̡6v \rc<b# \$s|燇V)hTC(Ľ]61!1M@a/`>ٸߣC/6ഷ#p@p `Zch\0 \0o 4OO i\0-\n/\0D. .Đ\0fiȫ\0ID\0\r0foGeJ|\rl   3~ iP&/\09  ^\0r0] ›o .\" M vPZm pP ڜޏ{C ?kϼ}d ʏ~=.-   m1> hЕ1;QIOP\rcpApVk\rQ* Q}q>u15BqQ[1flap\0*JQ=G _bGHF.0    = 2P P!#(3 \n!1&72f`/\0\"PU \$\r0 ,QrU&2f_X ]9\"S''y8\rkW)O)*Ra%\\ i%&ҳ+r3S`,v&2L&Pu*-0\"%HĬԞ@ؓHBP(\$p&,1M ح;\rn. I.',1)42u+3 ` S pL\nt_*S3;6r'h3555䜋d2q+68O7sC\"pm8ҭ69m\n@e0<8B8<,(8\0  0J<@IR6pԭmG\"116.\"5̂:8bA1;';?<*\$,̍o= T/3#҆");}elseif($_GET["file"]=="functions.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  12. lzw_decompress("f:gCI\n0S a9S`&(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\rK9 h   `I8䛱 St2+,I p9 m@:x)Cx34P7- 4r\"p3Fh-5U4͉\\6<D\$ l9R4t7dD3pΓk:)\\;\r@t\$4O<!pdQJ\rH}:&Ȅ5YWJ`NbKNSa d>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ж(' j A>BCd\"K\$ CA .².`.E洖yy\0D28t  68 FLB*,|\nx\\@@3r WKQb,%DBfȳD|͌E0/2>Y!Ć'`fmH<BB0\r*\0Gx n Y4,L%S,v0 XQ1HId`!.V H/×H0U0™`LI8k24JYN&8xJk:AK㝡nW!I;' \":24~J8ᒑG\"M=\rZ'ni9FrRt 3\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<7e F?XD, CkUL>1܇p0#\$V)pYs5A:U(95,F+&*{-::7:ʙyPX+\nI;\\sP1 rNJAT'-k?Y@fb񎒔RJimB~K\rKt4;OKc9% H5d3e8jP[s9,ĘbzKW&ed8)5ph\"0hL5\07 ڌڇ{ݿ<k\r+Xbl/؝XACs\nal}~ݴdrx(\r3nGrT+ QJP\n'?Ĵn~:  Q8`{a 4:L: uMߎMI,`BgN\rB\r\0o\"/2^D2)n\razR\$7`Lp*{`Oqtz%%Hg0Kf&)\\QW\0dp<Q\"c'/Q7>+j#\0ȺБ_ȍk3J(%O\0Tm4k:lʞmD\$\0'~ Z@ VL\"Hjn5Nlfj&M OdbӰROdiiN (%-4+:HpR?BM0JF.1 Mf~UT갊lˠ0U|Ђ@X4bg ]P?@z ` <R`-FI\0㬦|ОŬTkQkF@0LP\r#uܲpX^ѱap\0\r yPt%\0^8\rk\0ǡ1\ndB .\nQjq\$\r M˾Fo(︉ [ .#>Q`Y`M,J\n<uz+I!)+tŊlƜm\"\"17\"j0#Nm ٢O pRK#R7#C&!2\$>ϜC.R\"r\"Py˰7\rܼs)%#U\rOEЀyxCt@п*H+@0\rI L/ \\\rNR\r\0@+\$/*w0S\nt \"\0r/P\03L%rR2R*+0\"-3N1D7(tb/@12M6 d(c7*pl8(t 0Kp2-Fb\$R(/+2,̲l8rK!6\"Sa0bx\$O\0\re \r\"8't\r+P@Y1 YbR⹰\\jK)438h17z`pRRCB< F    4DtJ-tVD6\0NLTv_0\"qJI*.qR|HΠt]>\0OL(#n. 2Bn9Jm@Rs2|h tNn6BcO+҆eBO=,C:6:M<BV\\`/Bڧ,w:H͸2xpMnbnՄ0     1,4V#&ljKC\ngl\rIcY@Yh3\nU]@  \rLd\\ B\"t\rp'\n'O\\RИֳ5 S b%[\$Lu`5Yu[\0|EMh\\)\\u9bH.e@\r!e'VPC'c\"f(RŇ&#~\\qH]{^g'O<vz6lpg'8E{*/UVpo,+)Xk.0`s0hro^ 𦆰B\"jOk- % Ɓ 0gx+  [P7\"* hP P\rc<[`V 7:`U(Is*d;>   BGsG t:8d \0 @jwLvj ow7v b  pu-\n, u:)\"ut:WB<Sb12CײSd%)rpտ{cpqM!#P#@E}c\"@|d%kr\"*x w}״uWl&X~SB'u@6Chº..'+@Ӄ[T1 b\"\n\0\n`I\0n+/\"lW1uƴZDC(1pwм ^\0ZJ`b#5ɄH;(!`#^»yߍVGr|_pGeQjd'2I-h^ da)א:HH)5q XFQ_{8)~N~\"`\$1   B_N^h[N(+MwϙP'p65b?Ѵy&<ZTq,9Op@2MzĕPq4`eob\"fmvX@c9a0w  Db ~W\"u@Jri800#}7+ok@\n)lr%v܇!n{XYw*,bF^\r1y5BY՜#w:3&jBfY` BI|l0 ӫOr[rEa0bɋ\n   (\rGF@ؼ٭߮1ГSs+X%@ug9zfS#0 DB _wE B>{*@}kȽ\\P,\"-rCrVYםZ\r[S}\0Y%kcϖ2vs\rKO T@ s!2cw˒v,4&rxr؇~#\"X\r];SFF<ta/M&U>5s S>6U{p!\"y7MmeZD!*vwW   0w01|H\$ &ԉ+{GRH!rԁ - 24l\r\r\0t<ƅf:DSdeQ\r\\aEbGm gx-TGYKƢtp0?Frx 2\\V2;'\n€+b1DG5l'(/[,N(nG8bXQ*-R\n4q#[U<eĝ`&&o@u%5\0`\0E}#lʨUx%mY&Pb͕ .ϡ1<jnǃ\nV~oNp\n\$E&# % G\0= ek QC<}]A-Yb;ฆ[ UYc~T.\\<Wn\\oPqƉ6P\ns`c:3([zX{ P\\炫WY:߮:#9Y[Yt&l9kޱY_҉b~&v  *1 `f8SV^'}lz8 ZGb_]⢏fpJZ0@V'uy  CR'N ?Yk \$c =n  YJ>PRJ].짃};;S]@:I~ۑҝ|;Fyƃ}`/-#1@y7ys}\$Aa\\<xG֨BmamZx3,}ϝ:\nd9΋}Hm T,/KΪ (Sh:V,N\\\rB%Yvi,pyrrH&dL%(@L5T@1`٠:\nc,bO,\"ԣr(fYO-yk*&,kyIP\nrpE%`89ׅlUN6_<EdLK!Zbk*qC\$PsHnIM(qD@\"8\nrfC\rP pKƣ஛dL!NR9cli!a :\r\rPSS *0a,бd4Q\r3vLʘðGn\"3%Qd)i4usXMP^5O    bp xyTqDnByClq\0X2E%    dF,7G&Ri#瀉CVN\$LB!(<*1|H\"E u <P0T|s)C(oZ[ҵSt m\nn 6</> '|#h6\r.=(v;`\"OCܐ!B9.B!UEDĂd)K\0޻mF~   B{O\0ρ_u#5 =Lj79 6lCV  Tp08  1 x'0@gIwZ@9 Lᎎ\\v\0_(\".ЯA[sń7I(azl_EЦ< tU7`t0(3=o\$[h!B[HR ))nx aZ#=H8뛥 %@0w5J   A\"F:8N\" X- ?pj@)iUj\$̚-EE\n/PBP@y8jYK9  0HDd&0hX \\\$(`d\nEΤ@Jb*NRP\"(q.f#dGDMn9:*fЎt4:pM(5%Q\0eSb41eM),R\"km?\0rB (\\ŕde<\\BMiL (hR De\"rCR)9EJQҘ>    O´`A#bh|HN\$%Z#4- 2=D\\0Ȇ\\\"aUR   -Ik0\0ق HH~u]QF1 ')-\0'xeѷp\$Qea #\"Rǰ @\\F0Ѹ#\"&<1HЃ\" B.#h/TmA[\rR(¼@%E8&\$    `EÐ,B](a{@6Ik3[h Ew\01)%檘 @ڪ\"6aJI8J+4qa0\nB2ɗa!{qg1!9:\0&D8|8\0:5P10:yFDHUk3USLK fimBFk@EPM-;1%82ls1!&5Ra4P%eO/EI@C=MHd8@9rIЀ*B, ^\rۀN猗4BZCXs!    *@EN)Д4a\n )?`+&C01MSqDQB\"n)M!x \05 j3w\0⣂0!\$ \0`a72QZ>I4}xZu\0W dd4J226\n   ٠ŅOhF0Ț\0=΃%1\rAih @vM)\0`&a2KiKfhZU\nA M(iPW47|ZQ:5X>x#5s=0R>7i'ٞ\0ʙ)`hRd`ѵMIQ\\VV4TUR%9Fah47] M_`>P~_T!N\0.l%C(DZSqu\0in默2HqCM`AMqQ~5p +AZh3 \n62URbq%B(\nT󑜛F>8GM LpiȢEQfM&.©OQ\"=Z{RlaOثk} -~+`ewWT    ը2ߘ.1RH8Hdh@0\0[ @r j\"OZ1r#tQ@7V5k+ʽVl\r-U\$\$Xڼ4F6{/ǁPZs|\rcӀff? _XՔ@0nl܄Yg:װSs~9Ft\0/\n0']y^#&\rH jR0:⇣D7J~52lD}JTeΜ%}+R#k3T\0rYuhތf leA1S TP\"PhENVK`2Q\0eeK>I Fܚ-7S=BjN5U[Xl'\0 2j\0;͑J\"\r4hEFXmR\0Q*/XK{hWڑlm'j8ڎ.FsUԩ\"i+bBUl1 RCG-3)3\0'Nv?PeZ/iO]6b|1T jHھ@m-k_TP薯\\\069nU{-5!Gξ5 mS \$룱m3%`[B/eTmiNo!.\r 06,l\0:&|\rֻ\"Mkw*rHVÜ5ۂj „YpғX\rw{U߅qĒ\$uUl{\$׶5m(`/4/nIpj\\-_3\\)sזWmt\nJRDт%t\n*Rz2>\"a\081/s@ۆJ' lHuk Zh 8s}ȚP)R*be%os2aQJհqk6g.  R/({Ǥ~E;\$tlmIGR:i'Ap yۭDM/<wºp\r\"}\0PS'܆pk`CqEY3d|p{DJ;cHTWnW<)M5~Y2t9kR<q#\0ep7L+c \0u\0\0mWc}[* <ؾ+r7@+^/ķ_YƎ/y6پ%XKRoS\\ m/gP¾V%DGOiutN)ί&yS0jnrrTymyk! 8UDnB\0lPG.[z|8bGx\\s[#?>:\0Xz f f.4^  9 |\rz+GZD?5A A]1ϱ57bv`|1k.LUڐ/`We'kkܟI\0wvu]-%Ob3jb͙TA%&IPcB9͋{yBLtV?F:hUd[Ѡk8OSV kZ|*UG-k&IݔO9\0eQ>7pe[<Rݭh\$?ύ Aǐ-!i|ֿ[U fEƧStFRUH?ZI@ÑEY*YYZE=:+@V6^ڽN8VK2 #bɊ[2-  k2&*E NkV2yW8+֜q&91+ZD\",ʃ#-45cxP̕lX s-PχBkF\$5mW@\0!`@߁\"Oa714yous,|d*+ɢee7<Ŝ:ߘ]bg!bsH\nrnՖ@@r r)0 \" \0\"΀O4]ސaH*o,뀬.Cp3>ux5    暳VZҀ,,\rfHle:eZ@] \rs@%\"\n!khʴeȴ?ji: >{ɚ˟! W.EBV   \00029歚C\r4 P+.=5\$Kb h(5\0IC U4'V(-!0    ȕ:enÛ:-F;/#T< MVH/O۹QŞ4h- D5U\0@\" Fav@y';.HnrzxP^[bED;SY    P :1Niwfw1Y|FDiZD|{qR0\"(OD z`)`- |5Ql_c.k<50zҖкed\$\"JS \n\rHK_ӄt4sA\njV!o[lOPQwӆQ9!5\0Ymg(@uXO_a~&#( =:\0k4W\0]I+f  FjC#n7?NN풴)&z݊ohBlMTU)5ptt\rV .]͋лnJvضt(nѻݜD2)m۞([r2ze=n*̍vw8x+<` 2GFTB=vh=};L/wv[c)nL*7`7ޑ_\n{B%Q\0ǃ@py\0Ȉn'^庾 &6\0̃%EK;,Pel-:gKXTEPVP. PRlsOmth#Uvϲ=}a>\"ƽo|RtM<fMSZQB*o^&5*DQN\$*      BrD`e='?T MxkkZ}Q[~Ռ(qmQ:{ދ Ͳf}N@lCa\"N`APcԀV0\0BfP\0Iu54`:*`QwR(7Ȼjjgdc6,/%2# iɻ8\\nqSu۳nu4?W7\$>-0ϵЁ-7d}y[x~0Sky{!s(@6p\$a:ʨZ5}\0]BguTT\"K@ u<̞.ugGnڊ|axX5E@tçVw?\0ruY둹.?[f993    I\0ذ)OuɈz*b+\$S9~v}+񏄫tw\0\\");}elseif($_GET["file"]=="jush.js"){header("Content-Type: text/javascript; charset=utf-8");echo
  13. lzw_decompress("v0F==FS _6MƳr:ECIo:CXc\r؄J(:=Ea28x?'iSANNxsNBVl0S  Ul(D|҄P>E㩶yH ch-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#`<Be B#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@ɍ@}&L7 UwuYh2@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\0FvG I@%+_I` \r.NKI[ʖSJaUfSzM %\"Q|9Bcaq\08#<a:z1Uf>Zle5#U@iUG‚n%Ұ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ʖ-  9 O\$طzyM3\\9.oE(i 7   tߚ-&\nj!\ryyD1g]yR7\"~)TZ0E9MYZt Xe!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*ʑN P\r/pAY\0p\\~bLh !   Pd.y\no\0 жP ptP ovЂkn\0z+l60PoFNFOp N ` \rog 0}P\n@15\r9\$M\r\\\ngg \$Q    \rDd8\$kDj֢Ԇ& bѬ갿   =\n0Pؠ~ج6e2%x\"p@X~ ? цZelf\0Z), ,^`\08& ٩ r kFJP>Vԍp8%2>B m @G(s\$d̜v\"pw6}(V KˠKL ¾W q\r̤ʀQL%PdJHNxK:\n  %fn%ҌDM [#T\rr.LL&W/>h6 @E LPvC6O:Yh^ mn6nj>7`z `N\\j\rg\ri2I\$\"@[`hM3q3d \0ֵys\$ `D\$\0QOf1&\"~0 ` \"@ZG)  Y:SD.S%͈3 dmU5 <SSZ3 %r{e3Cu6o73dL\"c7LNYk>.p2Q3VذWBDt Cq#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 ,\"'x yR%RēS5KIFz   #XP>f-WX\rpUDt&7@? }O122#UK*)긋0o<>]HƿrLGNW%M^9X:ɥNsE@xy(HƙMd5<52B k!>\r^J`ISN4'ƚ**`>`|0,DJFxb 4lTؕ[[\\Ԡ\\{6\\ޖ (#mJԣ,`IJխl jj֟?֣kGkT9]3ohuJW\rk)\03@x,-   5B=࣐#gf&Z`#o Xf\r Jh5rqnz s,6otDybhCtn9n`X&\r'tpL7Η&lZ-w{ r@iUzM{rxאmSB\r@ H*BD.7(3XCV <Wу|dq*@@+x̼`^̘߬__NDX\0Q_D]}tYpf w\"3zn«MYZR\0 Q?{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Ýn Kuz @mѮ߭y͞y\")uY睘scy둶y7||{Ϙ*)4Y`ϵ[v^NXW7;_*x\r߼߉xm+m    \$\nl);|٠ڙ:N:_8NU5;p+UL \\9 O: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[/p oJKX<=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{@#2 h@#џ@\$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\0LYabk԰6)Y Ԯ    hzZIgVO3oLg3Y2ۉDoP`3̸ec-r72ԗD BZ%/I{ M\0ṕ.`o*ԯ%T\0&iR\n+o\r^2q\0\\I@    K#peC*!>/%|ȅ̒ގ\$)1P30(\r+\nZ z))\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цjH 9FBcCiBwMtx PM?p=8lg~ta%]b\$\rra,6tW)\0UF |쓢vhQ*Ol.C\$\\ցRR<lc&Cj3%ZMz9GpY⹣\0i \$Ddzt[')[)Qkpi0#cþNE(C2L   @9hEJ5,h{&Jz0 nv>[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<UH TVV#UUbOUDZ⢵ 8UJuS g)XDZKB\n@2x@d& eܫI @Fw8\$'IVV U\$ET_*d/FCYdpvG3њL^(`j2ScWJQYiHBckR\nU\$j\nZAiU*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 Jv]Df7Fᱳ,/+:XIi\0U@N\rʢ,.im _FYiUJ!gLjDiKA 6-UKf_N\0-33+diD    \"MmlLX㯸>&|Uс`h2n6I+ né-nD`ɔ@B!;XsmȯpC`p5O%Z/5#CK`XcbQ#Qaqp)G+~ۖ\"lM_^z!EХap86n+oJ,󇢺w\n]̓pR'eJq'ܨ%'nlOh@>NBȊX5,rGrZ l\r(ˑjIl%b;s+נWg7)*e13Le@(p\0ÎdsAD\0Í\\bD\nu/&1XRץE楂5T\r}7A٬k\\͵q2܀Z-wotZ]-yq2j+ՆխënXA\0\0+S+Y6_BV7znZ@̆Էƴ]-UMJc*s\"+\0xB3^0\rc\\j*P-\\Q8ʎlc%XVB},;(`*Q  \$r{KC%\rx  Q,/v\" p~   J5e E-^X;c\\׬m7?6C*庮,7Hf/9e0[@!bUБ=i.Jocj;B\0]ՔvG8O\\\0NJO\$.& p\\ H1bp:F\"8ŶVxRx=3f1+| \0BkbPLђ\$zc i,Pcb,pn(,`'/~kֵpq-ȱV܆\r  \0 dS+\"鈭1\0(-1~tcfBۑb}ؠ0<1\rL\$2d\"1&ƀBóN\rB\rr\"?vdZ.\".\0?w9o\r0с!dR뤶\0Hra%Њ+\0yrHsϒ4W#,\$ \0*xB\nP| 8@/\02UbΪx! dN3S?P(g\n8ppS 9@'  \0y\0y46H<\n`SCYjp:\0N(ӍX4kgDy<n4rS<?\nBf('~dgәS?<Vg(12)f`Za>t{ >\0P`O\\s <?4w~f@z~hBWxhAO'=P֌ײ=c[ysg|掳%M,Q8 'X hlUs ٢ 4qDx*8gNLBȖ;}%e@Yvho!\$NcCX@;YH'@^ Rf^x\0^os_f;pj]:Ԥ.mLl\rV\0@܀\"1%!_@-]8f-a]YWψh`(J@\rY   kB(x:5B\\QkO[:0¼ukX\\P\0[xŮ`RIGk5YzPҙ=l=e\02=k` [KB8C}kc{#آldfF.̵-A6KPv'lHiA8C    G`Gbyپ- 0Ĭ;[*_mlH{(;Uo*],ċX80CK  ! N(I`   VDvwrpc,\09~sXnr[ec4dpi   \\e2laZCkglbB7x%Żk` \n( @ź5ݘϭċ#tܖE}ńsLvE\nQQ۔76}Orjb%@7۵hw͹nk`Vq~~4{ˁ;8p2mP+ daX8&,=n}!/K&\rtH)/Y6@=}EUlK\\kb[1GM)J xXET /\"-<4xDp(3ʟߴ'+\$\r<rn`H\\t\"70=YWhs\rw~!0@6l\\ /B7 >F܉\\Rپ-nܧ\n?F~a+x\rl,fC+wiG.X!_71ym~ D7  G;gwb/89x@!R9éJqYh'3Ĭ*Xwˮ^   75`:#+ۭ0S@0o7:&~r (ZG1zpdN`/Fz@8t0Z_ 0{LnׇoEÍ=rGj]H ҷAf+Vm7B*q}cw=ۄgwE-H&Rh4M Z_L]WV'զ\"u @-aMs@9L:Ւ]#aoyb\n\0[rp*}Qbw?;Vcʰ  .s索XְyR=&drO2j!uxR{N&ѻ5}vy۰1o8Z#{NrQ:BHzW{W{:r}D\$j7)PCvVXdD7፮,h_]^qσܟxO]?p{\"O8Q?xw}J?9kx5bu& o^>wg]h#?+m(/ng   55<;ȅ˳x%;(V;o-˽.enkp_FX9WjQCB اv3R=솦;a][yȻ4/|##v  @_ǭ}UM>1\rCMqCdĘU#[ɦm\n\\\r6'> i I;R \0X<rW0[EdHSH\n^\\3TFxB\$    i-'Xf}\0#ɤ  1oB*;1(\0~@)h>{~wH/vL\n9?do,x)#>#b`',gT~t    Y}/]-'\0( @ϡ/>~olH/qDT~o|a #|F8dϥ/|uVh\n>{ _{G IaE&{VNodFBX׽(IN@Y9ɿ\n-{@Ro۽&o^3Y>|-~/?*`\n?S!Vϩ>}O⟕>RM?b@\nO? 0s\0Iπ+'X,`'?\0K௸CO2t>LOLv3\0[PΛlH\nhlr\$/\0+\0   \r@?K)<#Ps\0?K@@\0ꀱ\0%, p)?#\$\niL3[3? @O\0 A|P\0D? N@\$,/ \$B?0\0 \$\0VLhͅ    >#6+>R:p>7#\\гlΓAo<3l pe#7A@)@#AV?h 0*Z\0*\\Au_>kb?>\"c #6>B\"\0>\0ps?DPvA\\ #(>3EP>:<\nO\0d\"@A\0Aꎐ5    #  c  +@h؀\$\0:M3n3c`„T+I8B3@* @'”\\pM 8OlM c# 7B h`,    6o\\\\.S>DC0ƣS\$2B@&A>Lk 4A ܭ3@ ;>p \r\n3|\0\nOA:6\0 d7@8%`#É[=D\n3uLC9BC:`\$!h\$;B20u[ 8C    <篟dP|=q 2pV>   |*1\0\rE\0dAovPt'?d,PD*@ /#6CPBO\n8',5ÏE Lq\r?mEq\nzC@+r60C?3/̓\nP܏lHDͤ5\ni)D1(D7u>\n\$Aj4\0?4?LK A>Ͻ?qDI@\$;D8  &?;cJأbP\0    B# 3`‚)O3CMZ50EO6C\0\\\$p[9B#cj<11 B;cDBh? @`*.qbX o?;\0Kp38  RC6/\$>lͤpI ,!*\0+>= ]w\nT^pgź #\0?\$J@  \0*C*7 h\nj?:pAr]YLDbь B4d@(DcE@>\$     4ؑ </?\n/ĺ>gp>I6i8; Ɖc1AZ6!}<jDj(F?d't\0Te1 Av?lnos350#>œ_ dUкZP4D|;rC[9ꤥ5I5I\0EOB\0{9qC|\"pUZP` GcQCGPJO6(B z>7F0I:vOǑBuE,\\0Ǹr8qgA6>74D0qG>-SE@#G.*\0i\n\\-`*\0q\n\\e\"— )qun@`>D8   \0/@_ڀw#ǍlG>Ԅ-+ߐ6Wl%6l0\$5s&\r*\0e!rqI \"> Ș3EIL\"94G\$/\0 \0 -2>/倘Gg\n/LqBP\"#7zHMԅOO\0̏&2LT^P @Zd=]Q=KCE\0QO\\s0>qCzG>    @?0?\\o¿4M d19\0G? m\rD(ԴLd\\KJ8\rE-2 4U 0VAR=Ee5!2mqAEV\$ϕ I9    C&\\G)D 4I#p#C\\xC(\$H:NI(J\0΋\"w\0 ,)PǬϋ4<!=GoP6NQD\r[;A|K'AAP\0C:ʄ̉4*ToDF^\$)Ϣ\n)(S\0(\$:@Y8J#Ђ+\nQ5+`a+ i`6x𑤪:ڌ.T:a\0cv(^X ¼HO.\"JO\r>ex-JKPrԂ-`2_7-!\"JؐJH.o-.\$<BOЀ`> d\nH\"؆o+sؐ 3+ 6/a.\rnd˨ ?z1\0 ? 7<?\$\n`+Aw*MQ<Po?,) #P>€̄\0?jēVq?\$    9-2ID9Lg1h[ۏ1sC1sީ9Lz?   LWdovL#9`ͨ0ɦWh>\0> /)DL\$a9*<:C+JKPJ\"L\\*b 164 ja+\0%Qf ;KE`>>7tHwMPn3I:fD <LR'.\$BO\\\n    586̹D1<\r\$Z4%r̃ \$˶o^\\\0f[ze6|֓g&8+M=65\01Id{^fqd趈s7(|tM.]HS[Ԡ;7yC mI|A:`c8\ri @P `~\rla=M3f<R\0!@eثrdOt T-XY9A:38OadХ gLfx=4K\n&u0Kͨ,o7Ć,3:h|Kb)AN`: Ό;*sI&Rs>\rX\r!\0\nBsVM63KO:Įc5 X!AQ9z%` {:HDE cv!Ν,:X)(%2 a&,l38j1|͇=CRr<\$\"KB3'9:|)`Oj+9 }-S>2UU5BUNNSNO3KNЎ @:/7āQ!@. ( &v9d^ج![.pGc K#?fpÝeOd2\0k6),\r65GmOFVdix,a=O@ sc6`¤\rJ\0;H(*r -.M[BΠ!(MLPbUpJ:1E !:,:YB*KRޤr0جLa6;6+2 )UB`JsV0:0 _B14/AONe)A ~\r ̠NPw,C3殹T3q9}SQ\$APD;!:! Ys6RԁFt#CπQ\\`rXr<'72ؼO-w9Ӥb853{\07\ra\"\nh[jFa)+2<%M|m|\n54p    &bUQ8\0Eѥ4AAN,ˍ˝FؕTo(G`OGAGl`:=\0<\0TNϬ=. 6Ζ(SBİ\0,J?.(%,?B.<2hM΃I`Ό4*˯G 'I9RXE%,O\r,ʈs*(}<ڗ@cRj]D`URγ,.dr   \\NlR-󓴵˚kQK,I.T@1\0K4/]04KK\nC&F,SF0ԵS.-K2RLe'7L0oK3TS.4T:X̾49/:WR9.62J6S .cSv^ 0O|LMD%34z3Id\n#tPq5h{!7Zۻ2 thʠ!K7Y1S<h-<pj<4ӹO%@OKBS!10ԇSҐYF?UR 4!~Xl=H|5 QHC&\"1M' 85a`?SPl`0\\mTM,8'1eQaA& \nTRIG̿Zx6yQôaJkU& OXHphQEN=C\"Lɛ( Qe@\0;QPD\"/\rB༖t T\r<eeS}OmEPP\rӫP5B4U\rR==BSR}HT#E\0U=QEJ<S` ۂ1x\0U:O/+NJ`P!t8\rT 7 SR58\nc>ƺ! 1{ÀӼuEM4{֔4TGa;|5\"SNkS8D?JcU0կRtB { 5qSB,\0pj!\0006K1 ƒX @DV_.(_`-`Dua .X\rFRFDSRxh<mXjbW_G\nVĩS\00074\0LR\$QXp \$N&83&a+|lՉQsACX]_X]\0+8+UzsRPQ\0\08ՙPOMU H6!VX 5XaV/kӏVF`TZ\0D5FOSnkTMSվU\rTMZҺBoEgWGfń-Y(}V7T0B4 [95XmXht>LU`4\n͌To9vFUm\"uDՀ  \rw+\r`V(VPj]K⏜4oT.\$mDĵ Se@3׭;@7m:륥d!ZQ[5P 7;S/B!McGTW(V䯕<7[lt^\ri0Pa|VX̃a[x9 H]^&mҤ\0Xl㤫ހTOXl0(,`oau3U#'0+ӽ8]HT!XX\ryW@\$MQb-)X  o\n|`-q-bٶUVc  3N=5vAg\r8<IGPB9O^8.  Xk;+\"CZ/UUo[i`\$d].(s `-⽀qe-N=#[MPO^(B6_u2:0mxYg^5-YG8Ac VVd6\">\ra^Ю0 \"䱿R,3D2iG5 ?:\rT!wgM[7;[v{֪Cs\rU9d`yh\0h@~qT4_QVvF5 Ps*Mc]I91T0mV)SX[*cdA+1hb:IhM@s>P9vuT>ֽ` O5ccjϏ?QTmq\$=(V6F\rTr~\0|mC)[ՂN,d+;Qm-Ň\$oB-sRN:/8> b.40>,.tںJ\r\rk6 WMm3[x5 qLb6 ;`Lm4I6^d!5`7:aOh4-3HUmڒ^_NTꍱ[PH؝a=UH\rE \rjMSPsN6MXQ 5    \rۭYKqs[s-\0]aNd5?+CfRe^+@[P5GaҵoM@w\0QyoKUe}[_oK@nwxVpEPuo5R8c .   Uo5w\0\n(%NpV֮JAqtZ#Ոk6iEVR{qf{3l@PqHr!VS]6'q@> R=E\0S+ UjʔY[źuUոջrp6s]h't    mJ8QUUuDm2zЄBKv'Pl]AAfch\"RVpX;U5܎cְzPTuUQYZ5UJen5novs=HuZoaitoUڻuuH5n=jSUPZMNQmobFA>]i\\ G\rTvւ\"2v4γ=]2z\n=:\rh*sfw_Ut8[݄8]+=G7z=nۗJu8|4u]    caz׀Ywt]ܪ ^r)w]%i,e}w0<3nLr.iy-7(K&\r_;f[̈\\\rX+Ha=ܳbnc , c!8\$mVvRJ]g -WOsR(5]WHVC\\5@D!s%Β^sd%N97փ{U+I-ռP\0\"FЈS5F[zsk(7Ez1-@x̹>MgWMjԻn\n ^tLUc}AVR@;X-<s<tC8^!P}3qd\\ζL3u\\-\rSlX{sLNlLߟn&Zpt6_[\rVVC~IE?W%Uܫu[ATAW\r\rdwVkh,8ŊϔDػ|a6-_1O`jo?7>\nXsYn^c{j7:]E\"JVJe~.QHgT3rcVBce3e^Հ98\n Z(䇪    ;tzՍ#  q#\0V .\nS/Dk/k4(i J`uM5lG'\0n`54\r5t B}ZH4i:x4 ӊ53& `ġ amn-n\rWaMXCKQm4Ȉ5AXG@':LԠY3\"@WƎ, MQ[apfJ;`c=Rް~Vo韢wcXnч8K8tj't5eB:kxyaࣾFn    |:a09\$cuf\nw>\" a!8~Z\\xM#،J\$yHhMQH \$\0]`@3bS#<KXL~Xf5Shawj6^ړ߼ճr#j\0%\0%q;)9g.,bBDDԀ~:rX3\nvL50R/ͲNn_!)SPء%0=+@B9of`~)=Dp@L>wЈ?L2YI>!?,@[G>>,ROs*dRcGQG!ùsq|AXqP P%\\PxÿTI8ŶΤs#磵# Ş#ϏL<p_Ź>lE;C;#Q}H_LYJy\$KL/~=1J(0d/\$Ae)lE/mϡ54)QŀtGdqQQ1Ep0 d13t!C?\$^>Q|!B?F9!c 'WhALY䅐p1K\\y*&MA{~d=/pdtPRjEA\\(Y:\n,yP@iDy)9B\r!df=Lĝ4pd>>pdV•  Kpe&PhBe&Apd'D&Y6esU:Bd?O5\r'KeFDdeFEC\0t(|)-#)!m\n܊l4? [қI\rL^r5cU1\r,Rr?dRs7&^!O1F[-,\0)\nB}?^a! 9pe?f1n)N΍a~W}eS>JOB\nP%\n*AIleqE،^}QD2p   GfmJ\$}ҹ+-5Eg\0QTF6Y    #c*ʃK4@[s8LaN)CXD[ImR\0006N9fz3M=~9`%sg=>G9ﶤT것4Ztl炳86!_KthIv<LC7I/!6tbQ.ԊMfzOF\\2gj\$ OU@W54\$vP3-,\\Q;P͕4NGH72T6iSjg#̹T2@97@l3p\n\r#<O7\0 Nu;.|agqWrO=ʩ\$yLb(]:I (nqI` Ɇu@%!5;3K `ܛC,dVqX\0003N>Oo3xSƁ#1(XIeVx%UT#qNp #\$L)f|C3˹MbMG %d4L]Kmw6f酘 8\rvu9 rAx\0h^:bdghE4R}xAH|Eݤ9|ZIVsNCϗ.֑֢nw<ZNDC.'IEF=Q3?r+K[TF4\r)@pxOx34̗<`qD0ǥ[APicXIZEd 4YQY\\EQEviK\0B\0W݈OZ?fOkEْB^dַL1M5x,+WgStO\"L6SH= C54ms: eR4[&:ݚj#mّtՖ6lՎjbX5.KYbIgjeL   )j\n _VƦjwLZj.NqTn:CIx@4ԗctڬIR.1~:^wc+jsӫ.~vӺgoJj,/!dq%\$Zb\rvcOV%׬EJ!g5(KByk)R:ƟZa9~o͊n\0T޵+\\\0000܋=_ުhmsejKzлoX`DگT UK-g<N;fU\r5~:iQAyUCrQLZ6<m*qD|Zkg\"˭kZ=0IM^TZ1Һ^U8l,&}P6:˫:vúIf{ ?%lCfWc<`vKc5{ޫĵ9lh|jt>MNR=(ZD=Sl,95M7/qɘUACSa^ne~\0m)(%P!3JF;&ͲA[KslF1˧V28͔5p!!l   V\0m\"1I\r&Im35*|g.ZNt62倳qMZc]\rt-kZ/A{YpWЛsÔ _tvCi;EvI.фmQ𶂌Yܙ3#OGma Z1FUJt!s\\Msܴ\rګ1H]=,It5(5xX5o\\YVmARuYVsz\";ҿ?;*PZ,LA3XU^!ORȑe&4].qe:Mif    5c3}7t.Ӟvh9%A;:7zhdW%S]hЩ{׷D;٥e]i;g&V]YO⏹,>k2ۂ\"-R@2 %o\rTRS1_e!C_E֖Uɋu\\yS/˼WNmJ!@P\r`9Mss#|XnεAw^ttZ?=_eB\r`}P]Pe:XպIUN˝6CSRoMۭ%ۖ`Ps>@C!]EUjNl*B{\nSYʼnuOP&ԏDU\0^e\\\r RL޶U rVi5f~=tU'<=UCh.|2URkICpG!@<@㷯'f:?J0]T57YeGIf؜*U\rS \rz%GuYU'!PK6/M4<pj3UI\"m?]7*Ѽ|sKAFW5L6U\\@@]t]M6\ro[m㞍#B\"+?Oo݀eoXMvg\n-u\0S\nT<X_OZߠ][p( ^tUiiy<`8UÃNgF2W6{dE˻kn|pNM<GSqѫXrq̷6U\n#:q=8A9л_Y;@r  nF 7Msz^C<T>\\-x\\prqCV31LMtԫj]AXyN]z|\n]߲ASѼUفa'_w\$EY+F6]h%닸>U'ǎt]G*o]+'*w\\TŴ쬀1\0as;Kr`\"\0Z伵W.T܂q\0T!Ǥ*W]lrrӋo;*z]!uO6ծ\n`4/seTDH.CW?7E%X9\0 _g<U_xKMabAqOx\\Urᴷ5hyN[&qV|⶿kTU_Aw9i7=٭_V67;;8NE&ep!\n Q-`4Ѿ\r8֠`-t\0c:lCg@aB_o@H(7_@`*>Is>`ׄLM4(n '+٭&ӣOVtZ  \r>#Od^m:ah)Nd).)TtO=;pfWt`;l=)u[|tҰ\r%\rҕj2,J40{bI*trPpk:?ĝ<ӷJ|\\t#4[}8j\\\n뺝?/Z\nG}mS=Ex@X\0_J=KzG\nhWR 05ys>=0س|CNG~ R]/b   PЂ5ZB\nqҤ-Yv |ɢg`* vHOD4ۑGQEvboW׌\0\0003Q'_>@ ~kO_#`&<u쎰]Ƞ':NEH[-p+IHhў~DF/g1w&0Edlhݜ}{q\0FZ|v9H R4@r  ȝl#>?\$r361IA62»%lpo\"4\\>J@ȡ\"qyIrDUIiwI\0\$CI%<0fIeT2WfZ~;&BDC7e t5Oɣ&FBDNI]~@Q,?)a1,3 a8Jh\"3pRs-N8RYh\\{3Fu5D!?{S\$19|Ȩ-ʹ\"Ӵ5sy516'y<CkO7w]0ͨS SK9tyÅ   ha:M0Rn\$K;; Gʰl&B\n4\$iE6lx\"`\"huU:5#*(4[7,?{YTMs!܅{P\0,)\$~ScG4Y2s98AWe~PSUpQпi;|]P9P3S:e5W6#}_!tpYX^DdH4Pn\\f>Mc䵶م:\$@gOgIu\\wB叕^VÞT%j#[ɍ#qvoρe;8ubI\0q[>3l0 \rCJ&1=D2\re5}8.њ^xYѸ'.*Cy7Sf \r)8#Gg%V*\0aLf(s \0b\$z0\0h92`ߤ8\0jޒ2\0\0k闤\0AǤ`\0òS\0\0z}闧z@迥zkB\0\0s` zW\0mߤnz \0nϪ mG~zq\"\0o7\0鿮~zg`r޹Fϭj>,귰z5>F-\0~Ϥ\0ޱzܾ\0a쇴z޽;헫>k>ϥG\0s߳>d\0_o\0kzw{oqwz״~{@B@1 ~۱_zף>zǮ^zo\0s폵z~G^駽g紞9Ϫ޽\0s穾!췵 {\$q\0\0\$I\0 }h {ǰz?_\rz~N%z'{/UGzO{iw|/ɟ{w\0i?\n\0iϯ|WQw+A?{_ ^oοR|#|io?2|\r'Ǟ{z&{_C?~z7!7Xazzi?_O޼EҾ\0g@mz|?O {ק5>_za_V_ ^N%1O}\rw~  y}?>{_\r؞{~!\$g?cǮYƟz?zUo~|_!}@~_>5^{ǧߠg_b~wdzھ__yzk2zОzO{SIYOɟ\0m̞}^{w&|\r~泇?W?ߨ{-釸}%O>~g?=yD| _k؟6߼}S?\r_;it~o_8Qש_{YOu|Qz>~O|Ϳ/_0{C﬿}qE{%/}s/qI\0j|0g/b>{&SGY=}ݷ+0z-{7ϫ_@\$Y7܏F=~}`=<'HY\0q'oŀE8W\0002,CWޏ`^:zkK`{j5 o~fQcǪ~@O6M{qϙ_-,zW`?3zEo|H'@|Da̯M^=pHs(/sr{\0/@R\r퇧_>'I]ׯ:FW>e|` gO߬yzS\np@r|i 6ް}0jH~s}ј\r{\0!կH>4{\0\r GR |#zA {~\r >zT]O`=|#e|P[؈\"/O=A'ޑ?{|{Ǐ-> |\\yC7^@RzaU3CG zI0?ۂdە8h9@>%-w{F 4P~!O_=#֨J|r )H0V˿w!O,+` |>҇}a)7໽zk\0vh!t4A6.K\n_0=V~3x\nO{@BU H`Adp PߠzǨp=Lz5Y+>IzO>   s'^н~N-wO^Z9>>9V}ߖ%|b;8AF}M {8 q@ (߬yQѵ#|DRH!E<3#x!   'Z)!Fo\nIKA|  0\\Juԅ,t<D1E/FݶR *T9o2\\E\n8Mk@ 4D^ р[5DGA&ւ\$i   *\ndh}t)whhlBK}qrp\n`QDI  UJ;PWYc@|.8MН϶\"%B~ܒQa-C%x6SF0㈂yaddR},ƥJpZ,CGL.#\$,:r>u    5C !>v~\0@ 'tǺ\$H?,0ppC\nGF['`2ׅZ{@aQBȟ ' fK\rP(_p/ Ba `S\$!2چj\n8\0jّTXnDVrءs+҉4hQ(\0,J]-ĭC1EM\0!hF\0Wt rZ\$!@R{FˆPHQ9Q+afb\0(e /\$*T\nEU`楏^BBL\0PY*8TCI<9th,\"#hJ\0 \"ZQN(C\\{5SC^ƲP!OBN:Hx'Q91\$lj!0Cy\nS(Uu\r3/t\\8 #8@\nр9ybH*7] R_3^8>'g aY~EC`\0 +j\r8@V`\n\"3D\$p؀  8DD*5DGᎁwIQ S\$FY 1̈Q HDx۲Bc+FKf[BEL\0O@&҃?*TZTD:Ct \$gJ\r!\$xX(b#!\"}fE\0PD\rɅ*T :<rRvC [%J-CmŔ#@1PBQq\"Hlyb7؈d\$ FC@Lď\$ފ\\EXĜ@\nْv;=\0 ID9\$lb*T;\n~\$l%4O22   &@(!DnR!k%\$-\"`?; %S&_BRC~ ET4.R?bG\"&DQd R6 |.'\"Q96(B%'8r\"*6'D(s\nD= lET,azÊ&HQPU˂t3PBtH&Q 6FdCdVqas23|!1H1a§_     (310LU \"z+x(L#QT#\"pDE舌p1\0I Fh }uC,N萱FMDsF\0LGhPZ\"G*Uu2 OZQjR+\$IeQ\$EyH^%AȮ^NLa%W8Lt>+J蟑,L>A9/Y~,9=PDBO v+Lx뤂    FhbD:,I\"ANbqtFq¸j+4fW<᠅f&.~Ȟbˉ,SSP¤\rC\\lEC7PخCлH#(!TqEǦ!Rl\"m3 g.)A8:BZ0;j3 e%%ن\$ok4PѲAM\0Tb1cJ12 (z?B)H\":EasA4GvтEwE\nXD:_\0#HA\$~\$q%\$#,јōc2\"hQEh{/k(G]dM/1Yŧ2-Td赤^ŰCq[H2\$ŷC|%L,Pԋq^!SE44sc,&Z'dUюc73 H  J4]HwL\r+iFDp#L\$.5@EB~|k0!<\"Lmhy\$A#60      ibAHl;(\0/AHHdz}\rѢI0b rEv7jD.cvqPt,&JH%#t)P h8&>ʆ\\+d)J϶P\0k„7ibB\$Zde3BAWB?C z7nW͢#6h#f/+@'ca!,?>#!]i\$.\0 xC…c180Ful   A 2WK>㯻:F)  f~P%h  pl4Fܘ@S \$(C#k|T0h1EȎ(G(cpb4f0yh!\"S菏G\0= .hF |.=مGHopt=r2=z_Q:я2>oLǷFh5/& #\" HA}D\"Dj-1^QR2N6~?dw1\"Pt\0҄<GBZF?&\0!0 q\\p!У{?4\")^(WHH\n'\08ސ\0_BZp>鰝\$n^A\"3;GA <kQ.1F 2a\"A& tm#d\$F\0Lz;8ɏ\$#!1B3aQ=-;gJ!CzЍ\$Gߏ C*t`ȑd5bM    ! _\0S\r^ĵC]\\jB6\$cwGw9j&aO\$4@RE^DL4,7܈㐟{=ʔ?K%IU*G\rP0{.Y`3    DBD'hNC\$Gh\$cZ!90VR3Q~6CԀ2u04,MXrG\0:9P\$JH/ydw@=1N(@a@()\n3#[y\"LsG~^lHDԈ.<y`\n\0\"\"eИH}(`  ,Fjyh   С\"    DvI<|v([\$\n#~\$,;<dحE\\h0zY'!ತ@Ju!(_0@2\n>(EϨGVD\"či)6\$y fd~fC4d: 3JRWHFAC TZ@%q2.(rF9  PQ#GFRbA?ِ\"!`\nȟGiG84QHCAbL(h8G8M,4Hd%N~Yܜ.;@q&s5k3B@%u6(\$נؐU%7'HgϤ  I6!9L1  ҟȑ\$&\$95L#nò#6{E -'v@Q8䅢\0:?GN7T@^hHɣ,\n;Hcv-@) bfK5>@I\0%Kh0jFs)|P0U#yxZ-CC g/.O:ItFCM]P`X3b\0.&ll 3ҋ46<h4F(-K+t\$qA0\0001d\0^ 3Ö7\0\\ O+\0000z&o}mu2JX6RYK,/\n\0SciҘ\0006S3Me08)|-25yHS٩KRCД)TR5J _)TB)4%)RQ%J=Е/)RyS_ʣU4IP:@V~*Utcҡ>ʉ~* WT@ *Tl8(J~\nU@-+.UAү@n+\n)Z򰀒v)\n[`o0RUYX2#Ĕ+DyYR%N>G+SySR%fJ+S9KOoJWiX_U\n',2WLap%Tdu,1|i]ұI+Ti^%:K,WiZå0K,S̱i`%xK,V< \\\0/ #,rYlIgH%;2XYi\$eT/,RԴcr<N-ZYU0   T\0Z/O,Z4yO,Yĩ8j-nUDǩRen{y-v[)j٠\0Kx~w.[dko%Kmn\\49qKx.Z\\H e=. iq2@/.*\\#֩r\0_,->[쥩u%~˯?)]|uʜ_.]\$nKwy.YB̒%KS/.]    yrH-*^{2ݾ*^yzNT|a/_4XJ.]\$iw%K9/^г%F唹/_ܦ) >%i8)+`1‰`2%Jq[r_0<Ը)]R[w/Z`its%L0r]df\n0atV430_9rޘL5y0a™riz2l©&#={z_wSJbSf?30e[1\0s{1Ƃ^=le/|Ɇ&pw0Ɉ&!LpY1*`SKAsdyA{1d<Y&4>Y+-NdiJ̊rd\$&M̒rcCֹ3&&S̚eLXT̢g2e|iR4={2ef^̲2ei.&a̺YcCɚ30&g˜2fifhʙ32f_&2g<`7`I&:3a)P\$7La3Y 1?x3LϩOI 3jh\$=L.Vh3֙gs=~#0h79^pRb<ɡIL嘥4Fb҉8-(4c ҉b&L1h9f}4hC8ߠ;FiܓD\r|i3d\$\0T&{5BjקC{.g\0    1Wܒ& kհYY@A:~E3jSɪRfu̔#2Zkҹh&r̜5eyM&tz50)SD^Lz6:j׺cJz6:j;if4E ٹ:ޟL噡4FfډSRͦ#6j ɵQe6gDh\n@+MwZhDiaMGZl4 NA:pRkiE\rA:|q\$)pNzA:4BnSX|=Z76hӏfKu4vo|ݹuS{% 8YGN#dp|4cqƥAM \\_xQg ut >Dd`\"F0%pXH}Iƙf9-2CXP\0KJy:?LhIV5z(Xx1o#I2|:.8,cTx\nMdnYc̜ rTfDYunȺ1    A((E\$tDcXV(!^¥[\n%%Чb,/&))T%t|=Js##  G.\\`x'   &2EX̘gA8QERS0ĭ>8su\$@'8\nT91gΤ#i8BgUE#Gr%9ՑcN?-8(L;xѐ\\ƓqpPDCr\$P_\$(LP6PNg'Nќ;Fts\$);'XE    ̃p.H-Dne    .ا!t9/rα]#yȎ\\\\(f΁;pDs\"2\\(' N&+\$ӦP#:^x\0sxț:+]'V?:IZYƑ\\ò=u︷aNc9\n.3!=\"\0Y\"w^XsgOA=/jQ3\"2:55)af{2CV!5 3T*0Ț~\n57hq1;h\$H.e0  CwjNJ=+pʑͥC(t6Ć ZoyLgŷO|X5\$gn7d*2'gB oi#V)>Y>P'#^>’Ӌ70m`[P9ii~r0~}디   \\}VX5@>@ө?5K4)gkjR~jN[W\$rSZ]Kv{[P'OixOmJf%\0S'p , K<՘RP`\\Գ@]gyR\\8h `R'7HBc( 7f1c\0wMo3sG@`7zgFP\"(@mƐH:N3>eK:t%,(LMEAVOM:q5E%-)@jچSLME>dAesAz7D\nه.J\r 5lK\0nt@\n2:?V\"5lɭ&SQ[  }\0سK>tG0T:\nj!Y+!¶ (-m j!\njʹ(EЩ!5@J}6҅T+A&bZVE6iΞK 8BcaY(_'QW  %`\$}n\\3-4NԡŒ5EPᎆsJ\"ܽP*    h҇+?SUbwfHt'/\\x\nr\riFT=y5PA<J<Pbd* PPF\re8'P+f'ӴD@0DmN\")7 ,E7X6\$dU\rV&0%f@4UPg)aiӅNd7a<(tJ\",襯>dE:(RPQ S-84OU?ʹ3x`G=gKPb    'xB k8.b4FV%UXkJxQ \nǃ/TFa\0m_eF\"!ꚇ\rYm1F2Rp IhĵG(zZ3hϸm>hss4dsфQfq\0NQ2X5ݠDՎ5шTpk-B\"ʜ_ѹ ^n}ަthqqG8S-sQĢ>| +:-˓∖hU-x4IΓmGh G 0U>B4.ZM9[I`P:Cbs\nu(V\ns%T֣P'B|3DRQ\n]?6aT_O̤xC90Q5I\n,TTqC @*5JMITIy>Ji& \n1M\rc夘jycy:N㞗BM*t6ieϫ\nӱyz\njR\"tJ/; h>|f\0ZrCez&k`p \0s.\$t\$S#DM4xCU)W҄\0J*jV\0*\0\0Jlb\0`ZףvTM=I'D_ZW෍糸P +\n2NGS\"f\$j6V65pT>3ZXk");}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._wa1J GL6]\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
  14. connection(){global$h;return$h;}function
  15. adminer(){global$b;return$b;}function
  16. idf_unescape($t){$Qd=substr($t,-1);return
  17. str_replace($Qd.$Qd,$Qd,substr($t,1,-1));}function
  18. escape_string($X){return
  19. substr(q($X),1,-1);}function
  20. number($X){return
  21. preg_replace('~[^0-9]+~','',$X);}function
  22. remove_slashes($Hf,$Jc=false){if(get_magic_quotes_gpc()){while(list($x,$X)=each($Hf)){foreach($X
  23. as$Gd=>$W){unset($Hf[$x][$Gd]);if(is_array($W)){$Hf[$x][stripslashes($Gd)]=$W;$Hf[]=&$Hf[$x][stripslashes($Gd)];}else$Hf[$x][stripslashes($Gd)]=($Jc?$W:stripslashes($W));}}}}function
  24. bracket_escape($t,$Na=false){static$th=array(':'=>':1',']'=>':2','['=>':3');return
  25. strtr($t,($Na?array_flip($th):$th));}function
  26. charset($h){return(version_compare($h->server_info,"5.5.3")>=0?"utf8mb4":"utf8");}function
  27. h($P){return
  28. str_replace("\0","&#0;",htmlspecialchars($P,ENT_QUOTES,'utf-8'));}function
  29. nbsp($P){return(trim($P)!=""?h($P):"&nbsp;");}function
  30. nl_br($P){return
  31. str_replace("\n","<br>",$P);}function
  32. checkbox($C,$Y,$db,$Nd="",$Oe="",$ib=""){$J="<input type='checkbox' name='$C' value='".h($Y)."'".($db?" checked":"").($Oe?' onclick="'.h($Oe).'"':'').">";return($Nd!=""||$ib?"<label".($ib?" class='$ib'":"").">$J".h($Nd)."</label>":$J);}function
  33. optionlist($Ue,$sg=null,$Oh=false){$J="";foreach($Ue
  34. as$Gd=>$W){$Ve=array($Gd=>$W);if(is_array($W)){$J.='<optgroup label="'.h($Gd).'">';$Ve=$W;}foreach($Ve
  35. as$x=>$X)$J.='<option'.($Oh||is_string($x)?' value="'.h($x).'"':'').(($Oh||is_string($x)?(string)$x:$X)===$sg?' selected':'').'>'.h($X);if(is_array($W))$J.='</optgroup>';}return$J;}function
  36. html_select($C,$Ue,$Y="",$Ne=true){if($Ne)return"<select name='".h($C)."'".(is_string($Ne)?' onchange="'.h($Ne).'"':"").">".optionlist($Ue,$Y)."</select>";$J="";foreach($Ue
  37. as$x=>$X)$J.="<label><input type='radio' name='".h($C)."' value='".h($x)."'".($x==$Y?" checked":"").">".h($X)."</label>";return$J;}function
  38. select_input($Ja,$Ue,$Y="",$uf=""){return($Ue?"<select$Ja><option value=''>$uf".optionlist($Ue,$Y,true)."</select>":"<input$Ja size='10' value='".h($Y)."' placeholder='$uf'>");}function
  39. confirm(){return" onclick=\"return confirm('".lang(0)."');\"";}function
  40. print_fieldset($jd,$Vd,$Zh=false,$Oe=""){echo"<fieldset><legend><a href='#fieldset-$jd' onclick=\"".h($Oe)."return !toggle('fieldset-$jd');\">$Vd</a></legend><div id='fieldset-$jd'".($Zh?"":" class='hidden'").">\n";}function
  41. bold($Va,$ib=""){return($Va?" class='active $ib'":($ib?" class='$ib'":""));}function
  42. odd($J=' class="odd"'){static$s=0;if(!$J)$s=-1;return($s++%2?$J:'');}function
  43. js_escape($P){return
  44. addcslashes($P,"\r\n'\\/");}function
  45. json_row($x,$X=null){static$Kc=true;if($Kc)echo"{";if($x!=""){echo($Kc?"":",")."\n\t\"".addcslashes($x,"\r\n\"\\/").'": '.($X!==null?'"'.addcslashes($X,"\r\n\"\\/").'"':'undefined');$Kc=false;}else{echo"\n}\n";$Kc=true;}}function
  46. ini_bool($td){$X=ini_get($td);return(preg_match('~^(on|true|yes)$~i',$X)||(int)$X);}function
  47. sid(){static$J;if($J===null)$J=(SID&&!($_COOKIE&&ini_bool("session.use_cookies")));return$J;}function
  48. set_password($Vh,$N,$V,$G){$_SESSION["pwds"][$Vh][$N][$V]=($_COOKIE["adminer_key"]&&is_string($G)?array(encrypt_string($G,$_COOKIE["adminer_key"])):$G);}function
  49. 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
  50. q($P){global$h;return$h->quote($P);}function
  51. get_vals($H,$e=0){global$h;$J=array();$I=$h->query($H);if(is_object($I)){while($K=$I->fetch_row())$J[]=$K[$e];}return$J;}function
  52. get_key_vals($H,$i=null,$jh=0){global$h;if(!is_object($i))$i=$h;$J=array();$i->timeout=$jh;$I=$i->query($H);$i->timeout=0;if(is_object($I)){while($K=$I->fetch_row())$J[$K[0]]=$K[1];}return$J;}function
  53. get_rows($H,$i=null,$n="<p class='error'>"){global$h;$ub=(is_object($i)?$i:$h);$J=array();$I=$ub->query($H);if(is_object($I)){while($K=$I->fetch_assoc())$J[]=$K;}elseif(!$I&&!is_object($i)&&$n&&defined("PAGE_HEADER"))echo$n.error()."\n";return$J;}function
  54. unique_array($K,$v){foreach($v
  55. as$u){if(preg_match("~PRIMARY|UNIQUE~",$u["type"])){$J=array();foreach($u["columns"]as$x){if(!isset($K[$x]))continue
  56. 2;$J[$x]=$K[$x];}return$J;}}}function
  57. escape_key($x){if(preg_match('(^([\w(]+)('.str_replace("_",".*",preg_quote(idf_escape("_"))).')([ \w)]+)$)',$x,$B))return$B[1].idf_escape(idf_unescape($B[2])).$B[3];return
  58. idf_escape($x);}function
  59. where($Z,$p=array()){global$h,$w;$J=array();foreach((array)$Z["where"]as$x=>$X){$x=bracket_escape($x,1);$e=escape_key($x);$J[]=$e.(($w=="sql"&&preg_match('~^[0-9]*\\.[0-9]*$~',$X))||$w=="mssql"?" LIKE ".q(addcslashes($X,"%_\\")):" = ".unconvert_field($p[$x],q($X)));if($w=="sql"&&preg_match('~char|text~',$p[$x]["type"])&&preg_match("~[^ -@]~",$X))$J[]="$e = ".q($X)." COLLATE ".charset($h)."_bin";}foreach((array)$Z["null"]as$x)$J[]=escape_key($x)." IS NULL";return
  60. implode(" AND ",$J);}function
  61. where_check($X,$p=array()){parse_str($X,$bb);remove_slashes(array(&$bb));return
  62. where($bb,$p);}function
  63. where_link($s,$e,$Y,$Qe="="){return"&where%5B$s%5D%5Bcol%5D=".urlencode($e)."&where%5B$s%5D%5Bop%5D=".urlencode(($Y!==null?$Qe:"IS NULL"))."&where%5B$s%5D%5Bval%5D=".urlencode($Y);}function
  64. convert_fields($f,$p,$M=array()){$J="";foreach($f
  65. as$x=>$X){if($M&&!in_array(idf_escape($x),$M))continue;$Ga=convert_field($p[$x]);if($Ga)$J.=", $Ga AS ".idf_escape($x);}return$J;}function
  66. cookie($C,$Y,$Xd=2592000){global$ba;$F=array($C,(preg_match("~\n~",$Y)?"":$Y),($Xd?time()+$Xd:0),preg_replace('~\\?.*~','',$_SERVER["REQUEST_URI"]),"",$ba);if(version_compare(PHP_VERSION,'5.2.0')>=0)$F[]=true;return
  67. call_user_func_array('setcookie',$F);}function
  68. restart_session(){if(!ini_bool("session.use_cookies"))session_start();}function
  69. stop_session(){if(!ini_bool("session.use_cookies"))session_write_close();}function&get_session($x){return$_SESSION[$x][DRIVER][SERVER][$_GET["username"]];}function
  70. set_session($x,$X){$_SESSION[$x][DRIVER][SERVER][$_GET["username"]]=$X;}function
  71. auth_url($Vh,$N,$V,$m=null){global$Xb;preg_match('~([^?]*)\\??(.*)~',remove_from_uri(implode("|",array_keys($Xb))."|username|".($m!==null?"db|":"").session_name()),$B);return"$B[1]?".(sid()?SID."&":"").($Vh!="server"||$N!=""?urlencode($Vh)."=".urlencode($N)."&":"")."username=".urlencode($V).($m!=""?"&db=".urlencode($m):"").($B[2]?"&$B[2]":"");}function
  72. is_ajax(){return($_SERVER["HTTP_X_REQUESTED_WITH"]=="XMLHttpRequest");}function
  73. redirect($A,$le=null){if($le!==null){restart_session();$_SESSION["messages"][preg_replace('~^[^?]*~','',($A!==null?$A:$_SERVER["REQUEST_URI"]))][]=$le;}if($A!==null){if($A=="")$A=".";header("Location: $A");exit;}}function
  74. query_redirect($H,$A,$le,$Rf=true,$wc=true,$Dc=false,$ih=""){global$h,$n,$b;if($wc){$Hg=microtime(true);$Dc=!$h->query($H);$ih=format_time($Hg);}$Fg="";if($H)$Fg=$b->messageQuery($H,$ih);if($Dc){$n=error().$Fg;return
  75. false;}if($Rf)redirect($A,$le.$Fg);return
  76. true;}function
  77. queries($H){global$h;static$Lf=array();static$Hg;if(!$Hg)$Hg=microtime(true);if($H===null)return
  78. array(implode("\n",$Lf),format_time($Hg));$Lf[]=(preg_match('~;$~',$H)?"DELIMITER ;;\n$H;\nDELIMITER ":$H).";";return$h->query($H);}function
  79. apply_queries($H,$S,$sc='table'){foreach($S
  80. as$Q){if(!queries("$H ".$sc($Q)))return
  81. false;}return
  82. true;}function
  83. queries_redirect($A,$le,$Rf){list($Lf,$ih)=queries(null);return
  84. query_redirect($Lf,$A,$le,$Rf,false,!$Rf,$ih);}function
  85. format_time($Hg){return
  86. lang(1,max(0,microtime(true)-$Hg));}function
  87. remove_from_uri($if=""){return
  88. substr(preg_replace("~(?<=[?&])($if".(SID?"":"|".session_name()).")=[^&]*&~",'',"$_SERVER[REQUEST_URI]&"),0,-1);}function
  89. pagination($E,$Db){return" ".($E==$Db?$E+1:'<a href="'.h(remove_from_uri("page").($E?"&page=$E".($_GET["next"]?"&next=".urlencode($_GET["next"]):""):"")).'">'.($E+1)."</a>");}function
  90. get_file($x,$Kb=false){$Hc=$_FILES[$x];if(!$Hc)return
  91. null;foreach($Hc
  92. as$x=>$X)$Hc[$x]=(array)$X;$J='';foreach($Hc["error"]as$x=>$n){if($n)return$n;$C=$Hc["name"][$x];$qh=$Hc["tmp_name"][$x];$wb=file_get_contents($Kb&&preg_match('~\\.gz$~',$C)?"compress.zlib://$qh":$qh);if($Kb){$Hg=substr($wb,0,3);if(function_exists("iconv")&&preg_match("~^\xFE\xFF|^\xFF\xFE~",$Hg,$Xf))$wb=iconv("utf-16","utf-8",$wb);elseif($Hg=="\xEF\xBB\xBF")$wb=substr($wb,3);$J.=$wb."\n\n";}else$J.=$wb;}return$J;}function
  93. upload_error($n){$ie=($n==UPLOAD_ERR_INI_SIZE?ini_get("upload_max_filesize"):0);return($n?lang(2).($ie?" ".lang(3,$ie):""):lang(4));}function
  94. repeat_pattern($sf,$y){return
  95. str_repeat("$sf{0,65535}",$y/65535)."$sf{0,".($y%65535)."}";}function
  96. is_utf8($X){return(preg_match('~~u',$X)&&!preg_match('~[\\0-\\x8\\xB\\xC\\xE-\\x1F]~',$X));}function
  97. shorten_utf8($P,$y=80,$Og=""){if(!preg_match("(^(".repeat_pattern("[\t\r\n -\x{FFFF}]",$y).")($)?)u",$P,$B))preg_match("(^(".repeat_pattern("[\t\r\n -~]",$y).")($)?)",$P,$B);return
  98. h($B[1]).$Og.(isset($B[2])?"":"<i>...</i>");}function
  99. format_number($X){return
  100. strtr(number_format($X,0,".",lang(5)),preg_split('~~u',lang(6),-1,PREG_SPLIT_NO_EMPTY));}function
  101. friendly_url($X){return
  102. preg_replace('~[^a-z0-9_]~i','-',$X);}function
  103. hidden_fields($Hf,$md=array()){while(list($x,$X)=each($Hf)){if(!in_array($x,$md)){if(is_array($X)){foreach($X
  104. as$Gd=>$W)$Hf[$x."[$Gd]"]=$W;}else
  105. echo'<input type="hidden" name="'.h($x).'" value="'.h($X).'">';}}}function
  106. 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
  107. table_status1($Q,$Ec=false){$J=table_status($Q,$Ec);return($J?$J:array("Name"=>$Q));}function
  108. column_foreign_keys($Q){global$b;$J=array();foreach($b->foreignKeys($Q)as$q){foreach($q["source"]as$X)$J[$X][]=$q;}return$J;}function
  109. enum_input($U,$Ja,$o,$Y,$mc=null){global$b;preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$de);$J=($mc!==null?"<label><input type='$U'$Ja value='$mc'".((is_array($Y)?in_array($mc,$Y):$Y===0)?" checked":"")."><i>".lang(7)."</i></label>":"");foreach($de[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
  110. input($o,$Y,$r){global$h,$Bh,$b,$w;$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";}$ag=($w=="mssql"&&$o["auto_increment"]);if($ag&&!$_POST["save"])$r=null;$Uc=(isset($_GET["select"])||$ag?array("orig"=>lang(8)):array())+$b->editFunctions($o);$Ja=" name='fields[$C]'";if($o["type"]=="enum")echo
  111. nbsp($Uc[""])."<td>".$b->editInput($_GET["edit"],$o,$Ja,$Y);else{$Kc=0;foreach($Uc
  112. as$x=>$X){if($x===""||!$X)break;$Kc++;}$Ne=($Kc?" onchange=\"var f = this.form['function[".h(js_escape(bracket_escape($o["field"])))."]']; if ($Kc > f.selectedIndex) f.selectedIndex = $Kc;\" onkeyup='keyupChange.call(this);'":"");$Ja.=$Ne;$cd=(in_array($r,$Uc)||isset($Uc[$r]));echo(count($Uc)>1?"<select name='function[$C]' onchange='functionChange(this);'".on_help("getTarget(event).value.replace(/^SQL\$/, '')",1).">".optionlist($Uc,$r===null||$cd?$r:"")."</select>":nbsp(reset($Uc))).'<td>';$vd=$b->editInput($_GET["edit"],$o,$Ja,$Y);if($vd!="")echo$vd;elseif($o["type"]=="set"){preg_match_all("~'((?:[^']|'')*)'~",$o["length"],$de);foreach($de[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':'')."$Ne>".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'$Ne>";elseif(($gh=preg_match('~text|lob~',$o["type"]))||preg_match("~\n~",$Y)){if($gh&&$w!="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")echo"<textarea$Ja cols='50' rows='12' class='jush-js'>".h($Y).'</textarea>';else{$ke=(!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)):($Bh[$o["type"]]?$Bh[$o["type"]]+($o["unsigned"]?0:1):0));if($w=='sql'&&$h->server_info>=5.6&&preg_match('~time~',$o["type"]))$ke+=7;echo"<input".((!$cd||$r==="")&&preg_match('~(?<!o)int~',$o["type"])?" type='number'":"")." value='".h($Y)."'".($ke?" maxlength='$ke'":"").(preg_match('~char|binary~',$o["type"])&&$ke>20?" size='40'":"")."$Ja>";}}}function
  113. process_input($o){global$b;$t=bracket_escape($o["field"]);$r=$_POST["function"][$t];$Y=$_POST["fields"][$t];if($o["type"]=="enum"){if($Y==-1)return
  114. false;if($Y=="")return"NULL";return+$Y;}if($o["auto_increment"]&&$Y=="")return
  115. 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
  116. array_sum((array)$Y);if($r=="json"){$r="";$Y=json_decode($Y,true);if(!is_array($Y))return
  117. false;return$Y;}if(preg_match('~blob|bytea|raw|file~',$o["type"])&&ini_bool("file_uploads")){$Hc=get_file("fields-$t");if(!is_string($Hc))return
  118. false;return
  119. q($Hc);}return$b->processInput($o,$Y,$r);}function
  120. fields_from_edit(){global$Wb;$J=array();foreach((array)$_POST["field_keys"]as$x=>$X){if($X!=""){$X=bracket_escape($X);$_POST["function"][$X]=$_POST["field_funs"][$x];$_POST["fields"][$X]=$_POST["field_vals"][$x];}}foreach((array)$_POST["fields"]as$x=>$X){$C=bracket_escape($x,1);$J[$C]=array("field"=>$C,"privileges"=>array("insert"=>1,"update"=>1),"null"=>1,"auto_increment"=>($x==$Wb->primary),);}return$J;}function
  121. search_tables(){global$b,$h;$_GET["where"][0]["op"]="LIKE %%";$_GET["where"][0]["val"]=$_POST["query"];$Qc=false;foreach(table_status('',true)as$Q=>$R){$C=$b->tableName($R);if(isset($R["Engine"])&&$C!=""&&(!$_POST["tables"]||in_array($Q,$_POST["tables"]))){$I=$h->query("SELECT".limit("1 FROM ".table($Q)," WHERE ".implode(" AND ",$b->selectSearchProcess(fields($Q),array())),1));if(!$I||$I->fetch_row()){if(!$Qc){echo"<ul>\n";$Qc=true;}echo"<li>".($I?"<a href='".h(ME."select=".urlencode($Q)."&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($Qc?"</ul>":"<p class='message'>".lang(9))."\n";}function
  122. dump_headers($kd,$ue=false){global$b;$J=$b->dumpHeaders($kd,$ue);$gf=$_POST["output"];if($gf!="text")header("Content-Disposition: attachment; filename=".$b->dumpFilename($kd).".$J".($gf!="file"&&!preg_match('~[^0-9a-z]~',$gf)?".$gf":""));session_write_close();ob_flush();flush();return$J;}function
  123. dump_csv($K){foreach($K
  124. as$x=>$X){if(preg_match("~[\"\n,;\t]~",$X)||$X==="")$K[$x]='"'.str_replace('"','""',$X).'"';}echo
  125. implode(($_POST["format"]=="csv"?",":($_POST["format"]=="tsv"?"\t":";")),$K)."\r\n";}function
  126. apply_sql_function($r,$e){return($r?($r=="unixepoch"?"DATETIME($e, '$r')":($r=="count distinct"?"COUNT(DISTINCT ":strtoupper("$r("))."$e)"):$e);}function
  127. get_temp_dir(){$J=ini_get("upload_tmp_dir");if(!$J){if(function_exists('sys_get_temp_dir'))$J=sys_get_temp_dir();else{$Ic=@tempnam("","");if(!$Ic)return
  128. false;$J=dirname($Ic);unlink($Ic);}}return$J;}function
  129. password_file($j){$Ic=get_temp_dir()."/adminer.key";$J=@file_get_contents($Ic);if($J||!$j)return$J;$Sc=@fopen($Ic,"w");if($Sc){chmod($Ic,0660);$J=rand_string();fwrite($Sc,$J);fclose($Sc);}return$J;}function
  130. rand_string(){return
  131. md5(uniqid(mt_rand(),true));}function
  132. select_value($X,$_,$o,$hh){global$b,$ba;if(is_array($X)){$J="";foreach($X
  133. as$Gd=>$W)$J.="<tr>".($X!=array_values($X)?"<th>".h($Gd):"")."<td>".select_value($W,$_,$o,$hh);return"<table cellspacing='0'>$J</table>";}if(!$_)$_=$b->selectLink($X,$o);if($_===null){if(is_mail($X))$_="mailto:$X";if($Jf=is_url($X))$_=(($Jf=="http"&&$ba)||preg_match('~WebKit~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="&nbsp;";elseif(!is_utf8($J))$J="\0";elseif($hh!=""&&is_shortable($o))$J=shorten_utf8($J,max(0,+$hh));else$J=h($J);}return$b->selectVal($J,$_,$o,$X);}function
  134. is_mail($jc){$Ha='[-a-z0-9!#$%&\'*+/=?^_`{|}~]';$Vb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';$sf="$Ha+(\\.$Ha+)*@($Vb?\\.)+$Vb";return
  135. is_string($jc)&&preg_match("(^$sf(,\\s*$sf)*\$)i",$jc);}function
  136. is_url($P){$Vb='[a-z0-9]([-a-z0-9]{0,61}[a-z0-9])';return(preg_match("~^(https?)://($Vb?\\.)+$Vb(:\\d+)?(/.*)?(\\?.*)?(#.*)?\$~i",$P,$B)?strtolower($B[1]):"");}function
  137. is_shortable($o){return
  138. preg_match('~char|text|lob|geometry|point|linestring|polygon|string~',$o["type"]);}function
  139. count_rows($Q,$Z,$Ad,$Xc){global$w;$H=" FROM ".table($Q).($Z?" WHERE ".implode(" AND ",$Z):"");return($Ad&&($w=="sql"||count($Xc)==1)?"SELECT COUNT(DISTINCT ".implode(", ",$Xc).")$H":"SELECT COUNT(*)".($Ad?" FROM (SELECT 1$H$Yc) x":$H));}function
  140. slow_query($H){global$b,$T;$m=$b->database();$jh=$b->queryTimeout();if(support("kill")&&is_object($i=connect())&&($m==""||$i->select_db($m))){$Ld=$i->result("SELECT CONNECTION_ID()");echo'<script type="text/javascript">
  141. var timeout = setTimeout(function () {
  142.     ajax(\'',js_escape(ME),'script=kill\', function () {
  143.     }, \'token=',$T,'&kill=',$Ld,'\');
  144. }, ',1000*$jh,');
  145. </script>
  146. ';}else$i=null;ob_flush();flush();$J=@get_key_vals($H,$i,$jh);if($i){echo"<script type='text/javascript'>clearTimeout(timeout);</script>\n";ob_flush();flush();}return
  147. array_keys($J);}function
  148. get_token(){$Of=rand(1,1e6);return($Of^$_SESSION["token"]).":$Of";}function
  149. verify_token(){list($T,$Of)=explode(":",$_POST["token"]);return($Of^$_SESSION["token"])==$T;}function
  150. lzw_decompress($Ra){$Rb=256;$Sa=8;$kb=array();$cg=0;$dg=0;for($s=0;$s<strlen($Ra);$s++){$cg=($cg<<8)+ord($Ra[$s]);$dg+=8;if($dg>=$Sa){$dg-=$Sa;$kb[]=$cg>>$dg;$cg&=(1<<$dg)-1;$Rb++;if($Rb>>$Sa)$Sa++;}}$Qb=range("\0","\xFF");$J="";foreach($kb
  151. as$s=>$jb){$ic=$Qb[$jb];if(!isset($ic))$ic=$di.$di[0];$J.=$ic;if($s)$Qb[]=$di.$ic[0];$di=$ic;}return$J;}function
  152. on_help($pb,$_g=0){return" onmouseover='helpMouseover(this, event, ".h($pb).", $_g);' onmouseout='helpMouseout(this, event);'";}function
  153. edit_form($a,$p,$K,$Jh){global$b,$w,$T,$n;$Tg=$b->tableName(table_status1($a,true));page_header(($Jh?lang(10):lang(11)),$n,array("select"=>array($a,$Tg)),$Tg);if($K===false)echo"<p class='error'>".lang(12)."\n";echo'<form action="" method="post" enctype="multipart/form-data" id="form">
  154. ';if(!$p)echo"<p class='error'>".lang(13)."\n";else{echo"<table cellspacing='0' onkeydown='return editingKeydown(event);'>\n";foreach($p
  155. as$C=>$o){echo"<tr><th>".$b->fieldName($o);$Lb=$_GET["set"][bracket_escape($C)];if($Lb===null){$Lb=$o["default"];if($o["type"]=="bit"&&preg_match("~^b'([01]*)'\$~",$Lb,$Xf))$Lb=$Xf[1];}$Y=($K!==null?($K[$C]!=""&&$w=="sql"&&preg_match("~enum|set~",$o["type"])?(is_array($K[$C])?array_sum($K[$C]):+$K[$C]):$K[$C]):(!$Jh&&$o["auto_increment"]?"":(isset($_GET["select"])?false:$Lb)));if(!$_POST["save"]&&is_string($Y))$Y=$b->editVal($Y,$o);$r=($_POST["save"]?(string)$_POST["function"][$C]:($Jh&&$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='".($Jh?lang(15)."' onclick='return !ajaxForm(this.form, \"".lang(16).'...", this)':lang(17))."' title='Ctrl+Shift+Enter'>\n";}echo($Jh?"<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"]),'">
  156. <input type="hidden" name="save" value="1">
  157. <input type="hidden" name="token" value="',$T,'">
  158. </form>
  159. ';}global$b,$h,$Xb,$fc,$pc,$n,$Uc,$Zc,$ba,$ud,$w,$ca,$Pd,$Me,$tf,$Lg,$dd,$T,$vh,$Bh,$Ih,$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),$Jc);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);$Pd=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
  160. get_lang(){global$ca;return$ca;}function
  161. lang($t,$De=null){if(is_string($t)){$wf=array_search($t,get_translations("en"));if($wf!==false)$t=$wf;}global$ca,$vh;$uh=($vh[$t]?$vh[$t]:$t);if(is_array($uh)){$wf=($De==1?0:($ca=='cs'||$ca=='sk'?($De&&$De<5?1:2):($ca=='fr'?(!$De?0:1):($ca=='pl'?($De%10>1&&$De%10<5&&$De/10%10!=1?1:2):($ca=='sl'?($De%100==1?0:($De%100==2?1:($De%100==3||$De%100==4?2:3))):($ca=='lt'?($De%10==1&&$De%100!=11?0:($De%10>1&&$De/10%10!=1?1:2)):($ca=='bs'||$ca=='ru'||$ca=='sr'||$ca=='uk'?($De%10==1&&$De%100!=11?0:($De%10>1&&$De%10<5&&$De/10%10!=1?1:2)):1)))))));$uh=$uh[$wf];}$Ea=func_get_args();array_shift($Ea);$Pc=str_replace("%d","%s",$uh);if($Pc!=$uh)$Ea[0]=format_number($De);return
  162. vsprintf($Pc,$Ea);}function
  163. switch_lang(){global$ca,$Pd;echo"<form action='' method='post'>\n<div id='lang'>",lang(19).": ".html_select("lang",$Pd,$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($Pd[$_COOKIE["adminer_lang"]])){cookie("adminer_lang",$_COOKIE["adminer_lang"]);$ca=$_COOKIE["adminer_lang"];}elseif(isset($Pd[$_SESSION["lang"]]))$ca=$_SESSION["lang"];else{$ua=array();preg_match_all('~([-a-z]+)(;q=([0-9.]+))?~',str_replace("_","-",strtolower($_SERVER["HTTP_ACCEPT_LANGUAGE"])),$de,PREG_SET_ORDER);foreach($de
  164. as$B)$ua[$B[1]]=(isset($B[3])?$B[3]:1);arsort($ua);foreach($ua
  165. as$x=>$Kf){if(isset($Pd[$x])){$ca=$x;break;}$x=preg_replace('~-.*~','',$x);if(!isset($ua[$x])&&isset($Pd[$x])){$ca=$x;break;}}}$vh=&$_SESSION["translations"];if($_SESSION["translations_version"]!=2223616353){$vh=array();$_SESSION["translations_version"]=2223616353;}function
  166. get_translations($Od){switch($Od){case"en":$g="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}@i˞Nt~9B؍8:-pKX9,p:8(\0(@-BƎN@.9#3Ӊz7:ތ@Fċ1C@C)0:9(ƦkQ%<:KN 2c(L3B4tD!*B1,;:rè+3Q11\0Sz<,Ȥq9ikl*8z3eЃe7޵@\rY612*7qM*K16B 0 ۶(2L\$T\"m ċVv4 0صn\\l\"ލW6L9Ք8c/\$TzߍB6Rb. x9HG:Oϙ``)B; 8ZB!bˍ\\z |C2ΘgZQ9*ctK8\r(ɑ#:ܔ%Q8EqjBv\$cB3:xɅ8ǼtH^4#*:q\",ލa}vn60x!~I2^\$ :~c}Qc%ʌ\"Ȕ0./AH @峩\$\n[м\0P)i    3E\rF] ӤRXKC\r3ƒLɩ\$\r' 2➨I5jU/D@bHJYM/\\ϓM ;Xe!h% >@xS\nA@MS(rֱ IJsy܀J*7dEC;UWD܁2F?v\"I!aDnaBpZYKRC((xNT(@(\n \"Pd\rᰗPi‚ (ag4Uj'5~N8f *Ȧcg&MRRQ樣tql4B(?kj=Z\rA\$DR1_fz-Èf]#8 i@蓈a>D7nLu GA@a2yB<+)*T!ɰ!9Pr!p&V|'n3I\n[+@\r>ԉư@AC..ɴ~\0AJrCTJ<G,7!0hyl\0a4KbVٝ;%6@BH@|L{voP`{6h0^,i0쐘3\nb1BB[\"OX0EM/nY-d7\nW5ƈJ|d\0]e,U}2ekie6NeE\\]?o,wYoHǓ\0PW 2KKKf7a9 pPu)v`be*|Qyh%->l!mI|ޝN73XI/\\OĦUl0Ye-CI(Ԟ2a6'()]tMcMZN74ا   P|锝}D]R[kHcY|sc'{\\mEgX09k@K6F04S>}\rӳkF%+:arkl] 6Rl^քդWcmC55Թ4u(3ŵ6/bڙFV[WrnNSfJ \"|X}4sV)NqH]˷FZ({3gZaQ\nj-&9y8djYg\\t(Mwѥny5q՝>;kӢ˫>6U4>ڌIuka9&1hsWǺs:8FvD7ʆUC\"b<ɚ\r|#줩;?yNNU<uBO'\\-н5N-5[s(wUV^;/@_wT%9-4伞mzdžDɟm2Qgd\$sBdwM:|퓷hLEޝmnk1nȲr2\\KhK uhNɰf+nD\rV `BF0b\r b=\"pއe    \np) f.%\0W\0ǐ\\b\"lR3\0MI~.2j.#6;ʺwi,F#a@70ehݥS)6 B!xKLj#,r.l3\0\nYJ5f\nPjY\0\0M+.P%& 4] Ȍ\0e*̀0\\( #N.%Df'bB +:%\$X'd-@< fmCp*{m   4 DwVMDD\0[_\0)ԭ.K\" ZGbLF*K\rǑ";break;case"ar":$g="CPl*\r,&\nA(J.0Se\\\rb@0,\nQ,l)µAj_1CMe S\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\nV?\$ WFE{-:>W9J|eRhY+dxB&[*lꎠ(B&4S!dPB=tO    ?:XؐeJ    \$\n&3ޜ:OKЬJ\06\rx2â26Ҋb4jzBXm\$*!0e\\09[P(%WVϱeW41Ȓ-PI\n?Z-2<|P6*pi^Zԏ=\$RV-YmlOd6!^Rcè66^c0sR)ek/J]9JԇX)2O\n.6!1o~lkȦxhEř}SBY◦\ri!un\$E8<XO75h*mÐ6L@0M(3 c2µ`4ܛB\rp:cd9P@6\r;9nj#8@KP\r݅Ridb# >ZgŮzWsn_3\no¤Ưg \n l\rթqEsPFYICF\00Ò 8 < &`z@t9^ ü!2:C.Z\rے\r!7DC\\/6\$>RjT2u2xal)Ч M !ҪS\nl'S**JO1iJ?D\nzUI*Cm~5U\r3`kgwZ9J{LmJ(\"PdT6>L3+llF](e#sĎi2Or&a\$> iTM*0ܨ\r\r8Sd0r\rJS\01Fm\r՘@'0Bȋ1UT/iLjA    xp<C|N'Rμv V\n (nCsR&Hg `c\\iMlP(Q~TSQZd̲7\n\r\$)=\nQZ\nf)A<G@\n    8PT*@-RL/aA[!cC@GA/_͎-  e )Cde1tAlP   KgVBr~D2+G\"SfU)\$A]1a`KzEmX.Htqd 8yJf̣n   .2)-R5Wn    ` Q1f>N<w5iELi(\"#^ڽG6墺G^60CeAe_e5݆FLHDh=gժĸK(UYhH_t61ĕ4:(,`(v   _݁*̓ZN*\":噡%i/ȑ5uzѐ9N\n^QHeíԋ[o2 O\r?;>DTBAa LXPMo&7n)e 1!`G\r柦,X iy{u`/1(2%LycuelAӅTXZC*l;PR֢I! ZOu6Z\rx;SS(;ǻ,>{35pl01PBIb[w]uPA7_MXSEJ)>gmlU (P CVw (bb+d!vnO,Ic('{ԂvUUqiY2\\YywaY\rCl=[--;(iڭ.+,G&_:ŮYLwcӞ.)ՠ<Y}]J@J/7pgfBBz~C\$};SƓmKBfm-ci}43bKJ̧CfA7}fjl{E[eGtj\0e!ULOF2|{5MAm^{+<|tn,|/#žbXkI@D0+P# *Wc͔8f`Dt\"p*}, \r\n~c\r]r% vLNU'D=+/pM2Elm^?.6LhQJ&&/eO.ELb NOUotִPp0{p|\nyz\"n0k|M%dXCk^în{E\\+qQOl#\nyj%(\$ϸ`nݮk d<:~?|VU`qM_Ϊ WєhCB\$DQ`\"U]EUKG,^_lMf!Cpi'o),Nͤ\"\0\"zR*mn>U\".1°6/'V˪@*N\\jr,:@1 Y:?\\z\",\rV `h@7S UfN @ H \np0 r;pѩVK͑MW FՋ`^be1@,æ,dij'>2 \0Dn=PδM>(R>r;6ȚJ7#D /J^\rrev‚M򿓚3'h&&ӱ\n#D4 \rus!4]ⲄS{&\$%[T),FC )g6.N@ү \0@@\n\n `ھ\$H8l`G:Pl%0n>\$:W:o#t4B1=C_EpNrH]e?E    \0t @\n`";break;case"bg":$g="P\rE@4!Aw hZ(&~\nfaN`D4\"]4\r;Ae2a.arp@ד|.W.X4FP\$hRs}@ЗpДB4sE΢7f&E,iX\n FC1l7cMEo)_G_<Gӭ},k놊qPX}F+97i Z贚iQ_aZ*n^S9YV~]X\\R6}j} l4v=HD 겹%>L*H8@P|.3dm X3!r'HS1k6A>¦65   ܸkJ&j\"K.-:Df5Mb(<Oh(GZi2=^9-bk1l#j4-jAA1cA/KƁ>BOKm\r%2!1<h1\\hF\nOK8\0P6`6p-x:\rxx@:c(@)\"`: &,(,\r*ʣ]>8k#5{tmKw,.ŃDKbOqX҉!.ajү[0i7.L%E0D)hTjHV˶4F@ٸ((@6[5[Z4T/KMW&kud\njT-m<V\"R#䃶O\")93    \"s:6Tí=ץ;{]v! \rOupQ(WnTŐ2nRќa\\dR;{J\\L\"h-ݦO4[5t\\+oO~\rܥDXj! ?\r)֮;LVzL߹6F|FWEilv:a%r J8Uy7WWqy~(!\0 q5*r`  A{h x*- Q\r3X!T#~N}mG@\\CV%7Y?>@̹s14:nz!AMBP~D[+e52L^;HBH33   a  \$ý+䗛2ya9PAh80t xw@0@Cpe@7  P70p/K 0`%\0_ A0|j\\Xxa\09ǸuGؔmڌ+vi4ͯrav;VK<.Қz6NkypqeY)fxI m(ȼ=fNm\0G@\n p)/1ї/J})N@TʊD-dF?e%5cCE4ف[τdOLxĊ#o_zd9jj\nX5 2XK)cT{k˟fLΛCQF)I\nPoTG;騨\ny΢Z@+v9M#`{.2@)!0v(BsؚYaYDBM5qRB#C`/vLݜXV\rQAkkRj)m&ղR]E/oCLbSH< \\Q})>a,j|ODp  \nmSRqa[!   ;.6Fw0\rCeϸbXJAc诚jEFIeFP|rUHh*)ebѯj]]k\$)er0I\$V(kNECɹ`hO:W=H7M>J\"N?Ӌ<Cn#4\nHg.)T[    yx\"C5>99iԓn/qdUy3V8˙_KSߝ^QI|Ī<-q3241`{MHq99u*K-1VM3H|v찭iQ.Lpf\\@SFc99LZҥn BT! \$\0ei vbs8KU\$-z% f?gk'aO\rX d\\_T=~V쇬ȡǪ4t!`g%ЇOXQ :ܨyDnu\nK{==KV{oFlO\r35wIL:bkIrфIyj݌\nKtx/wiF?:XO#ItiI qcRE6?),#zWO۷-\"j!B*VJhP.0tdu\0FE.u[Ϫl\$db.e\r_Ǝi\0ᬰ\"+_\"⤪J=-\rp\rwp    .xPLOgQ\$…(I}f%D/ॴB PKB5 4`£jCO-\0p6tLPd@+  a`0#uPP0h#Z= TPg,)PnEAW\"0*0QB[Q.qE*^@H7<F,㍄QWBGjtрK1njy,D+A(;^n]P\$c*R`;ыh\"T1@%BTP*좻KRqgq1r,#Q1@ُGhVۤ0L\"*8i#Nk#4d&JdF\\i7rDD#] =oHHxoR]k+6y`%)G0rK%(Ǟml!KԿ.h\"r):qjs2BUdJjOoqQަ>jΛ.e2/m#2څ&.*&20M3 3!C#reczDg\"H;e h'4\$1A9N#9.U\"U:e9s4s >rb_!cKd?0rGs<\n=dce 3嶾]s>\nУD,Ddk(^h PO/#:0\\bc7B V̊t3\nBU#ſ\$  CJS&C%Dk;Qg<=CET#D]DF@3_?N\n4WBTCBFg%nPIS3tMp+Fuwr]1FR!-tRtR+Js.4j!P^-\"tK<tOJO>3x4욳]?4keQC&jweC+JKINC2SQ-E'2i3QGR\r.U(:4Íq49   >@<7>T(k.+P9@,fBI B٨<ΞF mYƲo L^`Ձ .S[ӷ\0\\ug\rV/&,d`,\rpF\"dm;k<H Pq')Đ\0\npmFNUfgT!bYP(scMkjbt~bHGdl,PCQ9FNs?zPB: Egڎ)tiGDYFw4<hXUZ>6oĊL*&du.pbLd:Miqmҹ=1v/\"QK%o\rn#]\"m/p0G+wW\r25/ZIpThPqvanyfS8,    =tڬ]vl4\rm(dQˍ}r4ÔUX Z+\$<\\c %w/zjm@J@lb蒵6&v 87QOKFpI=-Y<,`0/ٗt ]E^@z/8t>Ŕ{BM SOo~#";break;case"bn":$g="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.ILG3W9S2b!|;I7#=MTR/\rҞY'ERj!*؃ 5eO;w4ӅWF,}!ITdX/Z*5O5SyB+eQ1QT0*quyBH8=h7?x)\"`@N16 ·+.P%1A8cISM\")E/)t9`T?oKYȪARX]RY)y۵8!.RjsT\n@Ή*kf?yʎ,:OM`/jM2k5֖+U7kqT    ۑ8 Dˆq{En@:c\0\00ю\"ɍ_[\$KtTK\ne6T!›Mt\\vMn>&wJk83zkČ1O>B]R-ˇa_{Y&0rj`QOMie@@Yɷ7+'i}]W q x Q*\r9\0wr<3`؍+_b\ne#Bo<@Cps1` \r3@ r3h#;VS\n)bmANS\nAK7Z[M,\\_)xdp(8b;mLަҍ;j'Wm٠-&AW\n0@\",0&2Y\0Q%8&~;(x@\\a<3Dt^\0. !6t ཁ~i\r'^t};@`0@x >`Ѭ2}#Xa\rg'3bN m%F\nu.dgr/%tD(FL<'L\02^QJhm鱀Ȕz@\"-^Jg=fHq= Tt+DD+eyaylyU4ߌt KWel6\\|[rVSy&E.iN   \$|<@K <O:!PxmrD   qm;Q0SiD3/\0P    L*ʬ&PWgF !dGGhZ)EcUGZ9J׎kDwm{t\"{\0\rM C8 b0cydR;FW`VA9.΂[|aH]QN\"Q|+,\nP1j+±[\\lA-¨)ŭ\0C0au;km0<gHaI#4(Z{W`;^' [*]h%cTVe1  PzhZ|!@X9=ɉf[8z]bI!R[ YR 3&Hª8,S-LTNrL0'z}P+r    MFT \\K:FϕYz:5T!DRI2(sg6Ms\n2\r\rc1\r!2lCnL2~#mhY*iT)٢\0fYj0g~@}r@9oʊqMր\0R\"G%uW3{na1v!9Yl>@ՉX7>oyTH酿TtÚ\\!X!QM\"JݖSj#+p gDM}c]=^V\\:[T\n!Aj8i>7PipAgSu2=Px@m   ! @5EUj3_9\\(s{ł(W٫tzj;` w;{m (:zWN:`֝7>~62O6\rL{H?;p\n,NGO\r*(dGngw\0(@f:hDng{FbH``BlgP/BCx\"dLiN:Gː~SORPohP4\"\0b܏➫4@0[e\n/%`΍\"c-`hVh#0-!Р+8Sz)NJ#&؃TO&U SO}\nF\n&z8ŹOiD7'Տd.-%miڗ/P#nMSBq(gq.0,K&jPQ?Bfz҉4~1 /֓10^Qgh8h_1O  6q |;.S >İX2U/pp[%#ЪOB)EpPK )*>Vk`.dp.O}k1`cdǘ5g~\0Qt'F&B\$91].&-ƭWƈDA05^|{%-lnQ'R7'`DM\")2ѲrRl3RqC,~-fQqA.GG\"Ӳ @\r. k-M6rnP D1B{03.3) ^O\"D3q>W4Sq4βz)27oy8hP5SC1%,zHA(*eF7!2k5 hΪd-]&PU\r&HG_,L<=Xs\r,#Ӯ3!{ spzlV.thpjв>g,Hw:l8볮3hfyjLT l\$QtLJ٦]+N+'3.DX^+ksy.3wGu;\r218Ԙֱ\$-HQ73tG   9K7t۴,GsIr-0N*%@i 8a~F\n0F->o/t%d(F2\0eHT.U= <O4'uS.:Gw fU3\"PQQMt#کgNGUJ 5bX&[uiZ?Phlg5a]&>M*’Jt1V8ETj(U]5+tU]`\\WW%__2՗\\ ]Q]`7E\\b[bo_    WKI>Ed|P6O YbAEnXHsTtcњB1f/UTaԝ;fRft:5g1a;1%iNiPQtmMSlHIg5&7VlY6r5_*\rld.GO1Ĝ+-3D]3b33e3gX\"NPr3jnW(-!iw7M=jyp售3,\$o2stQe-lsh\rV` `  濠@ʬ?ha@ Ȝbb`@ J(\r@\nZ\0@``{j. ^xN+6sOWt767P!XY2Shc5sʹBl |{ WvG-M9!fH1edEҀP>U4aL%tL5+v3wY\"vN-n@k@FH֘?\nBnQfz(ËõuKvd)g݂\08Gi`4Pw.61-vyN8\n`c<w r\r o8b,gC5HlwΧJ\0‰TjъܖK)LU\n3%Ö)bKX>6 x\r,\n\$\n `ϣp\\X*X/XATHˮz)E*G,x/ԧX=)B͘g+LٟM8t?#ȉac uhQ(<yՎ@   \0t @\n`";break;case"bs":$g="D0\reLS?  E34S6MƨAt7ptp@u9 xN0V\"d7dp؈LAHa)̅.RL    p7LX\n FC1l7AGn7(UlbeēѴ>4)yFY\n,΢Af -e3Nw|H\r]ŧ43XݣwA!D6eiM~}œᣘ!2M !PIWIKlm0cL@#A\024 *#\n<M+shr5ү#*#ˢ8B/+_ P2`G\"c\nrڋf9=4FN,X&'**\n 2 2j5(G\"H84`:AM\\|4@mbN9! (\$`T1XPL    8IR.%t7*;J,1&#U`ԿU][RM3\0B07\rc\"K33'#<r14h2#2&+0Pꚺ:ڇ qȈ:J2DRV c[&\\i35sc@4Ǩ=I\0ZѭBߤ)xM&_RX=3t+x m\"#.l5/d@QPd(.hs')*cg)x¶9+Hc9^Z\r5\r0 ' 2%}4E{Z6CN7c1C:3X[50(@0݂@pF!b pA/.( v (\nH(%µP3wD5;%%P Ec K2x C@:t[.c8^}c\r#xZԎۣCXDRld'8:^Aq :]p%AɲdKm?TG5AMR%r#:Fphr (vÇcH<DuK-d\r6@ l!|NሇE` @}H7VȨyj4Bn@ CN36G82X[f(2{H P   L*!(^#\nƒ hHXL2.B`aXOȎi#ps%dͮVbją!`XR+8A!aBJ|]fEp1!Lb6i   8PT2s&h4\n@T\">=.IAz4\0006\"bFh-\"ڄB e '-GNM&Fc2qX(\n:ר Trp1.(4    ˒̞fERa ݉i5vӋbꉟӌ kM *K`ome#Ն|VgP(MLP R4bm Ny;̲\n\"4Ӡpp2yO9eLDMUm9\n\rM\"O\rǤ^Ĕ8s`C4O\\dsBP(f&@zN\nb&%vJMd|&\nQN>YHp%\$ڤT! \$  \0MSUj܂iAܪ:F…TC&~#Ӂ&%<:ZQLSnVtW.!Wdlv'PP쇋aR&:P2J#D<\\!Y^B|z()%&fqO%gq̸A\\sXEh, <ʆ%!d#Q\$ʵ!kВc\n:\r\$F\\NUXPŭJ9kB(\n T\"?gjCF1P\rL|S8t7VzUI]۷shIMB){V`Fh`o-Ļ-mP/\rVd-bڙ>|eaʲMU\0'\"1!&EsXI>12_.M  2RB9ZXy-jK4SsUgn 4q}Jps\$J/W.noť[];A.y}p Z`WY\$D`-O^_v]+=RM˷ƪy'%?\$w.弞ns׻qYqV; .rELuR' -&B7e6\\@H&@.k\n!6Wv۷Ysݯ@x9S8\"e22lO\0E4ʊ \0zІ|C\0e6Cvnp.84:p0|8ˎ؇H[\"aPY~iccLb.An4QD\$+j2.\n9\"\\Vm倥#\n.&NR]Ž FL82 ZR#C^iLt0ƈ/BQ !u܈&t\n{N%=!HJb=:Ў  !\r\n\rWԼ^XdY[\$.6\rq=vC#  C{~ \r  k jZ'/V5ltC\n@`1\$EXBUCZ~VLT<\$l:lމc\0GgqkE#tezH%0Z\0@9@b JO`ƌqȃ(͒XbE\0002c\"0'àkf1/1Cצ1\"L6T>D&+Rs)dLeN2(?\0\rЮffF5&c4\0!4R̍Y/0 Lr%     \r101&SLYfj6&\$F\\h3V^^X D4.\nRnL'x.\\@\r uL.i껂~ j508WKh3BXc\$V\"c.R;F1bQ@c&H7|P4\nD c(1R\$`X*";break;case"ca":$g="E9je3NCP\\33ADis9LF(d5MC    @e6 Ɠrd`gIhpL9Q*K5L S,W-\r<e4&\"Pb2ar\n1eyg4&Q:h4\rC MXa+\\>RLK&v 3épt0Y\$l1\"P d\$SL\$y)n+ OoM|)NS,,}tD\n2\r\$4쒠9I4\nb*\r#)`N(ˍ(9\nH0K !KD     (+2 &?PH\"CP#\n7,-#zpEH4cJhŠ2an|4\rZ0艢ℑi4\r#f\0(c9#P&A(r1S!L1[ MrQУMM5K˴@?a- 1-]q#ԔB2EI@P3 8J{\n&B6 ޔ`1BxY ؘa\r %- gX֥p |0usUȌlp?OB\\|L2S%YR0C\r,Tv;M[7\$VTcLő\rk^B,9\$P<hz(?+2A̚6d:S=\nH1 MJx3?ˀpLP2ޮ')SpScz? \nfl7?C(P905\0)B7; oBCs\\6 9tNhn g6f+9E\\\nqD9Κdp;4 2@&C(3:x˨\n0H^r6!6X\"Ptxa\n8;&꞉0%,`Jb6S;A(1+bzq/̘HlM \00ohhK\0PTAJBY3BNi/d@硠Si-XJbԝBf  A30HɡQ&!\$I1[mC( + \$9@C#\$ʆ5Ģd1 &\$lO\naP'`O4Z    9 aSrz&1fnIY  xMǦ)>]PL)p:p@HO\n7#\$q5+b\nryE\rɴm1(NT(@,\">0|:Ր_k!%/T98*e\0RCH\"W\nN(pY`b\ra+#Bf!hüscC=ԏ)5ʣFȓ#sF#;^R̂(caX0TPK |j3j3sXqAY0\$Չ\"{\nľtcbe ;AQ29;+t;[wFŏCFHXSpy⧇}P7&!ZFIi2 FU l@FKQNInΥFY6}T2P|(4/HOp)<QP\n\nG輣0j    duiT! \$V]d2 ڴ^Uu\$6;̂fh*\"d%qOG`aMnA|.%Ť͗Yy4f}PێQT4FvM~Vr,\$`alRWr\$Ȏ#ya 8!,Ɍs3F͍FԹ \$H' 7LHUR \$\rKuޅ1QI9\$\$(bY    f\"F\"MI|\n`U\$Sm'7d0ŒB5*SAj6iJ:OЀ2iwJ;㽪f/5i9H5iYT]:g슷z\"7xtIq]:iRcP)hg`((^5|Y-N]R>֔Bz+mBf{}miqC )DgnUib({wWOII[<jU- }Uû~ Ne[nYKWe@2Yl y)OD6u9} J花.ݜ/\0|6DWNfy=>^KywQޒztfnRL\nd B3`VW5EG(Q3}NKNӖEȱt\"\n|YMU&@^!J&qEl5t圫mTI;j.gz y骵N oe9 PONf\$00Ęu *=n&`F\"p^bdvMЫ'N(]cW2TYk'\0l^D62tk\0|#p.Fq 0MċPz ԋP\0\$>prhiOXf뾺œQ(/6 p,C*\n %n}FfPDE\r5dDb   \r    ^O@żrEEDA٫-)]b0\"R:n\$1pXlѪO({Mb\nϠH i,M    ϪDHS\ny~&惀#\nZ &m䛫,kC#F#ɄNb*\"2`bR*\$|+% \$ph==1\r phu\0‘JB/b& 1e\$(xd.:`*pa#n2@el~.xf0@cdVN>-k+-m.cy..O<m.ਭd0cPX r=l>d0/%Rr-s 2X\r^B^P\0z\\ !Ng.d?  X e\n3?/C' bUj  9 rtNӧ:J́/07zd7  _\0xNPf \\6IO` \0t @\n`";break;case"cs":$g="O8'c!~\nfaN2\rC 2i6Qh90'Hib7ii6ȍA;͆Y@v2\r&yHsJGQ8%9e:L:e2Zt@\n FC1l7AP4Tت;j\nbdWeHa1M̬Ne^/J-{JplPDle2bc u:F\rbʻP77LDn[?j1FU5/r(?y\$ߝִͦJMxɊ(So\04u=\n 1c(*\n99*^Xa8 QF&0B#Z:0)02 1P4L\niRB874Ƣ=#l:)*406ǃ(P! P2C|Jְ lj(\"H#z9Ƣ0K4i.5;C=@)\"c&w\"{H iX\rn:(B<x襍mz\nx6szMmEYWV\r+zٰCXꇵn\$\rq J26=eVme?K8SX:\\h#82dkMִ52t4Ҫ,0,\\୎\r6QCk\"\"C ~ 8乌cB&FW}m=\\\r4\$w ō팱l>b)B=9m_lScs4#FwgEKL     C}GbHډLX<j^{v(ځY:+6T: 27 X2PSsጨN(7\rs_kA?e\0Rmg_s`3A2pH   qPυoǎzI_-Y`ӿt| =F1O]cM%w/\r4ch^cZxb#2&3%#k=<mo_ZCI5Ce̢*i7O uƨԈN\r{.\0@3\r PAhl^ ü9̥`\\JC8/ a(n Ό!_ Hn |Ԕpedep^AFL`7{\$`%!BNs0Q\\5Y# ^BpN%es>.pQMzCX_HY&dj@@PD,AP/]G8= 1tEB!cq%pǨNWL#\nT\rN#\"\$cס@\\\"\$\\p !'_9rE-,Y%ny;|P \n<)F_zOjMrP㦉M0i \njW^kb  `\\z0#x)C|&*J#~IIBtMҴa=GMfk%&bDf*COM('&gCp[?HUaQ\rVLa: Ht+G-O]OxmL pJhJUn\0t:1d@9Duf%h٦e.ISh;2f2GMY&-ݤOFWK</Ɠ SØ:S9C(tX^j %^PUӚ]£_009 &ń0.wjѦ MÛf 3ɴL֐S ]hoQ#Ch2 T8Îsji6axrĩƪz5q:Op\n϶\\rj(i7n0  9ֱzKfPai!P*\n۸RfMJh=fp/+:\0.ִ!Hhֵ<Q   r& ׹yVڃqŵ&zԘ/^V|f::H+IڻL95:בxUY&9d̪&n4vҀ%k;mkP Hn]\\iYnF24ӯdI}F_ CE\"IV|-ff9<\r-TdTl\0IEVhn*tM-P˦\r=uQ*Fi3b\nQJH=#tbd[Cs5_    VV/.7pk]UXv\"~n ]*˳l=V=wXK;+l 6\"O\r!lo ]'`\n\nJ2B3!;i0\n؇keO҆~(%CƝM|8 RVy|*X)!1ۻjw2\\B9%jRuմ]=kv~ffs٤kK#BhfBMLvz8 bt<F\n N<rM<MO\0mX\r>P7 q~ffIyl\$ 0)\0Tڋ`:LxpebxP|80w MLO\r8Š\rE/~B2BDh\0Bb?`ԙ%>X'C@q<Y\r LI}&Ɣp|\rF7Єci8 H+.8 z@fg ̱l@U  p,‘G\n/jLЂЦSO],(:R1j!,렪y|nz#.ll1` ,3ְ\0\"|(\rn<Bl\\1r4[힫렴ƀ@˅96WHPW[Ý!eg!\n8W\r\rb@o7#\$by\$.e #r9%r,Nf@c\$/Cq[&‘5\" |'1U)l)  2p /~+ҘK\$>EwtBLؗQ)^k+`-D)+1^\"C\"V\"21Bf<t{E233Ly1b52G1\0S6V b2rY\"{Ĩ:0#1g;E01052v5b4M}2sx}68St^N\rV:\"_E&䥇qRJ&ahRrANGHH.iE\n\nZW6j7-*Ʀ/q8=?B \"*\"휂f[W8\n/J N1`#r/0rK\"L?%&ɭ7C+, |NFJ b('c٭\"-|KvP 6wtqˆj\ntKrCLTd<bL+h%S)1AO \$o\$Ԥ…PHZ'H /03%H'NelSn(\" Sq\"<<@EN'Q i2%64\$k()pkRlsWqKV2<u2\r5LS/%R<J1\$V!";break;case"da":$g="E9 Qk5NCP\\33AADeA\"o0#cI\\\n&Mpci :IMJs:0#sBS\nNFM,8PFY80cAn8h(r4&    I7S    |lIFS%o7l51r(6n7 13/)@a:0\n]te8g:`    hFAwZv\n)03h\n!~kjv-3e,k\$SVG)OŽ8\r;j螮#+2\"5C*\n-\0P< (<߭܉0\"ȢsBQx6͂Ш:\ra\0@)0j ڌ+),:cd3HH;SlԧP<-.\0> HK@i1#HދC\r3@7-nঝ;@쳎k#4mM\r\r#h\njp64c:D  84}[<\rh1Nk\$2\rP:a1 a^Np#o09,' v01G\n D-K8UP\rx2 rp}̔XBނ -(3 6*\r,<p:c9ë=\"-cXY`3+[5j @<իKB!bhJ\r}8)T n9S  8<Տ,`\rIjM\\ Cl12\$J9Y49\$S[\\@4'0z\r 9Ax^;rC/+8]`ԐKؾ1&cpm!A^0,\nqMΡ~r:ur^OI{g ݋nuKy3:#\$?z紤YjD9'   .f\0P @gOg^A4֞K H%@<p>0f'ފWa^MqP6!-D<Tn\r\0ЙIqІcKdu<GҲPL2RJO\naP#hqkM̈mW*ϑ S\rYBRKq*d@Q'15\"8G.d祀 OKj\r.X#@H`b:D-QLAl@sEg2)RWxNT(@,\"0\"(0T=5CdsAXT64!ضĴ`[/dS rJh96'Î%\\9UsP7ѕ{@5   S5m0S%Wz9PC{2g]eS\\ɩE`ГNZ@H\r A(A\nY);k\\O IY`*R_˜iH8!@0O\"K:TU2T.iQ/,0)n8*PNQXK*Z93o?{\n\r0^{4 k/ ѿBW5a~C \0%Ksg,B|UBCQ-\\b\0(sxbJP&(Sjdκ0\\aJC m&,;h>ꐒyE}4.yBz;#opd(]]te~8.pՂ4'X;g\$2w#x^R)N W T1;'fؒ=\r-VFSm ,ӏ (\".-B*x)Qyt2҄ޢ<\$ϖl9S-vsjgU @Pme+:}/AbaJD -{. tS8䀫]rT/:%D\rIe\0QQK\")j/f#xe\ngmGXhcQ5(=YkQ>vvyQti3`v7n휱A6ρUw@_zr   ݖ\\o\0鼯ּ9Xl%u58ba Z;ʻ+uYiEZZȎUf̥(6<KJ.~;|!m:Pd'WkIJgg\";R^J=z&wœbXQϗyu &ZcqMd{r7l\$qEyiiθoMMvf?Sh//M*ѧ@6-ExS|6=zrs[wm^ԩN5=%~mi)fD H=4'VփjaZ˽{7첅}9)WO)J/_<\\7q5;:b,WSpϲO@O\0A.>EpMX>[ezc4RA\r 0H)&@O1b`\$.KDFZdfl j K,e-*0˜OL! K  `A``<@aJyNlǤ3BCL5Hg#)v\n wbSNMb|l𾢄*ID* \0lK0,z/bf\"7;7 ZXlppU[ n\np9֨0~9ǖ\\T0I4(2H*^CYl1v= *fBO|Qy|e\r?Uqq%b2*Iu;Qe>*/\r`d`WD,RQbF\$\"%\$BcĪe'@e^-؞Z\nʋz@PC |.mG2@0>@'pIp\nDNoOQR#Œ\n\nzH5B.\r@";break;case"de":$g="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:9#c2 /K- )Sޡz-:`T`0H 49Bp:C(6 V6h`Ð( #;tɃx΀S2L;1H8-Ca:C(7͢(ɩ\"4cENP9l3H/oR3M#F=!<HK]Wlńb\$\0PJ@#:2CUJĢQ/U>?V܍2RPf6[ރrF\\C}\rhsNa2VUS.<c۱5*r5-\\=,*=(TLeՍ;xXxKjcx3\r ={ R@؍t;+Z3\rX7Bd܀Mm!apA09\rp  h@0܋  p#* mV؃mxݸnF(;pW؜Z\r܂f!b\n{L]p\n 46AH95rHO~:\0002?ϴj>]82 581%P75/owpE@P Scf `KnBp0=E|:\0x/lփ.L^ Y\$\0/K ሌPD}#x > I(\\(e5`!7Dm0|Z|ȝP-\nd  BrLZ9#C %85e#9P8\"aG:\n\n)<#DW     \n@__ 876yHw @ Ҁ=\"w 3:QR to\$ɻhCAH!f +R͜OVA |RXm1O4E0TVQ4!EF8L€O\naPvt\r (7cRӨs@rRJX \r -\"R'IfL\$`ҔP`\0k)l;B\r>J   (h0T\nS#|F0C\\{fΠf\"FP   8PTʪ@-Z<ņ’gx  0uɕB I%TWVf PSy`r*@M2a88{c<h\"S9l^<0Σ[+4MxweFejEIE+jCh'(7:AXÆ}Wv-u\04)\$ȳj^˵? ^S\rU\$J:@Pk'A溆`wR=%SY.Xϩ8-ڢj;y nU8U\r#&c*ԓ#S   h3贋T%׉ }3 0cjl1ۆ:g\nA5>6;>=!P 06fèpg2TRR[VaM=5[֙ulgiL3ksV5KhsvpBw\n!N|315t!HaDIY. m YO9pІGC JnwW`։)-*ɛeuSKjcҡ  )/|VD~L=KEf#iO՚*,`h-c )&(NE} `NSt36(9NL湋fZc\n:\"S\" \0!Sj}gg#na+R_\"rX{AT p>P06\$(uyK;5W<lW-BԌRײ\nָ\nē`K9Jr 2Z,T<Cf1ƲDi1co*sQ?yV2H/7Cߐ){\\KYiP3ZsG@;Yk6D<`3.cBw}wTU֧ߦJ_4RU-6P6\ry-h A( #ZpGLIVjn\0v@%Bb h.\$% o=b ΩL@\0_Il2nྃBlJ1B Fҵ0soZDoЉPh(}ЄC\0    xN   )v&p   ,>6@ ֲ'@͆{h`ȏ&oPqQ0eY^3:dk1!M*\n(P 2 \re/XH\"8oP^n ij \\oSfVQkWw^1oA    kBŐNego\$U:nm11f\nl)KAQm*L\" +Ib=\r\$\nSW.NMlu6'\"\\gZiΔ\r;GZ&z4v:@e.\rV f6\n; @bZ*BPP \np4B\n0m9pNjPB;*PLil뮂\$ۂTl0FDfc=&rccs' @P2c>G쀘#D R@ Hl\rnj|kf#T#..<\$R^fL!K0n34#\rBUe+yN S3Pb;6*W6*q\nf);6#;kFfeL8Fgh3+hJ8\$~cӒ@'Dj22\"5/IHzID4HS\04~\n2ҵjCTZ@ʜ6cJ=|k3ލZDOlM%x#I/b";break;case"el":$g="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\"TIFlhʪFt.KL\$@Jyn\$m/J4J %o< Ӥ(e |޽ \$=*Q6^6 K>{ŤoiֵlW3[iArLj^AjK⾜NLʼz\$2(: A@2\nb4+~.E_<rF[T\nꟾtz>RQ9B(R|ho\n\\9/uN2z9Q,A.819HFRdIvl21ZPRq*kͱ   PjB|Igгu)9[RXq9 >z.R!o3o)97 *i;pVWe\$okd؆Tܴ\\Ő&Ꞗ\rx4ƥ@ZzoZIsBz}rg-1TJt9籺CbZX/̹?RZR37nY/%OYeuk>H\rYe-\0:- _\"ȁ~Վh.pY)UR OeH,pȩRYEa\"SJTC1<ï\rسs&\0IKCe'#EN9XT\\>z\"0\0dh:4-o!1ŗG2+ *YPHG8I-aL)h< K62hW&MD4Cв\r=1U\n:.0],Rxys*125dL%if@Ր}I&,ijLIa]A/ xA\0hA3Dt^@. !6C.\r3%E)\r4  4P2Il !5 |+NԹ)xaB\$,}Yd2O%APxIIgp{F<*f}`\\ŒBC*9Ø#!6f+hH?*)[B^4@*VR!\r2E k҉@\$\0@\n )fG5Yi;傋vVARۧm=y ĨŠS\$wwj1Z+ʖ\"*!^z,: h)MXN6h>%(epYR\"r\r Bkéidφ؟zy&(14!( O&pmNf~f!*}*L(8    >dQ<Y   ?Q6dLse ʖ-T #K,֐qc mX qE:rW°0)Pt 1LUBu圳2;3b*g#!C΃ˑ{axlbcPiD̈́ZRhjh'G0w> ť\0)dfA)`mZ!\nUZ7M\"Eލn 6dn1jJƎ^Q7 ) F\0A@HK* W\nQfvH)q݁=Em˕t'4I6'%dL}]_o%F&8J:Y\$OǸb-vR'[rը᝚\"wl<ߜs8HSgcOնB8)rֵl%Qcd\$Rҩ   p #uu{\\-PBQ^[Q\"\rOA3\r4*,%GtʙgĨuL&IhD-:\\, gĐɏ/N7M0-(g{ *pD8r!oaёֆvswKcDˡ؀BT! \$\0hi 0ؠs8Q6R *K9 NbȊe2+2mY*E8bP%CLa4Md;KO7*((K\0beFĐ(Ȧ-iHް*\n^ v2Č,GgʰK E*/fدP\"k84'0G    \n  \\)*j]a фDiH̲U/E2D2֮\$|Nj[G,R.Fd˥\0 )\n-6NT56@plȪ*ngk'PpʒF q`&\\E+~e,( 4U/%b+xERJƿ\nd0qˌ~pB!\\#!c(Ҵԃ.kHwP[k mBjdBr\n+1e1ėeʗ2 @Uܐ\rt)Cp\r@ZBUFoّD )%҆jDZ0l`/̢.޶R{!d!S\rHI(D..,PtRs8{\rݱ*B QUg#pY,-r(-!-!.>қ.g\0Qο'Lr\$nfR*/)  D@+g)ji.xxjCP}  b  0!hh왆5n5C57PT\$sk bw2p\0,cJ13\0/0<fӬ B)P4S-:%;E2    =x0S.GrѼC8.\nD{5D*~*!~8,&Q#('p\n?A#ZEeC,JK<3X/:S:~Ge;.@\$\$EmR\\cfE  !-gl S=47?S37i{,?tK.-Kt?1M\0p T3BΫNj\r4#\0004)224g3{Qt0OSSI\"(8eBYTxL(vTq?45B7;KRxT*XS{W.eS/0   !NL/INDY%e;nq[Z2[NM\0C\\ 8uC\r4+T2).tX5 s1u9.##6nv#=5)Kv+Q5&5m`h`%b/bu.vHV!^.h&J,3fBg`k?!YtRtdGz+v\0Ju~Vh\0.HKa1av\$5#Z3*֣k6eSc3hU}5dSQTV0n mg'4jQeLgfW]+!/k\$ϘTKMul0\\u\rq\$tKLdv.   :drXB8b\$Wѥ^ɔ™uv0Ivp^wn8%nՇYhxmӆ\\='uq\nU6s6  6c*{{919p*QdBdh^\rV `\r \ri4OJrX2sǖȔB%%CjELDjx79R\nZp*mʑ-򎷘÷/1Ĩ\\2g(XR!HgmR_1,NLZMe.xf<Ћn7S\$[SC=xFX,_p!5C1xE@s/lH%ޖjzLp^G޵`,;n?ѐ6w??#O%}B3*Y/fH(xU1Se\\YQ9Qy'zk_&YyTM#HIM3^ZWT%g ? Vfĵ!Do|td(Dڒ\r g X 9Ŋ[!G\$KaF\rBgz% %T7TDT)B(˘AxEYzP.6K/l2wNЀ:0ql\rѺGQ\$`GNcKcEL(zo妆ӣq<(t5 ";break;case"es":$g="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ҍ#\n \n9H\"kP2P2ۂ4-!* O4@)9M apØ1/I204svxGjsRk'5&\rCRc )?DcX25P@)2\n{pM\r.tˮK,:c0,\nå\r*N0L# ߶p:,pxK@ CajH ,\rȻű^0vYns p9FLB9k;M @MP<I,HgZ06&\n=j0\\&BH1ĒJxP6ғw&=S '̵KOV=byRo1S9(BH \$:3v\" ERf72fnI2\$J6G6\03 %q&\$M5zv0 ]3^oҳab98#0@\r:aL\"7l)B3; o#X674؍ƕ py\"e);Q7RI=~0%1oPR\":fuX0  ;8\r,` D49Ax^;tcأ\\ zay#\"I@t}A|<NO@wHCD C\"ίcLݱ?`@5f y8%QCb&t?\0%jBH\n7#\\FAH%Cf^,:*Ay o='&ȩg8a)R0f;vqs'!H pkH0|    C>!:b@ -^9H16(<ɆVT@O\n\r G\rdl'8MA2\n<)GJI7#ĊP\\8xAálN    Za::Š3f   Ԑ3Fq|щ+WE/fG*D~Hd%6@h/b\"C\$&J@A   \$-A\0B    H)PCY?F2)F( \nLÂ@5\\lU-Ee A\r`'Pװa\rG<Sne5IQB1S!#bfh*ҪiH\rQ\0BhHYִu@    2\nȑح2KPTչ?P?&%Vj%=AYdpbha6e9~:=.JJuCSCNeg쳹AB剈\nQ*ZNj3`K5c)LH\\    g99PtdDSVX|ƒz%?\rH   -.jEgTYx9G`h*furQKy!P**-椓&\rc=9E.6HTCR(a*8!樋/+*娙`ޮ5V)-nqHcfcFsXf\0{(V0\\sIhdRY\nbZ_\\ 28 7oU\\ɪ7\r3ιPFs3f!!XBB;0x[4fV3<G~T\\[IN(j%I\nJ(:+)5\$4XE)WV&؋r     g_3?9j&e^Ԋ_.Yk \r۪=I`n\r/#jSTw5HrК3dYTj5G a#oB8lvsL6S*.K1Ju@ v\n]\0h̪\\*7vT*TUq'ޕMs.\rhg\"fZ~2:.?}=f> ZG'U\nQ[fdx~ CS w|\$o<'|sИ(@]RpV4Eb  <Yw|'rE fCvU\"Llϰ2  ٓ`مHnlE=տR|+L[]u   \"v=y>z~oҹkT?WmuK0.7]ÞEl1\"TIG~_D\rM&mp0pQ.͐`kLMpf7\\<CXPo'@]Pf\nrIB@6\$àO礦P\nY\"P б ЈlPDM\rc\0oU[ ㌥K̋\rvJM„c#bQ -PBFVP9 @͑2'p<д̀/@a\"Yf\$l7esjՅ fJLqn8W#\$I\"L.Oqd{' N&,p%&V1Gh0Șd9 gb,`tbe    ui@'\nZp8c-d-&ɑb0\$H̼CB6-ZjdU/ \n 2X1\08[8/+f KQ dEj~db:rdp\"~94Nz9.6kR#<\n2(w4H8(BG-ꈏb(W@2H8\n+\$\08%DHh>ˠOpfRd7eʥ].rne/f`B粦C#\"QW^DQs#8I,JvvIvG 7m\r\rkDf.~ʅ*>d`&1Y222\nd1EE/J& .V   \0@  t\n`";break;case"et":$g="K0a 5MC)~\nfaF0M\ry9 &!\n2IIنcfp(a53#tΧS%9pNS\$X\n FC1l7AGH\n7&xT\n*LP| j\n)NfS9f\\U}:Rɼ 4NғqUj;F| :/IIR7aýatpQl7׌9Q.SwL(LGye:^#&X_v Rө~2,X2Cj(L3|4P:Ԡ88#(޷Z -\0000!-\nx5Bz:HB87/d(\\ )07x3q|-ܓ,H'H%h7BS;h<P6,7>*C2zӄ\n2R)23XxLk\$M\nj~\$j+ \"(S~ء.:*HÜB4CPʈ 2:,\$tu'p;u؞:'@S\$4TIZ\n-0fų)\$6P4 XP5j4Nא:cL 0HZ(;h ܈dCPJ7C-Hl7m~R&R+!g3}b`P&'HD2QJt4#;cJ΋*}k~M̬YrE/%#x3#ik3)qH67˄ⱃ\n7(Cc5MP4Ö0؅?@|6*@!bSؕ,3HHۧ7cM퉖hܞ3i\r6bD;֪stjS51#*j\"TqΌ \\ p@7@2D49Ax^;rIhAr3<5r7vT D\"z>H*A(R%HK\r6\rH@ѿ\rʕBjJO/G4@wT@:/!#@B@PTjRH?c{&Z\r d\na=0\"\r!)?)؊,    )3Lk!d\nc%?@@`o0q9HMBO\naP3X#:Gej[.8Vl!/U>V:4@p\rPC)52F 3'I)\0F\n)HA`\0ç    z2%PIO xY\"U'@BD!P\" E    ~#QA[\$\n,P๗z\"4@aBԀ2.VT\nCi[A=|YL]_!-    ~.1\\Y5LLxF!ahDeLSg\nѷ2VPKQF*œ80eUYpA\0bLF\"%ԟ\reu)5\"[ Ղ\"VBJpgr<ŨCHC\nb;7\$L\\sgnRUdxV8\$Y!D0 Wy*>FSP\"2  E+ă  rG\$]ItѨT\nA\$#p鲆UD\"G.j`ẛB!L\$B(V8*4yRMǶC  \0AóJ(JPa0Cs F#BU )qv.ݔg\0I}[^]Fpjn15AXJR\r h\0̕NreR>!()XwrHĜEaZaP)6{(\"N2Cf}c6+0\n@ӔX@\\#) =9'c)2Aەц\$V0u3&dBPդģBɭGkWIlJ\rV.QkBXQVtSf(]ڎŪ9:H-3UU&ZQ!'\$6^XR%sY|Z\"/~hI?vֿ>/Veko LPׁFG;`qv=T[_&^Ay՟)J@y>3\\qZ;-\\i>p[<tr[/}L2f_:D_d~:D+i.LoyǸՋYsuO\$cۮd㜻8w.qK/}߷{۰ܽ kj MO͠B    Lv@/6O\$¼zǮ ה{U}\rE@8x9Wv(N24(Bp]    :Nsg!g0/=KJճ{P5J7ꂅHOP]3F/~/kঞ?7T6wW^_&avo8\0/hS+\0 Tp @P,\nmHj   ,Q@fyʾ_#ȿ)\rLN6-MbheF\rŔJ3sBIY-Yi D^.'\n\$\$ k\r&IGHALNoJPePzXi +ffzV 1#Qdee#*iF< ļ̽D J7M.=ij0|B̆`P   [\0Ƚ0Fjd&\01.Z(B1@۠ܤ2l!%r.*\\\0<&''.H``&e\\Db)i\0.h2=\npz e9jh\$ \\ \"j\rګ`jj,    F )\$C./cR 9\nK(B!Bl[ #h:Wd\$\r*((ZL_xqU*#L,t᭯fiaЧ-%`vj.ka.l423`@.i/\$0/rE@)ނMLNDrf\"0N95%Q\"`B\0&4H72`@\nj sf2*,&OJZd 6 ]R܎\nq)\r8jL.䰤V`{4nY7@7B \rNq²B07X䒆qDD-  \0t @\n`";break;case"fa":$g="B™6P텛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\rZUsLv4 K\"[ GXU+)6\r*>n?a &IYdcC1[fU6 PH*|jڮ\$+TɬZU9P&!%E2z'esΪ 0r41\"Ȉ=  P?:oR@ʒ\nҤld,\\bɄ#i4,ZMCR<1\"Kؒ6`6p@4\r @:\r\09\0(H2*(W;3d\$jBŒ*z3M<\$kᐌ  DSWȵ\$ePiUPLK , 81;\$D#Yc::0/=R(ڈL\n`D2W~b.%}z/̽MShWmai*w.a8nSXUd,h8wX&B9{簈\n۪x<27άL:wĸ}8hyuMmBQIkC6I)D?숧O4k@NfzDF(V[A&Q}i\$B%mUH/pJn϶mlrrFs)+\$<U[;!bI]ӠeܧDp]٬96!e98oKy}WU%6dn,JlYC}KƘ 8|\"wC\$t@r  p` pa P xr D@ps\r!7D 2 n\r`2vj\"\0|V-ɻAHUMa@0z'5\$pI}D̘j7F+u4l0]7L@PhI4-( Y( Fko.u'\nA4NS)%,(93+(5Fs_; E-dieوwHy\r@ҤpoQj`7)%C A:P0r\rW C\r,1ަ'0u@_W@tbQ+UzE(Nl?5\$\"\nYi\$50nI}+M+\nƣ(ӦwKPDCiLXI#3\nخO|-N*\n    8PT@-j^i( fLTXW&XD CY-}-/DDVh R4=ͤJ\\wQ ث>,x+bU,Jݪh:[4ح  %H-MfJнzeҁ4vmh56+b38 G֍JHECEq(@F\$\"JchDbG!\\AaC{2VaX֬Ɩ\$-d/&[-K՞j#+nݚ ؔ}kWt\"*c)uu'ua*0    Xbv*vV-]-yd. ~+\rAS>f b\"eu*sf8C>Q4<&3&):\0;\"yOVz4y&͡\r'-;Q`{9f/I(s}vZTW4?ua~y9'2^r2uc#1q\\\"jroG</jWi,Gfgf2:0<QͰ)ZHJNDM%kU7Zh):pN|SK`^+k;|U^+5B_\nXycŐ>\r%\$ K3牺aW<6y#,i7;z\\9JLn@4]@(@ \02l.|tNYrŲNkPVn[\r̷WnkV-FAm4,ch39=Qe^rajR )jh2h/M\\zY\0MaM0fSO-҉_Y>Rāx7ajqWo,u*ڳK8!lc@ DN1   d\$8ʮHfn\0ff0t:,oUK69P,p'\0g\nXMB@~#!D[Jf(p0P?/H8cP>Q/-:ކzM&4.MF*РD[GP8F(:n C/N9.Pϥ\nFdpNU0ޘpnЦeJ PC \0[w0q(ɐˊB*а\"g̙PEgx>Їc^cDzQdP7֪ ǡ.Lng    Xzst^Gd I`1-:EV3n)\07^0/\$/Ӎ\"nE\"'QrM5.f@@ `@i\r \rm PJ܄@Y6\nZ7^QE-Mc L¦'/ҺH7~\0a%L d̗lڰv!+ZiD6b'4(Nت%h\"VchbV&1\\MNLʰM2Wn댳i3.N䘾OvC-2ί/rc~r޸*,i&15d\nn4X.`He^b(%k\ni\$,obGAR,.p[^͖ =n/օb%jDÉJ@1Vrv.X2{jB߱B`h̑Zm*G6eGo8";break;case"fi":$g="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ٽ[ɧ@84P:C4P߄ > 4Ct6!'mJt7.P P21`|6%-%k(%r`AAI&#Jl 0[n\" 79O, \$%x8#\rcL #hSC@2(h(H)4BP  S;0m:7-X%;+m:*ܻ\"R;HKY 5G#NZ\r#89 ;a82L3?8P4\n9*J“ 5&*\$S(2ZZx6-L&\$B Ew::܃    KĉP J@00,؃ q.XL   CxY ~Hi^1={h\rXX3I(Z\$T90/48@6@8-`έP `8j 7'KB4*վ˴O(\r\\ZycRl@ݵ#cSꍆŏ;o*N2)#qY4 b#S p@&-.6a\rSx:kj* Jj\$S/;([g܍ Alj6ήJBLR x\"\r\080t xw@ xr ༻Cq)4@H_ D |\n0 Q҃\$mTb) 7eBL UɤT0R 97jN?((\0\0Y?2\nLXu iTUv9%P]6'1l\"LU!T~ id&(4Rn=fR*HC`bo!̾Y+&5KrHO\naP9&) &GO%\0BSn 3DX#0   &I' /!\n9<P(dA(*\r̰PY+%R8՚Ab\r!@BD!P\"@(L+@9< \$^)V\n8!CT;?4rG,\r\nj9hٮ)\$\"fY9UtD\n\0Ke?JKZgl۴v(*9HEZ̑u*^@PCGmXA0 K\"I2x~Yۣ)GP\\R=&SqnRѪ8nM^HkeJͬ'4hei&TR*%Hm\r- &ܼ#bTtdK^(4]y)f\"\"IYׁ\0zOx\n    <cT9k\$L:8);B0p\0PDD[.#\n!@Q:uhdS<H!;xIzm;\nA iV`y@J>4bvNWrȭqydӤmɫTY+o5Y21SLB>F4Lr*?Bu\r:uuEJN;i6#HH(e#@ߠ4i3#\\07r |0Df.щ>t8M-6&uo )c]EI湏4\$n LZT\nic(.8W\nچ.Ȝaoe[`_9)\0:tl4[w _f^*|: 9J eB.9`\rLbi>\nt(PT8)BW#[V{ILd}KV]a9-o70%xv(\r׹d5oɸpP=^g/\\v82d'r8    S\nOyGePxQ>ktvj\\ߜgy|ݑIwZr  A>}w%`̠6Bw\r>Z.D]%Z),<w^k7{SױR2.%տyW-ۯn*5?Z]SC\rnDws/nՁg3ff\ny\"`\"iH0l.rt\"Xn`lΜk\ngϏ0F>\0X%b<k\"/&Xo^LbLN4%\\\\(&Є.\n/\npH&Ϯc\rp #\"*Bd(a D) nD-f'o \np@Ok8 \"\$F0дl 5c nDϪ.Hgp *    v_pPp#'VG.Op]\n\$ ycDDN:~g%@\$QʠG`cn<(0k{d\"Rπ\np0h>mLj5J &w%8c\nc5 8?vD(#?V/cX5ɼ6c,Vdwc\$crV1g^hz/ sAHhf-Clx?(r4M  (}8.(]2D\rMYPR/    )]P\"n,]Dd *ԂM18k* Bϲ긔 +BD`n 1r\n^Dګ56J%8*)~\0001s) \nDeLZ-\rD\$FKb>";break;case"fr":$g="E 1iu9 fSi7\n \0% (m8g3Ie IcIi Di6Lİ22@sY2:JeS\ntLM&Ӄ PsLe Cf4(iƓ<B\n LgStgMCL7j?7Y3:NxINa;OB',f&BuLK^\rfΈ9g!uzc7'z\\/;{xkG',shyf3a}B6\r#+ c`N%\nJ< L*⼢@*#((7\0P7*zP݄DʁB0es\nKB82##q&'   \n#eCt\nhcSQhF,Rt Mt+\n#s&t|1_\r?j쵈b»C*<\$B\rŧx@%&60)2O3;SQ6'x\$1r\n^P0zä2&62t.2xƁHKjZĻgº\"3qC\0͕#=\nW\rd12X\\㒸 ٤c R\r*vR:,1I7C)x2NEh98T`vPy%\$_Ύ^obWɊz1NX7OELDIZ# v& \"9*ɬ(x?@5[#@>#舣Ljz~ 8NN>cF@=3FY:4%z§B&<T%7۱s0T=\\+(Y\0e)N\rژHݎH>¨d'P}[V߄x#'f[t˹.'B5\0)B3ڲKAJXʍ7WY)p!tC*\r% \"#  -=΂aqD,Rs}LJ\ri#%@5uA=\rT3D\rp` pa ؜ |8bhhDk/f >mA/ ) \$̧d\rQ'\$\rY;f H s9P(X{!Oa;t3L \n (r\0CLW`s\$!rc'̼7LҠFULBXCkHdRdɒ/3C:&y2ii5& ɓ!FVHəAI(fDc(DXqYAmnU˜T'. N!j:>OQR63j.bt'Eb&9.7 a|2jeu\"VɃ*N%t#I\nyTĕ^Wf&\$\$u L!)^“   j\r- \0U\n @8 &ZL^'b:\na\rޢtRc ;'  8GBGaƶ3\n4RՊ&:\raHd@9aSE0\$:aAX%:}N84vR/lSHGdygdBm5ŗ\$Uo6F۹(vvrK>\ny WR頯 9H6!%ܞ&%\rR^IHs0fDjE+gD\$PӐeZAR\"r   G0a2[y9g@s)C\"Xc Q|eњ\$C\rt™̄ > H2U]%|`+oS̪x=?RVn~1rpݏ83(9(jY\\5v8\nb\$;&\nnсѩP 0)AR:ld9Aʛe Xd9i\0^4* m-MYe I MHc1%tGaJM.jӢOMVWGvjN3J:JNHV3!g/[&&wNm63oKL'cm%ɫ+)knw     g#Pi˲†Yl5(#\"vlXa\\2-UU)>jXɱ3>vA*V'bB       lk1bNAW]s0'TkbK W&GP=1SZ(K(>N;!f=OS~?Xo\$˝:^'\r;\n3,{Inmr\"Wpt;xWOqj75\\I>@K^aS2*%\$7b|5  @(4`خ'|lk->+ױhvsH[2hV[{OW׈1\rt5wI羿K2wM}V]0 ȅ͉xS./Q]N.I̼\nO, bhz!P2ljn.\n/P\$u\0)Js P#RGh.L`NJ   HCt'uoh\0vn pdh /8=̳]=|EY`s\$J\0p?Ād.dŮjLbXPDp\"X#;o\r6%&ˡPJOn,Q*Q(ϓԬQ'QF (nP%H@42\$&HRxPo,aяHo\\DƘXf\\80抣ZþWK~f~,q]\rcc*fdbidf̏|fj2q!q&q; 1>ߑVq1RQX\n0.4QMF&@rFER6`,|1OB̑!JTǬ%#js&x r%~DLˑ6ZME1   E&ѠҦ''   E:z Ǹб!bFn΃6dѱֹbu\r#1v&f!3G-+E20&`2\0,@j\r&l5c:o!'/!-꺰53:dH3 Z\rqo-Z;b\rԎcidp  5őI4]Y#1*c̔\0E<`[5㈙Jp&`tH\$1Xu?\rOVE3>E;nl)S3[9;)׫J\$T%\\CB3BpZs3DSC F'8;f/1\r”G#^VLB)j?֦VLbCK=D\" *F\n% @(@ށĚ 1wBú:+ V\$qfIHp\nfnIKL\0 ,\\ ԓ*>F@u";break;case"gl":$g="E9jg:P\\33AADy@Tl2\r&a9\r1h2aBQ<A'6XkYx̒lc\nNFId1\0BM  h,@\n FC1l7AF# \n74u&e7B\rƃ b7fS%6P\n\$ף]EFS'M\"cr5z;djQ0·[(p% \n#     ˇ)A`Y'7T8#DqNJ̓B;PQ\nrǓ;T(^e:3ҲCIYJ欥r *44oꆖ{Z[.\rR8\nNB߈c\n߈NQBʡB7ģa`P4̔5**DC\n:,p>\nRs3 jP@1;@)\"Aä H1pțH(M*h)\01+S1Dڎ;h:HK~&j5-NSsp7Ș31<HKYVEQ#?4dB͌N!>4skWP\") \r&` p t̕1māRtPbc 7 l| #Ɵ*t #(Y.+R\r4R!KD4܎#'l+'8@93A\$\rCUJ(HSmi0cr\r^Q>ʴwK8L\n;3peu{Zk}\$S^0I\nV0\n\rPHӵn: moi^[ώ\$x׾b#n6CAp@\"1[U fV3/#k=—B 7߱1&˹O>M_k̶8|p玽Px C@:t )@p^` 90tDM@g^/>gʹ^A*Oa1kAMt   A?!`h\r`@\0<eY0\rA\0P  @\0(*ܛ¦;#Ā4b:(}^  |a.L(]AP@<=aJ\$DЌP&   \$Ci^%,%`0ؓnKlym  )U86\$(?Fȡڅ\0£'-t,sR:}fٯ\$z1|͛ !k3SΆ#~PIF+)|i\$I:'P\"ܑDJJ̚Q/+cM}I!7vy)F'\0R+A  \$-BxNT(@-\$! A\"J(DKꪧeP(HP\nBdmo.BQO]biJI+ +\$^Y&5&Zn%V\$ˡ{.8Zi|ǝ9]!Gy֗\r1\rQ_1:͚reDV̔IH謪C'鈒nV)Q`tt¥DH\$S@8нC}*2c6LxXgMcKq80\\'iX7veTCTk(فΝԀ\r7+o:\$]2%LJR% P\n@N׿5xdsIy\$4HkҒX=GsДiY!V&_Y™8`(#;@XR6i<tSdZ1Jb@E@ e2pgŇ\"_^A3ĝX\0^T hILtϠR2 -eaV9)lh3[~    i Ʉ\r/!^(&afDVXKN:P]nugF\$ʞn3rIg''Wl!`r>2je>v ݴ-I8PYרUehYJ*IJXrr'     1 ^=SHK„J%i   rq1C\"d&{z\n_Wοoade3{}j U*M1ZnGkF  DT9DM:cG{&|X\"+1 !JЯ弾@!ܹje5{)2콐W^e}ym>bc9=v\$wm=WxHkd]ݖu:IwWrףFSNLC\\.SlO>ӇTǣo%a٪=Np'^ %1ka~^:,[AÂ,dݲ|3PI|ts\nC{~T.48KN^C~ O}ټcdmMB\$\0.p\0T ƍJN-D\$y7\05D2.l:lb`^@dֹCN\r&k=F`NsNpXk> ?&bR łs\n(pNfI<>> \0Qn9Pd7\rg\niopfGM 1} >/1&Ŕp5);+ -0p8\0d0.\$%JIجjqvD\"h &\0 F+#*GC18vb)B#w cѬ`sLbNK ߂VO,wސ/FHH@`u\0Ɗ%تPAC֢fXpN\nZ 5K,##HUB.#\$*bBjdWoe6#I\$v1ħ\rPkpnqDOt\$0J3>('E:ҚbN\"V\r(|%Ub0n?@AC,,˱\0n+j)˜Ē.RE I%vʻ\n㪚L.12.[\0}\0(H\r#،½OT;j6W+bd1n2Klh^!B&D2XE8x\$f)Kx+&J'+pQ5C~Qe7(])nY@+";break;case"hu":$g="B4e7P\\33\r5 d8NF0Q8mC|e6kiL 0 CT\\\n Č'LMBl4fjMRr2X)\no9D:OF\\@\n FC1l7AL5 \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:)h6P5OaizTVh\"\"@\r##:1eX #df=7P2Kd 7Ċ+q[95t>6D0  IC\rJ\rPʬBP\"=A\0BH86̓JHЋ!T֊b9;cbJ5Lk'*i /n%TU#dԐ\02h:5tW5PٿKp11 ֜ :3ho9Pp\07Cb\r˛)X\rѸr*\rGLR0)X#d0\01#sE6~6Tx O((WPr*j1լ^fI4Pl^_2Rn\0P64hiCȽޫx<jTN/k\rL0WPhdN3QGx3(Rock*\r~0p:c\n9,27|0XC`3+AWj @,*l)ɀ7nlY\0\r%rI:éBnnh0L22H!ɲ9Ψ;]\r^ A9%r2J2w!b4)0z\r:;P\\\n@rp^B xx+.4@^r %>j)^A2FiB2taJ#!*^!\$2qpT7 !W;%h<Pn\r'Ǘ I'xdܲk(l:h(Zs o\0\"GXtT,Qiܝpz34rw*q|0 nHy42#S\\R8aJPfD2xF jJ<J\n Q1 hLBO\naR@BU]\$93TW)(:900\\Y@sUy-0\0nԓd&4Ʌ  5И`j'd e,xKjO87 [bÞATl3J:4x S 1\"HU,>((pZ IPX)JWS&eC8y]eݯ3=g͑N}\0PLщ7(.-Gӵ)(%=J   b36hfYJ[xF; f,Y1 X3Ǒ4\$Lrq(Yb[鬳yѺ.jM))T(™ (!TRVO ed2UZ۩y3nJkj`J~0;9'uQUe(lJ3lT\r%T ٛؖ1=l\rrd.\"ǃDZD    ag}Ig*@@ j)V)QH<ͰkKvy_WX9+s1\n\\f2z-β>-`j\$rxr]&c\"[\nF&|R)x*ͬRP\\ȹ#a2\\ɬ0Ôe;8\\xes6|XayL7yRɽ9>TT \"QH*˶eCR}Pu \0:\\_K!Π\0Cӡwبk;wkr LsSybr-RZ!>K>tm+BJ!%a!Y(Tnl{S{>C}r炪@kW_?¤c   ~oD6HᕔW0L((j h ZM;sUK+!d:{dx%-Гt'E*R\n\n4\$tkA>3C'beHƘȩ\rjҭ n1+k*{=fT:xf|Ug≏{pڣpf   ֻDqZVTY_Be ރ?漅͗>yo1t(bz!DT7<߁v<?^V\nG^ܬACJf vnԽc? ש052cEJApɞl))NCBCZ0 &(溱 鄊P EL'.6Sϐ@SݰBz璹Dďpj˅o(mZn?\$CoFf+KzH6<!\$*j<:Bݥ,pq\"s oRoBАY}   )T\r+20 EElPfଣD9D9b^N<l#0\\igo\$AɲeLq4=۪h.\nfq8Rl.f7Og( kGy+qo1F\"Mxڪ¤Iĸ„ǒ* &DB&c6hM܉>ꖱ5nb[E| 6b2 ;2z3*!c &jVȐpȒ6!r0l%}%OtL%jXЫhRiv(vi^Pr&Mb|G4\nZ>/.<m\$*jc\"Dsd+,,nS,p#@\$BH\$ma^&.F#+2.tMC'0#=lI0INT\n\"z&7\0bðTaf l4   i|Vm\$Nf~lSَbb 8\"dmF#6`ߋZ^F\"|\"7eR11C6\n5H Xjs~38c\n\")8ă   ƀaD\\{N<|Ā( \0 `is: #?{п5eH@6B3BQ8⸭&\\4=8 \"»?btAAs6B\r90\$F:k0\0@\r";break;case"id":$g="A7 \"Ʉi7ᙘ@s\r0#Xp0)u&r5NbQs0yIaE&\"Rn`FK61NdQ*\"pim:d3\rFqk7Qi9 &ȉɍ)\n)\r'   %%y@h0q@p&)_QN*DpLYfiFNuG#[~@pX, '\rĶG*041#\"E1SYάnѥr٥@uI.TwP8#;:R( 0޶HBN LJ<(ގBCH\" #298or\$P(@0~BT4Ț+ Tv\06\$t(:\rx\r&)\"b264-29+/TP*J*׳n75C*\" 4!RR0B2@3 P3LnlH#i!\"Х-4!2ڿ    jꀼ\n\r-J3R8P): h4\0:C J˲ڒMKi@Ni 5Ȅ:(}\"0j˲(3,^2zhy\n;Ym1\nw08K@6B@S&,3 .X\n{-\"\r̪Ɨc06Vx΄ab9c\nDK)cpRc6!bò扅\04l'#2ܬPc Qn\rZ,\"Hd4#;Ҙ<`hɦFD49Ax^;rr32<=MH0էXDI^0ϔ(JRnfԅv `1pj̾=b\">\$\n  r \"r(J% ϡUڢ\$Bփ|A|qr*M4#y\"(\$cIS24jhq`\0A P%:l-&Nb0g@'0#a&d4>U9(%,\$\"M <H>0MAmM2(Eŀ@W30    8Jg{\"4RL'jO9\"X\0cV(ܶBxNT(@(\n \"Pd\n  \"   ԜR\"740\rʜ e vզCzv\$ltɵDT ;P#eK9tf'FBf%\nb&z%.j|DxNȀV1)Ժ2z'n1HPc>/}t|M\$XHy     aC =z^\rB c*eVZCi5D^2\rZDUAMdPZD^ dq-x1ZQX%MA ڻBN^P\\΂0-4G8˾F'qE@BH]ezf4Q֑^ý@(rrOB2ޟA\0/\"t\0\rPMbPc稊N\nՈBY\"uiI8?7UE!8w\"TZ|MUPrjN*ĶUuǏprߒ.Q@#}nw5)6,[`R\\CA/㕇nmF젿Mp_0MxD   I.m`MVxS&zv8 U'#fY&.rIゃ\n;ʖ;\$Δځ&%ID   Gr.75H_1#?j2\0J\ne\n䚓kaɷϞcZ'bN\nE5fUCN-p\\۞2ksfJ36sg|;fw@u_*E\0?ݔO\$Yfp LNRl(ڎk3DA4Nkャ.'ؚ})(>PMM䫥VTG6rm<8UkDvyD{!D\"'%S^]'r,N%`c)o?<B9/_!5\$4V䕓*k&͜o7m\np-u )+'ps8L?O/?Sy~Ɉ)wT:3TPCqMK9z';4*O2O&,;Ųvn˩;]Sz/~Oujk58+@GsydFuKVCAUzEHkb]oVURˠH'zʻ ֹ%\r    W }A-q[F6Hfc(eFxi,*`Z\0@#<%*-XbDe\rޛdGJE7;cXS7F+,~#~#i :Bcnb 4P    (CLpjg2f\0b6y*FP\"-ElpU    R+! PnВ H f8Be 1,f`lFTPD\0Lʬ\" b\\ZjnbPj4J`\r JI% C.c\n 9.`X`XDp@vUF&Ш9G6&! Q22iJWFQ0(D.JyncB*";break;case"it":$g="S4Χ#x% (a9@L&)o l2\rp\"u91qp(ab㙦I!6NsYf7Xj\0BcH 2NgC,Z0cAn8S|\\o& N &(܂ZM7\r1Ib2Ms:\$Ɠ9ZY7D   C#\"'j   !4Nz Sfʠ 1+k33 \rJR[i\n\"&V3Nw0)ln4Nt]Rژj    iPpƣލf6ʪ-(B#L Cf8@N) 2 P\"\0^2Óbt9@cu    0*ݯ   zԒ r7Gp6    f:=A<4/-0\$\"*h7=<\r3 / h1\n/K`*sMb/r;#K8 Cʨ]!\r\$@ 82&!KαÈ    KRHc3Sc@Q\"\rLSo#܇CpȌKBe?# XQH0k=NJF8:O1Q0QͷJιPͳ,8- 9\ryк w69S \"   3 Δ *\rĎ<l@10\r4`0XAR2xRZ*b#)+dZapA -l`6&4s.JI 0[pYv7w 9\"Ȑ䚦)]iҨ931|cY*Qx\rC@:tLoCj@ ^5<:sŰ\rXD`rtv}(rB\"R<v B3 ;hV*?h)Q Đjaa%ӂ\nI{Qjj4}H p? 2 dvOQI!aȓH҃QaԚF! C<1j\rS3`7򙠠i&@'0ւ jFO\r7>Mzmḏt䩡K6rށ0-RSZ R\0-&+҇Ht\"XCI=-\$\0r8O *\0BERh@,-trH qȉ}!.W2J0L(D ([Uz\ruOүI9M'ki-AEڠ\n5FN\nh':eݷU.y,]L0:\$Tܙ܉\n\nB)@äk\"\n    'z\"FܑJ Qij-\n!0Ys.Q5t:'\$#3:>r^Jl Ah` *]i;40RL(Su&QJNԆgGa!\$8<gRuxB`qk\rfe#,LC4\$#rY7rT\"g䂍^)C \0?\n!L2S\$\\I\n*|\0/ J`ᔁG,0    -4[[SYA`hm\n[‹l bZ9m-iJ{ u\r*[sx#spvk[>ӛJos(8A\r!Zb0S=/v?lN  %(p@PW \"F.5\"&h!%KMɶt=\$](II8>d<l\rfu#ȇC#rS+qRZLu ʱ66ٲB& mW,zYw!:H \nRkgw039!C?ҌZO '.R;YY[:)TI^L@la69:Y j&bq#Pufѫ%I{*,8+NveYmJ&(    ՛1Mv]<m*ڷYdVX+0WGXdJY{GͺddVڌ6hK);|oٜ(ˎ6(c߅\r-u%3x+1{G;|a\rwd7(7hΡqUڿhm;/Bq5[}fml5Qj^&q^jsQ) YzQs\nH㋈   \"C7l{l޳;H;m)G7i<2x: d:,U)oB<fʿo=7m kc4')ĀQgTG׉hM/pׯbh>.t?x\nߺO ¥g=RZ=vt޿uh cA1gQ!WG-Z   tBDf*2PTh*\r&qbˉ0-p0, j/ƊhB..B0BI#fc+eˈ)C0fjnPĞ\r\"Z= 9h *1HBg0=ɾ*e\np*\07%f B`&Hk#܅,c&jv\$Nm/jClg\n\0Dz/#ZEĆ/d&C\r8]˨_`#bB{\$b\$0O#Nb,Yd!\"Cn\0003hߣQ^~cN},\$V2,.vu@G\$H!Raͩtx%WӏPbBk=#..\$&  \"\$K \"@F񸗠-ėJ\"Ho\nqn`ɨ\rhIbZN +:2\nXCЫ`XiD̤@   \0t @\n`";break;case"ja":$g="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~9 s=(4>rt/׮TRE:S*Lҡ\0U'(T#d   HEqE')xZJA1 1@#9򬣰D   sIU*\$ʨS/l _')<E`.Rs<rJ8H*AU*dB8W*ԆE>U# ŽR8#8D*<r_aETIB#d+lrjHγA3>%ʨEYpEu 6\r2äFV 27m\nb4Nb9=Qd~Y@=&\$'16Z/%uo\\I@B]D+@1\$DsHS\$CRR9hQ9vs|\ns LS)*q2\$o/\$Y+xB06\rے0h<h4 @g9+.`0A9+ed@NR[Ѭ=sԩ\$<omiZPTWF@ÌjQ%x{fPNѡ`\r4\095x3\re%^Q4*\rx۞!\07c1#͙`3#Xݎ]3/A\0P9.a\\1[\r%P)B42ar\0@ h@|= [%\\%D}2W)>*'ALkT-܃hu~0CF0Ò 8@p :\0Ah80t xw@0G(rР3qw7^r7X\"ZUnA/ ]Я\n !,a]HW+*\01`9&'\$'eXߪ(~?zrBC\n2 gd,(PZ\rAE  \"\n&h\$) \"cU\\4om LV\n#|BG2c\$L0E^\$@4  п1> \$ÔQpu\0E˝ `tr8:\0Mʺ 7@b3g\\\088<NO\naQ,   5\$@#꣮5D.HEӄZV3\nFA8inv7W<i b@6#@V]GjAYI5q(A,:D}mBvLJ(b<'\0 A\nW@(L U (SZǗY\\>WЈC0afj;@CEM<6{؊9\"!HPD`8>㚺uSTyN,ֲυWo+X\$~1:[@LXM\"YE8qzT%(}0uq-0HE|,!W  :% )UTxAL箵P0K;=P(pz)Sld=QDTMu ָ[)IcRKH8JVKd\\}5\0lk)V\\\\ڵ͹?&ey\\ƵDlDq/ZH/\"]6^EKX1AHOֲQZq@@ \$4<\rho8V@ C,EVGI0^\rffNՊm7r1Dk/:>EhyLIc\naLy]L\rx@~w0;WT;IQJu39H\$XeXBBSiKhHM#\0PW 6㌘-F:s\nhJ+V\ruj\") )0V-@\0i v `˭vrOɹ-v.҂{5zpXu-ˑD}@G m~zM,w~{I頦wz=\0KCQ@u&#y?漫D,daxW2gJ^SلA*ʑ#Fq^4rz{x\\<ro%\\9ŵ[/5\\>\\:;r89v<rmfCa\"ς*m-\r Kp\n[O,%%*׎o#촖i\\N\"NN |\" R δi24BΥO,0fo\\D#:F\"0|0 iڷ<Lo=K^*m0Ce[0POEfP6P&pn˰iZ\"t26?B\0Ee|0Vj#\0/\0\n/а }/lU`&Ḥ\r̦\$\0\\l`+%rG1yo'LG!cO1t#QEd˱q8u\0GdO B?\0  \rGDy QHq!d}!͏C.p1LR1#FI\$I!V\\I`\"x*Nr6Ʊ\"1W1`^\0EbnF.a0{a)!~ؑ+!x@\$u&2 \nvD,d2-kE/g4\rV `JvE~\r v9%xB@\npp s\"<Cؐ no&3+:,Bkrvt,   #2qC1#&QTo%8\"2m@'- cSڅX8/!\nj9 nsGngch°kB0aeS\$#)&2S=28\nnR5s8\0\r'ĭPj\\W\rme\nRa9MVTʳ A+EB\nF3Bz8-8H@\n:\n `:\0_drJ\r='(bVoæ\\Ā@SF[-\\%*_?,L\\4\0@tlHD\r4qB@6G1qc*JK;&hTB0@";break;case"ko":$g="EdHڕL@؊ZhR? E30شDc:!#t+BuӐd<LJN\$HiBvrZ2X\\,S\n%ɖ\n؞VA*zc*D0cAn8ȡR`Mi XZ: J>]ñN,   v%q UY7D 7i6LS: h4NP +[Gbu,ݔ# qO){M%K#d`̫z [*KXvEJLd *\n`J<A@p*Ā?DY8v\"9#@N%ypC0Ti0JAWBGYXʓăC\0Luʓdaڧ   ,RxuEJ\\NȤi`\$&ɤTEA\\ve\"gGYM'\$!e,M3Z!\$E*N1u@@x&u%+K\"H87#h7AW8x8^)\"`'\\4MR:v%YYaz0g%RbbRBHoAdÄ9Pv' .cA2)TT&%JeX?k5#IQ.A/& (#`9@9cׯiT\$dy2vIo;EXtviRe9lhtiO-ұ*fW\\A16dfL3I6UEm GvhJC:]׀6NԄ׍06<-JR3M`P7CnL<9c6:\rxac|9t0rk:@\$]df!bqXjYNviA&/Ό\n7FFzt<D7[&#a7%nCp\r.,2=PxM[ s@x< dw2 ]C8/U<WFCxn#v _95 |`eU\r\n\\+0z6pBE`s#Ad<R\$H9!\$(h\r/4@\$H Pr<G`A@X!,*C~T02LNY ̤A2& R<Hȼ h\\=? 7I#@ҭ͊WA[sXqX`h 0\0cuzA@'0{VMQ(XVҸ4Fp7ESJyQ2xv\nCPBh)Y'AHб|AWFS%\r΅VBA\0b\r!+15`2\r*1C#2.XVp \n@\"@U8\"OA[O*IXLu8%pd\"PX6L2/D\"`v}bc_m/eDYSSwgruy8M @'%͞+%S]v0?;K\"7WQAҤYRb)%h\n?PsJvHU\0\"KЉڏ\"eY\r!22L2qC!?u㼙([JYme6%*Mr\$L,mi޶D[+LvRcL\rR\n >oSaW4b%8b`(p Q\"b(PID;\0{I-Զ*|C   \0aBPoK6]IC,\r/QIG /@1yVY2A,F.1Жi'qAɲ(贾6ڦEh4yeٕ%m  4    iI\$.vJ+!#+LU,.J'%d}e|y\$\$K >)Ji Cw\$P둦0Ie!RD3)_b E~   2ld̩/Ku0dcFHJDi-wnաM[ۘߛc\$q/NWI*}\rJשiKN#0I|^_&|’NN;YU3#pX 8m!aU%&,VO61537dePt6WtXQ|eunҩۇ]ZnϜ\r4ݳx+N%#ܤ-j    51:oݿuN/L(JEo<[:5o<>;y A홱cLFioMgy\n`Z\n+Pb<pJءLf,̓9R+I\0J!*5P 'ATÜ) W00SMbxu4ojF/\0< ~X!n*P.P.p\0&N<3BZ}>i úb 6=\$`]EO- T' :/f[pPlPP@lE2',TND\0:NtVP!A n̳,&H֐\0^>N 0 Nmr\$\nF<l\n:n\r)\nOPj\0G\$vM\r 1 FN!;pDmd    2žM a\0L*qHn 4VoDÐ{1aPAdƄem0ѐp&l@0|kEJCB`k/n^l V2\$=(\\HO}jb?xKaa))Pw>ް8( pi\r \r`@* j8:V @W4V`\"*\nZ\0@U\"(,3k@k21(p+8&61j@\",KahZ!fH20i,F2C&Ab,>\0i%   rVh\n59m`\$\"A`/MpDd2pD\\!Q' d0.\0@d,5]#\rFl&#.Ɲ4.<IMD\"\$DPacR8 V@ \r)#2fHm⌅0Yaj4R6 )RS>̺fNsqs`\r3dn66 Dʶ^äb=Ct!B>\0";break;case"lt":$g="T4FH% (e8NǓY@W̦á@f\rQ4k9MaŌ!^-  Nd)!BaS9lt:F 0cAn8 U i0#InP!D @l2Kg\$)L=&:\nb+ulF0jo:\r#(8Yƛ/:E @t4MHI'S9P춛hb&Nq|JPQOn3}WY,#H(,1XI3&7tٻ,AuPdtܺi枧z8jJ\nд#RӍ()h\"< : /~6 * D@5 Λ<+8!87ȥ[98ʕ(,lR)ă@bzk)1 #\nh5((\r?S4%KP6r::@AzKM;D9&;*H  \nRӶQbckx 2S=D. 6㪖C\n @\0\\h ΂Wx:.UG/45s8ކ#;a2\02͎c\nHҿ<\\\rIR,:T2Qm{.,,pʀiZg\rcVֲ0mnٶVPЄH1CJ9;`S=tx LaCD\ntg9ۘ\"RR0~\$LK6Hl8,qX\")z=VoiKٌKu\$Ccʎ\\l{#2x3\r=eL3ދ%cp\r1:ą>H9 ;7'57b(P9)\"=b#PHXLi+U夂U83@%.i?N}yH\\ipܾ,ٍIK6OҀ9t2|^8<D!`z@t9^ ü29 g\rCHo\rg 浆Dpc|ShP,`Jp콴\$H\$ !uG8aLb ?ڈJ>]Q\n (%\0\0:RY#eԷY{@`(+'%\$Ȓ`\rMȂPE\$jM_Z@F Y60Pj0q}>`\0Aߚ\"PԒ\"g P~>¤l3/l\0ɠFr=/O͓LECpf,p؝N\$PQ+5X|.\n\0#k>?-lIp\\ƌ!\$D |-\nȳ>nm%.G4IbfFl    2 ŸT\"ԃb!ĹH e\$A>*RZO4D Q<)y+ r+&8GG,56+vy#%'AͶ[9\$h4Z1r{Ԕ7+°gFv2BV„Έ/<    N\"Jo'؂o\\mU`7Nt8\$ [[me&QfZb{U\"pt)\$2)nu<Bڒ9Lے},r]1ȾR#*Uf7^PKP8v\0\"]EE` j<\"ʒ<+\"n&[*(Qs7`n*\$Zf\0W3R(y!.ƪD\nQ!P*~p)VCZ%Ģ\$%*,\0^SVbrZ1\\   INͤFY;6l%٤W\nSFo({9e3Ѳ;64Qf6/P 9Jr։Ϛ0eCj\"jlK\rymVW8;2bv&o4ПbFKf(*\\?Dd]ب>|yQ\rfl#~<\\|T ;^Sa79&X/HdR峷t\nx>BᱍnAv[䓇\\Q5ڽ8~\"4@[\r/\$Dr3ѽv㘆\rRӺHa4a}o{tPЪSMM5;%%؆-H;Eé,h׬?ufV*#g+\n~߼gm\\N^fzIe% Ng?KuOE-G~oԫĄȏFK\n7ȏޒ\"=ϓ~w \$#5/o3i]lcDB:%I00œ\nHiK-7Ob(5,bjj,,&g# \r%NdXp@͜TD<T/I\")p?[&IFP5=0L(\"M,#!pi\"NN6c,KOFO -Ϣ<q[#\rblQ HSnY..\n~I\$3 ֈ\r.E(﬙\rXƥ  jR\rGx( ,-OQC!HqL‘pG,    J-PFfqJ'0 fnAoQF@Җ1uonSBX3 o2. qά..eP ;6oɂDzqWM\\\r  D:\"B    \" M(e\rV `DeOĵ;z3*\rWc*s@\np rZ:HM#\nͬeo2m)L\nB#\nGBmlUB%%\"#T, -^ÊEF8X.\\'}96w,dy%ĪF~^ަC1weJEcJī+_b+aB?B<?D((%4\rM5 `5%&Eld#Sn|DDH[FD3^h&_jF&B%4X.b    \n `\r %P8`-3CM<rF@db3Jj)ðxd5r3f`8?&t?=/J    >Qq )Dʆã\n2(/c@";break;case"nl":$g="W2N)~\nfaO7Ms)j5 FSn2X!o0 p(a<MSle 2tI&#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@̓!2C24eZ2I3Ȉx/+:00p@,   ,' NK2jPBڌ#H<#(桮\$\$B0b1TRI(7%;ãR(\r6 P6Ғf؍KTI\0(Zj#r'.CW9jĊm,:++øA:lLN#V   S\r)\\#5E_Ă\\èKXlLȋI\n)Ի\" |F0,FEZJ0:V6dIdlc{E\0֎Rv8ܞHK鷳<DS\")\rCkZxp4\nC,OS岆\"(8eVz20mt'905e:3U<l72s6(%\$:cH9îs6CN#(Ҩ2RNȼ),:T:˲v!஌on78ɨud**o,3ܗ)[,\nY2鼒#⿹k p4A0zL#txɎ⽎Ar3韲CJM8\$XDOs7^0-\r*}{~)Dsi|:<I0\0W(-\0& Uv#g@\$MI9'd:\"cގ#AǼ:8G H&\$N\"C\"u(3zC#r&2^MU\$p\0 -gpٕSb+1Eɷw\r\$9(q\"@g:@2Ć:(ex\n)%S&\"%`JQeȁr8#`^\n) J\0*GI&XNT(@,\"2\0PK?)-0vR!T\"\$    H@C0alD ;-hA}3~́''EkTgF 1l'VD]5\rGϦdCeKh+W*bNM ((Ƽn@tTgd4&IAP'\0TT,I:voJ6 4 @Ҷ1'2x9OTR<f0y</j(wvh4ɐx25&\"B)0\"Ps22!yr[I'dE#:XlO̽ zxJL\n\$:fУm@BHdsgs5V<fiE<R 2}`*dBZ\\~qN2m~Ȋn\rk':]?xnD4J* +J2\n嵛I!ag7P]umJUR|w/i޻\"ۊ\r\r܋d0&G3VKd/6x0& h+9IȆ\0AXS{0\nf8-<A7r[,FDSd   RIYNT>j*^lNqXp   s~l9\$}ж]&i7Gx+fܶc}G9AKgMW@γeWG[Iy= huQ'@]K9'cR&!PX8h\\ձV%2mAtsE[︘c i9{A `|.P{P׷6Ɩ{|.õ(Ka,؎//z,@zshҊPl BbXƃPn:D&^CNJEPB)dCB4I 6[1[ ӾdkBQ]Dm<~w.ն֝O䒞4z~v3gwix]՟ vi9z9p@vF)ZmjyoO\r}\0CKEՂ>ĎbYzc=e   P-˔tKEn?(wu~,ARov_~V]r>n.K(\0~3\0tbtH\$o#0/0+mB3 \nKc!bfD~\reXCF5 hsbJ_k4\r&ǥmTɅErJPL!  *o^&S`#B_c8M0ՂXd!L\092E\$gb`ZXNjB>BR#V%l (qB0#B#Br*(n   \n\r ̹R(I\"1P(\$##̪\0E|0 c6̍FbAHTHFL.JA˄hc  .BϦq1%}#a#PNL\r6*c8uF8P'J#4\"ţ(l/\"L]    ]m]!]fp*e 9nRZ#%.ҥ`TtZ¥;`JP0`?2P %bpѸ(bKk(,qڊ'+Z`A^j5\$:8eJfĜ`\"%D\\   \0@  t\n`";break;case"no":$g="E9 Qk5NCP\\33AADeA\"atl\\u6xA%kl9!B)̅)#I̦Zi¨q,@\n FC1l7AGCyo9Lq\n\$?6B%#)\n̳hZr&K(6nW mj4`qe>䶁\rKM7'*\\^w6^MҒa>mv>t4   O[߽0ȽGy`N-1B9{mi&@vl HS\$c/߾C80r`6 ²zd48a*-ʠ9b9oą-\n:9B0P#+r緫dn(!L.7:Cc.hcA7@)\"`Ґ%/ ތX\nʂ C刭KV;\r#(O-R1 x<Z.C@e  ȪZ5\rR0e.)n;- ̨E\0Pڶ!-L)lP܄BC;   .TصZ9l2Z% x %pJL8\"R:16В\rA X2 Pΐ{_|} (7| Ll\0)V\0~Cb^%w_3Cr>   #z00f*6/TB*9c5I0X\r¶0\$[aJR*ؿ.A\0)B6R7!\0[1rz f\n<؏(Cd\\#bv8:[~J7<;ѿȨ@88cu:%)Z9tK\0x0B|3Лt|1z z   L4ӡxDKڋ;_A)\n\\P|2034+|Ҵvձ9I^蝦pò5kD)).%̦.|      \n ( A5@YSy)eʳ؛#rS`S암^LL?ZDjSz0\"OB>(d@ \r7d>! A \nrbKI2icUc Y\r<8N>>2eI0gNN2OXiC΀@d&䈒H@S L68 0T\n5\"~Ta1D#R\" T@B_A8PTL@,\"a'Ȏ3AsDdHAX)pU:AطFIƨ^40ŝjuI\r}:Cv7QM G!\r c 6Qn҈c!0iB'l[c\0vdo%Ct㰃pv0QY:dzԬ@,\"ZpiYPHRCBe85=UD:ц\niO(Y9WIq1. `1\$&bޠN@e̒3Æ-PnlL!TRZM)k\04@PTh2*).ę*`g0ޞfrT! \$B颠Qj.PH؈d)|\\<(%H\0^U A.#\0t\\! }1nl'B]\0 BA{1e_kAL[Jei<g7vS{     ` +z%މҍݑHXVcfb   TRi!\n\n1d,Pį)X%    :D>vLkޔL(t8p\$T'x bVkAgI##sQ͏Rgb]\nq2}nsظYJ?5,2#`ɿ*졡#Isԇ/Tj9;9\"<O.,3Wtֵ~w;) ('oG   Ld&uJsvȄNƒ^Jazm2+4Z ܾk^7Vݲm1    N2;rIzs}Iy`=\r7Àk\"`8gbx^SZelS!|L1fǼs#3l   v,2++[V\0AUUw (E0Xi:O8Ee9çDP;fx*/;#d;½P_u޺ xפݹ'-Y\"ʉO{ܿ{>P&2S\rYyJ68bI&\"?_?Oex/| y-d:Jw˹PC#/H[~_;tܾ`Ӻ@2]9/_;>y`C^oo*&MzJ*Oh@O X+:8z/\"0c+IEBn(BHDd!/PB-?~Y 3+h;iD)F9k8)eJ8X jpPi=@KȄV@ЖVK!JЊCHd&\rV\rc!=<p}~   SN\$2ɪ\nRE~KL%0@җP0,s\"iPG.f46O.b`8C|H8m̘#\re   Ctq^:DE`#D0eѣdJH٣=崗 jJJoq*L:E\rg\nFѠ5‡C\$Bf2#̐ѰxdeP.v9`1#qb-\$'p._q \"ڡk\ne!tÔ[dќ:K(2Nh#\$G>q0\0'vK̭\$0Od\0\n dZ8bB\".\r ";break;case"pl":$g="C=D)eb)e7BQp 9s\r&ybob\$Gs(M0gin0!Sa`b!29)V%9    Y 4I0cAn8X1b2i<\n!GjC\r6\"'CD7 8k@r2юFF6ՎZB .j4 Ui'\nv7v;=SF7&A<؉vwCNAg\r(s:D\\<#(r7\\xy)V>2A\no|!*#0j3< P:#=?8¾7\0= (ȨȠzh\r*\0hz(   ˄\nLLX C\n\np\"h9;Ɍ3#8#z'(,Sr1\r704nhºkX9T\$ؗ\"9\0ĵIZ2\"5)D-œ:l\":֯̀\\9;ʹS\$'FH ȓ1chWurʎUHP:[N(0L1`P2Hz6(o87L# s\n1*:0H!/0R\0<v+ΠK!p(H_>4E&BH1 \rʽTX=UC&d'1̹uX9̉tNdB\r)) S2\r +ԳbSr^*uܹNYh6\n=.vOBP h*x3\$OmLK 4OVTɄAN# \"kxjZ5nX\\'nE%a˷1R\\Y    Y뫈tOWqG!rsG+\r}= ~ )Z b#O|cR0#56`ò]%ml66Oy6J!5ߐr¦̟-pk!~RFJ|! /d0=A:@/ː3 (x 5P^hr :C @0Øn@C}\n/\\4R!,(1ԔSOX@?D(\"u5!\0 z17\nPp9'%P#qU8(R^LIv]A` Z+j*!5B#[3Y ;BdG^i|\$35\0XyS@\"J:`\$\\\$Vp2rrAM䘚~üR\"VF E j ,\r8n0F2O0][}|)\nNdž3\0a 4XBpp^tHKP\$^R)R   :\$+q*JZd^l9ڒl6Lةs(v@C?\$j\$fApƐrN:\0o^i i* ЪKpÂ\nh)  't%i:at{Y4203j-(FʒxǬD\r\ra'4^/:WT7\0<ωb22]dXHoͬ2NK#!]Q\nļ1˒s P4_2(d.JUmd2L'4C-`4vD~!gfS M5FN<JY\rlhQ4Rd\\g2C(P+DbY.A1J`_Բ0'\$><PFd   p\\_YOݝiCr F3,ŜAA \")LhUwA@BH:Bڈ_\niL)jF2(G;y+5   2:|<<d))|4 `۵ux9Zu|\$ZRk|^V]m{ή\nlJ٭FVaSE\n68}}J٪pE?u-[z:\rh0˸4]Asܒ9X8YUX\0`~ Da)P܃/DXdȏ zk\$ep!-\$&]VR\nHaM\n      r\$6\02;0&\r AYйܩ}ON;1\$kՉKS!ԟ~SQ6\n4ۗZ0N!#wNۊ '!0iaoR5e\n=weHj[Ϯ_B[{>ӛ &|ɰc~>3ՏP8f,=LO)}߼m<OYxq~{_ n? ra]%NΣ=qdNFO\nLP`=ɪ7\0 \r!߭N 'Uo\00G펠/μـʹn2(6Xc,씫iGJɰϹP}    \0r&ǣ*\n:L`('>K? ka-g0kb%A%\$`M Y >\\P\">hH^\"\n^pPŐ(*ȅV\0N2,Sn9,LEIJpn\nBTo&gTQTNM\0FslPϤfC1\0PЦ\"l+cfl<Q ^z c8]<Q <aK@j&d\n xG\r+%0D2pQ]\0000ͥ9CC8FM(9 U 5KJ &>l/22\\4Y&aN[0(|My\0nBEC\r.R` Er&n+#mR\n,l3*rv둴;'̰ Z1%>Cb   *J\0fjFmq (@ea=\$:i;DÅX3s7: Be),aU\nj5DE5ƪۃ3b0lcT!5`c͏m>xV0?Ӑopd\rV\rb<BN ir9\nJ11w\$!u@\np&ʹ *k2pA?a2O@c(2ѝ@@ LQ\\K0\\ B:?/+O#*7JXˢJ9Z ><I.\\G/G̪@|kQl @v\"bv\"Z!ILF(hy/Բ˛I8EE\"X|c>EIb.L\ro)=\$tI#oR'J:T\0gH(3e>D #   qF=N)x\"\$E0{O{^ԫ8sf4o|?>q6Q\$ClhKVǞ4qhM{(Kq@EDXMb%";break;case"pt":$g="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##R3I4͐2pҤ6CJڹZ8ȱt6\"7.L P0iX!/\n\nN㌯Bc2\"Kha\0 DE+?(}o,E+91jLnR85c`蟌j\nbMxƸ2q1*/8:ılk+ѭ@&.U29Stj'\r3 BCtѣ-0ꬺJ( M(&\\.j\07؞9Ct\rl96(Jr#l Ō6\$עlp>)Q\"c 7\\\nP\r6Nxƹ0o 3T1l+Tl>BUecg0ds؊ZK\\p=\"Z[0P*gY3ӛ>Lk\r8Ѵd737 vR(b  ޠ' êMmXَ[3+AW S \rZPb#qiJpA7%NR^\rXKtF\n{z[dpb鼴/tߒuv 9 &D C:3:x؃ˠt^7ÐΑ__5 |9|P0gk'<ddJĐ)sr \"\\4!4\nN%\0D_1!A@\$&m+6@NWdy@N{d|r \$(3A(e%S k]| b>+#zU*@H B3zgV^?\$؁,ɘn lHdBH\n\n<)DR<*LtۢH!:\\o>#10Dž@`U#1oG1fi``3h\" ȳۃ\$D!rH=1unT\n 8PTz@,KȲOرz_J!@ 1DB#˾XErZ@[:Ci#a1R( 1fQ\n2V+d8q)zI50sH&LbtnB   9v ;JEdeܬH#SMUm\$J\rbwP+:I W0E b&P8ER@^CS`7JzNȨuۉ:0X4HpSi,\"\0RA(\r  ˡekY5fѭ\0(aPLVe\$hV<\rlpIƥ+\rSPU\\**\\Y)\${&hO5+M\ru-\nbzm\$9#\njI.ϐBH ` piVPU̽wmu^X\\kZIa^(\\Dh#op,%6J~&3،dp Xlbե\\ 8c\\oH3@2XzkO\n.hƱ|WYY&8ۜ/{iĸi\$&rxQ /Kwpjˇu8ù:R/DƔl-B2xeA   hw ǴןP~\\#=<s3  'dP\$\$\\]X(<0^ڴƄee\ncChT㍈XZ]Է)Pʙf%z2S}n\0QFIԽDkhQjGS.\r4e`+\nn[mkyo\n(td%n%Hs\0P`o;wLg5ھ6qrGY\r {՚'ͭfHbo<*/\\%El<7Xn22ky|u3/N˝C͝C62^PGNk:{EۜΦv^߫ \nA\rB4A..]\\ڿ^jؔcf{C}S@\$,.(^|\nnWv 9(Qݏ+8ѷnͫeҙˆ5\n,tmN>g署|{y\0߶!3Xl{o;˗5tq%J*6vis%F]   h_wZ#\0 ZXŐ; d\";KlFfJ\0'/ L\n@?kEZF%p\0ʘv0]VNSbܐ*fmЌb(fH#tPi!    \n.˿   e k[/,ų[ \rp8\0h@LDS\"q0ه}LRb[\r\0   \r R\r/&a8cqBwfPq2\$P셶\\Gh0Bcq3nrL\rV c[\n>!D\03_Z*iJRCs\npf.1nʎƍv'BoLilb#2(mʯ\rp ,+R0\"1^ѐ f X'\0(GFF(   \"(ш7E+#^V0X\$.U7 rjP6RJ6@FhA45dCr.xg&-0i&м0͵'Lz .\r9R&cTb3#@fM'N2p^    dL2&#\$;&I\\eL:@`ZD\0R/1\n8.S1RXd*r[#̧^(ne%(vW/e\n%R{VYgf7PhGF";break;case"pt-br":$g="V7jm̧(1?  E30\n'0f\rR 8g6e6 㱤rG%oihXj2LSIp 6NLv>%9\$\\n 7FZ)\r9h5\rQz4Fi7M &)A9\"*RQ\$sNXHfF[\"MQ'Sfs!\r4g฽䧂fLo7TY|%7RA\\yiuL b0՝4\$ˊ͒rF(s/6:\0Ꞅ\rp ̹Zh@5(l@JB (*@7Cꡯ2]\rZD7 C!0LPBB8=l&3R.)ɨ<l)ij;9Ci[]1;1xƬؘ7tF9'rV2hŮE270)2b.\rꒋ4è:ƠP6 H@5N!tKS7J/A-\0001(0Y\r'SêSm4v\$\r8Ti!a\0؀@P9GL:1c茠TΉ@ <Ѓd@U6%,Pڢ}B    p 8 ϢkOØSt!L7lGx`ڏ%dcKP)c1}\r#b<L>\0P<\$(c)ɅƁC;L[ST%3 c\0002 4\r\n|<L1I:69( #>70u\0h0P905a\0)B3Ȗ({:Zꣃ26zخ㤭rS\$޸ͽBr0:+&^#uXN{ &@c@,5!d44c0z\r8a^(]X\\ zW^    XE9 /i>N\$^A{  ?z tM9cv23bl\r5-7.ghB!(02@EH\nZ hf\n\n)%E\n HCq6%'0҇3\0;9RIQ:F+2Q\n42<k\n!@F0~&07a&Cc8ѭB\r9!C@)O\naQ2O_ed85G#utf>2]\r|3Gx\nkd\$ \$ FAs`#Hv#?!FDB,_R75ĝb|]b+B\0U\n @D0\"b0!\r UP   xIBN>( h8/E{uS|2\02JFNQJ;UT0I<ti<Q`fi8(\\XS@&*xo\r3*K7`-\$cm>u^i폢Y& .gDP9hUb:FQR,AFvòdb%Wi!l!e1='إcS\\QD`ȦijlEH ±^ɣk@d4BI%mF 1^J4{jɀCg3]:/\"/\":iWNꀠT sZ\0005R377#Љ9EvQ<Q5!SAP*/5x-2Ӗe.2FphyV \$NEknFgnp3 N!2xbSoqFF[D/' %\$Y \$*%8%s1t8c3ESۛ# VZhY*To^4Lzέ_S`_p a@p%b_*5\0C{y˜M/<D!2xYR3jifJb/     4a2W1F\r̥F;V&k   O8eԩb)WbD%lZ    Fo05?C ܛt=R.cQG^&n-u rD\"`x!SzSpKRT[,`n-AyҩTzCZ4-2S?mCySۜͨTnh-\\ʪUmCzѭOætmhه7 6i]zBJau3aJ\n168pFa`}   헻%wq<7 r}̜=nu:tdͺ66RTeN:ActmF/    vry\\ 66aYR=P ϣ>+|{\$,E5GDx)t?\"dw\"PJjkC^3T.RA.\0&B'\nT j:aKi'3\0F \$|^ŒFnSB8h@\\\$c P\0U>-Ύ%&2\nčL/One^*2Pz'NFc<xJJh f%PI P-\nDO 0+pj \":1\ro\n\0npPPrS¦ Z\0۱\n-P\r k\"'BMK*C\nto1Sn \r\0`HfWn-L:p^pv\n*\$nZ\"%\01C W4.Hj1\rV Z,\r4i[ c\n:' (@\$1& ZT`2CɬtٍL,Rّ'1ʅ\$D~bN%#0Q/FOh\$1\"xh *mk\r:&Dre#O†MlatS/DG#\0;pn*l\\,C7\"E_ +rݫ)R,X6pC\0zGSRƵ%F²R؄ca-.\"* .r9ڢ@Qz021 ]NZ2~ze,Y\"8I4rS\"723\nP R JY[SF00-2/`72`Z&%,.T+Pd5H5D&%\0%`K%ˮ#FFqF/";break;case"ro":$g="S:VBl 9LSBQp  @p:\$\"cfLL#>eL1p(/iiLI@-    Nde9% @nh|X\n FC1l7AFsyo9B&\rن7 F԰82`uZ:LFSazE2`xHx(n9̹gIf;=,f oNƜ :n N,h2YYN;΁ Af2r'-Kk{3>1`L@[Q2B z2˨ބ:/a62āJ'&::80Ґ/!¸+Mc\"1Ic)    \r)[c1P\$T80K&\nH!6(6Zp 0tBpQ\n0B1 T7p8&j(2L6 **t#4!\0( cΈ2TH+)Nm*4C D<o-\\.\"ɍ\rb\r͓:}D:6`Ag pLNpH\0%BK\\L;V5p)CFBoJ[cbm_­X7:T@8r ) 3]Q`4LO(WFF2Qipgc[{\n\rx2߶8]<j!k`ZOZ\0ќN\rͽP/M7AZc06/l<&7 704ƫc̡800li)aJz!bKt@A H/) p3/\n*{4 m?E2\nС( 4Bڤq\0:㳮`3,\r:h¬h9,+ԇ` D49Ax^;rʧ D\0`^QK/ X\"=G+x >R%.*ϋteiB% \r-ƆPs:AV2{(rV Y2F°AQ&5p(*Ni4T^n+̘ы\\.S4    6(\"JMjG)Bt*KY#: D.M.\r*YdB9'DZA)mԯwDJE:/Vj(a@'0T>'ԅBR(  \\\\(8iwpC+E|046̈́%fḒ8gSLH!SvK0T\nrH:5Kd9ACIPI&ګՊ頧@u)4bBdu.Ɩz\r. A:; @\\m\\!0P  d- ::L*&Zhƌŗ`!eNP3  N-@i3BUP.0yH%f+!eSVIbY`&M:K+VjnaRPmȖI`P  h^wRPsES:\0Az2J#4 fAMP* q3?Mrv\"LIUZUn@HTeMܢb!}2}tC:D2[xÃ3Xɦ;Os7&V:~!(y01TYr^jvg{54zxK  IG-#31IptypoB);j=`^NXFwC  MҜ\$mD\rTBzș4aԩ*㈚\$֊̮[bT+:8ť1(PسfG.j\n-'iԁQ颓sa=ZY,bvQƌX    ō1l\0+O(;eYi.CadJ[uDqf    |y=\\DmBktѥ3H-;YA`d!ELo y   ^,!<#\nX#d&l9k=J\"nfi-ѽO3=.V(^efSp}4M(V15oK\"1lD4~c5B]*,pOaps&vKw#|[Pp{ o-sk04T\r[m=oUE~ Jx9Z5SxqZ2׻}h=voEρ&;eABS{j@׼.o<`   [G\rO\n9;*9˖|<%eB{!=/hLG-Qx'O\$/ t:c\0a|,1+Kк<܈fE(κ? .kj*\n:E棶+  :ld,,0_JN턨 rc\ng.%_-+FWp6-,Pl\$Bl\\P<Ćtg`    ⮶C @;%'B]#:J8mfL\\X.j\rl-\r4ObIOI   nnUINe=`\$V(c\$KG.rAVD Aw\r1E=nFT16q;/A`3Jqrj@CD\nsp\\HzcQvCn[l!J?M+qbR1Vk\rDEEpk\n\0F(őQM\"{Fbz  lko>3P\\3&X@Vޣr4ZQwT#d1r<\n\\X.2\"lYA\"N@/2C#-\$2o\"q'OF/'6Ki@epPep&o6CX\r+C&@\nZ,\$^mR,t\r-\"Lڇ4#<BFlB2*Cf.JN#3E䒞#,1b\\dTpmU l,A#\"zN%/&bg\$)C?,RNm4XPTMq8떫 c+7n- fSs8\$QC*)h6&tK4\\A8,36aFc(sIV\\F,_=û>&N^&# 'LMl{C3\0&@Jw*\$@V./` GҸ&37e\"Bȣ/(#>`DJ:1뢋@@v  i~ u\re#H(gr<@ \0t @\n`";break;case"ru":$g="I4Qb\rh-Z(KA{ᙘ@s4\$hX4mEF yAg \nQBKW2)RA@apz\0]NKWRiAy-]!& pCE#yl\n@N'R)@%9*I.Z3{AZ(Tq\0(`1 ƃQp9Xi\$fi'B2,lƄ~C>4PT!HkhRHb4i6FFc{Y3-jrɼ 4NQ 8'cIg2O9d0<CA: #ܹ)#dà) ,znLӊ֮m&0N.A%\no7 d\rŒC8h*hZ]9kcFh0:2FH1s Sѯ*inhɉ9!L. Hh\r, dĦ3H(JXD4ƁN()|FйtҊ#\n1Pqs,JS\n\rHhRԂ-rOB ,;\$- hʾؐ:+h<%PQdRR   #h\r(:-\r#o (K2T!5Gn9[&.@ R4Ñ,0,-K\r˰CcաK]x!.I5: oR QNc\"b)d2\\#\$]t\\#8 7}\nGhUZ\\DR9IkI6}J, -tX[p:c\0ȸ0F%k,CZnR(5,jK0Ք:rjBTeu(*T6e)g4jE>ia*}1Hfđ\"KT(2V2\r]v_x仕®\r{͔\$C`t@( o 6\"\nTP7p 9Pψs @Xs9B\n+    VO(`409QIMU`F64T;#d<*Gx@@;+_,\$SHy7Kϯ\"\nqA=P]ALDGlW;*d\rN:\\iwGG  9z% s90 i/x f4@:;P\\C\$F\r9Xz!Bp/NL9\0.s*_`|A\r #\n=2̵Ap\r),3Hj^S( MHQw^j|bbuKHbL5FCdO(hm7\0(.0s*T)r\"8MfB%JXcLme*E=\ra,'\";7XbO&PCG! \\(\"t˭i/ҎHy;2y\rAu>+3 A\0A0zS6` .7T_6Pma*%O\naP\nldcF)W)dV_\raת\$ZUZy9DĽ;]͂t]3@ln\\7B@ 4p@` ǴnPV.!iX'Օ^f9s}HN^#rH0B1C(k.^U[\r5Oq)! UWU\\fCA2`v !4]{-!UJqRQH+[!K @uZ Vqxeًr3^V YI@[(B5tULx&|P[IcXVN\\^;N(j\$͛6,McUgFFEE,& (QJE\$ɢJ{8;#j\r<1{!#&by%9\\SquE=Pp)Sd{AlvŠf=, +\"ucws@mY AN3T\$ (Y<DI*],QLCVcV~|(I:4hp9rfh]9[ޚQsv@=o/ cI0&CX6MR2)]*3Z'\rM|fZ{nJJA =>BT! \$ #3IP`} sZLjgLf kDꈐ4.bb.K}fgYюҾ/d.8e–~Y}~絈sOb^\r.>|=EeGVGR=Z*d/Ob\0:~4\$O%}\0,#} ֢\0pC0</0@h F#\$\"^c %\"r/bx(o[b%SDZp pLG@^ F.CIp!׏u3b\$OJfF /PJTKOLhFd3}}lw[BuD\$o0\"R&- b\rZ\$hM*/P\"S.f,.Zd[hOnt*O .7b\\,t&Lxh6%XʐNBJL<DcVˬDB1%DF1N:Z˶\$,wHPPOo\0NJ! .>-BW0p,Ŵ5e0\r'<ұ#(*\$QxD<@z\n=%KѝA1jRC' A\$zFBm82@Ǹ{\$fS\rj(+Q Ҧ #7,c`@\$wgY~\$qa-QS-7.O 6RKPc//,xBd!ge%+,1Ê*\"B*/a赓NWRW/,+6 36J355Rpw7l#-*'\0HD&\$LkZ\0&ECPӂv+\$,Fu99\$N:r\$%)PZyn%=d4,&.Nb1*sK8;LB`N09pTyĆ̽fC(f3q4g4DNdzA)5cE'EQ҄tG*2oD^Ro%XubgHHGT4SEgI IRG8Q0QKvJ28fҥ&<!A\r8BCn(n)Q1x^\$uD-c031g\rIs%-0AJ[Q.;RR\njeow^jopRkLT5G\"iT\\D'0u8I\$HBe\0AmnO=e}*N2KFV/]%\"7nbPNFu(URվQZ5%\"@.u=L'[lKY5ZJY=ZwH*&ŽZ1!5EW}[*ѷ^e;;8./5v5Ӎdn/!so15e.ds}c>pvD!v:eweN,MԯMFR|uJvIQSt#\"ea)Q^6jqJYvFA8na}5  Q-0SbFF1MO0\$f0!64/cop֕2GEpE.l<|Dr9i/Q5opc5/1*q˧E47Wbgp^7'3hM@sh)FMQ&QyktoWAwt(J\0ğ+\nZ\0@_@`\$V 0}A92dhewn[0x~3}3~-}bO5!P>%qFf |4>d&@n\r^PtoxR5Ơ\\    c]mMpR9UeA]vq-[!S   Y)X<@O1:4+1eF0i<I-\$<VX^\nշ֢8B\r\n(C<w >\r҈mme9EG,T.zI:9QƞSt)<C!SdEuj'FT  I  Fm`@\n2\n `\\Z&V]N kSp9mf2nF A,xkt ;)G!_ch0?#ȄqY \\ 5taPa7Ð(7h\r&u5XrQNA)!9D\n ";break;case"sk":$g="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Ҹ2;'a-`8 QF<0B\"`?0ʓK`9.(62Icʳ\rs@PC%l6P\$hۭc4b`9X*NLlޜP6 Đ7xA\$B65Ú)\"`%\"GA\0ł%X)M#CB~US۰J\0   Bv7c\\X\0ĂMaX͍`cSZ;>c0è5s3C(o\\_/P5hޟ=%A#\$J8.IŦ!tWbgB\rpڣ`0  1#rH [_X(քLnc:&:Y9m\0U*VHfR6|S>^PQ(#07\\35\0B(YJVo SJŃ.VL`%L꒎x3\rʔ\$P `7/X<:q9@@.p50\nsv=7cc(P9)Hct^уZrb#&43\"zPFGj\nb2C,ڐتU8\rsO><9b0)ZⱠ;v\n8\r6ڇHC0=A:@/.\"a*\r\r/d&HtA|1RPD:^AQ\n)`BǬyj \"b%rr   Iy/e#yW1)k( ;fX b4ugJ*+b\0:Up<a|(DDq{=dD:9:5k G@^7AN%!\$<J4jCShjqBcdQDHqԒy۩'˜TSJrM(3/''\$ \\é5JӄMSk|8+ a(`nX\$C-bW (!Pk'BD&r ɋA<'\0 A\nR@@(L\\ӐC BnaQDFW@EYu蔋`\0ae\n;K0<,Ghx!=-b QRݫ/ZMջT1Ӈ6ӈ`M\$\"4f!n(Z|P>u͖`|&9o 4TxU r+\\DD8\0)C# E?1ESlx\$Ynxbxk-L)}\nZBC;i8:N 2Xb`+xuHo\\j9P1U++,~C!\rTQc~^9aFsRJ^Xxacц/JɯAޢgDTL\0Qj\rn&%\":`E*?0շ.ak 0}^/D^W9 \rea3.b(+Bc1!^jaoEp,Pvc搓p   ͹  \$)64s}-8\"ٛfpyfM 3TfiȊ&V*1m0IA Eϋb8R٠ul0|ǖzMf>z/'C\r ZTN۰BE;Qɋ4DRRu?   BC̒gGo\"<CYN;KJ :G&*\n0QJY^*0ŚKR\n3ILQDǕ\$үbI7;21\0(ޕt#Q0{#nx%72-aRU=^ʴuUԮ5tzP)7x7azt)(\"P@L9qWCb%   葾H#r`IV\$T4F/xh7G0ȿ)떂r=6#֏P|j:Yd4zZg741fm 4OSZ1<t% \"\$'ZK?-~1_?a,⼟Ti_G}Bm&M.6Ck0P \$0/02 L\rWDB\"'P\ntGEP2fCX6%tuDg(&ea}ebB])xmvu*#f0\$BSi\"Ȏ/`@B}bO0 LLt&ʔ눫2+*t KkY\0 N_MpGVR%XQ\n; j(B1OƃCq0&1q.9〢2(c&K\$p#N\n8j{\$\$|Sn:du6/oQ1q:ϭQ8Z岳&hqFsov%`ePViJYyJ' (QdE̎.\nr'2MGe*#2\r1ǃQ%en\n.`fY%1N<Q’^~ ²a\$r l.q( :DiR>|CL'cL K)o2Kr2C@<MI&N\nCl1npoX\" -.O.m\r{.>R  bA\nXt\rJ.%Xx;C\"AP i:LI@`nj&i.<('(T&GD%b>)P\nL\nq #c&Y׭N'8P \0d9\03 Nk**#>em J\nFD^⌥)#dYBzzR3:v1W<EDu`  /B.X-R[,E\"׉9BL>SRlƘ-Τ`/RygtNtN0Ѯ=o_r?laTCBXB{@ n_kt.zP>%3 IΫ-\$QIk)LЦC_ih젤J%cd3&J @\n ,it\\&nP\ndIM@9#is1-Eb?f   C^DSjy C&e0iNO\$'\\ w\$\npb#f!    \0t @\n`";break;case"sl":$g="S:Dib#L&H% (6l7WƓ@d0\rY]0XI \r&y'̲%9J nnS鉆^  #!j6 !n7F9<lI/*LQZvccMQ3g#N\0e3Nb    Pp@sNnbf.Pl5MBz 67Q>gk53trρDы(P   FSU8Fzi63iI2 syO\nE./b;Z4 P ,)6HŠN!-Bj\nD87(9!1 #k^Ҡ.`PZECAЛ4(2BZ5#̜bH82hܟZ:\r8)\"cޗ(Z\nx0I03 Ĵh 1\$ˌ%F3촉{E : ID0ԕ0Ԓ!CUN2P:X(J9 \"J5Òx8K+b72.p6P2XB+Vè6RB9h[? (q-gj]PFTT#6X;˓EL*|<d0\":bk-%0WCMgZx13 Ҡ\$MҨ\rX\rØ1Ø3\\@T_/hT2:!@s(3ZZb#7x@3#Cm\\_')8 <\\I<%b<Û7O\n;_3t)x\r#\rc4 nn 0z\r8a^(\\Fʀ#C8^#xT̎ؾ!cXDK^073/;\"Zi*xMs#&WBLxgZ4d>AMdO'&ښd 4sB~v   @\nH&K,[Y*M`Lrga@}aF!tRn\$G9F\\ꚇ*4Dɋ\$~s4lff<p ܭ\rm d&Jˇ 䝙(2~T!\n<)Fj;Q{z\$}F\$49Foi32[opn\$!g~R,Jașn0k7c\0M 9PédNXү颗Y*\rv4Zjg5U-H%\$(U\n'6FpcDKh4  Il0e|A\"I00%IxB,ˬ[?VIلf đ*SFIhLoj*DC{ *ehwIOɔ3%7ЊôF9:T:Ù3P (-钕+JM%@de22BCͪ(\0QᔽVV˦ӌ gN0^ 1n^᭢B4>\rJJ\"@~\r7sܐ):>/^~B    hb>O[~ O\"R3}%)v\n >I<I0Aa FehLԦ F/m_Hả/a 2Uaoe^RE N-Ɗ#=A͆D'\$Qϵ0X8`iBhaaH.·=^1 ?1 񣘔bv=5Pe\rB5'{i\$xHqaOrr|(\\fH*0f\"Ls.B=ث4c<rXA<ar\\sjȹC1rtEkc\00G<҅5 @|\nZ\"QB?[LeáP#S!4T㸉@2(LJ)Co1A>\\-|LyM@BEx%3ώS20_/%1:<a) e@\\}~ޛ6E4@SðzEҴMhz^<[3!3    qi\$[2L!%-\nI2j?hM܄DhE<9pq\"LN_@U^;Wv̠r}D FN=ˣr_pBNks3?Xn\$|T>oߓ0ːx,0na(nFYɈ#tYk;WTZ);sUٸ+n&gI)0dICu   MQE,:OЩBmj2D3+CF)*v: E(F(KO>&OZ\$RnrP4&&l+k>n.PSd)nm<Bk~PxZX@mޠ6\n1`ȷJB\n`; oepWDak*(pF&W%vPR5F`&`](cjnжN az\$- 殍` P3 >P+R'm<>\"ubG]pcCg PQQQXA7H G^ b y{J'6\"OG.h.\"QnB,I1ހ\$>3O\rÖ<ƢCHq C4SB^笙b8cvT#!\ng 24&/D’C2\$\$U%2%^\rVm:nT'B~^XL\nU6\np2/` d-#b,G\$L/*d B(2OD+l+ \"0#E#%&Tބ    \r  \nM H&0e䈤o-3(-%r60 B`\rl83Jb4\$&c+l\"JM2^Rj\nm6v'fS^jC7b261 ..JF\$ .ØO&兊?3]-\r x@/N'|((u<np\0Sg23Nu Ғ\0\0/ `B =e\" &\"A%){\nb0%6AC\"-~d?e~F07&b\n%\"1EC)?J'8'f>CZ#4iɌ";break;case"sr":$g="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\$?ƃF1ED48 t%Ln58x&45-Jh%z)Ţ!I:۬е*H\"h\"|>r\\-q,25ZE\$+\$Jz,mZHQ&EԂA6 #LtU8iRrX\$Tf|^@b1'\"ˊ_>\rRFő\nl ꠫q̅\"fD<Yt6X2à@79\"&\r.D3-7Uji\nL@.J,@\"E\03gsg\\<ݦ)siTmN\n3C9`jp<\$/l HR<C&4\nk+c8Mh;yї\$ [pSjC;W   )BW    5f\$AOX ;> 95E.JkI !6PicK_v췮pǦ*2'fGwjQe]}U7URg-,50d^_G>bnL_\"ʂp[1ynlN]2l]߼UWǫnIZSjUwݶ׍ܷa\098#x3\rʵ^т\r<9c06`3CXt !0 AXm@A낀\nKYD,iA%˜R͵K^ԺHs\$Tr\"Ob+9b'vY.X?ZdFdPhag\\9XøoK42^d0װ\"\r:\0x/pe@-p^#x:4 z4:FwPk@_ʰ(<,sBY\$0N,z}1bVItP谊eLW4]qG>\"]Kf%a72M)A74!A\0P    Bc^\\Q!&s2c/`2NqWdK\\ yE}ʣ]{Tΐc\\9_\rX؄AT2.Aeb 0VPI\$!@ҳNZfq9c`h 1ES\0cK@ ek'Կ6BxS\nI:+\$G(A4Xd&j0RtN!>x8FF*2R֨dXٗÛNInc}O`\0b\r!- 18'&2`7R\r+-,iQK\"G=[9rv\$4:(Z-c%FI2\0U\n @DG\"TEOxO*,=ĨXk\0D0\"kqnl X\"H_-S *P  (]|TBNdH_e1-Z{C0a~;JԳ\r@&QPc_YSt3^h`\$38Jv^\\ 3J'H&\rU.,MUSXT%B˯xV[In:Qno#w:,|!,r\nԓD& +XAATBϢ)0u'i&mM@RMz%z}ȉt.%73H'2iyګJRmd0(\nt8@\") g\\2;Lh)y3p( I2^}0  'Ԝo>^Pjt@Sq2 gw?ڥ\"?VK%C\$:TUVʼnNA\"jnfQ\n`~*1Dgpg]Ҵ>(4eamBAa RNs{7#,eM.]DufA\rb  V15<- D2)7˲Z殟VBp v<9q Lo<|t1H^Eꮕɸh/tDr瞽[goN Ccogξ>/sspqB3>]z}]]j=zDṿxPv )j@Kù#\$G[z|%Q؅:M\"\${bXS*x)]OȈiL[;+m=j     rQy66j8C+g;W㥑\nWRD:BVh I<_B jD@7 AP`bYOoC mbP144Hg~P\nn(+w^lbHA\nR3(\r|GvDJ.pV,rOЖBОnB%\nd\n\" SnK LMzmpf\$JEt)=>K'\$0X10\"9K ,C  VPhu&Pw[ ]b4ݣsMaQ#HfUPx-qm F*xtq:&/6j` Ĉ+],L#펅Pu&ѤvQdιQѿ-iXcnc<+>`Ip\"3ECͧ p2C>1-\$j# zjM>#\0|l G#D4*fl<*@ea\$& *Jvsm0NpB~ ,[f!+%! r=bHزZWE_(MiCL1\"ے`    eD}56 \nGQ2r''IΝ.\02,c&+ps1-0-R-0M0%\r&*(O:g-JHd\nHb0ibdHQqw71+S%37q21\$>c%,|Er3/C΅3cC;<\n,#,Xbڟ轫y{R>U<32M.3J)'>s+9%zXFsͯB21gD!Q?4R\"TW/1/t0׍F csj)UG! e-%\n.\n5ʷ@QsBDg,EIAuE?.  tB)3\"H98Vœ-LbPSև@fI nWM4ʮ\$tT=TΛOi\$[5EQ`QNC&+&RO.ίRp\\1SL\0z@bȷWN{@.i'\"(@E)N\rb\np e@@Q411O*'Z<զUR)𖌐nw\0E_  ڢ[V;-fI lD `j   !bJby-PSp]ͱb |/\"`JuENvPx9\0-tp%Ae@BЃd].r)#LvY+H4THNqfSy1+AfGeodœ11sC6{hlANMe\n1sd/o)]po jEcY[T7V2pp\$\n>x/v4f!A@bHҿ@@\n \n `M*ip*ʌ̧8ζoKi2\rQ   V`\\=kULyWLL54v4{8'p9 qMd7\"P (^\rVTgvBH.`";break;case"ta":$g="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\07 2k,SD)Y,:҄)\rkf.b:C lJNr\$Ţ)20\nq\$&*A\$:SPzik\0ҏ9#xܣU-P  J8\r,suYB\"\"+I\\Բ#6|\"ܢʵ(+r\07CURl,A\\'\r{EH _*4 ةP)DX\$B\0T2&4\rRB\$.k{k=8F@2hfN=ޮ}%t\\)Yc2,5͖2OSHrOTe\n!VHrC\nRRB̈́54Bh5)Ֆ1+%\\IBIqi)SG-;w\râ]2>/<\nb4h>^–7T|1\r\")HC.PV  Ls'(`fC\r^).mEA'RRWn|mD<}C2qsA o)+Ţ%\0O[U] l&_mmX#p:Owjw~#89=wV]b)K89`'XViC G@m&lKV%2fèl\r@nE\rx6W*ّ+=,>˅to\"brE>UfcJp|й+kvR-\$zl3q9_hӄ͔LB}ݱ& /*.N!xK%YHw\$∋C    ijIpp](`Úhp\r:0h9\r\\J%#AxVdA(Ǵ\nYd_-U@(c}.xD<NL-\"pس@Q;\00lEa[yIAP7PC x:0{Øf tVaS\$0pŠvaS\n)+ ) R\rQYX   +\$َ|   @pS0I0Ș\$\\^ӄƵҙD9OX2PN*=CY  \0bhȌ#Pц^)*~ACM \0PM ,\rjük<\0\$=@Ah80t xw@@t 2k|O@{` D O j\$CYlLzP\rHzAV#\$MMSCے\r/ڠD|t9UDخMe(>M-A@\$ LSbq;T:߬wGԋiD^yۺi/rZסNiM9Rxt;R1++u)C79O\$q ~*{tM1Sݷ2!uool>^(\n  \$|<@KX<I~O z:2V~k e\r&+7'~M#@'0!R5aL.LCaJv]PCh?`èrzpHev DN6e\"*br\nhhzF\n:iRy#%1#\\ ݠ\"e+p \n@\"@V\"k#+LUšfA~BZݤ^6H42:SY&hA2`Zv !\"E<JH #,0#tms̸iuh؇hQ\rЕgqK@:RII|&mfh-ZCxN]7ArF]0?:}ֺngpnK΋&sTgj<ڞvÒ]xFors Nud@˷*:}>3H 944ih`i` pJ|gK0YFςZqw\$\"~rHu \\˝ojkv1/@ӛu6K@T7b7s(40{8e gE>&h_R~/1f8TkL1LgTp}9\"\"g[(:O\0jȪ)4ō~CH}J|`B(1ZJ@Ґ>JKfsMp@b vG8PDGnD v`:i\"PhގZ,gƋ߃@E\n+,hhmevf\0\n+B/ KJgO fNKNۆTPoZhhfdI椔   \0@Ȇ \r# h<Lv\$IKpGNp-\0~7f96ko\0Vdu͹/-O4l.or/vql۰kĿױ5 Ep+1W  Ou1bQ1ojb)    \\+ ֨k;걏W1 ]N622Q\" Qn-A kjLB0L⸘HlB(brm@p\\x(\r=(#FH汛!֏h+IQ'N]@F0t/W(r}\$\n2=ءNA)   \n~,9`Hh'*N<|ʼ\\hCf%Pcؖ jĐp/2uer\$y/5R\nljy5l0djjs\$6\"NВl]8c8E0pCn.]9ӃSf:mzs0;2*rVvdۓר#S=13;q2m!{\\-KB%08\"'k.2#do/0-DI06NT/A45D\"Т|8()a\np' <r ;;1_eG6\0@\n\r\$0:5BF)EMȀn#.fHA\"0lwE2S-QhL'HT֊);A2<=THԳON~S; O%;O⼓n'jRPSPB5FSu7M:(Ut`u]G*So\$%U'&h4{VSW**S!qSqWWQp{FT=?Y4VLsCfoZяFCy;\\R/+F'^pcJKYR1V G\"=QgN'b5zVUv6ÁXJnJL5䭽4r(Mw4A5>ӹdn\nb\nٱ^hAzKߵ̡LfvD[Y2t16u'lHjRUŒ|iI\n\0ˇ]\n@hVAkkikn%c:Tn6Pǿ'6Df79ior4Q?aKMDe}Lv>ahV?WWlmV7qdudz514u5,58@()fj+:Mw5QbHdzu{y   w@z ȱkx6E#TXw6˦}ש 03z|w}\n8|d*hM\rNSĤsXPn& b[sNt3\\*@,@\rS8u\\{VGh7G\\{YWk]ꕅ\\g~xxq<Rxy\ru +rX,ΗI:XxQ00%8_y,`wBK^UL!v4AVuӉ!lfb5OnV+POyhSJ W+ctYNY@EHYV'/@aIe*Lޣ  4ה8vbv\r[u\nJurV狔}9b>ٖqDP{ayA eŘńI=}ΤdvVteHS%  \r39ߛY 6tˠ+NYgYo>   \nϷx˦B w0 81+IfL8u2,Iy2GcQ!Ou3J#FB:ħgI7qXS=mZV\$X[8r-W<ҝe\rV` `֖8ȫ,\r\r ̙&+=c\r,j@ijM8\nZ\0Ai{.EbWݦo6I3EB^OX%1y)ttn;hCEp     m巷aOr?m.4&۷zS|t;/47S]%d{OBmE#\$BR?-4uDLUaq{n?H32^VE\$c>(g   nA-83eg՛x'x >HuQë-E8csϤ]NZaei]3\n>< Al\rPYF DT}7/!(ͶEl4@0\0PXgMYfN'7d#&\n\rӜP'C`T<j0G7TH\0\\qӦ\r|fZrEN8G2(oZy6\0z:=>ư=@ԝ3;Uvļ|M5!kIqdA` \0@  t\n`";break;case"th":$g="\\! M@0tD\0 \nX:&\0*\n8\0 E30/\0ZB (^\0AK 2\0&b8KG n   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*/TI9&35kh_H\"UFq8Ő.e| &l UPIsLJ/\$'ajYfI۱aY93d\\!WqJCMc=a6T  ^RQSh+;ĐF!pY뛍.^Ӄ,Eg+ #h(:R{#\0ox(L\n⹲ ;ybFbӷDriDmU2>Q6ZPw[|D7Oa6%>NZamʜ4_׼E<.E;R,}unN08*ثW3:V%E;5,e mщ둛ύ˷3u{8weYڳb;+7#`A@9cdW:XmI+wdm'hpFʢ?YI!0ۀnټ`8Eu\",D;j.\rh 0Ș,(P8S\n\nz-\r+˜,P0܊{,DGbwڤD8mոB:f8:!6pٵ#`t@(xo 6#ʃcT\"3/FDnBo>P7@Cps1 \r3 r3x\$%hT\n\n)j\"M ) IQ  I`eR`\"._eEԦgg\n>6bTN .J9X\nr84ܠEh'*1cل)o@RV`&C;у(x8@\\9\r3Dt^@. !Ru ཟS@dL\r>@~å 5D;l:^AAhavCYiΗJ55Tb~3sSoW;:DWJcM9(;<\0(A*   \nA5/ٸUJYV/}azgrWT1jEvxK\nvKUNº[ 6  eXv[5\$ޜR`\$PzA\0d\r-2A 8\0fA6\0K#   @9&O?NG{57l½8k+etr. L\"gq,{[Z\\\\et-DMwvl\r1VZg\\͑<S=[TyIҰACi Ŧ\0~y!*XwуK:+ymu:Lj2⣂W ('@BD!P\"L(L镉^XCsVC ӂ.~Vγ>stY(q^w(qPD 0lftX~F.(RRyM+M77oϻl\0,kAwyX\\ A?Au l6yKmN    Wȃwb1]pڐrnid\\WosV\$>Pթ]JޖjJPpˀX\\0Wk+zEPK qa A+jRTV_;?11Vߎ\na=P pqƁC\"W7\0)F9qg~ـO0lg^`tA\0/E流qʎ!S!2-m&yTP Wh+(Q:<OxIDLv<.N3!βbV/(\rlr~\\[ZB Ix0Uu\rC \0R1p> -}D,ll @ DK S>I`p\\CoPG`øӹ,KхzVQ:<,D1d/ΏDOpJ\0ɟ\0vg\"\$Ud0F`b(J&SJCFl6Sm\nʭ Zd\\c_f_ i L|0-ڃ        x2Hok\\ura\nQ_C)#\0gtp6'X'@Ef&hDDQ \nn)y-TMN+0wp p%2%PQ9EEX~1A15?+hQHq*lo0(=  b6Nf-XEDװ_:Bs+fBp H \r'CztZH\$+.<&C21y9쮸}B,\rQ(Sdpݭ &Xo2zm\$)`6N,ky%FC\$mu%;%(1#jnODۂć(Ҝ<Dzr\rO j+P9k&`\0;gLDi<1rҠ1OrK\$mRs0O3((1RY'C\0\$UFܠEΗ5 hXk!LǦ&8r8DFCDD.Rzo\$FDd*Sm&'E  4R44̶v'Q,nEfE3y<n;3,(\"N.025A    *R=e*{1ne- RA44<t@TE<9A=,ACD?O_Dt)5rDvfF49XuC@T+)4mEpV\\78/T-C6 uRF'rPvr<#Q4mP\nC+3Di%ؔA]'A&BM3)GcO@HF\r~Q\$̄i `57*\r/S.m3j9\\Bw6J\0000@oQA!DlqNPwNi n,T\rRTW}Y3tH(KO\\WեPF_Y[5Q[ H7#UuuXTfّi?DO<vuWT-w^Y]`}*a >ۤ!+_`YY`\r]GR3;Z`__cc)d0DEImSIA5p}O4\"v^cbL/yf3vy/6,M aOP{ klr'/XK/LaD(w%} \0_#bgQR=\"wK6e/%t)0g0v0If@k\r \rl+쟣ÔlBЬ\r@ J\nphx \"q0.o(bY--:L#=Vk3QQ&k0@u@-.vQ'r9~r7'?eKd&\\7Q;.Vceb<\"Rhcn} 0L\rWuwڡ@daGHmU4qkrS T߳54(O/lO6nqmhw1r&m(Ӄw\\D|=sʽܔjX\rńC]Jv+H2\n<1ҙj\"d[\"zSyFyn3 (%8.Jؐ.h @\nώ\n `?WLUzŀЬBv\rldEm1_#fK+8(Iho1)X8r.]cw84n\r8Ն@>ˎWXIs}KH6N{Vy     \0t @\n`";break;case"tr":$g="E6M i=BQp 9 3!i6`'y\\\nb,P!= 2̑Ho<NXbn)̅'b):GX@\n FC1l7ASv*|%4F`(a1\r    !^2Q|%O3vMA\\ 7\\e93a:sFNdp'tFK!vt @e#>ǜ㑄̠%%M :Ir?F 5   \"ih`ttT;ơ䐣##Cd<CkLPX9`*#z:A\"cJV::|\0@e(A{\nx@P t#JIƼ0BH87    \n\0789B4)<)S#0e0m #C7/j𨌪Od  ⤪,L,τX,\"#M&7N35#o,hMX#먠>`P>~1:c<{|ьʓ0D՜'p5( \rn; HVP5#EEK޴|_PAMo}z,݇%)[nCs| m<\"',`v^\r%fWaTP1,XACx3Cpʓd:|507p< l3;A3CXZ`3)bYP 1BaJObÒ =@)B0R\rN:L9\rB5H)80=NO(ȟ\$:Ü =2ؼ2b \$I+/)9P0(@8w#(8=(ɾ9 0z\r8a^\\0*<\$8^c9axEkL닺5A,\$Rx!fQ:_L&lDL(p#)-9vw*߇C@\r˥\"NOnJ&5#0 > a@\$\nTJ DtՠVǼ\nʪ#Ty\0Pb\$2;.ٹer`P\\Qzn\n\$\$ES   03J`q`䉗+ N:V˒dev!96/.@˜T6D|5Oz-DS>ٹpi>Ay ɒuE󃧜7sOi`7nMHg j>ZHF\n  )?<JC;̻lZ'qH,xNT(@+q  3j  )\"@{ )\"Pg\n\0&]=͸2Р[7kwH`T@*,    BCgIv(v-\0ړ\",i{Nƞu\"<T#)!l(\$dKY(d@WU]^uHVE^n/ Й{  ^ؠDst.9xmOY l04jsW#X#\\EbIyz0κ'zD.Sꗠ0p'GNhC\".\rUZ}O_HD!  ܦ% RG< 򂨦8,]㜪ȝ0pM4-סr^SŊ9T%LZA7zzgB  qǰ^B8(uD0t@Aa G^f#9D@ͅ8S|!SyWT :@ŧS\"o-tYqŔ!cYp  O\$\\n,\\x Wv,|Q2tc\"}>;\n\"4iZ0ԓ1YG)Ÿ87<ȧYT?4dJ@) ù)\$Ԍ:ϺwļX/tCf!FH!t(bȨ̀}y>)h,pH4_0pE\"8Du MXw\$!&9EX/\nRHgY#\"75rjր8Ւ\\|fB\r*4UrH[:{_#q.d7-}_ijj؋\\60OZm )QΙY?XOAhmv'Jkӣ+OLN2E_e 9IKej1A\0k^', aNH=Ϻ㢧I{{/n xn絗N/\"Ʈ\$NO1xQYr\rv0<ҥzW adkj'NYcv18On0=*g1N/6+u-)    [Xb|߸?kA8O   w0^gyoMh0ߪqj[#tB.-,&*|wXz C|/ǁpEL\rP )X4.mPNU\0UPE.D66/d\\p8˗PiA o尒\r   BNZPp\r e\nĴ(0 E;\0,>dn|\$od\n ;,NG\0;u0F(Mc˪,-v!iz9EV#bPK,G6K6SLi2e.\$*NQrxqC_\"\\XC4@E\0d/.hO\"l\nZ~ܤ8L/d94FqŮmBc*ZmRC6j*qNQ1dF&)'^j8@%\\=Hci\"b. )%:oeV,fqฯVK\r'G^1\\WkVuegV)f c\$\"0(^1*n.bcd \$=ZeCY--\rda-v</D\n H\0)8/*i*D}h\"4E/g{5cfI]e\"*e?)\$~g4D\\B^-xɟ0E\rc*>a(RB3fR";break;case"uk":$g="I4ɠh-`&KBQp 9 rh- -}[ZH`RdbrbhdZGH\rMs6@Se+ȃE6JTdJsh\$g\$Gfj >Cf4jSdRB\rhSE6\rVG!TIV{ZLʔi%QBvUXhZ <,΢Aev4 s)@tNC  Ӑt4zC    kK4 \\L+U0\\F>kC5A2@\$M4TAJ\\GB4;!/(+`P{\\\r 'TSX6VZ(\"I(L` ʱ\nf@ \\.)D(SkZڱ-ꄗ.YD~HMVF: E:fF(ɳ˚lGLA;Szu CDRJ`hr@=Bs;MNrJۭ)S3NjfBTш54T462(>ɫ)F#DMRDkgVhIt;rFH  #h\r(:K\r#n@(K*cbQFvGFSj%,@5jmKpX|YmwMش  #fmc2(\n,IxmZerG{_rաF B̞AWmZճFq[(HE} ZR3G\0%:(4EA\0P:cH0myACI'l^)!lPxRQ1&pY)^cOC\$*;)\r 8/k~ԙM3X]uYi#٢5FYa_w}=jBj6}U]x{e+8#6crxf U\rhT\r,6@na133|7t 3 !;0\\@:PIk3FCU\0C\naH#76\0Aq#\02],\nЮQ\"HJ%bb I!'~i\"#VW#CbDr#.jhУΎɲP\$GAe|bxCs;Hxr]A<\0\$A?Ah80t xw@0@C.!)j\r!7DÑ/g>[|2xa˕sҺ0a\rg!yhn\\A2!U4DEEM!O&wf+dmuL٨F))([\0-IF~T\n 8)G<<T)DG3TD|qrg5 \\g\n?o%q-C*ҞZu >jBSzJAMQ)}IJҌnG\$84|}E.N uȻCr<?N 7@et:q\0m@d&#G9)pSENXX]Xh\$dhٲg^r)ؓ:,RaOTL䀗K0oN  3t\$F\nBWP䛵qdk/eJ5M)6J3AM1\rL&!'He!\n h4q64eahY4jf!%HؑzR&2/Ӳ*n e .@CexVE6-E.[s|qA`U^uD\$yQA   ;&b&61\"(RHɕ8g5^|[Xw/Z;4@+J:'8}b:??Gfrgji⍈F#1K\0PZBh[ͭDˋы HY6FM|X2\rL;`\r\r!2_C-١L2 w&`:bj+~\nXEZvQдŤŎ,Mh(蔒BeޡQklo\n,hLp|hC\"/~(1E^I|lSQ'NMT۵M1 R Fk(   B~WT#Bl|ƙiuW@|U<'BT! \$\n7Iպv gSBiq\\\n)際eE}+ꣳz\\Kη\rKSv:IL\0\0SQi-}Hay,c\nqxF  ?ޠ_z2n_ҝܝK9ui{uT*d'-<{a&2Sޔ}\">+_oHokW\\;>||bYF%b  ڍn-\"Bx2!#Ќ^ ^~D\0vMV\\(P6B_f?o*P  5dʪ#Tb(͒~nFpj <#CF,X|4Ί@ЂbEP,5hl  LbNb G!l\r} 0mG}f?\rP.ܰ|܍ F>\$%I<|cnajD&ՍDh#BMƸ,+HGT0ZJ^c9nqjn%E2zB-kbY\0~HfF!4h\n!lf%@SL~LuuDcX%LMLEOͱ)D6|)Kq7 MMUM\n+|*q \r!\"\$0B!q^βtF1}oDn0n16~x(2\r2X<FPTk&}jV2vS!O,&o))·*.E~R[\" (rW+q=.(*R#B#.+P.#-\rrEKR%2 %i\$ELDC0rG2 p.V®\"EVf,?\$72j`E)E#t7.v2j:*@g2.Ǯ R!sJ #NnpE2gPی('  BB(w0Q2]<_./3*3\$s!w bsb|P\$/>-F=R#AJ9>tsBC!\$+B_`\0VO5e\r&Mtʧ.o.JqC|=Ғ'+'GOG/U0ryrHG2I{Fd4cPqHyIBdZ԰tD(Г64*Fl^hdTU@bs KS@#s!DTb 쩒1yP!PQ5\0( !8+OQtT<5&NB> P[PUBBFLG!g4 ZQU*2¿Rr  XQ%Mlz䋏wCZvV!ND@4 S-f꧋J4V\\pOS4+]k\nVQ*JfF*œ;f4+J?)thalW6N(/:I0\0*,V[+:6&dOcv~h9EpYϤ)\\aF9f X5Ys)R5e#h9doSccIOi/-Ad' s7*-bS.(ra'B@ʢx˼\\@@ I\np eB\0/QS7<{2+:zlqO-uiq2{7 gdvl311J8@p\$&E7BR\0>J@S\\Ur%\nH7\\FmcmCv'#GB4  d#|7\\\"9<8Ȕ> {͍551\$6lV1    ]Q vM23W}\0ӳ1\r\"hx&B>%8_ܦ\ng>)>3-\0s~VjO6%K4\0yAlvd_:&a'xl.   \r,n\0 @ \rj?x<wfhH8rTLRC|РCs  N2 L.|Qvׂ;m]C U\rR0fLbB4BOc&^";break;case"vi":$g="Bp& *(J.0Q,Z)v@Tf\npjp*VC`]rY<#\$b\$L2@%9IΓ4˅d3\rFqt9N1QE3ڡhj [J;o\n(Ub daI¾RiD\0\0A)X8@q:g!C_#y̸6: ڋ.K;.inE{\rB\n'_2ka!W&Asv6'HƻvO IvLØ:J8楩Bakj*#ӊX\n\npEɚ44K\nd@3!pK P k<H\n3|/\" 1J'\0\0PR!1d2V#IpN&   Z)    R܈f1BC\rܘAZ8B<@(4=9%3.sdn4ʠP6`6sH*:7\nb4*\\,ToS*˳2 h  KFt @IV\rC-c!h<!@uw\0)Rԕ<Qтn  ~/E+beLaM]@ёD벅FHq, P\$\$ҋ+DZ(R@-^H#46)j&0rKe0d<\\cp\r m )JH9U\n U~4kݍdYIާYcT]RҏNIU{b s57;ˤ1Cb #{40U3 ]iB:3Ra’*HOqN9`@q:Tke?s*03|(z#uCOuFM(I l]c]Bȕ[Η\n΢p2|t{haҋ|a\$|ӻd1ZC\rd3Dt^@. !6\0poAXjnaDGgUPx/ ؕCX\"aBLm0Gڿ`F+Ks>'̑tD(sgBI>[\r|.쁬nH\n}<%8C\$Wxhv1!Jb0Ў>2Pg.Q\"tR~\n\$\\TC~|oE\nIpI\"AҫCpo?7*:C   4A9EJAC`oVRl\0pDW̒Q  `/\n<)Gfw9\"E P#Q\$'r}DV֚V maBI\nDt8;U)']0Tf@M{Og%?O5<O.;>[VEC,IM!\$&jZL '\\ Q\n?Td|.Bcb5j@{0X&%,vGJXUI,cV@YY 1 ʪcٌ A&H.X 0,Àl64XQ\nЕ\"/Qߨi~\r  !P\n\$ Rưq\n\nYB8(]1gJ͒0\$_   !V4N+atG1҆% Fz#6MDxNLt80׮wP1FuLRk!|I*\0F\0\nbEn\\n.A\"Af\"PRrD`&`BI7S)7Aa!AVsFiP! l_Ā_w`Cx !d\$)'ts!Z'y3&(OdLp&oΤjҐfA\\Rl!%ټfI]\$  vfL1Q)d{KnL-?;FJPZ@Hfy:)ClK\\L0K힑Ԕ9)V]}M/ 2?H!1+oUS7B%}bA\"TQT7Ò;ha\"6.~;ĺ<noQR(蛁u)7\$1J\0Z<t( X\"ck`] Uh]F;{~\n8{d0!;\${,h4Eb;|!#um(d{X{Y4-]WhbĎ6[%%V\"6?9u`/FGF=y M8?f];0Qrf/%.g@et'/YB8O&RsUhӾ 8>^d]u]Y\"Dّu=^C6OFtO\$oZ 9,Xoi\$zp'eY2-^'>JF|J&\$7,^8F`\"I!vH\nYT:w@nm &@0]W    >o .o GX#N\$%0+T>ΈOnP   /j5dP쐑 w.lʻ %^-P |0,f<ȇ4D1Ooĕ,kE\0_ Q ZﺏQN;Ĕi\$pS^oLlC\\M\0C*^kXP55 Ggx;+jZC9§)xQۡwźВ\"\\    b\rv(KG&R\$BbH1ObJG \np*l%\0JPk40\$!\$I4mJv)PIQ\0Sr \rh%Ǩp Ī6dQxzl9%J~,df0dvldp\"U:n/SDF\\ 6K+.H7g62LX_b(Pl@[\$vp8ND7H<\nJOG 2\"pϮβ%N\0W S@UNb!r^.cxNp*Cz`EA^0hGQJb\npy)4hs\09̗vs3NVk5T\r3XU b\nď2ݤc:S5]R4b";break;case"zh":$g="^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*cTAns%O-3!J1.[\$hVdDcMAlN-9@)6_Dseۂ%yP̞BFy s\nZñ()tI4^F'<\$\"H83h73G?5x4Û*)\"`նI\0DYS1 RZL9H]8\$O\\sS1}SUR)v]SJCART- tui D%8sZN]\"^9zW%s\0]92AZx59OO!g)T \0:cH3\01#pF    )\"oCWPrDC/&rI۷5S\\G,ב'1Q, sVVY,sSL1:AS   xG)u'L6fX`ҥH6DŽʍ069+jseAJ=\"\r(p:cD9@6\r;9 幌#8`KC`ՅSb#   9Hs\$b%jG4ji+m;Y\ndQ>\n{7Y><HFϏQNfՎLϤ9xC4 \\ #D49Ax^;p2r#p9 \0; F:>l(k@='ʟ\0<( @BQ|0*n/@WzÜxBBB.@d\$W4\\ ?\08Niԝ\0 G\"z{`(0D2%DCFl!^).&RnND\" ¸Z.#ʱKU{\ncI-p2e\n\r֚@Èu4J3 A\0A\rQF0[1hDR8xS\nIVфyA,S +\nV\na    pݮ\0C8 a\03*g_0F\nEpҞҁVK'eͭna@xA<'\0 A\n}ЈB`EhK1j@Jb!48S,u'\rD 0lDڈqF\0æ` 0DT]O g\"c \"%&f1ᣓxjJk1QKUY1֥1~&8h&1#w,(QȠpV x/c=hN'myM.`wE%rϓƬ˜iA9.w|1wjy\"tO6*YleUǞYN,}S(-B@  N(;(%\r@Lg[SVq\"mpf\r,SYt @DM&/00e퍴{j,Sv    CMWUaP%,T! \$ \"Ik|iÄ Jy-Gmbe]\0^05<W#)¼J1\$XQ&#aF3)CW驌 D'\nL]FJ9Ȩ,: %|OJh\$vy@A*dPW 2{>BDDr89jbw)? -9Vf95<%ڄA:RoblZ:= @: Stި;P+huAIkXLG,qv&  \0^Z#Ce\"6مk{mlE%Qm\"Tr. E8ۚmj&R_oX)KTc꾱ެk]-N6<q,WmXlYGOMkymK-`ur!! bb>'y*bOn\"\$\n.V'DM{IhޡSͧ-3q\0UZ\nU]?g4y{g/jgt).̝0.c*|{.D/1 #7U7[z]{w~.:0<Қ7W*ل؞STN;Y<\\y5S\"|o[?7J{Ov\0˟\0\0, cdREo:ʈ-\0klo9\" \r or\\©~-t£Fˡv\rBGBb&B(>80tIlN;mZVjZf\rV `PCXn \r ne6>Nx \np p9j䌌^hc4#zR<V` pf>.!CҢ>d'㐻F|:\r!jdBؠ\r9\r2R6\"Z'n!vTA<H \"ib֡X|zOލg\n\0C\$2ܓ\0\$cj|e^d@AYn-ةxJ6J:A+8CRFlgzҥ1P @ \r0,FgnL&\$ JxG%jOj貦5C*n2\r! &P: ANn ,E@ \0@  t\n`";break;case"zh-tw":$g="^%ӕ\\r|% u:HB(\\4prneRQ̡D8 S\nt*.tI&GNAʤSV:    t%9Sy:\"<rST, #!j61uL\0U:.I9BK&]\nDX[ }-,r&a;Dxr4&)s3St\rAb EE1ԣg:x]#0, (4\rGqZS )ЪOLP\0Δ:}ryZse\\BABs @2*bPr\n/k)P)<ĩpY.RDLGI,Ii.Oct\0Fdt)\\*/]g9f]^KL)pYr2.)h2]*X!rB #h\r(:AE\n\r#RՎlЦ(K`\$ qlCyRPa s-a~WġrGALKIUYWSj\$PO\\SPSTZC)qPd1H\nY N(Kq]g1G9{aq%)2PQL1pMi|B<QI*[e2ZE8è65-Hc79ԡHtQ˄^DqrmV5̥*eġ]/5Qu+ISN1<[gjYXiW.r[n/68kvThKu3Md86\$\r06:#+u>Κ7n.<9ӎc6\rxacR9p0!:k:VĤBib#Q] >DYC^Grt\"D'Q?j\")H7eLjFvr)JȉL9xG_ӹp@ ,3:x/ pe@p^{\0P^r4pX\"AU\n/ Dj9 S*<{xP(X0F*A(-\"VIJWa-XP  A a\nR 0D\"bsa \$G@ d< Dq.&բ+v:\0O gv^Q(|    !J3!Hl na:uo\r vMȩRl@psM\0  hB\rlshd B\$|2fU=X`3q4p@` ƌ'Pn2('Ԣ2H#3hÐ_a#EK\$\0\0U\n @ &Z<@<A*R9ɒD06\n¿(\"PXr6J*<v< .]U\"]B/hP8O\"ȶu9Y>@f&Q*9Ăj-vG@KH\09)n)D+`)\0\$QN5(WD`(Ȕ@)sQ:*R\na=Ppt@l!G'Tbի@kAD9EK{v.\rHuD556JЪCݎT\\ZȋWLU2xOHx@\n5Ly'oֶ L+]]v-y\rЇ@U\n!A+ Pi4Ź)\r`p>)G@N9t\0ch<sc|r(xKzҳ/E+66EؤmC%\"rQB#z@('cϛ`\nRDKY%)萋=N\nqЯHsa'Ho3ꞗH/LPɦ_HDYے~Y`9t4<(Uչ1an=Zȹ0m@B ψӋW=-!ZjlZzt9gBm&Ifb\"7sһj\\[Юfٱ\$_LoʀP     KAZ7aS4FxxYCo    n]{C臇 ѼLfz[Gj >_5qְ֛pt͹kә#ɻ/='\\w1퓫\\l\$oN8B]2d1_,en?t6^;KD⼕r#yBR?C!KWHj̹4zQxW]\0 .;x\r~yRw#gת~>*Y+BԺukCj~_\\{˜X[wva~ .zO_¨|U,N+o 2j|XBςOU¢\nPo' 6&D2W|*P%6D\"D.JL\$*?P0^\"fg0n*jUyepPk0pk    ؿ0D^F\$fGO\0pRä8c ? ,8>7\r#\"   \r h\"]ifJl\0'P4RHAMhHSF.z%b'@B.emڡ?a1c\"f\rV `~bp%\r p,7@\\Ɲc4s\np qv:Ctf{̨#B8\$`    w@8\r~#09mG KӢW@ހâ:`B}C45ld.ftMzz*\"m\"&-bS9#\"\n\$c.31@\0\r'Dj/ /*Ŷ[Z.!2\nnDU(\$Ձ,\"̙|Ҩhƀ@\nT\n `\0 fjA,`ɤq-O<.1\n j.<?\$ nc^3G*&@4@+n]!%8 dF   \0t @\n`";break;}$vh=array();foreach(explode("\n",lzw_decompress($g))as$X)$vh[]=(strpos($X,"\t")?explode("\t",$X):$X);return$vh;}if(!$vh)$vh=get_translations($ca);if(extension_loaded('pdo')){class
  167. Min_PDO
  168. extends
  169. PDO{var$_result,$server_info,$affected_rows,$errno,$error;function
  170. __construct(){global$b;$wf=array_search("SQL",$b->operators);if($wf!==false)unset($b->operators[$wf]);}function
  171. dsn($cc,$V,$G){try{parent::__construct($cc,$V,$G);}catch(Exception$uc){auth_error($uc->getMessage());}$this->setAttribute(13,array('Min_PDOStatement'));$this->server_info=$this->getAttribute(4);}function
  172. query($H,$Ch=false){$I=parent::query($H);$this->error="";if(!$I){list(,$this->errno,$this->error)=$this->errorInfo();return
  173. false;}$this->store_result($I);return$I;}function
  174. multi_query($H){return$this->_result=$this->query($H);}function
  175. store_result($I=null){if(!$I){$I=$this->_result;if(!$I)return
  176. false;}if($I->columnCount()){$I->num_rows=$I->rowCount();return$I;}$this->affected_rows=$I->rowCount();return
  177. true;}function
  178. next_result(){if(!$this->_result)return
  179. false;$this->_result->_offset=0;return@$this->_result->nextRowset();}function
  180. result($H,$o=0){$I=$this->query($H);if(!$I)return
  181. false;$K=$I->fetch();return$K[$o];}}class
  182. Min_PDOStatement
  183. extends
  184. PDOStatement{var$_offset=0,$num_rows;function
  185. fetch_assoc(){return$this->fetch(2);}function
  186. fetch_row(){return$this->fetch(3);}function
  187. 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;}}}$Xb=array();class
  188. Min_SQL{var$_conn;function
  189. __construct($h){$this->_conn=$h;}function
  190. select($Q,$M,$Z,$Xc,$We=array(),$z=1,$E=0,$Df=false){global$b,$w;$Ad=(count($Xc)<count($M));$H=$b->selectQueryBuild($M,$Z,$Xc,$We,$z,$E);if(!$H)$H="SELECT".limit(($_GET["page"]!="last"&&+$z&&$Xc&&$Ad&&$w=="sql"?"SQL_CALC_FOUND_ROWS ":"").implode(", ",$M)."\nFROM ".table($Q),($Z?"\nWHERE ".implode(" AND ",$Z):"").($Xc&&$Ad?"\nGROUP BY ".implode(", ",$Xc):"").($We?"\nORDER BY ".implode(", ",$We):""),($z!=""?+$z:null),($E?$z*$E:0),"\n");$Hg=microtime(true);$J=$this->_conn->query($H);if($Df)echo$b->selectQuery($H,format_time($Hg));return$J;}function
  191. delete($Q,$Mf,$z=0){$H="FROM ".table($Q);return
  192. queries("DELETE".($z?limit1($H,$Mf):" $H$Mf"));}function
  193. update($Q,$O,$Mf,$z=0,$ug="\n"){$Th=array();foreach($O
  194. as$x=>$X)$Th[]="$x = $X";$H=table($Q)." SET$ug".implode(",$ug",$Th);return
  195. queries("UPDATE".($z?limit1($H,$Mf):" $H$Mf"));}function
  196. insert($Q,$O){return
  197. queries("INSERT INTO ".table($Q).($O?" (".implode(", ",array_keys($O)).")\nVALUES (".implode(", ",$O).")":" DEFAULT VALUES"));}function
  198. insertUpdate($Q,$L,$Bf){return
  199. false;}function
  200. begin(){return
  201. queries("BEGIN");}function
  202. commit(){return
  203. queries("COMMIT");}function
  204. rollback(){return
  205. queries("ROLLBACK");}}$Xb["sqlite"]="SQLite 3";$Xb["sqlite2"]="SQLite 2";if(isset($_GET["sqlite"])||isset($_GET["sqlite2"])){$zf=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
  206. Min_SQLite{var$extension="SQLite3",$server_info,$affected_rows,$errno,$error,$_link;function
  207. __construct($Ic){$this->_link=new
  208. SQLite3($Ic);$Wh=$this->_link->version();$this->server_info=$Wh["versionString"];}function
  209. query($H){$I=@$this->_link->query($H);$this->error="";if(!$I){$this->errno=$this->_link->lastErrorCode();$this->error=$this->_link->lastErrorMsg();return
  210. false;}elseif($I->numColumns())return
  211. new
  212. Min_Result($I);$this->affected_rows=$this->_link->changes();return
  213. true;}function
  214. quote($P){return(is_utf8($P)?"'".$this->_link->escapeString($P)."'":"x'".reset(unpack('H*',$P))."'");}function
  215. store_result(){return$this->_result;}function
  216. result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
  217. false;$K=$I->_result->fetchArray();return$K[$o];}}class
  218. Min_Result{var$_result,$_offset=0,$num_rows;function
  219. __construct($I){$this->_result=$I;}function
  220. fetch_assoc(){return$this->_result->fetchArray(SQLITE3_ASSOC);}function
  221. fetch_row(){return$this->_result->fetchArray(SQLITE3_NUM);}function
  222. fetch_field(){$e=$this->_offset++;$U=$this->_result->columnType($e);return(object)array("name"=>$this->_result->columnName($e),"type"=>$U,"charsetnr"=>($U==SQLITE3_BLOB?63:0),);}function
  223. __desctruct(){return$this->_result->finalize();}}}else{class
  224. Min_SQLite{var$extension="SQLite",$server_info,$affected_rows,$error,$_link;function
  225. __construct($Ic){$this->server_info=sqlite_libversion();$this->_link=new
  226. SQLiteDatabase($Ic);}function
  227. query($H,$Ch=false){$re=($Ch?"unbufferedQuery":"query");$I=@$this->_link->$re($H,SQLITE_BOTH,$n);$this->error="";if(!$I){$this->error=$n;return
  228. false;}elseif($I===true){$this->affected_rows=$this->changes();return
  229. true;}return
  230. new
  231. Min_Result($I);}function
  232. quote($P){return"'".sqlite_escape_string($P)."'";}function
  233. store_result(){return$this->_result;}function
  234. result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
  235. false;$K=$I->_result->fetch();return$K[$o];}}class
  236. Min_Result{var$_result,$_offset=0,$num_rows;function
  237. __construct($I){$this->_result=$I;if(method_exists($I,'numRows'))$this->num_rows=$I->numRows();}function
  238. fetch_assoc(){$K=$this->_result->fetch(SQLITE_ASSOC);if(!$K)return
  239. false;$J=array();foreach($K
  240. as$x=>$X)$J[($x[0]=='"'?idf_unescape($x):$x)]=$X;return$J;}function
  241. fetch_row(){return$this->_result->fetch(SQLITE_NUM);}function
  242. fetch_field(){$C=$this->_result->fieldName($this->_offset++);$sf='(\\[.*]|"(?:[^"]|"")*"|(.+))';if(preg_match("~^($sf\\.)?$sf\$~",$C,$B)){$Q=($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"=>$Q,);}}}}elseif(extension_loaded("pdo_sqlite")){class
  243. Min_SQLite
  244. extends
  245. Min_PDO{var$extension="PDO_SQLite";function
  246. __construct($Ic){$this->dsn(DRIVER.":$Ic","","");}}}if(class_exists("Min_SQLite")){class
  247. Min_DB
  248. extends
  249. Min_SQLite{function
  250. __construct(){parent::__construct(":memory:");}function
  251. select_db($Ic){if(is_readable($Ic)&&$this->query("ATTACH ".$this->quote(preg_match("~(^[/\\\\]|:)~",$Ic)?$Ic:dirname($_SERVER["SCRIPT_FILENAME"])."/$Ic")." AS a")){parent::__construct($Ic);return
  252. true;}return
  253. false;}function
  254. multi_query($H){return$this->_result=$this->query($H);}function
  255. next_result(){return
  256. false;}}}class
  257. Min_Driver
  258. extends
  259. Min_SQL{function
  260. insertUpdate($Q,$L,$Bf){$Th=array();foreach($L
  261. as$O)$Th[]="(".implode(", ",$O).")";return
  262. queries("REPLACE INTO ".table($Q)." (".implode(", ",array_keys(reset($L))).") VALUES\n".implode(",\n",$Th));}}function
  263. idf_escape($t){return'"'.str_replace('"','""',$t).'"';}function
  264. table($t){return
  265. idf_escape($t);}function
  266. connect(){return
  267. new
  268. Min_DB;}function
  269. get_databases(){return
  270. array();}function
  271. limit($H,$Z,$z,$D=0,$ug=" "){return" $H$Z".($z!==null?$ug."LIMIT $z".($D?" OFFSET $D":""):"");}function
  272. limit1($H,$Z){global$h;return($h->result("SELECT sqlite_compileoption_used('ENABLE_UPDATE_DELETE_LIMIT')")?limit($H,$Z,1):" $H$Z");}function
  273. db_collation($m,$nb){global$h;return$h->result("PRAGMA encoding");}function
  274. engines(){return
  275. array();}function
  276. logged_user(){return
  277. get_current_user();}function
  278. tables_list(){return
  279. get_key_vals("SELECT name, type FROM sqlite_master WHERE type IN ('table', 'view') ORDER BY (name = 'sqlite_sequence'), name",1);}function
  280. count_tables($l){return
  281. array();}function
  282. table_status($C=""){global$h;$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"]=$h->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
  283. is_view($R){return$R["Engine"]=="view";}function
  284. fk_support($R){global$h;return!$h->result("SELECT sqlite_compileoption_used('OMIT_FOREIGN_KEY')");}function
  285. fields($Q){global$h;$J=array();$Bf="";foreach(get_rows("PRAGMA table_info(".table($Q).")")as$K){$C=$K["name"];$U=strtolower($K["type"]);$Lb=$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("~'(.*)'~",$Lb,$B)?str_replace("''","'",$B[1]):($Lb=="NULL"?null:$Lb)),"null"=>!$K["notnull"],"privileges"=>array("select"=>1,"insert"=>1,"update"=>1),"primary"=>$K["pk"],);if($K["pk"]){if($Bf!="")$J[$Bf]["auto_increment"]=false;elseif(preg_match('~^integer$~i',$U))$J[$C]["auto_increment"]=true;$Bf=$C;}}$Fg=$h->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($Q));preg_match_all('~(("[^"]*+")+|[a-z0-9_]+)\s+text\s+COLLATE\s+(\'[^\']+\'|\S+)~i',$Fg,$de,PREG_SET_ORDER);foreach($de
  286. as$B){$C=str_replace('""','"',preg_replace('~^"|"$~','',$B[1]));if($J[$C])$J[$C]["collation"]=trim($B[3],"'");}return$J;}function
  287. indexes($Q,$i=null){global$h;if(!is_object($i))$i=$h;$J=array();$Fg=$i->result("SELECT sql FROM sqlite_master WHERE type = 'table' AND name = ".q($Q));if(preg_match('~\bPRIMARY\s+KEY\s*\((([^)"]+|"[^"]*")++)~i',$Fg,$B)){$J[""]=array("type"=>"PRIMARY","columns"=>array(),"lengths"=>array(),"descs"=>array());preg_match_all('~((("[^"]*+")+)|(\S+))(\s+(ASC|DESC))?(,\s*|$)~i',$B[1],$de,PREG_SET_ORDER);foreach($de
  288. as$B){$J[""]["columns"][]=idf_unescape($B[2]).$B[4];$J[""]["descs"][]=(preg_match('~DESC~i',$B[5])?'1':null);}}if(!$J){foreach(fields($Q)as$C=>$o){if($o["primary"])$J[""]=array("type"=>"PRIMARY","columns"=>array($C),"lengths"=>array(),"descs"=>array(null));}}$Gg=get_key_vals("SELECT name, sql FROM sqlite_master WHERE type = 'index' AND tbl_name = ".q($Q),$i);foreach(get_rows("PRAGMA index_list(".table($Q).")",$i)as$K){$C=$K["name"];$u=array("type"=>($K["unique"]?"UNIQUE":"INDEX"));$u["lengths"]=array();$u["descs"]=array();foreach(get_rows("PRAGMA index_info(".idf_escape($C).")",$i)as$kg){$u["columns"][]=$kg["name"];$u["descs"][]=null;}if(preg_match('~^CREATE( UNIQUE)? INDEX '.preg_quote(idf_escape($C).' ON '.idf_escape($Q),'~').' \((.*)\)$~i',$Gg[$C],$Xf)){preg_match_all('/("[^"]*+")+( DESC)?/',$Xf[2],$de);foreach($de[2]as$x=>$X){if($X)$u["descs"][$x]='1';}}if(!$J[""]||$u["type"]!="UNIQUE"||$u["columns"]!=$J[""]["columns"]||$u["descs"]!=$J[""]["descs"]||!preg_match("~^sqlite_~",$C))$J[$C]=$u;}return$J;}function
  289. foreign_keys($Q){$J=array();foreach(get_rows("PRAGMA foreign_key_list(".table($Q).")")as$K){$q=&$J[$K["id"]];if(!$q)$q=$K;$q["source"][]=$K["from"];$q["target"][]=$K["to"];}return$J;}function
  290. view($C){global$h;return
  291. array("select"=>preg_replace('~^(?:[^`"[]+|`[^`]*`|"[^"]*")* AS\\s+~iU','',$h->result("SELECT sql FROM sqlite_master WHERE name = ".q($C))));}function
  292. collations(){return(isset($_GET["create"])?get_vals("PRAGMA collation_list",1):array());}function
  293. information_schema($m){return
  294. false;}function
  295. error(){global$h;return
  296. h($h->error);}function
  297. check_sqlite_name($C){global$h;$Cc="db|sdb|sqlite";if(!preg_match("~^[^\\0]*\\.($Cc)\$~",$C)){$h->error=lang(21,str_replace("|",", ",$Cc));return
  298. false;}return
  299. true;}function
  300. create_database($m,$d){global$h;if(file_exists($m)){$h->error=lang(22);return
  301. false;}if(!check_sqlite_name($m))return
  302. false;try{$_=new
  303. Min_SQLite($m);}catch(Exception$uc){$h->error=$uc->getMessage();return
  304. false;}$_->query('PRAGMA encoding = "UTF-8"');$_->query('CREATE TABLE adminer (i)');$_->query('DROP TABLE adminer');return
  305. true;}function
  306. drop_databases($l){global$h;$h->__construct(":memory:");foreach($l
  307. as$m){if(!@unlink($m)){$h->error=lang(22);return
  308. false;}}return
  309. true;}function
  310. rename_database($C,$d){global$h;if(!check_sqlite_name($C))return
  311. false;$h->__construct(":memory:");$h->error=lang(22);return@rename(DB,$C);}function
  312. auto_increment(){return" PRIMARY KEY".(DRIVER=="sqlite"?" AUTOINCREMENT":"");}function
  313. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){$Nh=($Q==""||$Mc);foreach($p
  314. as$o){if($o[0]!=""||!$o[1]||$o[2]){$Nh=true;break;}}$c=array();$ef=array();foreach($p
  315. as$o){if($o[1]){$c[]=($Nh?$o[1]:"ADD ".implode($o[1]));if($o[0]!="")$ef[$o[0]]=$o[1][0];}}if(!$Nh){foreach($c
  316. as$X){if(!queries("ALTER TABLE ".table($Q)." $X"))return
  317. false;}if($Q!=$C&&!queries("ALTER TABLE ".table($Q)." RENAME TO ".table($C)))return
  318. false;}elseif(!recreate_table($Q,$C,$c,$ef,$Mc))return
  319. false;if($La)queries("UPDATE sqlite_sequence SET seq = $La WHERE name = ".q($C));return
  320. true;}function
  321. recreate_table($Q,$C,$p,$ef,$Mc,$v=array()){if($Q!=""){if(!$p){foreach(fields($Q)as$x=>$o){$p[]=process_field($o,$o);$ef[$x]=idf_escape($x);}}$Cf=false;foreach($p
  322. as$o){if($o[6])$Cf=true;}$ac=array();foreach($v
  323. as$x=>$X){if($X[2]=="DROP"){$ac[$X[1]]=true;unset($v[$x]);}}foreach(indexes($Q)as$Jd=>$u){$f=array();foreach($u["columns"]as$x=>$e){if(!$ef[$e])continue
  324. 2;$f[]=$ef[$e].($u["descs"][$x]?" DESC":"");}if(!$ac[$Jd]){if($u["type"]!="PRIMARY"||!$Cf)$v[]=array($u["type"],$Jd,$f);}}foreach($v
  325. as$x=>$X){if($X[0]=="PRIMARY"){unset($v[$x]);$Mc[]="  PRIMARY KEY (".implode(", ",$X[2]).")";}}foreach(foreign_keys($Q)as$Jd=>$q){foreach($q["source"]as$x=>$e){if(!$ef[$e])continue
  326. 2;$q["source"][$x]=idf_unescape($ef[$e]);}if(!isset($Mc[" $Jd"]))$Mc[]=" ".format_foreign_key($q);}queries("BEGIN");}foreach($p
  327. as$x=>$o)$p[$x]="  ".implode($o);$p=array_merge($p,array_filter($Mc));if(!queries("CREATE TABLE ".table($Q!=""?"adminer_$C":$C)." (\n".implode(",\n",$p)."\n)"))return
  328. false;if($Q!=""){if($ef&&!queries("INSERT INTO ".table("adminer_$C")." (".implode(", ",$ef).") SELECT ".implode(", ",array_map('idf_escape',array_keys($ef)))." FROM ".table($Q)))return
  329. false;$zh=array();foreach(triggers($Q)as$xh=>$kh){$wh=trigger($xh);$zh[]="CREATE TRIGGER ".idf_escape($xh)." ".implode(" ",$kh)." ON ".table($C)."\n$wh[Statement]";}if(!queries("DROP TABLE ".table($Q)))return
  330. false;queries("ALTER TABLE ".table("adminer_$C")." RENAME TO ".table($C));if(!alter_indexes($C,$v))return
  331. false;foreach($zh
  332. as$wh){if(!queries($wh))return
  333. false;}queries("COMMIT");}return
  334. true;}function
  335. index_sql($Q,$U,$C,$f){return"CREATE $U ".($U!="INDEX"?"INDEX ":"").idf_escape($C!=""?$C:uniqid($Q."_"))." ON ".table($Q)." $f";}function
  336. alter_indexes($Q,$c){foreach($c
  337. as$Bf){if($Bf[0]=="PRIMARY")return
  338. recreate_table($Q,$Q,array(),array(),array(),$c);}foreach(array_reverse($c)as$X){if(!queries($X[2]=="DROP"?"DROP INDEX ".idf_escape($X[1]):index_sql($Q,$X[0],$X[1],"(".implode(", ",$X[2]).")")))return
  339. false;}return
  340. true;}function
  341. truncate_tables($S){return
  342. apply_queries("DELETE FROM",$S);}function
  343. drop_views($Yh){return
  344. apply_queries("DROP VIEW",$Yh);}function
  345. drop_tables($S){return
  346. apply_queries("DROP TABLE",$S);}function
  347. move_tables($S,$Yh,$bh){return
  348. false;}function
  349. trigger($C){global$h;if($C=="")return
  350. array("Statement"=>"BEGIN\n\t;\nEND");$t='(?:[^`"\\s]+|`[^`]*`|"[^"]*")+';$yh=trigger_options();preg_match("~^CREATE\\s+TRIGGER\\s*$t\\s*(".implode("|",$yh["Timing"]).")\\s+([a-z]+)(?:\\s+OF\\s+($t))?\\s+ON\\s*$t\\s*(?:FOR\\s+EACH\\s+ROW\\s)?(.*)~is",$h->result("SELECT sql FROM sqlite_master WHERE type = 'trigger' AND name = ".q($C)),$B);$Fe=$B[3];return
  351. array("Timing"=>strtoupper($B[1]),"Event"=>strtoupper($B[2]).($Fe?" OF":""),"Of"=>($Fe[0]=='`'||$Fe[0]=='"'?idf_unescape($Fe):$Fe),"Trigger"=>$C,"Statement"=>$B[4],);}function
  352. triggers($Q){$J=array();$yh=trigger_options();foreach(get_rows("SELECT * FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($Q))as$K){preg_match('~^CREATE\\s+TRIGGER\\s*(?:[^`"\\s]+|`[^`]*`|"[^"]*")+\\s*('.implode("|",$yh["Timing"]).')\\s*(.*)\\s+ON\\b~iU',$K["sql"],$B);$J[$K["name"]]=array($B[1],$B[2]);}return$J;}function
  353. trigger_options(){return
  354. array("Timing"=>array("BEFORE","AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","UPDATE OF","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
  355. routine($C,$U){}function
  356. routines(){}function
  357. routine_languages(){}function
  358. begin(){return
  359. queries("BEGIN");}function
  360. last_id(){global$h;return$h->result("SELECT LAST_INSERT_ROWID()");}function
  361. explain($h,$H){return$h->query("EXPLAIN QUERY PLAN $H");}function
  362. found_rows($R,$Z){}function
  363. types(){return
  364. array();}function
  365. schemas(){return
  366. array();}function
  367. get_schema(){return"";}function
  368. set_schema($og){return
  369. true;}function
  370. create_sql($Q,$La){global$h;$J=$h->result("SELECT sql FROM sqlite_master WHERE type IN ('table', 'view') AND name = ".q($Q));foreach(indexes($Q)as$C=>$u){if($C=='')continue;$J.=";\n\n".index_sql($Q,$u['type'],$C,"(".implode(", ",array_map('idf_escape',$u['columns'])).")");}return$J;}function
  371. truncate_sql($Q){return"DELETE FROM ".table($Q);}function
  372. use_sql($Gb){}function
  373. trigger_sql($Q,$Mg){return
  374. implode(get_vals("SELECT sql || ';;\n' FROM sqlite_master WHERE type = 'trigger' AND tbl_name = ".q($Q)));}function
  375. show_variables(){global$h;$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$x)$J[$x]=$h->result("PRAGMA $x");return$J;}function
  376. show_status(){$J=array();foreach(get_vals("PRAGMA compile_options")as$Te){list($x,$X)=explode("=",$Te,2);$J[$x]=$X;}return$J;}function
  377. convert_field($o){}function
  378. unconvert_field($o,$J){return$J;}function
  379. support($Fc){return
  380. preg_match('~^(columns|database|drop_col|dump|indexes|move_col|sql|status|table|trigger|variables|view|view_trigger)$~',$Fc);}$w="sqlite";$Bh=array("integer"=>0,"real"=>0,"numeric"=>0,"text"=>0,"blob"=>0);$Lg=array_keys($Bh);$Ih=array();$Re=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL","SQL");$Uc=array("hex","length","lower","round","unixepoch","upper");$Zc=array("avg","count","count distinct","group_concat","max","min","sum");$fc=array(array(),array("integer|real|numeric"=>"+/-","text"=>"||",));}$Xb["pgsql"]="PostgreSQL";if(isset($_GET["pgsql"])){$zf=array("PgSQL","PDO_PgSQL");define("DRIVER","pgsql");if(extension_loaded("pgsql")){class
  381. Min_DB{var$extension="PgSQL",$_link,$_result,$_string,$_database=true,$server_info,$affected_rows,$error;function
  382. _error($qc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
  383. 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){$Wh=pg_version($this->_link);$this->server_info=$Wh["server"];pg_set_client_encoding($this->_link,"UTF8");}return(bool)$this->_link;}function
  384. quote($P){return"'".pg_escape_string($this->_link,$P)."'";}function
  385. select_db($Gb){global$b;if($Gb==$b->database())return$this->_database;$J=@pg_connect("$this->_string dbname='".addcslashes($Gb,"'\\")."'",PGSQL_CONNECT_FORCE_NEW);if($J)$this->_link=$J;return$J;}function
  386. close(){$this->_link=@pg_connect("$this->_string dbname='postgres'");}function
  387. query($H,$Ch=false){$I=@pg_query($this->_link,$H);$this->error="";if(!$I){$this->error=pg_last_error($this->_link);return
  388. false;}elseif(!pg_num_fields($I)){$this->affected_rows=pg_affected_rows($I);return
  389. true;}return
  390. new
  391. Min_Result($I);}function
  392. multi_query($H){return$this->_result=$this->query($H);}function
  393. store_result(){return$this->_result;}function
  394. next_result(){return
  395. false;}function
  396. result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
  397. false;return
  398. pg_fetch_result($I->_result,0,$o);}}class
  399. Min_Result{var$_result,$_offset=0,$num_rows;function
  400. __construct($I){$this->_result=$I;$this->num_rows=pg_num_rows($I);}function
  401. fetch_assoc(){return
  402. pg_fetch_assoc($this->_result);}function
  403. fetch_row(){return
  404. pg_fetch_row($this->_result);}function
  405. fetch_field(){$e=$this->_offset++;$J=new
  406. stdClass;if(function_exists('pg_field_table'))$J->orgtable=pg_field_table($this->_result,$e);$J->name=pg_field_name($this->_result,$e);$J->orgname=$J->name;$J->type=pg_field_type($this->_result,$e);$J->charsetnr=($J->type=="bytea"?63:0);return$J;}function
  407. __destruct(){pg_free_result($this->_result);}}}elseif(extension_loaded("pdo_pgsql")){class
  408. Min_DB
  409. extends
  410. Min_PDO{var$extension="PDO_PgSQL";function
  411. connect($N,$V,$G){global$b;$m=$b->database();$P="pgsql:host='".str_replace(":","' port='",addcslashes($N,"'\\"))."' options='-c client_encoding=utf8'";$this->dsn("$P dbname='".($m!=""?addcslashes($m,"'\\"):"postgres")."'",$V,$G);return
  412. true;}function
  413. select_db($Gb){global$b;return($b->database()==$Gb);}function
  414. close(){}}}class
  415. Min_Driver
  416. extends
  417. Min_SQL{function
  418. insertUpdate($Q,$L,$Bf){global$h;foreach($L
  419. as$O){$Jh=array();$Z=array();foreach($O
  420. as$x=>$X){$Jh[]="$x = $X";if(isset($Bf[idf_unescape($x)]))$Z[]="$x = $X";}if(!(($Z&&queries("UPDATE ".table($Q)." SET ".implode(", ",$Jh)." WHERE ".implode(" AND ",$Z))&&$h->affected_rows)||queries("INSERT INTO ".table($Q)." (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).")")))return
  421. false;}return
  422. true;}}function
  423. idf_escape($t){return'"'.str_replace('"','""',$t).'"';}function
  424. table($t){return
  425. idf_escape($t);}function
  426. connect(){global$b;$h=new
  427. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2])){if($h->server_info>=9)$h->query("SET application_name = 'Adminer'");return$h;}return$h->error;}function
  428. get_databases(){return
  429. get_vals("SELECT datname FROM pg_database ORDER BY datname");}function
  430. limit($H,$Z,$z,$D=0,$ug=" "){return" $H$Z".($z!==null?$ug."LIMIT $z".($D?" OFFSET $D":""):"");}function
  431. limit1($H,$Z){return" $H$Z";}function
  432. db_collation($m,$nb){global$h;return$h->result("SHOW LC_COLLATE");}function
  433. engines(){return
  434. array();}function
  435. logged_user(){global$h;return$h->result("SELECT user");}function
  436. tables_list(){$H="SELECT table_name, table_type FROM information_schema.tables WHERE table_schema = current_schema()";if(support('materializedview'))$H.="
  437. UNION ALL
  438. SELECT matviewname, 'MATERIALIZED VIEW'
  439. FROM pg_matviews
  440. WHERE schemaname = current_schema()";$H.="
  441. ORDER BY 1";return
  442. get_key_vals($H);}function
  443. count_tables($l){return
  444. array();}function
  445. table_status($C=""){$J=array();foreach(get_rows("SELECT relname AS \"Name\", CASE relkind WHEN 'r' THEN 'table' WHEN 'mv' THEN 'materialized view' WHEN 'f' THEN 'foreign table' ELSE 'view' END AS \"Engine\", pg_relation_size(oid) AS \"Data_length\", pg_total_relation_size(oid) - pg_relation_size(oid) AS \"Index_length\", obj_description(oid, 'pg_class') AS \"Comment\", relhasoids::int AS \"Oid\", reltuples as \"Rows\"
  446. FROM pg_class
  447. WHERE relkind IN ('r','v','mv','f')
  448. AND relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema())
  449. ".($C!=""?"AND relname = ".q($C):"ORDER BY relname"))as$K)$J[$K["Name"]]=$K;return($C!=""?$J[$C]:$J);}function
  450. is_view($R){return
  451. in_array($R["Engine"],array("view","materialized view"));}function
  452. fk_support($R){return
  453. true;}function
  454. fields($Q){$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
  455. FROM pg_class c
  456. JOIN pg_namespace n ON c.relnamespace = n.oid
  457. JOIN pg_attribute a ON c.oid = a.attrelid
  458. LEFT JOIN pg_attrdef d ON c.oid = d.adrelid AND a.attnum = d.adnum
  459. WHERE c.relname = ".q($Q)."
  460. AND n.nspname = current_schema()
  461. AND NOT a.attisdropped
  462. AND a.attnum > 0
  463. ORDER BY a.attnum")as$K){preg_match('~([^([]+)(\((.*)\))?([a-z ]+)?((\[[0-9]*])*)$~',$K["full_type"],$B);list(,$U,$y,$K["length"],$wa,$Fa)=$B;$K["length"].=$Fa;$cb=$U.$wa;if(isset($Ca[$cb])){$K["type"]=$Ca[$cb];$K["full_type"]=$K["type"].$y.$Fa;}else{$K["type"]=$U;$K["full_type"]=$K["type"].$y.$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
  464. indexes($Q,$i=null){global$h;if(!is_object($i))$i=$h;$J=array();$Ug=$i->result("SELECT oid FROM pg_class WHERE relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema()) AND relname = ".q($Q));$f=get_key_vals("SELECT attnum, attname FROM pg_attribute WHERE attrelid = $Ug AND attnum > 0",$i);foreach(get_rows("SELECT relname, indisunique::int, indisprimary::int, indkey, indoption FROM pg_index i, pg_class ci WHERE i.indrelid = $Ug AND ci.oid = i.indexrelid",$i)as$K){$Yf=$K["relname"];$J[$Yf]["type"]=($K["indisprimary"]?"PRIMARY":($K["indisunique"]?"UNIQUE":"INDEX"));$J[$Yf]["columns"]=array();foreach(explode(" ",$K["indkey"])as$qd)$J[$Yf]["columns"][]=$f[$qd];$J[$Yf]["descs"]=array();foreach(explode(" ",$K["indoption"])as$rd)$J[$Yf]["descs"][]=($rd&1?'1':null);$J[$Yf]["lengths"]=array();}return$J;}function
  465. foreign_keys($Q){global$Me;$J=array();foreach(get_rows("SELECT conname, pg_get_constraintdef(oid) AS definition
  466. FROM pg_constraint
  467. 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($Q)." AND pn.nspname = current_schema())
  468. AND contype = 'f'::char
  469. 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],$ce)){$K['ns']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$ce[2]));$K['table']=str_replace('""','"',preg_replace('~^"(.+)"$~','\1',$ce[4]));}$K['target']=array_map('trim',explode(',',$B[3]));$K['on_delete']=(preg_match("~ON DELETE ($Me)~",$B[4],$ce)?$ce[1]:'NO ACTION');$K['on_update']=(preg_match("~ON UPDATE ($Me)~",$B[4],$ce)?$ce[1]:'NO ACTION');$J[$K['conname']]=$K;}}return$J;}function
  470. view($C){global$h;return
  471. array("select"=>$h->result("SELECT pg_get_viewdef(".q($C).")"));}function
  472. collations(){return
  473. array();}function
  474. information_schema($m){return($m=="information_schema");}function
  475. error(){global$h;$J=h($h->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
  476. nl_br($J);}function
  477. create_database($m,$d){return
  478. queries("CREATE DATABASE ".idf_escape($m).($d?" ENCODING ".idf_escape($d):""));}function
  479. drop_databases($l){global$h;$h->close();return
  480. apply_queries("DROP DATABASE",$l,'idf_escape');}function
  481. rename_database($C,$d){return
  482. queries("ALTER DATABASE ".idf_escape(DB)." RENAME TO ".idf_escape($C));}function
  483. auto_increment(){return"";}function
  484. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){$c=array();$Lf=array();foreach($p
  485. as$o){$e=idf_escape($o[0]);$X=$o[1];if(!$X)$c[]="DROP $e";else{$Sh=$X[5];unset($X[5]);if(isset($X[6])&&$o[0]=="")$X[1]=($X[1]=="bigint"?" big":" ")."serial";if($o[0]=="")$c[]=($Q!=""?"ADD ":"  ").implode($X);else{if($e!=$X[0])$Lf[]="ALTER TABLE ".table($Q)." RENAME $e TO $X[0]";$c[]="ALTER $e TYPE$X[1]";if(!$X[6]){$c[]="ALTER $e ".($X[3]?"SET$X[3]":"DROP DEFAULT");$c[]="ALTER $e ".($X[2]==" NULL"?"DROP NOT":"SET").$X[2];}}if($o[0]!=""||$Sh!="")$Lf[]="COMMENT ON COLUMN ".table($Q).".$X[0] IS ".($Sh!=""?substr($Sh,9):"''");}}$c=array_merge($c,$Mc);if($Q=="")array_unshift($Lf,"CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");elseif($c)array_unshift($Lf,"ALTER TABLE ".table($Q)."\n".implode(",\n",$c));if($Q!=""&&$Q!=$C)$Lf[]="ALTER TABLE ".table($Q)." RENAME TO ".table($C);if($Q!=""||$rb!="")$Lf[]="COMMENT ON TABLE ".table($C)." IS ".q($rb);if($La!=""){}foreach($Lf
  486. as$H){if(!queries($H))return
  487. false;}return
  488. true;}function
  489. alter_indexes($Q,$c){$j=array();$Yb=array();$Lf=array();foreach($c
  490. as$X){if($X[0]!="INDEX")$j[]=($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")$Yb[]=idf_escape($X[1]);else$Lf[]="CREATE INDEX ".idf_escape($X[1]!=""?$X[1]:uniqid($Q."_"))." ON ".table($Q)." (".implode(", ",$X[2]).")";}if($j)array_unshift($Lf,"ALTER TABLE ".table($Q).implode(",",$j));if($Yb)array_unshift($Lf,"DROP INDEX ".implode(", ",$Yb));foreach($Lf
  491. as$H){if(!queries($H))return
  492. false;}return
  493. true;}function
  494. truncate_tables($S){return
  495. queries("TRUNCATE ".implode(", ",array_map('table',$S)));return
  496. true;}function
  497. drop_views($Yh){return
  498. drop_tables($Yh);}function
  499. drop_tables($S){foreach($S
  500. as$Q){$Ig=table_status($Q);if(!queries("DROP ".strtoupper($Ig["Engine"])." ".table($Q)))return
  501. false;}return
  502. true;}function
  503. move_tables($S,$Yh,$bh){foreach(array_merge($S,$Yh)as$Q){$Ig=table_status($Q);if(!queries("ALTER ".strtoupper($Ig["Engine"])." ".table($Q)." SET SCHEMA ".idf_escape($bh)))return
  504. false;}return
  505. true;}function
  506. trigger($C){if($C=="")return
  507. array("Statement"=>"EXECUTE PROCEDURE ()");$L=get_rows('SELECT trigger_name AS "Trigger", condition_timing AS "Timing", event_manipulation AS "Event", \'FOR EACH \' || action_orientation AS "Type", action_statement AS "Statement" FROM information_schema.triggers WHERE event_object_table = '.q($_GET["trigger"]).' AND trigger_name = '.q($C));return
  508. reset($L);}function
  509. triggers($Q){$J=array();foreach(get_rows("SELECT * FROM information_schema.triggers WHERE event_object_table = ".q($Q))as$K)$J[$K["trigger_name"]]=array($K["condition_timing"],$K["event_manipulation"]);return$J;}function
  510. trigger_options(){return
  511. array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW","FOR EACH STATEMENT"),);}function
  512. routines(){return
  513. get_rows('SELECT p.proname AS "ROUTINE_NAME", p.proargtypes AS "ROUTINE_TYPE", pg_catalog.format_type(p.prorettype, NULL) AS "DTD_IDENTIFIER"
  514. FROM pg_catalog.pg_namespace n
  515. JOIN pg_catalog.pg_proc p ON p.pronamespace = n.oid
  516. WHERE n.nspname = current_schema()
  517. ORDER BY p.proname');}function
  518. routine_languages(){return
  519. get_vals("SELECT langname FROM pg_catalog.pg_language");}function
  520. last_id(){return
  521. 0;}function
  522. explain($h,$H){return$h->query("EXPLAIN $H");}function
  523. found_rows($R,$Z){global$h;if(preg_match("~ rows=([0-9]+)~",$h->result("EXPLAIN SELECT * FROM ".idf_escape($R["Name"]).($Z?" WHERE ".implode(" AND ",$Z):"")),$Xf))return$Xf[1];return
  524. false;}function
  525. types(){return
  526. get_vals("SELECT typname
  527. FROM pg_type
  528. WHERE typnamespace = (SELECT oid FROM pg_namespace WHERE nspname = current_schema())
  529. AND typtype IN ('b','d','e')
  530. AND typelem = 0");}function
  531. schemas(){return
  532. get_vals("SELECT nspname FROM pg_namespace ORDER BY nspname");}function
  533. get_schema(){global$h;return$h->result("SELECT current_schema()");}function
  534. set_schema($ng){global$h,$Bh,$Lg;$J=$h->query("SET search_path TO ".idf_escape($ng));foreach(types()as$U){if(!isset($Bh[$U])){$Bh[$U]=0;$Lg[lang(23)][]=$U;}}return$J;}function
  535. use_sql($Gb){return"\connect ".idf_escape($Gb);}function
  536. show_variables(){return
  537. get_key_vals("SHOW ALL");}function
  538. process_list(){global$h;return
  539. get_rows("SELECT * FROM pg_stat_activity ORDER BY ".($h->server_info<9.2?"procpid":"pid"));}function
  540. show_status(){}function
  541. convert_field($o){}function
  542. unconvert_field($o,$J){return$J;}function
  543. support($Fc){global$h;return
  544. preg_match('~^(database|table|columns|sql|indexes|comment|view|'.($h->server_info>=9.3?'materializedview|':'').'scheme|processlist|sequence|trigger|type|variables|drop_col|kill)$~',$Fc);}function
  545. kill_process($X){return
  546. queries("SELECT pg_terminate_backend(".number($X).")");}function
  547. max_connections(){global$h;return$h->result("SHOW max_connections");}$w="pgsql";$Bh=array();$Lg=array();foreach(array(lang(24)=>array("smallint"=>5,"integer"=>10,"bigint"=>19,"boolean"=>1,"numeric"=>0,"real"=>7,"double precision"=>16,"money"=>20),lang(25)=>array("date"=>13,"time"=>17,"timestamp"=>20,"timestamptz"=>21,"interval"=>0),lang(26)=>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$x=>$X){$Bh+=$X;$Lg[$x]=array_keys($X);}$Ih=array();$Re=array("=","<",">","<=",">=","!=","~","!~","LIKE","LIKE %%","ILIKE","ILIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$Uc=array("char_length","lower","round","to_hex","to_timestamp","upper");$Zc=array("avg","count","count distinct","max","min","sum");$fc=array(array("char"=>"md5","date|time"=>"now",),array("int|numeric|real|money"=>"+/-","date|time"=>"+ interval/- interval","char|text"=>"||",));}$Xb["oracle"]="Oracle";if(isset($_GET["oracle"])){$zf=array("OCI8","PDO_OCI");define("DRIVER","oracle");if(extension_loaded("oci8")){class
  548. Min_DB{var$extension="oci8",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
  549. _error($qc,$n){if(ini_bool("html_errors"))$n=html_entity_decode(strip_tags($n));$n=preg_replace('~^[^:]*: ~','',$n);$this->error=$n;}function
  550. 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
  551. true;}$n=oci_error();$this->error=$n["message"];return
  552. false;}function
  553. quote($P){return"'".str_replace("'","''",$P)."'";}function
  554. select_db($Gb){return
  555. true;}function
  556. query($H,$Ch=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
  557. false;}set_error_handler(array($this,'_error'));$J=@oci_execute($I);restore_error_handler();if($J){if(oci_num_fields($I))return
  558. new
  559. Min_Result($I);$this->affected_rows=oci_num_rows($I);}return$J;}function
  560. multi_query($H){return$this->_result=$this->query($H);}function
  561. store_result(){return$this->_result;}function
  562. next_result(){return
  563. false;}function
  564. result($H,$o=1){$I=$this->query($H);if(!is_object($I)||!oci_fetch($I->_result))return
  565. false;return
  566. oci_result($I->_result,$o);}}class
  567. Min_Result{var$_result,$_offset=1,$num_rows;function
  568. __construct($I){$this->_result=$I;}function
  569. _convert($K){foreach((array)$K
  570. as$x=>$X){if(is_a($X,'OCI-Lob'))$K[$x]=$X->load();}return$K;}function
  571. fetch_assoc(){return$this->_convert(oci_fetch_assoc($this->_result));}function
  572. fetch_row(){return$this->_convert(oci_fetch_row($this->_result));}function
  573. fetch_field(){$e=$this->_offset++;$J=new
  574. stdClass;$J->name=oci_field_name($this->_result,$e);$J->orgname=$J->name;$J->type=oci_field_type($this->_result,$e);$J->charsetnr=(preg_match("~raw|blob|bfile~",$J->type)?63:0);return$J;}function
  575. __destruct(){oci_free_statement($this->_result);}}}elseif(extension_loaded("pdo_oci")){class
  576. Min_DB
  577. extends
  578. Min_PDO{var$extension="PDO_OCI";function
  579. connect($N,$V,$G){$this->dsn("oci:dbname=//$N;charset=AL32UTF8",$V,$G);return
  580. true;}function
  581. select_db($Gb){return
  582. true;}}}class
  583. Min_Driver
  584. extends
  585. Min_SQL{function
  586. begin(){return
  587. true;}}function
  588. idf_escape($t){return'"'.str_replace('"','""',$t).'"';}function
  589. table($t){return
  590. idf_escape($t);}function
  591. connect(){global$b;$h=new
  592. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2]))return$h;return$h->error;}function
  593. get_databases(){return
  594. get_vals("SELECT tablespace_name FROM user_tablespaces");}function
  595. limit($H,$Z,$z,$D=0,$ug=" "){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
  596. limit1($H,$Z){return" $H$Z";}function
  597. db_collation($m,$nb){global$h;return$h->result("SELECT value FROM nls_database_parameters WHERE parameter = 'NLS_CHARACTERSET'");}function
  598. engines(){return
  599. array();}function
  600. logged_user(){global$h;return$h->result("SELECT USER FROM DUAL");}function
  601. tables_list(){return
  602. get_key_vals("SELECT table_name, 'table' FROM all_tables WHERE tablespace_name = ".q(DB)."
  603. UNION SELECT view_name, 'view' FROM user_views
  604. ORDER BY 1");}function
  605. count_tables($l){return
  606. array();}function
  607. table_status($C=""){$J=array();$pg=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 = $pg":"")."
  608. UNION SELECT view_name, 'view', 0, 0 FROM user_views".($C!=""?" WHERE view_name = $pg":"")."
  609. ORDER BY 1")as$K){if($C!="")return$K;$J[$K["Name"]]=$K;}return$J;}function
  610. is_view($R){return$R["Engine"]=="view";}function
  611. fk_support($R){return
  612. true;}function
  613. fields($Q){$J=array();foreach(get_rows("SELECT * FROM all_tab_columns WHERE table_name = ".q($Q)." ORDER BY column_id")as$K){$U=$K["DATA_TYPE"];$y="$K[DATA_PRECISION],$K[DATA_SCALE]";if($y==",")$y=$K["DATA_LENGTH"];$J[$K["COLUMN_NAME"]]=array("field"=>$K["COLUMN_NAME"],"full_type"=>$U.($y?"($y)":""),"type"=>strtolower($U),"length"=>$y,"default"=>$K["DATA_DEFAULT"],"null"=>($K["NULLABLE"]=="Y"),"privileges"=>array("insert"=>1,"select"=>1,"update"=>1),);}return$J;}function
  614. indexes($Q,$i=null){$J=array();foreach(get_rows("SELECT uic.*, uc.constraint_type
  615. FROM user_ind_columns uic
  616. LEFT JOIN user_constraints uc ON uic.index_name = uc.constraint_name AND uic.table_name = uc.table_name
  617. WHERE uic.table_name = ".q($Q)."
  618. ORDER BY uc.constraint_type, uic.column_position",$i)as$K){$od=$K["INDEX_NAME"];$J[$od]["type"]=($K["CONSTRAINT_TYPE"]=="P"?"PRIMARY":($K["CONSTRAINT_TYPE"]=="U"?"UNIQUE":"INDEX"));$J[$od]["columns"][]=$K["COLUMN_NAME"];$J[$od]["lengths"][]=($K["CHAR_LENGTH"]&&$K["CHAR_LENGTH"]!=$K["COLUMN_LENGTH"]?$K["CHAR_LENGTH"]:null);$J[$od]["descs"][]=($K["DESCEND"]?'1':null);}return$J;}function
  619. view($C){$L=get_rows('SELECT text "select" FROM user_views WHERE view_name = '.q($C));return
  620. reset($L);}function
  621. collations(){return
  622. array();}function
  623. information_schema($m){return
  624. false;}function
  625. error(){global$h;return
  626. h($h->error);}function
  627. explain($h,$H){$h->query("EXPLAIN PLAN FOR $H");return$h->query("SELECT * FROM plan_table");}function
  628. found_rows($R,$Z){}function
  629. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){$c=$Yb=array();foreach($p
  630. as$o){$X=$o[1];if($X&&$o[0]!=""&&idf_escape($o[0])!=$X[0])queries("ALTER TABLE ".table($Q)." RENAME COLUMN ".idf_escape($o[0])." TO $X[0]");if($X)$c[]=($Q!=""?($o[0]!=""?"MODIFY (":"ADD ("):"  ").implode($X).($Q!=""?")":"");else$Yb[]=idf_escape($o[0]);}if($Q=="")return
  631. queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)");return(!$c||queries("ALTER TABLE ".table($Q)."\n".implode("\n",$c)))&&(!$Yb||queries("ALTER TABLE ".table($Q)." DROP (".implode(", ",$Yb).")"))&&($Q==$C||queries("ALTER TABLE ".table($Q)." RENAME TO ".table($C)));}function
  632. foreign_keys($Q){$J=array();$H="SELECT c_list.CONSTRAINT_NAME as NAME,
  633. c_src.COLUMN_NAME as SRC_COLUMN,
  634. c_dest.OWNER as DEST_DB,
  635. c_dest.TABLE_NAME as DEST_TABLE,
  636. c_dest.COLUMN_NAME as DEST_COLUMN,
  637. c_list.DELETE_RULE as ON_DELETE
  638. FROM ALL_CONSTRAINTS c_list, ALL_CONS_COLUMNS c_src, ALL_CONS_COLUMNS c_dest
  639. WHERE c_list.CONSTRAINT_NAME = c_src.CONSTRAINT_NAME
  640. AND c_list.R_CONSTRAINT_NAME = c_dest.CONSTRAINT_NAME
  641. AND c_list.CONSTRAINT_TYPE = 'R'
  642. AND c_src.TABLE_NAME = ".q($Q);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
  643. truncate_tables($S){return
  644. apply_queries("TRUNCATE TABLE",$S);}function
  645. drop_views($Yh){return
  646. apply_queries("DROP VIEW",$Yh);}function
  647. drop_tables($S){return
  648. apply_queries("DROP TABLE",$S);}function
  649. last_id(){return
  650. 0;}function
  651. schemas(){return
  652. get_vals("SELECT DISTINCT owner FROM dba_segments WHERE owner IN (SELECT username FROM dba_users WHERE default_tablespace NOT IN ('SYSTEM','SYSAUX'))");}function
  653. get_schema(){global$h;return$h->result("SELECT sys_context('USERENV', 'SESSION_USER') FROM dual");}function
  654. set_schema($og){global$h;return$h->query("ALTER SESSION SET CURRENT_SCHEMA = ".idf_escape($og));}function
  655. show_variables(){return
  656. get_key_vals('SELECT name, display_value FROM v$parameter');}function
  657. process_list(){return
  658. 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"
  659. FROM v$session sess LEFT OUTER JOIN v$sql sql
  660. ON sql.sql_id = sess.sql_id
  661. WHERE sess.type = \'USER\'
  662. ORDER BY PROCESS
  663. ');}function
  664. show_status(){$L=get_rows('SELECT * FROM v$instance');return
  665. reset($L);}function
  666. convert_field($o){}function
  667. unconvert_field($o,$J){return$J;}function
  668. support($Fc){return
  669. preg_match('~^(columns|database|drop_col|indexes|processlist|scheme|sql|status|table|variables|view|view_trigger)$~',$Fc);}$w="oracle";$Bh=array();$Lg=array();foreach(array(lang(24)=>array("number"=>38,"binary_float"=>12,"binary_double"=>21),lang(25)=>array("date"=>10,"timestamp"=>29,"interval year"=>12,"interval day"=>28),lang(26)=>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$x=>$X){$Bh+=$X;$Lg[$x]=array_keys($X);}$Ih=array();$Re=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$Uc=array("length","lower","round","upper");$Zc=array("avg","count","count distinct","max","min","sum");$fc=array(array("date"=>"current_date","timestamp"=>"current_timestamp",),array("number|float|double"=>"+/-","date|timestamp"=>"+ interval/- interval","char|clob"=>"||",));}$Xb["mssql"]="MS SQL";if(isset($_GET["mssql"])){$zf=array("SQLSRV","MSSQL");define("DRIVER","mssql");if(extension_loaded("sqlsrv")){class
  670. Min_DB{var$extension="sqlsrv",$_link,$_result,$server_info,$affected_rows,$errno,$error;function
  671. _get_error(){$this->error="";foreach(sqlsrv_errors()as$n){$this->errno=$n["code"];$this->error.="$n[message]\n";}$this->error=rtrim($this->error);}function
  672. connect($N,$V,$G){$this->_link=@sqlsrv_connect($N,array("UID"=>$V,"PWD"=>$G,"CharacterSet"=>"UTF-8"));if($this->_link){$sd=sqlsrv_server_info($this->_link);$this->server_info=$sd['SQLServerVersion'];}else$this->_get_error();return(bool)$this->_link;}function
  673. quote($P){return"'".str_replace("'","''",$P)."'";}function
  674. select_db($Gb){return$this->query("USE ".idf_escape($Gb));}function
  675. query($H,$Ch=false){$I=sqlsrv_query($this->_link,$H);$this->error="";if(!$I){$this->_get_error();return
  676. false;}return$this->store_result($I);}function
  677. multi_query($H){$this->_result=sqlsrv_query($this->_link,$H);$this->error="";if(!$this->_result){$this->_get_error();return
  678. false;}return
  679. true;}function
  680. store_result($I=null){if(!$I)$I=$this->_result;if(!$I)return
  681. false;if(sqlsrv_field_metadata($I))return
  682. new
  683. Min_Result($I);$this->affected_rows=sqlsrv_rows_affected($I);return
  684. true;}function
  685. next_result(){return$this->_result?sqlsrv_next_result($this->_result):null;}function
  686. result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
  687. false;$K=$I->fetch_row();return$K[$o];}}class
  688. Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
  689. __construct($I){$this->_result=$I;}function
  690. _convert($K){foreach((array)$K
  691. as$x=>$X){if(is_a($X,'DateTime'))$K[$x]=$X->format("Y-m-d H:i:s");}return$K;}function
  692. fetch_assoc(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_ASSOC,SQLSRV_SCROLL_NEXT));}function
  693. fetch_row(){return$this->_convert(sqlsrv_fetch_array($this->_result,SQLSRV_FETCH_NUMERIC,SQLSRV_SCROLL_NEXT));}function
  694. fetch_field(){if(!$this->_fields)$this->_fields=sqlsrv_field_metadata($this->_result);$o=$this->_fields[$this->_offset++];$J=new
  695. stdClass;$J->name=$o["Name"];$J->orgname=$o["Name"];$J->type=($o["Type"]==1?254:0);return$J;}function
  696. seek($D){for($s=0;$s<$D;$s++)sqlsrv_fetch($this->_result);}function
  697. __destruct(){sqlsrv_free_stmt($this->_result);}}}elseif(extension_loaded("mssql")){class
  698. Min_DB{var$extension="MSSQL",$_link,$_result,$server_info,$affected_rows,$error;function
  699. 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
  700. quote($P){return"'".str_replace("'","''",$P)."'";}function
  701. select_db($Gb){return
  702. mssql_select_db($Gb);}function
  703. query($H,$Ch=false){$I=mssql_query($H,$this->_link);$this->error="";if(!$I){$this->error=mssql_get_last_message();return
  704. false;}if($I===true){$this->affected_rows=mssql_rows_affected($this->_link);return
  705. true;}return
  706. new
  707. Min_Result($I);}function
  708. multi_query($H){return$this->_result=$this->query($H);}function
  709. store_result(){return$this->_result;}function
  710. next_result(){return
  711. mssql_next_result($this->_result);}function
  712. result($H,$o=0){$I=$this->query($H);if(!is_object($I))return
  713. false;return
  714. mssql_result($I->_result,0,$o);}}class
  715. Min_Result{var$_result,$_offset=0,$_fields,$num_rows;function
  716. __construct($I){$this->_result=$I;$this->num_rows=mssql_num_rows($I);}function
  717. fetch_assoc(){return
  718. mssql_fetch_assoc($this->_result);}function
  719. fetch_row(){return
  720. mssql_fetch_row($this->_result);}function
  721. num_rows(){return
  722. mssql_num_rows($this->_result);}function
  723. fetch_field(){$J=mssql_fetch_field($this->_result);$J->orgtable=$J->table;$J->orgname=$J->name;return$J;}function
  724. seek($D){mssql_data_seek($this->_result,$D);}function
  725. __destruct(){mssql_free_result($this->_result);}}}class
  726. Min_Driver
  727. extends
  728. Min_SQL{function
  729. insertUpdate($Q,$L,$Bf){foreach($L
  730. as$O){$Jh=array();$Z=array();foreach($O
  731. as$x=>$X){$Jh[]="$x = $X";if(isset($Bf[idf_unescape($x)]))$Z[]="$x = $X";}if(!queries("MERGE ".table($Q)." USING (VALUES(".implode(", ",$O).")) AS source (c".implode(", c",range(1,count($O))).") ON ".implode(" AND ",$Z)." WHEN MATCHED THEN UPDATE SET ".implode(", ",$Jh)." WHEN NOT MATCHED THEN INSERT (".implode(", ",array_keys($O)).") VALUES (".implode(", ",$O).");"))return
  732. false;}return
  733. true;}function
  734. begin(){return
  735. queries("BEGIN TRANSACTION");}}function
  736. idf_escape($t){return"[".str_replace("]","]]",$t)."]";}function
  737. table($t){return($_GET["ns"]!=""?idf_escape($_GET["ns"]).".":"").idf_escape($t);}function
  738. connect(){global$b;$h=new
  739. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2]))return$h;return$h->error;}function
  740. get_databases(){return
  741. get_vals("EXEC sp_databases");}function
  742. limit($H,$Z,$z,$D=0,$ug=" "){return($z!==null?" TOP (".($z+$D).")":"")." $H$Z";}function
  743. limit1($H,$Z){return
  744. limit($H,$Z,1);}function
  745. db_collation($m,$nb){global$h;return$h->result("SELECT collation_name FROM sys.databases WHERE name =  ".q($m));}function
  746. engines(){return
  747. array();}function
  748. logged_user(){global$h;return$h->result("SELECT SUSER_NAME()");}function
  749. tables_list(){return
  750. 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
  751. count_tables($l){global$h;$J=array();foreach($l
  752. as$m){$h->select_db($m);$J[$m]=$h->result("SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES");}return$J;}function
  753. 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
  754. is_view($R){return$R["Engine"]=="VIEW";}function
  755. fk_support($R){return
  756. true;}function
  757. fields($Q){$J=array();foreach(get_rows("SELECT c.*, t.name type, d.definition [default]
  758. FROM sys.all_columns c
  759. JOIN sys.all_objects o ON c.object_id = o.object_id
  760. JOIN sys.types t ON c.user_type_id = t.user_type_id
  761. LEFT JOIN sys.default_constraints d ON c.default_object_id = d.parent_column_id
  762. WHERE o.schema_id = SCHEMA_ID(".q(get_schema()).") AND o.type IN ('S', 'U', 'V') AND o.name = ".q($Q))as$K){$U=$K["type"];$y=(preg_match("~char|binary~",$U)?$K["max_length"]:($U=="decimal"?"$K[precision],$K[scale]":""));$J[$K["name"]]=array("field"=>$K["name"],"full_type"=>$U.($y?"($y)":""),"type"=>$U,"length"=>$y,"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
  763. indexes($Q,$i=null){$J=array();foreach(get_rows("SELECT i.name, key_ordinal, is_unique, is_primary_key, c.name AS column_name, is_descending_key
  764. FROM sys.indexes i
  765. INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
  766. INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
  767. WHERE OBJECT_NAME(i.object_id) = ".q($Q),$i)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
  768. view($C){global$h;return
  769. array("select"=>preg_replace('~^(?:[^[]|\\[[^]]*])*\\s+AS\\s+~isU','',$h->result("SELECT VIEW_DEFINITION FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_SCHEMA = SCHEMA_NAME() AND TABLE_NAME = ".q($C))));}function
  770. collations(){$J=array();foreach(get_vals("SELECT name FROM fn_helpcollations()")as$d)$J[preg_replace('~_.*~','',$d)][]=$d;return$J;}function
  771. information_schema($m){return
  772. false;}function
  773. error(){global$h;return
  774. nl_br(h(preg_replace('~^(\\[[^]]*])+~m','',$h->error)));}function
  775. create_database($m,$d){return
  776. queries("CREATE DATABASE ".idf_escape($m).(preg_match('~^[a-z0-9_]+$~i',$d)?" COLLATE $d":""));}function
  777. drop_databases($l){return
  778. queries("DROP DATABASE ".implode(", ",array_map('idf_escape',$l)));}function
  779. rename_database($C,$d){if(preg_match('~^[a-z0-9_]+$~i',$d))queries("ALTER DATABASE ".idf_escape(DB)." COLLATE $d");queries("ALTER DATABASE ".idf_escape(DB)." MODIFY NAME = ".idf_escape($C));return
  780. true;}function
  781. auto_increment(){return" IDENTITY".($_POST["Auto_increment"]!=""?"(".number($_POST["Auto_increment"]).",1)":"")." PRIMARY KEY";}function
  782. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){$c=array();foreach($p
  783. as$o){$e=idf_escape($o[0]);$X=$o[1];if(!$X)$c["DROP"][]=" COLUMN $e";else{$X[1]=preg_replace("~( COLLATE )'(\\w+)'~","\\1\\2",$X[1]);if($o[0]=="")$c["ADD"][]="\n  ".implode("",$X).($Q==""?substr($Mc[$X[0]],16+strlen($X[0])):"");else{unset($X[6]);if($e!=$X[0])queries("EXEC sp_rename ".q(table($Q).".$e").", ".q(idf_unescape($X[0])).", 'COLUMN'");$c["ALTER COLUMN ".implode("",$X)][]="";}}}if($Q=="")return
  784. queries("CREATE TABLE ".table($C)." (".implode(",",(array)$c["ADD"])."\n)");if($Q!=$C)queries("EXEC sp_rename ".q(table($Q)).", ".q($C));if($Mc)$c[""]=$Mc;foreach($c
  785. as$x=>$X){if(!queries("ALTER TABLE ".idf_escape($C)." $x".implode(",",$X)))return
  786. false;}return
  787. true;}function
  788. alter_indexes($Q,$c){$u=array();$Yb=array();foreach($c
  789. as$X){if($X[2]=="DROP"){if($X[0]=="PRIMARY")$Yb[]=idf_escape($X[1]);else$u[]=idf_escape($X[1])." ON ".table($Q);}elseif(!queries(($X[0]!="PRIMARY"?"CREATE $X[0] ".($X[0]!="INDEX"?"INDEX ":"").idf_escape($X[1]!=""?$X[1]:uniqid($Q."_"))." ON ".table($Q):"ALTER TABLE ".table($Q)." ADD PRIMARY KEY")." (".implode(", ",$X[2]).")"))return
  790. false;}return(!$u||queries("DROP INDEX ".implode(", ",$u)))&&(!$Yb||queries("ALTER TABLE ".table($Q)." DROP ".implode(", ",$Yb)));}function
  791. last_id(){global$h;return$h->result("SELECT SCOPE_IDENTITY()");}function
  792. explain($h,$H){$h->query("SET SHOWPLAN_ALL ON");$J=$h->query($H);$h->query("SET SHOWPLAN_ALL OFF");return$J;}function
  793. found_rows($R,$Z){}function
  794. foreign_keys($Q){$J=array();foreach(get_rows("EXEC sp_fkeys @fktable_name = ".q($Q))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
  795. truncate_tables($S){return
  796. apply_queries("TRUNCATE TABLE",$S);}function
  797. drop_views($Yh){return
  798. queries("DROP VIEW ".implode(", ",array_map('table',$Yh)));}function
  799. drop_tables($S){return
  800. queries("DROP TABLE ".implode(", ",array_map('table',$S)));}function
  801. move_tables($S,$Yh,$bh){return
  802. apply_queries("ALTER SCHEMA ".idf_escape($bh)." TRANSFER",array_merge($S,$Yh));}function
  803. trigger($C){if($C=="")return
  804. array();$L=get_rows("SELECT s.name [Trigger],
  805. 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],
  806. CASE WHEN OBJECTPROPERTY(s.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing],
  807. c.text
  808. FROM sysobjects s
  809. JOIN syscomments c ON s.id = c.id
  810. 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
  811. triggers($Q){$J=array();foreach(get_rows("SELECT sys1.name,
  812. 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],
  813. CASE WHEN OBJECTPROPERTY(sys1.id, 'ExecIsInsteadOfTrigger') = 1 THEN 'INSTEAD OF' ELSE 'AFTER' END [Timing]
  814. FROM sysobjects sys1
  815. JOIN sysobjects sys2 ON sys1.parent_obj = sys2.id
  816. WHERE sys1.xtype = 'TR' AND sys2.name = ".q($Q))as$K)$J[$K["name"]]=array($K["Timing"],$K["Event"]);return$J;}function
  817. trigger_options(){return
  818. array("Timing"=>array("AFTER","INSTEAD OF"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("AS"),);}function
  819. schemas(){return
  820. get_vals("SELECT name FROM sys.schemas");}function
  821. get_schema(){global$h;if($_GET["ns"]!="")return$_GET["ns"];return$h->result("SELECT SCHEMA_NAME()");}function
  822. set_schema($ng){return
  823. true;}function
  824. use_sql($Gb){return"USE ".idf_escape($Gb);}function
  825. show_variables(){return
  826. array();}function
  827. show_status(){return
  828. array();}function
  829. convert_field($o){}function
  830. unconvert_field($o,$J){return$J;}function
  831. support($Fc){return
  832. preg_match('~^(columns|database|drop_col|indexes|scheme|sql|table|trigger|view|view_trigger)$~',$Fc);}$w="mssql";$Bh=array();$Lg=array();foreach(array(lang(24)=>array("tinyint"=>3,"smallint"=>5,"int"=>10,"bigint"=>20,"bit"=>1,"decimal"=>0,"real"=>12,"float"=>53,"smallmoney"=>10,"money"=>20),lang(25)=>array("date"=>10,"smalldatetime"=>19,"datetime"=>19,"datetime2"=>19,"time"=>8,"datetimeoffset"=>10),lang(26)=>array("char"=>8000,"varchar"=>8000,"text"=>2147483647,"nchar"=>4000,"nvarchar"=>4000,"ntext"=>1073741823),lang(27)=>array("binary"=>8000,"varbinary"=>8000,"image"=>2147483647),)as$x=>$X){$Bh+=$X;$Lg[$x]=array_keys($X);}$Ih=array();$Re=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","NOT IN","IS NOT NULL");$Uc=array("len","lower","round","upper");$Zc=array("avg","count","count distinct","max","min","sum");$fc=array(array("date|time"=>"getdate",),array("int|decimal|real|float|money|datetime"=>"+/-","char|text"=>"+",));}$Xb['firebird']='Firebird (alpha)';if(isset($_GET["firebird"])){$zf=array("interbase");define("DRIVER","firebird");if(extension_loaded("interbase")){class
  833. Min_DB{var$extension="Firebird",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
  834. connect($N,$V,$G){$this->_link=ibase_connect($N,$V,$G);if($this->_link){$Lh=explode(':',$N);$this->service_link=ibase_service_attach($Lh[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
  835. quote($P){return"'".str_replace("'","''",$P)."'";}function
  836. select_db($Gb){return($Gb=="domain");}function
  837. query($H,$Ch=false){$I=ibase_query($H,$this->_link);if(!$I){$this->errno=ibase_errcode();$this->error=ibase_errmsg();return
  838. false;}$this->error="";if($I===true){$this->affected_rows=ibase_affected_rows($this->_link);return
  839. true;}return
  840. new
  841. Min_Result($I);}function
  842. multi_query($H){return$this->_result=$this->query($H);}function
  843. store_result(){return$this->_result;}function
  844. next_result(){return
  845. false;}function
  846. result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
  847. false;$K=$I->fetch_row();return$K[$o];}}class
  848. Min_Result{var$num_rows,$_result,$_offset=0;function
  849. __construct($I){$this->_result=$I;}function
  850. fetch_assoc(){return
  851. ibase_fetch_assoc($this->_result);}function
  852. fetch_row(){return
  853. ibase_fetch_row($this->_result);}function
  854. 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
  855. __destruct(){ibase_free_result($this->_result);}}}class
  856. Min_Driver
  857. extends
  858. Min_SQL{}function
  859. idf_escape($t){return'"'.str_replace('"','""',$t).'"';}function
  860. table($t){return
  861. idf_escape($t);}function
  862. connect(){global$b;$h=new
  863. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2]))return$h;return$h->error;}function
  864. get_databases($Lc){return
  865. array("domain");}function
  866. limit($H,$Z,$z,$D=0,$ug=" "){$J='';$J.=($z!==null?$ug."FIRST $z".($D?" SKIP $D":""):"");$J.=" $H$Z";return$J;}function
  867. limit1($H,$Z){return
  868. limit($H,$Z,1);}function
  869. db_collation($m,$nb){}function
  870. engines(){return
  871. array();}function
  872. logged_user(){global$b;$k=$b->credentials();return$k[1];}function
  873. tables_list(){global$h;$H='SELECT RDB$RELATION_NAME FROM rdb$relations WHERE rdb$system_flag = 0';$I=ibase_query($h->_link,$H);$J=array();while($K=ibase_fetch_assoc($I))$J[$K['RDB$RELATION_NAME']]='table';ksort($J);return$J;}function
  874. count_tables($l){return
  875. array();}function
  876. table_status($C="",$Ec=false){global$h;$J=array();$Eb=tables_list();foreach($Eb
  877. as$u=>$X){$u=trim($u);$J[$u]=array('Name'=>$u,'Engine'=>'standard',);if($C==$u)return$J[$u];}return$J;}function
  878. is_view($R){return
  879. false;}function
  880. fk_support($R){return
  881. preg_match('~InnoDB|IBMDB2I~i',$R["Engine"]);}function
  882. fields($Q){global$h;$J=array();$H='SELECT r.RDB$FIELD_NAME AS field_name,
  883. r.RDB$DESCRIPTION AS field_description,
  884. r.RDB$DEFAULT_VALUE AS field_default_value,
  885. r.RDB$NULL_FLAG AS field_not_null_constraint,
  886. f.RDB$FIELD_LENGTH AS field_length,
  887. f.RDB$FIELD_PRECISION AS field_precision,
  888. f.RDB$FIELD_SCALE AS field_scale,
  889. CASE f.RDB$FIELD_TYPE
  890. WHEN 261 THEN \'BLOB\'
  891. WHEN 14 THEN \'CHAR\'
  892. WHEN 40 THEN \'CSTRING\'
  893. WHEN 11 THEN \'D_FLOAT\'
  894. WHEN 27 THEN \'DOUBLE\'
  895. WHEN 10 THEN \'FLOAT\'
  896. WHEN 16 THEN \'INT64\'
  897. WHEN 8 THEN \'INTEGER\'
  898. WHEN 9 THEN \'QUAD\'
  899. WHEN 7 THEN \'SMALLINT\'
  900. WHEN 12 THEN \'DATE\'
  901. WHEN 13 THEN \'TIME\'
  902. WHEN 35 THEN \'TIMESTAMP\'
  903. WHEN 37 THEN \'VARCHAR\'
  904. ELSE \'UNKNOWN\'
  905. END AS field_type,
  906. f.RDB$FIELD_SUB_TYPE AS field_subtype,
  907. coll.RDB$COLLATION_NAME AS field_collation,
  908. cset.RDB$CHARACTER_SET_NAME AS field_charset
  909. FROM RDB$RELATION_FIELDS r
  910. LEFT JOIN RDB$FIELDS f ON r.RDB$FIELD_SOURCE = f.RDB$FIELD_NAME
  911. LEFT JOIN RDB$COLLATIONS coll ON f.RDB$COLLATION_ID = coll.RDB$COLLATION_ID
  912. LEFT JOIN RDB$CHARACTER_SETS cset ON f.RDB$CHARACTER_SET_ID = cset.RDB$CHARACTER_SET_ID
  913. WHERE r.RDB$RELATION_NAME = '.q($Q).'
  914. ORDER BY r.RDB$FIELD_POSITION';$I=ibase_query($h->_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
  915. indexes($Q,$i=null){$J=array();return$J;}function
  916. foreign_keys($Q){return
  917. array();}function
  918. collations(){return
  919. array();}function
  920. information_schema($m){return
  921. false;}function
  922. error(){global$h;return
  923. h($h->error);}function
  924. types(){return
  925. array();}function
  926. schemas(){return
  927. array();}function
  928. get_schema(){return"";}function
  929. set_schema($ng){return
  930. true;}function
  931. support($Fc){return
  932. preg_match("~^(columns|sql|status|table)$~",$Fc);}$w="firebird";$Re=array("=");$Uc=array();$Zc=array();$fc=array();}$Xb["simpledb"]="SimpleDB";if(isset($_GET["simpledb"])){$zf=array("SimpleXML");define("DRIVER","simpledb");if(class_exists('SimpleXMLElement')){class
  933. Min_DB{var$extension="SimpleXML",$server_info='2009-04-15',$error,$timeout,$next,$affected_rows,$_result;function
  934. select_db($Gb){return($Gb=="domain");}function
  935. query($H,$Ch=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)){$Pg=0;foreach($I
  936. as$Ed)$Pg+=$Ed->Attribute->Value;$I=array((object)array('Attribute'=>array((object)array('Name'=>'Count','Value'=>$Pg,))));}return
  937. new
  938. Min_Result($I);}function
  939. multi_query($H){return$this->_result=$this->query($H);}function
  940. store_result(){return$this->_result;}function
  941. next_result(){return
  942. false;}function
  943. quote($P){return"'".str_replace("'","''",$P)."'";}}class
  944. Min_Result{var$num_rows,$_rows=array(),$_offset=0;function
  945. __construct($I){foreach($I
  946. as$Ed){$K=array();if($Ed->Name!='')$K['itemName()']=(string)$Ed->Name;foreach($Ed->Attribute
  947. 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
  948. as$x=>$X){if(!isset($this->_rows[0][$x]))$this->_rows[0][$x]=null;}}$this->num_rows=count($this->_rows);}function
  949. _processValue($ic){return(is_object($ic)&&$ic['encoding']=='base64'?base64_decode($ic):(string)$ic);}function
  950. fetch_assoc(){$K=current($this->_rows);if(!$K)return$K;$J=array();foreach($this->_rows[0]as$x=>$X)$J[$x]=$K[$x];next($this->_rows);return$J;}function
  951. fetch_row(){$J=$this->fetch_assoc();if(!$J)return$J;return
  952. array_values($J);}function
  953. fetch_field(){$Kd=array_keys($this->_rows[0]);return(object)array('name'=>$Kd[$this->_offset++]);}}}class
  954. Min_Driver
  955. extends
  956. Min_SQL{public$Bf="itemName()";function
  957. _chunkRequest($ld,$va,$F,$yc=array()){global$h;foreach(array_chunk($ld,25)as$gb){$jf=$F;foreach($gb
  958. as$s=>$jd){$jf["Item.$s.ItemName"]=$jd;foreach($yc
  959. as$x=>$X)$jf["Item.$s.$x"]=$X;}if(!sdb_request($va,$jf))return
  960. false;}$h->affected_rows=count($ld);return
  961. true;}function
  962. _extractIds($Q,$Mf,$z){$J=array();if(preg_match_all("~itemName\(\) = (('[^']*+')+)~",$Mf,$de))$J=array_map('idf_unescape',$de[1]);else{foreach(sdb_request_all('Select','Item',array('SelectExpression'=>'SELECT itemName() FROM '.table($Q).$Mf.($z?" LIMIT 1":"")))as$Ed)$J[]=$Ed->Name;}return$J;}function
  963. select($Q,$M,$Z,$Xc,$We=array(),$z=1,$E=0,$Df=false){global$h;$h->next=$_GET["next"];$J=parent::select($Q,$M,$Z,$Xc,$We,$z,$E,$Df);$h->next=0;return$J;}function
  964. delete($Q,$Mf,$z=0){return$this->_chunkRequest($this->_extractIds($Q,$Mf,$z),'BatchDeleteAttributes',array('DomainName'=>$Q));}function
  965. update($Q,$O,$Mf,$z=0,$ug="\n"){$Mb=array();$wd=array();$s=0;$ld=$this->_extractIds($Q,$Mf,$z);$jd=idf_unescape($O["`itemName()`"]);unset($O["`itemName()`"]);foreach($O
  966. as$x=>$X){$x=idf_unescape($x);if($X=="NULL"||($jd!=""&&array($jd)!=$ld))$Mb["Attribute.".count($Mb).".Name"]=$x;if($X!="NULL"){foreach((array)$X
  967. as$Gd=>$W){$wd["Attribute.$s.Name"]=$x;$wd["Attribute.$s.Value"]=(is_array($X)?$W:idf_unescape($W));if(!$Gd)$wd["Attribute.$s.Replace"]="true";$s++;}}}$F=array('DomainName'=>$Q);return(!$wd||$this->_chunkRequest(($jd!=""?array($jd):$ld),'BatchPutAttributes',$F,$wd))&&(!$Mb||$this->_chunkRequest($ld,'BatchDeleteAttributes',$F,$Mb));}function
  968. insert($Q,$O){$F=array("DomainName"=>$Q);$s=0;foreach($O
  969. as$C=>$Y){if($Y!="NULL"){$C=idf_unescape($C);if($C=="itemName()")$F["ItemName"]=idf_unescape($Y);else{foreach((array)$Y
  970. as$X){$F["Attribute.$s.Name"]=$C;$F["Attribute.$s.Value"]=(is_array($Y)?$X:idf_unescape($Y));$s++;}}}}return
  971. sdb_request('PutAttributes',$F);}function
  972. insertUpdate($Q,$L,$Bf){foreach($L
  973. as$O){if(!$this->update($Q,$O,"WHERE `itemName()` = ".q($O["`itemName()`"])))return
  974. false;}return
  975. true;}function
  976. begin(){return
  977. false;}function
  978. commit(){return
  979. false;}function
  980. rollback(){return
  981. false;}}function
  982. connect(){return
  983. new
  984. Min_DB;}function
  985. support($Fc){return
  986. preg_match('~sql~',$Fc);}function
  987. logged_user(){global$b;$k=$b->credentials();return$k[1];}function
  988. get_databases(){return
  989. array("domain");}function
  990. collations(){return
  991. array();}function
  992. db_collation($m,$nb){}function
  993. tables_list(){global$h;$J=array();foreach(sdb_request_all('ListDomains','DomainName')as$Q)$J[(string)$Q]='table';if($h->error&&defined("PAGE_HEADER"))echo"<p class='error'>".error()."\n";return$J;}function
  994. table_status($C="",$Ec=false){$J=array();foreach(($C!=""?array($C=>true):tables_list())as$Q=>$U){$K=array("Name"=>$Q,"Auto_increment"=>"");if(!$Ec){$qe=sdb_request('DomainMetadata',array('DomainName'=>$Q));if($qe){foreach(array("Rows"=>"ItemCount","Data_length"=>"ItemNamesSizeBytes","Index_length"=>"AttributeValuesSizeBytes","Data_free"=>"AttributeNamesSizeBytes",)as$x=>$X)$K[$x]=(string)$qe->$X;}}if($C!="")return$K;$J[$Q]=$K;}return$J;}function
  995. explain($h,$H){}function
  996. error(){global$h;return
  997. h($h->error);}function
  998. information_schema(){}function
  999. is_view($R){}function
  1000. indexes($Q,$i=null){return
  1001. array(array("type"=>"PRIMARY","columns"=>array("itemName()")),);}function
  1002. fields($Q){return
  1003. fields_from_edit();}function
  1004. foreign_keys($Q){return
  1005. array();}function
  1006. table($t){return
  1007. idf_escape($t);}function
  1008. idf_escape($t){return"`".str_replace("`","``",$t)."`";}function
  1009. limit($H,$Z,$z,$D=0,$ug=" "){return" $H$Z".($z!==null?$ug."LIMIT $z":"");}function
  1010. unconvert_field($o,$J){return$J;}function
  1011. fk_support($R){}function
  1012. engines(){return
  1013. array();}function
  1014. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){return($Q==""&&sdb_request('CreateDomain',array('DomainName'=>$C)));}function
  1015. drop_tables($S){foreach($S
  1016. as$Q){if(!sdb_request('DeleteDomain',array('DomainName'=>$Q)))return
  1017. false;}return
  1018. true;}function
  1019. count_tables($l){foreach($l
  1020. as$m)return
  1021. array($m=>count(tables_list()));}function
  1022. found_rows($R,$Z){return($Z?null:$R["Rows"]);}function
  1023. last_id(){}function
  1024. hmac($Ba,$Eb,$x,$Qf=false){$Ua=64;if(strlen($x)>$Ua)$x=pack("H*",$Ba($x));$x=str_pad($x,$Ua,"\0");$Hd=$x^str_repeat("\x36",$Ua);$Id=$x^str_repeat("\x5C",$Ua);$J=$Ba($Id.pack("H*",$Ba($Hd.$Eb)));if($Qf)$J=pack("H*",$J);return$J;}function
  1025. sdb_request($va,$F=array()){global$b,$h;list($hd,$F['AWSAccessKeyId'],$qg)=$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
  1026. as$x=>$X)$H.='&'.rawurlencode($x).'='.rawurlencode($X);$H=str_replace('%7E','~',substr($H,1));$H.="&Signature=".urlencode(base64_encode(hmac('sha1',"POST\n".preg_replace('~^https?://~','',$hd)."\n/\n$H",$qg,true)));@ini_set('track_errors',1);$Hc=@file_get_contents((preg_match('~^https?://~',$hd)?$hd:"http://$hd"),false,stream_context_create(array('http'=>array('method'=>'POST','content'=>$H,'ignore_errors'=>1,))));if(!$Hc){$h->error=$php_errormsg;return
  1027. false;}libxml_use_internal_errors(true);$ei=simplexml_load_string($Hc);if(!$ei){$n=libxml_get_last_error();$h->error=$n->message;return
  1028. false;}if($ei->Errors){$n=$ei->Errors->Error;$h->error="$n->Message ($n->Code)";return
  1029. false;}$h->error='';$ah=$va."Result";return($ei->$ah?$ei->$ah:true);}function
  1030. sdb_request_all($va,$ah,$F=array(),$jh=0){$J=array();$Hg=($jh?microtime(true):0);$z=(preg_match('~LIMIT\s+(\d+)\s*$~i',$F['SelectExpression'],$B)?$B[1]:0);do{$ei=sdb_request($va,$F);if(!$ei)break;foreach($ei->$ah
  1031. as$ic)$J[]=$ic;if($z&&count($J)>=$z){$_GET["next"]=$ei->NextToken;break;}if($jh&&microtime(true)-$Hg>$jh)return
  1032. false;$F['NextToken']=$ei->NextToken;if($z)$F['SelectExpression']=preg_replace('~\d+\s*$~',$z-count($J),$F['SelectExpression']);}while($ei->NextToken);return$J;}$w="simpledb";$Re=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","IN","IS NULL","NOT LIKE","IS NOT NULL");$Uc=array();$Zc=array("count");$fc=array(array("json"));}$Xb["mongo"]="MongoDB (beta)";if(isset($_GET["mongo"])){$zf=array("mongo");define("DRIVER","mongo");if(class_exists('MongoDB')){class
  1033. Min_DB{var$extension="Mongo",$error,$last_id,$_link,$_db;function
  1034. connect($N,$V,$G){global$b;$m=$b->database();$Ue=array();if($V!=""){$Ue["username"]=$V;$Ue["password"]=$G;}if($m!="")$Ue["db"]=$m;try{$this->_link=@new
  1035. MongoClient("mongodb://$N",$Ue);return
  1036. true;}catch(Exception$uc){$this->error=$uc->getMessage();return
  1037. false;}}function
  1038. query($H){return
  1039. false;}function
  1040. select_db($Gb){try{$this->_db=$this->_link->selectDB($Gb);return
  1041. true;}catch(Exception$uc){$this->error=$uc->getMessage();return
  1042. false;}}function
  1043. quote($P){return$P;}}class
  1044. Min_Result{var$num_rows,$_rows=array(),$_offset=0,$_charset=array();function
  1045. __construct($I){foreach($I
  1046. as$Ed){$K=array();foreach($Ed
  1047. as$x=>$X){if(is_a($X,'MongoBinData'))$this->_charset[$x]=63;$K[$x]=(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
  1048. as$x=>$X){if(!isset($this->_rows[0][$x]))$this->_rows[0][$x]=null;}}$this->num_rows=count($this->_rows);}function
  1049. fetch_assoc(){$K=current($this->_rows);if(!$K)return$K;$J=array();foreach($this->_rows[0]as$x=>$X)$J[$x]=$K[$x];next($this->_rows);return$J;}function
  1050. fetch_row(){$J=$this->fetch_assoc();if(!$J)return$J;return
  1051. array_values($J);}function
  1052. fetch_field(){$Kd=array_keys($this->_rows[0]);$C=$Kd[$this->_offset++];return(object)array('name'=>$C,'charsetnr'=>$this->_charset[$C],);}}}class
  1053. Min_Driver
  1054. extends
  1055. Min_SQL{public$Bf="_id";function
  1056. select($Q,$M,$Z,$Xc,$We=array(),$z=1,$E=0,$Df=false){$M=($M==array("*")?array():array_fill_keys($M,true));$Cg=array();foreach($We
  1057. as$X){$X=preg_replace('~ DESC$~','',$X,1,$Ab);$Cg[$X]=($Ab?-1:1);}return
  1058. new
  1059. Min_Result($this->_conn->_db->selectCollection($Q)->find(array(),$M)->sort($Cg)->limit(+$z)->skip($E*$z));}function
  1060. insert($Q,$O){try{$J=$this->_conn->_db->selectCollection($Q)->insert($O);$this->_conn->errno=$J['code'];$this->_conn->error=$J['err'];$this->_conn->last_id=$O['_id'];return!$J['err'];}catch(Exception$uc){$this->_conn->error=$uc->getMessage();return
  1061. false;}}}function
  1062. connect(){global$b;$h=new
  1063. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2]))return$h;return$h->error;}function
  1064. error(){global$h;return
  1065. h($h->error);}function
  1066. logged_user(){global$b;$k=$b->credentials();return$k[1];}function
  1067. get_databases($Lc){global$h;$J=array();$Jb=$h->_link->listDBs();foreach($Jb['databases']as$m)$J[]=$m['name'];return$J;}function
  1068. collations(){return
  1069. array();}function
  1070. db_collation($m,$nb){}function
  1071. count_tables($l){global$h;$J=array();foreach($l
  1072. as$m)$J[$m]=count($h->_link->selectDB($m)->getCollectionNames(true));return$J;}function
  1073. tables_list(){global$h;return
  1074. array_fill_keys($h->_db->getCollectionNames(true),'table');}function
  1075. table_status($C="",$Ec=false){$J=array();foreach(tables_list()as$Q=>$U){$J[$Q]=array("Name"=>$Q);if($C==$Q)return$J[$Q];}return$J;}function
  1076. information_schema(){}function
  1077. is_view($R){}function
  1078. drop_databases($l){global$h;foreach($l
  1079. as$m){$bg=$h->_link->selectDB($m)->drop();if(!$bg['ok'])return
  1080. false;}return
  1081. true;}function
  1082. indexes($Q,$i=null){global$h;$J=array();foreach($h->_db->selectCollection($Q)->getIndexInfo()as$u){$Pb=array();foreach($u["key"]as$e=>$U)$Pb[]=($U==-1?'1':null);$J[$u["name"]]=array("type"=>($u["name"]=="_id_"?"PRIMARY":($u["unique"]?"UNIQUE":"INDEX")),"columns"=>array_keys($u["key"]),"lengths"=>array(),"descs"=>$Pb,);}return$J;}function
  1083. fields($Q){return
  1084. fields_from_edit();}function
  1085. convert_field($o){}function
  1086. unconvert_field($o,$J){return$J;}function
  1087. foreign_keys($Q){return
  1088. array();}function
  1089. fk_support($R){}function
  1090. engines(){return
  1091. array();}function
  1092. found_rows($R,$Z){global$h;return$h->_db->selectCollection($_GET["select"])->count($Z);}function
  1093. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){global$h;if($Q==""){$h->_db->createCollection($C);return
  1094. true;}}function
  1095. drop_tables($S){global$h;foreach($S
  1096. as$Q){$bg=$h->_db->selectCollection($Q)->drop();if(!$bg['ok'])return
  1097. false;}return
  1098. true;}function
  1099. truncate_tables($S){global$h;foreach($S
  1100. as$Q){$bg=$h->_db->selectCollection($Q)->remove();if(!$bg['ok'])return
  1101. false;}return
  1102. true;}function
  1103. alter_indexes($Q,$c){global$h;foreach($c
  1104. as$X){list($U,$C,$O)=$X;if($O=="DROP")$J=$h->_db->command(array("deleteIndexes"=>$Q,"index"=>$C));else{$f=array();foreach($O
  1105. as$e){$e=preg_replace('~ DESC$~','',$e,1,$Ab);$f[$e]=($Ab?-1:1);}$J=$h->_db->selectCollection($Q)->ensureIndex($f,array("unique"=>($U=="UNIQUE"),"name"=>$C,));}if($J['errmsg']){$h->error=$J['errmsg'];return
  1106. false;}}return
  1107. true;}function
  1108. last_id(){global$h;return$h->last_id;}function
  1109. table($t){return$t;}function
  1110. idf_escape($t){return$t;}function
  1111. support($Fc){return
  1112. preg_match("~database|indexes~",$Fc);}$w="mongo";$Re=array("=");$Uc=array();$Zc=array();$fc=array(array("json"));}$Xb["elastic"]="Elasticsearch (beta)";if(isset($_GET["elastic"])){$zf=array("json");define("DRIVER","elastic");if(function_exists('json_decode')){class
  1113. Min_DB{var$extension="JSON",$server_info,$errno,$error,$_url;function
  1114. rootQuery($qf,$wb=array(),$re='GET'){@ini_set('track_errors',1);$Hc=@file_get_contents($this->_url.'/'.ltrim($qf,'/'),false,stream_context_create(array('http'=>array('method'=>$re,'content'=>json_encode($wb),'ignore_errors'=>1,))));if(!$Hc){$this->error=$php_errormsg;return$Hc;}if(!preg_match('~^HTTP/[0-9.]+ 2~i',$http_response_header[0])){$this->error=$Hc;return
  1115. false;}$J=json_decode($Hc,true);if($J===null){$this->errno=json_last_error();if(function_exists('json_last_error_msg'))$this->error=json_last_error_msg();else{$vb=get_defined_constants(true);foreach($vb['json']as$C=>$Y){if($Y==$this->errno&&preg_match('~^JSON_ERROR_~',$C)){$this->error=$C;break;}}}}return$J;}function
  1116. query($qf,$wb=array(),$re='GET'){return$this->rootQuery(($this->_db!=""?"$this->_db/":"/").ltrim($qf,'/'),$wb,$re);}function
  1117. connect($N,$V,$G){$this->_url="http://$V:$G@$N/";$J=$this->query('');if($J)$this->server_info=$J['version']['number'];return(bool)$J;}function
  1118. select_db($Gb){$this->_db=$Gb;return
  1119. true;}function
  1120. quote($P){return$P;}}class
  1121. Min_Result{var$num_rows,$_rows;function
  1122. __construct($L){$this->num_rows=count($this->_rows);$this->_rows=$L;reset($this->_rows);}function
  1123. fetch_assoc(){$J=current($this->_rows);next($this->_rows);return$J;}function
  1124. fetch_row(){return
  1125. array_values($this->fetch_assoc());}}}class
  1126. Min_Driver
  1127. extends
  1128. Min_SQL{function
  1129. select($Q,$M,$Z,$Xc,$We=array(),$z=1,$E=0,$Df=false){global$b;$Eb=array();$H="$Q/_search";if($M!=array("*"))$Eb["fields"]=$M;if($We){$Cg=array();foreach($We
  1130. as$lb){$lb=preg_replace('~ DESC$~','',$lb,1,$Ab);$Cg[]=($Ab?array($lb=>"desc"):$lb);}$Eb["sort"]=$Cg;}if($z){$Eb["size"]=+$z;if($E)$Eb["from"]=($E*$z);}foreach($Z
  1131. as$X){list($lb,$Pe,$X)=explode(" ",$X,3);if($lb=="_id")$Eb["query"]["ids"]["values"][]=$X;elseif($lb.$X!=""){$eh=array("term"=>array(($lb!=""?$lb:"_all")=>$X));if($Pe=="=")$Eb["query"]["filtered"]["filter"]["and"][]=$eh;else$Eb["query"]["filtered"]["query"]["bool"]["must"][]=$eh;}}if($Eb["query"]&&!$Eb["query"]["filtered"]["query"]&&!$Eb["query"]["ids"])$Eb["query"]["filtered"]["query"]=array("match_all"=>array());$Hg=microtime(true);$pg=$this->_conn->query($H,$Eb);if($Df)echo$b->selectQuery("$H: ".print_r($Eb,true),format_time($Hg));if(!$pg)return
  1132. false;$J=array();foreach($pg['hits']['hits']as$gd){$K=array();if($M==array("*"))$K["_id"]=$gd["_id"];$p=$gd['_source'];if($M!=array("*")){$p=array();foreach($M
  1133. as$x)$p[$x]=$gd['fields'][$x];}foreach($p
  1134. as$x=>$X){if($Eb["fields"])$X=$X[0];$K[$x]=(is_array($X)?json_encode($X):$X);}$J[]=$K;}return
  1135. new
  1136. Min_Result($J);}}function
  1137. connect(){global$b;$h=new
  1138. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2]))return$h;return$h->error;}function
  1139. support($Fc){return
  1140. preg_match("~database|table|columns~",$Fc);}function
  1141. logged_user(){global$b;$k=$b->credentials();return$k[1];}function
  1142. get_databases(){global$h;$J=$h->rootQuery('_aliases');if($J){$J=array_keys($J);sort($J,SORT_STRING);}return$J;}function
  1143. collations(){return
  1144. array();}function
  1145. db_collation($m,$nb){}function
  1146. engines(){return
  1147. array();}function
  1148. count_tables($l){global$h;$J=$h->query('_mapping');if($J)$J=array_map('count',$J);return$J;}function
  1149. tables_list(){global$h;$J=$h->query('_mapping');if($J)$J=array_fill_keys(array_keys($J[$h->_db]["mappings"]),'table');return$J;}function
  1150. table_status($C="",$Ec=false){global$h;$pg=$h->query("_search?search_type=count",array("facets"=>array("count_by_type"=>array("terms"=>array("field"=>"_type",)))),"POST");$J=array();if($pg){foreach($pg["facets"]["count_by_type"]["terms"]as$Q)$J[$Q["term"]]=array("Name"=>$Q["term"],"Engine"=>"table","Rows"=>$Q["count"],);if($C!=""&&$C==$Q["term"])return$J[$C];}return$J;}function
  1151. error(){global$h;return
  1152. h($h->error);}function
  1153. information_schema(){}function
  1154. is_view($R){}function
  1155. indexes($Q,$i=null){return
  1156. array(array("type"=>"PRIMARY","columns"=>array("_id")),);}function
  1157. fields($Q){global$h;$I=$h->query("$Q/_mapping");$J=array();if($I){$be=$I[$Q]['properties'];if(!$be)$be=$I[$h->_db]['mappings'][$Q]['properties'];if($be){foreach($be
  1158. 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
  1159. foreign_keys($Q){return
  1160. array();}function
  1161. table($t){return$t;}function
  1162. idf_escape($t){return$t;}function
  1163. convert_field($o){}function
  1164. unconvert_field($o,$J){return$J;}function
  1165. fk_support($R){}function
  1166. found_rows($R,$Z){return
  1167. null;}function
  1168. create_database($m){global$h;return$h->rootQuery(urlencode($m),array(),'PUT');}function
  1169. drop_databases($l){global$h;return$h->rootQuery(urlencode(implode(',',$l)),array(),'DELETE');}function
  1170. drop_tables($S){global$h;$J=true;foreach($S
  1171. as$Q)$J=$J&&$h->query(urlencode($Q),array(),'DELETE');return$J;}$w="elastic";$Re=array("=","query");$Uc=array();$Zc=array();$fc=array(array("json"));}$Xb=array("server"=>"MySQL")+$Xb;if(!defined("DRIVER")){$zf=array("MySQLi","MySQL","PDO_MySQL");define("DRIVER","server");if(extension_loaded("mysqli")){class
  1172. Min_DB
  1173. extends
  1174. MySQLi{var$extension="MySQLi";function
  1175. __construct(){parent::init();}function
  1176. connect($N="",$V="",$G="",$Gb=null,$vf=null,$Bg=null){mysqli_report(MYSQLI_REPORT_OFF);list($hd,$vf)=explode(":",$N,2);$J=@$this->real_connect(($N!=""?$hd:ini_get("mysqli.default_host")),($N.$V!=""?$V:ini_get("mysqli.default_user")),($N.$V.$G!=""?$G:ini_get("mysqli.default_pw")),$Gb,(is_numeric($vf)?$vf:ini_get("mysqli.default_port")),(!is_numeric($vf)?$vf:$Bg));return$J;}function
  1177. set_charset($ab){if(parent::set_charset($ab))return
  1178. true;parent::set_charset('utf8');return$this->query("SET NAMES $ab");}function
  1179. result($H,$o=0){$I=$this->query($H);if(!$I)return
  1180. false;$K=$I->fetch_array();return$K[$o];}function
  1181. quote($P){return"'".$this->escape_string($P)."'";}}}elseif(extension_loaded("mysql")&&!(ini_get("sql.safe_mode")&&extension_loaded("pdo_mysql"))){class
  1182. Min_DB{var$extension="MySQL",$server_info,$affected_rows,$errno,$error,$_link,$_result;function
  1183. 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
  1184. set_charset($ab){if(function_exists('mysql_set_charset')){if(mysql_set_charset($ab,$this->_link))return
  1185. true;mysql_set_charset('utf8',$this->_link);}return$this->query("SET NAMES $ab");}function
  1186. quote($P){return"'".mysql_real_escape_string($P,$this->_link)."'";}function
  1187. select_db($Gb){return
  1188. mysql_select_db($Gb,$this->_link);}function
  1189. query($H,$Ch=false){$I=@($Ch?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
  1190. false;}if($I===true){$this->affected_rows=mysql_affected_rows($this->_link);$this->info=mysql_info($this->_link);return
  1191. true;}return
  1192. new
  1193. Min_Result($I);}function
  1194. multi_query($H){return$this->_result=$this->query($H);}function
  1195. store_result(){return$this->_result;}function
  1196. next_result(){return
  1197. false;}function
  1198. result($H,$o=0){$I=$this->query($H);if(!$I||!$I->num_rows)return
  1199. false;return
  1200. mysql_result($I->_result,0,$o);}}class
  1201. Min_Result{var$num_rows,$_result,$_offset=0;function
  1202. __construct($I){$this->_result=$I;$this->num_rows=mysql_num_rows($I);}function
  1203. fetch_assoc(){return
  1204. mysql_fetch_assoc($this->_result);}function
  1205. fetch_row(){return
  1206. mysql_fetch_row($this->_result);}function
  1207. 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
  1208. __destruct(){mysql_free_result($this->_result);}}}elseif(extension_loaded("pdo_mysql")){class
  1209. Min_DB
  1210. extends
  1211. Min_PDO{var$extension="PDO_MySQL";function
  1212. connect($N,$V,$G){$this->dsn("mysql:charset=utf8;host=".str_replace(":",";unix_socket=",preg_replace('~:(\\d)~',';port=\\1',$N)),$V,$G);return
  1213. true;}function
  1214. set_charset($ab){$this->query("SET NAMES $ab");}function
  1215. select_db($Gb){return$this->query("USE ".idf_escape($Gb));}function
  1216. query($H,$Ch=false){$this->setAttribute(1000,!$Ch);return
  1217. parent::query($H,$Ch);}}}class
  1218. Min_Driver
  1219. extends
  1220. Min_SQL{function
  1221. insert($Q,$O){return($O?parent::insert($Q,$O):queries("INSERT INTO ".table($Q)." ()\nVALUES ()"));}function
  1222. insertUpdate($Q,$L,$Bf){$f=array_keys(reset($L));$_f="INSERT INTO ".table($Q)." (".implode(", ",$f).") VALUES\n";$Th=array();foreach($f
  1223. as$x)$Th[$x]="$x = VALUES($x)";$Og="\nON DUPLICATE KEY UPDATE ".implode(", ",$Th);$Th=array();$y=0;foreach($L
  1224. as$O){$Y="(".implode(", ",$O).")";if($Th&&(strlen($_f)+$y+strlen($Y)+strlen($Og)>1e6)){if(!queries($_f.implode(",\n",$Th).$Og))return
  1225. false;$Th=array();$y=0;}$Th[]=$Y;$y+=strlen($Y)+2;}return
  1226. queries($_f.implode(",\n",$Th).$Og);}}function
  1227. idf_escape($t){return"`".str_replace("`","``",$t)."`";}function
  1228. table($t){return
  1229. idf_escape($t);}function
  1230. connect(){global$b;$h=new
  1231. Min_DB;$k=$b->credentials();if($h->connect($k[0],$k[1],$k[2])){$h->set_charset(charset($h));$h->query("SET sql_quote_show_create = 1, autocommit = 1");return$h;}$J=$h->error;if(function_exists('iconv')&&!is_utf8($J)&&strlen($lg=iconv("windows-1250","utf-8",$J))>strlen($J))$J=$lg;return$J;}function
  1232. get_databases($Lc){global$h;$J=get_session("dbs");if($J===null){$H=($h->server_info>=5?"SELECT SCHEMA_NAME FROM information_schema.SCHEMATA":"SHOW DATABASES");$J=($Lc?slow_query($H):get_vals($H));restart_session();set_session("dbs",$J);stop_session();}return$J;}function
  1233. limit($H,$Z,$z,$D=0,$ug=" "){return" $H$Z".($z!==null?$ug."LIMIT $z".($D?" OFFSET $D":""):"");}function
  1234. limit1($H,$Z){return
  1235. limit($H,$Z,1);}function
  1236. db_collation($m,$nb){global$h;$J=null;$j=$h->result("SHOW CREATE DATABASE ".idf_escape($m),1);if(preg_match('~ COLLATE ([^ ]+)~',$j,$B))$J=$B[1];elseif(preg_match('~ CHARACTER SET ([^ ]+)~',$j,$B))$J=$nb[$B[1]][-1];return$J;}function
  1237. engines(){$J=array();foreach(get_rows("SHOW ENGINES")as$K){if(preg_match("~YES|DEFAULT~",$K["Support"]))$J[]=$K["Engine"];}return$J;}function
  1238. logged_user(){global$h;return$h->result("SELECT USER()");}function
  1239. tables_list(){global$h;return
  1240. get_key_vals($h->server_info>=5?"SELECT TABLE_NAME, TABLE_TYPE FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() ORDER BY TABLE_NAME":"SHOW TABLES");}function
  1241. count_tables($l){$J=array();foreach($l
  1242. as$m)$J[$m]=count(get_vals("SHOW TABLES IN ".idf_escape($m)));return$J;}function
  1243. table_status($C="",$Ec=false){global$h;$J=array();foreach(get_rows($Ec&&$h->server_info>=5?"SELECT TABLE_NAME AS Name, 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
  1244. is_view($R){return$R["Engine"]===null;}function
  1245. fk_support($R){global$h;return
  1246. preg_match('~InnoDB|IBMDB2I~i',$R["Engine"])||(preg_match('~NDB~i',$R["Engine"])&&version_compare($h->server_info,'5.6')>=0);}function
  1247. fields($Q){$J=array();foreach(get_rows("SHOW FULL COLUMNS FROM ".table($Q))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
  1248. indexes($Q,$i=null){$J=array();foreach(get_rows("SHOW INDEX FROM ".table($Q),$i)as$K){$J[$K["Key_name"]]["type"]=($K["Key_name"]=="PRIMARY"?"PRIMARY":($K["Index_type"]=="FULLTEXT"?"FULLTEXT":($K["Non_unique"]?"INDEX":"UNIQUE")));$J[$K["Key_name"]]["columns"][]=$K["Column_name"];$J[$K["Key_name"]]["lengths"][]=$K["Sub_part"];$J[$K["Key_name"]]["descs"][]=null;}return$J;}function
  1249. foreign_keys($Q){global$h,$Me;static$sf='`(?:[^`]|``)+`';$J=array();$Bb=$h->result("SHOW CREATE TABLE ".table($Q),1);if($Bb){preg_match_all("~CONSTRAINT ($sf) FOREIGN KEY ?\\(((?:$sf,? ?)+)\\) REFERENCES ($sf)(?:\\.($sf))? \\(((?:$sf,? ?)+)\\)(?: ON DELETE ($Me))?(?: ON UPDATE ($Me))?~",$Bb,$de,PREG_SET_ORDER);foreach($de
  1250. as$B){preg_match_all("~$sf~",$B[2],$Dg);preg_match_all("~$sf~",$B[5],$bh);$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',$Dg[0]),"target"=>array_map('idf_unescape',$bh[0]),"on_delete"=>($B[6]?$B[6]:"RESTRICT"),"on_update"=>($B[7]?$B[7]:"RESTRICT"),);}}return$J;}function
  1251. view($C){global$h;return
  1252. array("select"=>preg_replace('~^(?:[^`]|`[^`]*`)*\\s+AS\\s+~isU','',$h->result("SHOW CREATE VIEW ".table($C),1)));}function
  1253. 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
  1254. as$x=>$X)asort($J[$x]);return$J;}function
  1255. information_schema($m){global$h;return($h->server_info>=5&&$m=="information_schema")||($h->server_info>=5.5&&$m=="performance_schema");}function
  1256. error(){global$h;return
  1257. h(preg_replace('~^You have an error.*syntax to use~U',"Syntax error",$h->error));}function
  1258. create_database($m,$d){return
  1259. queries("CREATE DATABASE ".idf_escape($m).($d?" COLLATE ".q($d):""));}function
  1260. drop_databases($l){$J=apply_queries("DROP DATABASE",$l,'idf_escape');restart_session();set_session("dbs",null);return$J;}function
  1261. rename_database($C,$d){$J=false;if(create_database($C,$d)){$Zf=array();foreach(tables_list()as$Q=>$U)$Zf[]=table($Q)." TO ".idf_escape($C).".".table($Q);$J=(!$Zf||queries("RENAME TABLE ".implode(", ",$Zf)));if($J)queries("DROP DATABASE ".idf_escape(DB));restart_session();set_session("dbs",null);}return$J;}function
  1262. auto_increment(){$Ma=" PRIMARY KEY";if($_GET["create"]!=""&&$_POST["auto_increment_col"]){foreach(indexes($_GET["create"])as$u){if(in_array($_POST["fields"][$_POST["auto_increment_col"]]["orig"],$u["columns"],true)){$Ma="";break;}if($u["type"]=="PRIMARY")$Ma=" UNIQUE";}}return" AUTO_INCREMENT$Ma";}function
  1263. alter_table($Q,$C,$p,$Mc,$rb,$nc,$d,$La,$nf){$c=array();foreach($p
  1264. as$o)$c[]=($o[1]?($Q!=""?($o[0]!=""?"CHANGE ".idf_escape($o[0]):"ADD"):" ")." ".implode($o[1]).($Q!=""?$o[2]:""):"DROP ".idf_escape($o[0]));$c=array_merge($c,$Mc);$Ig=($rb!==null?" COMMENT=".q($rb):"").($nc?" ENGINE=".q($nc):"").($d?" COLLATE ".q($d):"").($La!=""?" AUTO_INCREMENT=$La":"");if($Q=="")return
  1265. queries("CREATE TABLE ".table($C)." (\n".implode(",\n",$c)."\n)$Ig$nf");if($Q!=$C)$c[]="RENAME TO ".table($C);if($Ig)$c[]=ltrim($Ig);return($c||$nf?queries("ALTER TABLE ".table($Q)."\n".implode(",\n",$c).$nf):true);}function
  1266. alter_indexes($Q,$c){foreach($c
  1267. as$x=>$X)$c[$x]=($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
  1268. queries("ALTER TABLE ".table($Q).implode(",",$c));}function
  1269. truncate_tables($S){return
  1270. apply_queries("TRUNCATE TABLE",$S);}function
  1271. drop_views($Yh){return
  1272. queries("DROP VIEW ".implode(", ",array_map('table',$Yh)));}function
  1273. drop_tables($S){return
  1274. queries("DROP TABLE ".implode(", ",array_map('table',$S)));}function
  1275. move_tables($S,$Yh,$bh){$Zf=array();foreach(array_merge($S,$Yh)as$Q)$Zf[]=table($Q)." TO ".idf_escape($bh).".".table($Q);return
  1276. queries("RENAME TABLE ".implode(", ",$Zf));}function
  1277. copy_tables($S,$Yh,$bh){queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");foreach($S
  1278. as$Q){$C=($bh==DB?table("copy_$Q"):idf_escape($bh).".".table($Q));if(!queries("\nDROP TABLE IF EXISTS $C")||!queries("CREATE TABLE $C LIKE ".table($Q))||!queries("INSERT INTO $C SELECT * FROM ".table($Q)))return
  1279. false;}foreach($Yh
  1280. as$Q){$C=($bh==DB?table("copy_$Q"):idf_escape($bh).".".table($Q));$Xh=view($Q);if(!queries("DROP VIEW IF EXISTS $C")||!queries("CREATE VIEW $C AS $Xh[select]"))return
  1281. false;}return
  1282. true;}function
  1283. trigger($C){if($C=="")return
  1284. array();$L=get_rows("SHOW TRIGGERS WHERE `Trigger` = ".q($C));return
  1285. reset($L);}function
  1286. triggers($Q){$J=array();foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($Q,"%_\\")))as$K)$J[$K["Trigger"]]=array($K["Timing"],$K["Event"]);return$J;}function
  1287. trigger_options(){return
  1288. array("Timing"=>array("BEFORE","AFTER"),"Event"=>array("INSERT","UPDATE","DELETE"),"Type"=>array("FOR EACH ROW"),);}function
  1289. routine($C,$U){global$h,$pc,$ud,$Bh;$Ca=array("bool","boolean","integer","double precision","real","dec","numeric","fixed","national char","national varchar");$Ah="((".implode("|",array_merge(array_keys($Bh),$Ca)).")\\b(?:\\s*\\(((?:[^'\")]|$pc)++)\\))?\\s*(zerofill\\s*)?(unsigned(?:\\s+zerofill)?)?)(?:\\s*(?:CHARSET|CHARACTER\\s+SET)\\s*['\"]?([^'\"\\s,]+)['\"]?)?";$sf="\\s*(".($U=="FUNCTION"?"":$ud).")?\\s*(?:`((?:[^`]|``)*)`\\s*|\\b(\\S+)\\s+)$Ah";$j=$h->result("SHOW CREATE $U ".idf_escape($C),2);preg_match("~\\(((?:$sf\\s*,?)*)\\)\\s*".($U=="FUNCTION"?"RETURNS\\s+$Ah\\s+":"")."(.*)~is",$j,$B);$p=array();preg_match_all("~$sf\\s*,?~is",$B[1],$de,PREG_SET_ORDER);foreach($de
  1290. as$if){$C=str_replace("``","`",$if[2]).$if[3];$p[]=array("field"=>$C,"type"=>strtolower($if[5]),"length"=>preg_replace_callback("~$pc~s",'normalize_enum',$if[6]),"unsigned"=>strtolower(preg_replace('~\\s+~',' ',trim("$if[8] $if[7]"))),"null"=>1,"full_type"=>$if[4],"inout"=>strtoupper($if[1]),"collation"=>strtolower($if[9]),);}if($U!="FUNCTION")return
  1291. array("fields"=>$p,"definition"=>$B[11]);return
  1292. array("fields"=>$p,"returns"=>array("type"=>$B[12],"length"=>$B[13],"unsigned"=>$B[15],"collation"=>$B[16]),"definition"=>$B[17],"language"=>"SQL",);}function
  1293. routines(){return
  1294. get_rows("SELECT ROUTINE_NAME, ROUTINE_TYPE, DTD_IDENTIFIER FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = ".q(DB));}function
  1295. routine_languages(){return
  1296. array();}function
  1297. last_id(){global$h;return$h->result("SELECT LAST_INSERT_ID()");}function
  1298. explain($h,$H){return$h->query("EXPLAIN ".($h->server_info>=5.1?"PARTITIONS ":"").$H);}function
  1299. found_rows($R,$Z){return($Z||$R["Engine"]!="InnoDB"?null:$R["Rows"]);}function
  1300. types(){return
  1301. array();}function
  1302. schemas(){return
  1303. array();}function
  1304. get_schema(){return"";}function
  1305. set_schema($ng){return
  1306. true;}function
  1307. create_sql($Q,$La){global$h;$J=$h->result("SHOW CREATE TABLE ".table($Q),1);if(!$La)$J=preg_replace('~ AUTO_INCREMENT=\\d+~','',$J);return$J;}function
  1308. truncate_sql($Q){return"TRUNCATE ".table($Q);}function
  1309. use_sql($Gb){return"USE ".idf_escape($Gb);}function
  1310. trigger_sql($Q,$Mg){$J="";foreach(get_rows("SHOW TRIGGERS LIKE ".q(addcslashes($Q,"%_\\")),null,"-- ")as$K)$J.="\n".($Mg=='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
  1311. show_variables(){return
  1312. get_key_vals("SHOW VARIABLES");}function
  1313. process_list(){return
  1314. get_rows("SHOW FULL PROCESSLIST");}function
  1315. show_status(){return
  1316. get_key_vals("SHOW STATUS");}function
  1317. 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
  1318. 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
  1319. support($Fc){global$h;return!preg_match("~scheme|sequence|type|view_trigger".($h->server_info<5.1?"|event|partitioning".($h->server_info<5?"|routine|trigger|view":""):"")."~",$Fc);}function
  1320. kill_process($X){return
  1321. queries("KILL ".number($X));}function
  1322. max_connections(){global$h;return$h->result("SELECT @@max_connections");}$w="sql";$Bh=array();$Lg=array();foreach(array(lang(24)=>array("tinyint"=>3,"smallint"=>5,"mediumint"=>8,"int"=>10,"bigint"=>20,"decimal"=>66,"float"=>12,"double"=>21),lang(25)=>array("date"=>10,"datetime"=>19,"timestamp"=>19,"time"=>10,"year"=>4),lang(26)=>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$x=>$X){$Bh+=$X;$Lg[$x]=array_keys($X);}$Ih=array("unsigned","zerofill","unsigned zerofill");$Re=array("=","<",">","<=",">=","!=","LIKE","LIKE %%","REGEXP","IN","IS NULL","NOT LIKE","NOT REGEXP","NOT IN","IS NOT NULL","SQL");$Uc=array("char_length","date","from_unixtime","lower","round","sec_to_time","time_to_sec","upper");$Zc=array("avg","count","count distinct","group_concat","max","min","sum");$fc=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.2.5";class
  1323. Adminer{var$operators;function
  1324. name(){return"<a href='https://www.adminer.org/' target='_blank' id='h1'>Adminer</a>";}function
  1325. credentials(){return
  1326. array(SERVER,$_GET["username"],get_password());}function
  1327. permanentLogin($j=false){return
  1328. password_file($j);}function
  1329. bruteForceKey(){return$_SERVER["REMOTE_ADDR"];}function
  1330. database(){return
  1331. DB;}function
  1332. databases($Lc=true){return
  1333. get_databases($Lc);}function
  1334. schemas(){return
  1335. schemas();}function
  1336. queryTimeout(){return
  1337. 5;}function
  1338. headers(){return
  1339. true;}function
  1340. head(){return
  1341. true;}function
  1342. loginForm(){global$Xb;echo'<table cellspacing="0">
  1343. <tr><th>',lang(31),'<td>',html_select("auth[driver]",$Xb,DRIVER),'<tr><th>',lang(32),'<td><input name="auth[server]" value="',h(SERVER),'" title="hostname[:port]" placeholder="localhost" autocapitalize="off">
  1344. <tr><th>',lang(33),'<td><input name="auth[username]" id="username" value="',h($_GET["username"]),'" autocapitalize="off">
  1345. <tr><th>',lang(34),'<td><input type="password" name="auth[password]">
  1346. <tr><th>',lang(35),'<td><input name="auth[db]" value="',h($_GET["db"]),'" autocapitalize="off">
  1347. </table>
  1348. <script type="text/javascript">
  1349. focus(document.getElementById(\'username\'));
  1350. </script>
  1351. ',"<p><input type='submit' value='".lang(36)."'>\n",checkbox("auth[permanent]",1,$_COOKIE["adminer_permanent"],lang(37))."\n";}function
  1352. login($Zd,$G){global$w;if($w=="sqlite")return
  1353. lang(38,'login()');return
  1354. true;}function
  1355. tableName($Sg){return
  1356. h($Sg["Name"]);}function
  1357. fieldName($o,$We=0){return'<span title="'.h($o["full_type"]).'">'.h($o["field"]).'</span>';}function
  1358. selectLinks($Sg,$O=""){echo'<p class="links">';$Yd=array("select"=>lang(39));if(support("table")||support("indexes"))$Yd["table"]=lang(40);if(support("table")){if(is_view($Sg))$Yd["view"]=lang(41);else$Yd["create"]=lang(42);}if($O!==null)$Yd["edit"]=lang(43);foreach($Yd
  1359. as$x=>$X)echo" <a href='".h(ME)."$x=".urlencode($Sg["Name"]).($x=="edit"?$O:"")."'".bold(isset($_GET[$x])).">$X</a>";echo"\n";}function
  1360. foreignKeys($Q){return
  1361. foreign_keys($Q);}function
  1362. backwardKeys($Q,$Rg){return
  1363. array();}function
  1364. backwardKeysPrint($Oa,$K){}function
  1365. selectQuery($H,$ih){global$w;return"<p><code class='jush-$w'>".h(str_replace("\n"," ",$H))."</code> <span class='time'>($ih)</span>".(support("sql")?" <a href='".h(ME)."sql=".urlencode($H)."'>".lang(10)."</a>":"")."</p>";}function
  1366. rowDescription($Q){return"";}function
  1367. rowDescriptions($L,$Nc){return$L;}function
  1368. selectLink($X,$o){}function
  1369. selectVal($X,$_,$o,$df){$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=lang(44,strlen($df));return($_?"<a href='".h($_)."'".(is_url($_)?" rel='noreferrer'":"").">$J</a>":$J);}function
  1370. editVal($X,$o){return$X;}function
  1371. selectColumnsPrint($M,$f){global$Uc,$Zc;print_fieldset("select",lang(45),$M);$s=0;$M[""]=array();foreach($M
  1372. as$x=>$X){$X=$_GET["columns"][$x];$e=select_input(" name='columns[$s][col]' onchange='".($x!==""?"selectFieldChange(this.form)":"selectAddRow(this)").";'",$f,$X["col"]);echo"<div>".($Uc||$Zc?"<select name='columns[$s][fun]' onchange='helpClose();".($x!==""?"":" this.nextSibling.nextSibling.onchange();")."'".on_help("getTarget(event).value && getTarget(event).value.replace(/ |\$/, '(') + ')'",1).">".optionlist(array(-1=>"")+array_filter(array(lang(46)=>$Uc,lang(47)=>$Zc)),$X["fun"])."</select>"."($e)":$e)."</div>\n";$s++;}echo"</div></fieldset>\n";}function
  1373. selectSearchPrint($Z,$f,$v){print_fieldset("search",lang(48),$Z);foreach($v
  1374. as$s=>$u){if($u["type"]=="FULLTEXT"){echo"(<i>".implode("</i>, <i>",array_map('h',$u["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'",$f,$X["col"],"(".lang(49).")"),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
  1375. selectOrderPrint($We,$f,$v){print_fieldset("sort",lang(50),$We);$s=0;foreach((array)$_GET["order"]as$x=>$X){if($X!=""){echo"<div>".select_input(" name='order[$s]' onchange='selectFieldChange(this.form);'",$f,$X),checkbox("desc[$s]",1,isset($_GET["desc"][$x]),lang(51))."</div>\n";$s++;}}echo"<div>".select_input(" name='order[$s]' onchange='selectAddRow(this);'",$f),checkbox("desc[$s]",1,false,lang(51))."</div>\n","</div></fieldset>\n";}function
  1376. selectLimitPrint($z){echo"<fieldset><legend>".lang(52)."</legend><div>";echo"<input type='number' name='limit' class='size' value='".h($z)."' onchange='selectFieldChange(this.form);'>","</div></fieldset>\n";}function
  1377. selectLengthPrint($hh){if($hh!==null){echo"<fieldset><legend>".lang(53)."</legend><div>","<input type='number' name='text_length' class='size' value='".h($hh)."'>","</div></fieldset>\n";}}function
  1378. selectActionPrint($v){echo"<fieldset><legend>".lang(54)."</legend><div>","<input type='submit' value='".lang(45)."'>"," <span id='noindex' title='".lang(55)."'></span>","<script type='text/javascript'>\n","var indexColumns = ";$f=array();foreach($v
  1379. as$u){if($u["type"]!="FULLTEXT")$f[reset($u["columns"])]=1;}$f[""]=1;foreach($f
  1380. as$x=>$X)json_row($x);echo";\n","selectFieldChange(document.getElementById('form'));\n","</script>\n","</div></fieldset>\n";}function
  1381. selectCommandPrint(){return!information_schema(DB);}function
  1382. selectImportPrint(){return!information_schema(DB);}function
  1383. selectEmailPrint($kc,$f){}function
  1384. selectColumnsProcess($f,$v){global$Uc,$Zc;$M=array();$Xc=array();foreach((array)$_GET["columns"]as$x=>$X){if($X["fun"]=="count"||($X["col"]!=""&&(!$X["fun"]||in_array($X["fun"],$Uc)||in_array($X["fun"],$Zc)))){$M[$x]=apply_sql_function($X["fun"],($X["col"]!=""?idf_escape($X["col"]):"*"));if(!in_array($X["fun"],$Zc))$Xc[]=$M[$x];}}return
  1385. array($M,$Xc);}function
  1386. selectSearchProcess($p,$v){global$h,$w;$J=array();foreach($v
  1387. as$s=>$u){if($u["type"]=="FULLTEXT"&&$_GET["fulltext"][$s]!="")$J[]="MATCH (".implode(", ",array_map('idf_escape',$u["columns"])).") AGAINST (".q($_GET["fulltext"][$s]).(isset($_GET["boolean"][$s])?" IN BOOLEAN MODE":"").")";}foreach((array)$_GET["where"]as$X){if("$X[col]$X[val]"!=""&&in_array($X["op"],$this->operators)){$tb=" $X[op]";if(preg_match('~IN$~',$X["op"])){$nd=process_length($X["val"]);$tb.=" ".($nd!=""?$nd:"(NULL)");}elseif($X["op"]=="SQL")$tb=" $X[val]";elseif($X["op"]=="LIKE %%")$tb=" LIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif($X["op"]=="ILIKE %%")$tb=" ILIKE ".$this->processInput($p[$X["col"]],"%$X[val]%");elseif(!preg_match('~NULL$~',$X["op"]))$tb.=" ".$this->processInput($p[$X["col"]],$X["val"]);if($X["col"]!="")$J[]=idf_escape($X["col"]).$tb;else{$ob=array();foreach($p
  1388. as$C=>$o){$Cd=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"])||$Cd)){$C=idf_escape($C);$ob[]=($w=="sql"&&$Cd&&!preg_match("~^utf8_~",$o["collation"])?"CONVERT($C USING ".charset($h).")":$C);}}$J[]=($ob?"(".implode("$tb OR ",$ob)."$tb)":"0");}}}return$J;}function
  1389. selectOrderProcess($p,$v){$J=array();foreach((array)$_GET["order"]as$x=>$X){if($X!="")$J[]=(preg_match('~^((COUNT\\(DISTINCT |[A-Z0-9_]+\\()(`(?:[^`]|``)+`|"(?:[^"]|"")+")\\)|COUNT\\(\\*\\))$~',$X)?$X:idf_escape($X)).(isset($_GET["desc"][$x])?" DESC":"");}return$J;}function
  1390. selectLimitProcess(){return(isset($_GET["limit"])?$_GET["limit"]:"50");}function
  1391. selectLengthProcess(){return(isset($_GET["text_length"])?$_GET["text_length"]:"100");}function
  1392. selectEmailProcess($Z,$Nc){return
  1393. false;}function
  1394. selectQueryBuild($M,$Z,$Xc,$We,$z,$E){return"";}function
  1395. messageQuery($H,$ih){global$w;restart_session();$ed=&get_session("queries");$jd="sql-".count($ed[$_GET["db"]]);if(strlen($H)>1e6)$H=preg_replace('~[\x80-\xFF]+$~','',substr($H,0,1e6))."\n...";$ed[$_GET["db"]][]=array($H,time(),$ih);return" <span class='time'>".@date("H:i:s")."</span> <a href='#$jd' onclick=\"return !toggle('$jd');\">".lang(56)."</a>"."<div id='$jd' class='hidden'><pre><code class='jush-$w'>".shorten_utf8($H,1000).'</code></pre>'.($ih?" <span class='time'>($ih)</span>":'').(support("sql")?'<p><a href="'.h(str_replace("db=".urlencode(DB),"db=".urlencode($_GET["db"]),ME).'sql=&history='.(count($ed[$_GET["db"]])-1)).'">'.lang(10).'</a>':'').'</div>';}function
  1396. editFunctions($o){global$fc;$J=($o["null"]?"NULL/":"");foreach($fc
  1397. as$x=>$Uc){if(!$x||(!isset($_GET["call"])&&(isset($_GET["select"])||where($_GET)))){foreach($Uc
  1398. as$sf=>$X){if(!$sf||preg_match("~$sf~",$o["type"]))$J.="/$X";}if($x&&!preg_match('~set|blob|bytea|raw|file~',$o["type"]))$J.="/SQL";}}if($o["auto_increment"]&&!isset($_GET["select"])&&!where($_GET))$J=lang(57);return
  1399. explode("/",$J);}function
  1400. editInput($Q,$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
  1401. 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
  1402. unconvert_field($o,$J);}function
  1403. dumpOutput(){$J=array('text'=>lang(58),'file'=>lang(59));if(function_exists('gzencode'))$J['gz']='gzip';return$J;}function
  1404. dumpFormat(){return
  1405. array('sql'=>'SQL','csv'=>'CSV,','csv;'=>'CSV;','tsv'=>'TSV');}function
  1406. dumpDatabase($m){}function
  1407. dumpTable($Q,$Mg,$Dd=0){if($_POST["format"]!="sql"){echo"\xef\xbb\xbf";if($Mg)dump_csv(array_keys(fields($Q)));}else{if($Dd==2){$p=array();foreach(fields($Q)as$C=>$o)$p[]=idf_escape($C)." $o[full_type]";$j="CREATE TABLE ".table($Q)." (".implode(", ",$p).")";}else$j=create_sql($Q,$_POST["auto_increment"]);set_utf8mb4($j);if($Mg&&$j){if($Mg=="DROP+CREATE"||$Dd==1)echo"DROP ".($Dd==2?"VIEW":"TABLE")." IF EXISTS ".table($Q).";\n";if($Dd==1)$j=remove_definer($j);echo"$j;\n\n";}}}function
  1408. dumpData($Q,$Mg,$H){global$h,$w;$fe=($w=="sqlite"?0:1048576);if($Mg){if($_POST["format"]=="sql"){if($Mg=="TRUNCATE+INSERT")echo
  1409. truncate_sql($Q).";\n";$p=fields($Q);}$I=$h->query($H,1);if($I){$wd="";$Xa="";$Kd=array();$Og="";$Gc=($Q!=''?'fetch_assoc':'fetch_row');while($K=$I->$Gc()){if(!$Kd){$Th=array();foreach($K
  1410. as$X){$o=$I->fetch_field();$Kd[]=$o->name;$x=idf_escape($o->name);$Th[]="$x = VALUES($x)";}$Og=($Mg=="INSERT+UPDATE"?"\nON DUPLICATE KEY UPDATE ".implode(", ",$Th):"").";\n";}if($_POST["format"]!="sql"){if($Mg=="table"){dump_csv($Kd);$Mg="INSERT";}dump_csv($K);}else{if(!$wd)$wd="INSERT INTO ".table($Q)." (".implode(", ",array_map('idf_escape',$Kd)).") VALUES";foreach($K
  1411. as$x=>$X){$o=$p[$x];$K[$x]=($X!==null?unconvert_field($o,preg_match('~(^|[^o])int|float|double|decimal~',$o["type"])&&$X!=''?$X:q($X)):"NULL");}$lg=($fe?"\n":" ")."(".implode(",\t",$K).")";if(!$Xa)$Xa=$wd.$lg;elseif(strlen($Xa)+4+strlen($lg)+strlen($Og)<$fe)$Xa.=",$lg";else{echo$Xa.$Og;$Xa=$wd.$lg;}}}if($Xa)echo$Xa.$Og;}elseif($_POST["format"]=="sql")echo"-- ".str_replace("\n"," ",$h->error)."\n";}}function
  1412. dumpFilename($kd){return
  1413. friendly_url($kd!=""?$kd:(SERVER!=""?SERVER:"localhost"));}function
  1414. dumpHeaders($kd,$ue=false){$gf=$_POST["output"];$Ac=(preg_match('~sql~',$_POST["format"])?"sql":($ue?"tar":"csv"));header("Content-Type: ".($gf=="gz"?"application/x-gzip":($Ac=="tar"?"application/x-tar":($Ac=="sql"||$gf!="file"?"text/plain":"text/csv")."; charset=utf-8")));if($gf=="gz")ob_start('ob_gzencode',1e6);return$Ac;}function
  1415. homepage(){echo'<p class="links">'.($_GET["ns"]==""&&support("database")?'<a href="'.h(ME).'database=">'.lang(60)."</a>\n":""),(support("scheme")?"<a href='".h(ME)."scheme='>".($_GET["ns"]!=""?lang(61):lang(62))."</a>\n":""),($_GET["ns"]!==""?'<a href="'.h(ME).'schema=">'.lang(63)."</a>\n":""),(support("privileges")?"<a href='".h(ME)."privileges='>".lang(64)."</a>\n":"");return
  1416. true;}function
  1417. navigation($te){global$ia,$w,$Xb,$h;echo'<h1>
  1418. ',$this->name(),' <span class="version">',$ia,'</span>
  1419. <a href="https://www.adminer.org/#download" target="_blank" id="version">',(version_compare($ia,$_COOKIE["adminer_version"])<0?h($_COOKIE["adminer_version"]):""),'</a>
  1420. </h1>
  1421. ';if($te=="auth"){$Kc=true;foreach((array)$_SESSION["pwds"]as$Vh=>$yg){foreach($yg
  1422. as$N=>$Qh){foreach($Qh
  1423. as$V=>$G){if($G!==null){if($Kc){echo"<p id='logins' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'>\n";$Kc=false;}$Jb=$_SESSION["db"][$Vh][$N][$V];foreach(($Jb?array_keys($Jb):array(""))as$m)echo"<a href='".h(auth_url($Vh,$N,$V,$m))."'>($Xb[$Vh]) ".h($V.($N!=""?"@$N":"").($m!=""?" - $m":""))."</a><br>\n";}}}}}else{if($_GET["ns"]!==""&&!$te&&DB!=""){$h->select_db(DB);$S=table_status('',true);}if(support("sql")){echo'<script type="text/javascript" src="',h(preg_replace("~\\?.*~","",ME))."?file=jush.js&amp;version=4.2.5",'"></script>
  1424. <script type="text/javascript">
  1425. ';if($S){$Yd=array();foreach($S
  1426. as$Q=>$U)$Yd[]=preg_quote($Q,'/');echo"var jushLinks = { $w: [ '".js_escape(ME).(support("table")?"table=":"select=")."\$&', /\\b(".implode("|",$Yd).")\\b/g ] };\n";foreach(array("bac","bra","sqlite_quo","mssql_bra")as$X)echo"jushLinks.$X = jushLinks.$w;\n";}echo'bodyLoad(\'',(is_object($h)?substr($h->server_info,0,3):""),'\');
  1427. </script>
  1428. ';}$this->databasesPrint($te);if(DB==""||!$te){echo"<p class='links'>".(support("sql")?"<a href='".h(ME)."sql='".bold(isset($_GET["sql"])&&!isset($_GET["import"])).">".lang(56)."</a>\n<a href='".h(ME)."import='".bold(isset($_GET["import"])).">".lang(65)."</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(66)."</a>\n";}if($_GET["ns"]!==""&&!$te&&DB!=""){echo'<a href="'.h(ME).'create="'.bold($_GET["create"]==="").">".lang(67)."</a>\n";if(!$S)echo"<p class='message'>".lang(9)."\n";else$this->tablesPrint($S);}}}function
  1429. databasesPrint($te){global$b,$h;$l=$this->databases();echo'<form action="">
  1430. <p id="dbs">
  1431. ';hidden_fields_get();$Hb=" onmousedown='dbMouseDown(event, this);' onchange='dbChange(this);'";echo"<span title='".lang(68)."'>DB</span>: ".($l?"<select name='db'$Hb>".optionlist(array(""=>"")+$l,DB)."</select>":'<input name="db" value="'.h(DB).'" autocapitalize="off">'),"<input type='submit' value='".lang(20)."'".($l?" class='hidden'":"").">\n";if($te!="db"&&DB!=""&&$h->select_db(DB)){if(support("scheme")){echo"<br>".lang(69).": <select name='ns'$Hb>".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
  1432. tablesPrint($S){echo"<p id='tables' onmouseover='menuOver(this, event);' onmouseout='menuOut(this);'>\n";foreach($S
  1433. as$Q=>$Ig){echo'<a href="'.h(ME).'select='.urlencode($Q).'"'.bold($_GET["select"]==$Q||$_GET["edit"]==$Q,"select").">".lang(70)."</a> ";$C=$this->tableName($Ig);echo(support("table")||support("indexes")?'<a href="'.h(ME).'table='.urlencode($Q).'"'.bold(in_array($Q,array($_GET["table"],$_GET["create"],$_GET["indexes"],$_GET["foreign"],$_GET["trigger"])),(is_view($Ig)?"view":""),"structure")." title='".lang(40)."'>$C</a>":"<span>$C</span>")."<br>\n";}}}$b=(function_exists('adminer_object')?adminer_object():new
  1434. Adminer);if($b->operators===null)$b->operators=$Re;function
  1435. page_header($lh,$n="",$Wa=array(),$mh=""){global$ca,$ia,$b,$Xb,$w;page_headers();if(is_ajax()&&$n){page_messages($n);exit;}$nh=$lh.($mh!=""?": $mh":"");$oh=strip_tags($nh.(SERVER!=""&&SERVER!="localhost"?h(" - ".SERVER):"")." - ".$b->name());echo'<!DOCTYPE html>
  1436. <html lang="',$ca,'" dir="',lang(71),'">
  1437. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  1438. <meta http-equiv="Content-Script-Type" content="text/javascript">
  1439. <meta name="robots" content="noindex">
  1440. <meta name="referrer" content="origin-when-crossorigin">
  1441. <title>',$oh,'</title>
  1442. <link rel="stylesheet" type="text/css" href="',h(preg_replace("~\\?.*~","",ME))."?file=default.css&amp;version=4.2.5",'">
  1443. <script type="text/javascript" src="',h(preg_replace("~\\?.*~","",ME))."?file=functions.js&amp;version=4.2.5",'"></script>
  1444. ';if($b->head()){echo'<link rel="shortcut icon" type="image/x-icon" href="',h(preg_replace("~\\?.*~","",ME))."?file=favicon.ico&amp;version=4.2.5",'">
  1445. <link rel="apple-touch-icon" href="',h(preg_replace("~\\?.*~","",ME))."?file=favicon.ico&amp;version=4.2.5",'">
  1446. ';if(file_exists("adminer.css")){echo'<link rel="stylesheet" type="text/css" href="adminer.css">
  1447. ';}}echo'
  1448. <body class="',lang(71),' nojs" onkeydown="bodyKeydown(event);" onclick="bodyClick(event);"',(isset($_COOKIE["adminer_version"])?"":" onload=\"verifyVersion('$ia');\"");?>>
  1449. <script type="text/javascript">
  1450. document.body.className = document.body.className.replace(/ nojs/, ' js');
  1451. var offlineMessage = '<?php echo
  1452. js_escape(lang(72)),'\';
  1453. </script>
  1454.  
  1455. <div id="help" class="jush-',$w,' jsonly hidden" onmouseover="helpOpen = 1;" onmouseout="helpMouseout(this, event);"></div>
  1456.  
  1457. <div id="content">
  1458. ';if($Wa!==null){$_=substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1);echo'<p id="breadcrumb"><a href="'.h($_?$_:".").'">'.$Xb[DRIVER].'</a> &raquo; ';$_=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> &raquo; ";if($_GET["ns"]!=""||(DB!=""&&is_array($Wa)))echo'<a href="'.h($_."&db=".urlencode(DB).(support("scheme")?"&ns=":"")).'">'.h(DB).'</a> &raquo; ';if(is_array($Wa)){if($_GET["ns"]!="")echo'<a href="'.h(substr(ME,0,-1)).'">'.h($_GET["ns"]).'</a> &raquo; ';foreach($Wa
  1459. as$x=>$X){$Ob=(is_array($X)?$X[1]:h($X));if($Ob!="")echo"<a href='".h(ME."$x=").urlencode(is_array($X)?$X[0]:$X)."'>$Ob</a> &raquo; ";}}echo"$lh\n";}}echo"<h2>$nh</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
  1460. 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
  1461. page_messages($n){$Kh=preg_replace('~^[^?]*~','',$_SERVER["REQUEST_URI"]);$pe=$_SESSION["messages"][$Kh];if($pe){echo"<div class='message'>".implode("</div>\n<div class='message'>",$pe)."</div>\n";unset($_SESSION["messages"][$Kh]);}if($n)echo"<div class='error'>$n</div>\n";}function
  1462. page_footer($te=""){global$b,$T;echo'</div>
  1463.  
  1464. ';switch_lang();if($te!="auth"){echo'<form action="" method="post">
  1465. <p class="logout">
  1466. <input type="submit" name="logout" value="',lang(73),'" id="logout">
  1467. <input type="hidden" name="token" value="',$T,'">
  1468. </p>
  1469. </form>
  1470. ';}echo'<div id="menu">
  1471. ';$b->navigation($te);echo'</div>
  1472. <script type="text/javascript">setupSubmitHighlight(document);</script>
  1473. ';}function
  1474. int32($we){while($we>=2147483648)$we-=4294967296;while($we<=-2147483649)$we+=4294967296;return(int)$we;}function
  1475. long2str($W,$ai){$lg='';foreach($W
  1476. as$X)$lg.=pack('V',$X);if($ai)return
  1477. substr($lg,0,end($W));return$lg;}function
  1478. str2long($lg,$ai){$W=array_values(unpack('V*',str_pad($lg,4*ceil(strlen($lg)/4),"\0")));if($ai)$W[]=strlen($lg);return$W;}function
  1479. xxtea_mx($gi,$fi,$Pg,$Gd){return
  1480. int32((($gi>>5&0x7FFFFFF)^$fi<<2)+(($fi>>3&0x1FFFFFFF)^$gi<<4))^int32(($Pg^$fi)+($Gd^$gi));}function
  1481. encrypt_string($Kg,$x){if($Kg=="")return"";$x=array_values(unpack("V*",pack("H*",md5($x))));$W=str2long($Kg,true);$we=count($W)-1;$gi=$W[$we];$fi=$W[0];$Kf=floor(6+52/($we+1));$Pg=0;while($Kf-->0){$Pg=int32($Pg+0x9E3779B9);$ec=$Pg>>2&3;for($hf=0;$hf<$we;$hf++){$fi=$W[$hf+1];$ve=xxtea_mx($gi,$fi,$Pg,$x[$hf&3^$ec]);$gi=int32($W[$hf]+$ve);$W[$hf]=$gi;}$fi=$W[0];$ve=xxtea_mx($gi,$fi,$Pg,$x[$hf&3^$ec]);$gi=int32($W[$we]+$ve);$W[$we]=$gi;}return
  1482. long2str($W,false);}function
  1483. decrypt_string($Kg,$x){if($Kg=="")return"";if(!$x)return
  1484. false;$x=array_values(unpack("V*",pack("H*",md5($x))));$W=str2long($Kg,false);$we=count($W)-1;$gi=$W[$we];$fi=$W[0];$Kf=floor(6+52/($we+1));$Pg=int32($Kf*0x9E3779B9);while($Pg){$ec=$Pg>>2&3;for($hf=$we;$hf>0;$hf--){$gi=$W[$hf-1];$ve=xxtea_mx($gi,$fi,$Pg,$x[$hf&3^$ec]);$fi=int32($W[$hf]-$ve);$W[$hf]=$fi;}$gi=$W[$we];$ve=xxtea_mx($gi,$fi,$Pg,$x[$hf&3^$ec]);$fi=int32($W[0]-$ve);$W[0]=$fi;$Pg=int32($Pg-0x9E3779B9);}return
  1485. long2str($W,true);}$h='';$dd=$_SESSION["token"];if(!$dd)$_SESSION["token"]=rand(1,1e6);$T=get_token();$tf=array();if($_COOKIE["adminer_permanent"]){foreach(explode(" ",$_COOKIE["adminer_permanent"])as$X){list($x)=explode(":",$X);$tf[$x]=$X;}}function
  1486. add_invalid_login(){global$b;$Ic=get_temp_dir()."/adminer.invalid";$Sc=@fopen($Ic,"r+");if(!$Sc){$Sc=@fopen($Ic,"w");if(!$Sc)return;}flock($Sc,LOCK_EX);$zd=unserialize(stream_get_contents($Sc));$ih=time();if($zd){foreach($zd
  1487. as$_d=>$X){if($X[0]<$ih)unset($zd[$_d]);}}$yd=&$zd[$b->bruteForceKey()];if(!$yd)$yd=array($ih+30*60,0);$yd[1]++;$wg=serialize($zd);rewind($Sc);fwrite($Sc,$wg);ftruncate($Sc,strlen($wg));flock($Sc,LOCK_UN);fclose($Sc);}$Ka=$_POST["auth"];if($Ka){$zd=unserialize(@file_get_contents(get_temp_dir()."/adminer.invalid"));$yd=$zd[$b->bruteForceKey()];$Be=($yd[1]>30?$yd[0]-time():0);if($Be>0)auth_error(lang(74,ceil($Be/60)));session_regenerate_id();$Vh=$Ka["driver"];$N=$Ka["server"];$V=$Ka["username"];$G=(string)$Ka["password"];$m=$Ka["db"];set_password($Vh,$N,$V,$G);$_SESSION["db"][$Vh][$N][$V][$m]=true;if($Ka["permanent"]){$x=base64_encode($Vh)."-".base64_encode($N)."-".base64_encode($V)."-".base64_encode($m);$Ef=$b->permanentLogin(true);$tf[$x]="$x:".base64_encode($Ef?encrypt_string($G,$Ef):"");cookie("adminer_permanent",implode(" ",$tf));}if(count($_POST)==1||DRIVER!=$Vh||SERVER!=$N||$_GET["username"]!==$V||DB!=$m)redirect(auth_url($Vh,$N,$V,$m));}elseif($_POST["logout"]){if($dd&&!verify_token()){page_header(lang(73),lang(75));page_footer("db");exit;}else{foreach(array("pwds","db","dbs","queries")as$x)set_session($x,null);unset_permanent();redirect(substr(preg_replace('~\b(username|db|ns)=[^&]*&~','',ME),0,-1),lang(76));}}elseif($tf&&!$_SESSION["pwds"]){session_regenerate_id();$Ef=$b->permanentLogin();foreach($tf
  1488. as$x=>$X){list(,$hb)=explode(":",$X);list($Vh,$N,$V,$m)=array_map('base64_decode',explode("-",$x));set_password($Vh,$N,$V,decrypt_string(base64_decode($hb),$Ef));$_SESSION["db"][$Vh][$N][$V][$m]=true;}}function
  1489. unset_permanent(){global$tf;foreach($tf
  1490. as$x=>$X){list($Vh,$N,$V,$m)=array_map('base64_decode',explode("-",$x));if($Vh==DRIVER&&$N==SERVER&&$V==$_GET["username"]&&$m==DB)unset($tf[$x]);}cookie("adminer_permanent",implode(" ",$tf));}function
  1491. auth_error($n){global$b,$dd;$n=h($n);$zg=session_name();if(isset($_GET["username"])){header("HTTP/1.1 403 Forbidden");if(($_COOKIE[$zg]||$_GET[$zg])&&!$dd)$n=lang(77);else{add_invalid_login();$G=get_password();if($G!==null){if($G===false)$n.='<br>'.lang(78,'<code>permanentLogin()</code>');set_password(DRIVER,SERVER,$_GET["username"],null);}unset_permanent();}}if(!$_COOKIE[$zg]&&$_GET[$zg]&&ini_bool("session.use_only_cookies"))$n=lang(79);$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(80),lang(81,implode(", ",$zf)),false);page_footer("auth");exit;}$h=connect();}$Wb=new
  1492. Min_Driver($h);if(!is_object($h)||($Zd=$b->login($_GET["username"],get_password()))!==true)auth_error((is_string($h)?$h:(is_string($Zd)?$Zd:lang(82))));if($Ka&&$_POST["token"])$_POST["token"]=$T;$n='';if($_POST){if(!verify_token()){$td="max_input_vars";$je=ini_get($td);if(extension_loaded("suhosin")){foreach(array("suhosin.request.max_vars","suhosin.post.max_vars")as$x){$X=ini_get($x);if($X&&(!$je||$X<$je)){$td=$x;$je=$X;}}}$n=(!$_POST["token"]&&$je?lang(83,"'$td'"):lang(75).' '.lang(84));}}elseif($_SERVER["REQUEST_METHOD"]=="POST"){$n=lang(85,"'post_max_size'");if(isset($_GET["sql"]))$n.=' '.lang(86);}if(!ini_bool("session.use_cookies")||@ini_set("session.use_cookies",false)!==false)session_write_close();function
  1493. select($I,$i=null,$Ze=array(),$z=0){global$w;$Yd=array();$v=array();$f=array();$Ta=array();$Bh=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($Fd=0;$Fd<count($K);$Fd++){$o=$I->fetch_field();$C=$o->name;$Ye=$o->orgtable;$Xe=$o->orgname;$J[$o->table]=$Ye;if($Ze&&$w=="sql")$Yd[$Fd]=($C=="table"?"table=":($C=="possible_keys"?"indexes=":null));elseif($Ye!=""){if(!isset($v[$Ye])){$v[$Ye]=array();foreach(indexes($Ye,$i)as$u){if($u["type"]=="PRIMARY"){$v[$Ye]=array_flip($u["columns"]);break;}}$f[$Ye]=$v[$Ye];}if(isset($f[$Ye][$Xe])){unset($f[$Ye][$Xe]);$v[$Ye][$Xe]=$Fd;$Yd[$Fd]=$Ye;}}if($o->charsetnr==63)$Ta[$Fd]=true;$Bh[$Fd]=$o->type;echo"<th".($Ye!=""||$o->name!=$Xe?" title='".h(($Ye!=""?"$Ye.":"").$Xe)."'":"").">".h($C).($Ze?doc_link(array('sql'=>"explain-output.html#explain_".strtolower($C))):"");}echo"</thead>\n";}echo"<tr".odd().">";foreach($K
  1494. as$x=>$X){if($X===null)$X="<i>NULL</i>";elseif($Ta[$x]&&!is_utf8($X))$X="<i>".lang(44,strlen($X))."</i>";elseif(!strlen($X))$X="&nbsp;";else{$X=h($X);if($Bh[$x]==254)$X="<code>$X</code>";}if(isset($Yd[$x])&&!$f[$Yd[$x]]){if($Ze&&$w=="sql"){$Q=$K[array_search("table=",$Yd)];$_=$Yd[$x].urlencode($Ze[$Q]!=""?$Ze[$Q]:$Q);}else{$_="edit=".urlencode($Yd[$x]);foreach($v[$Yd[$x]]as$lb=>$Fd)$_.="&where".urlencode("[".bracket_escape($lb)."]")."=".urlencode($K[$Fd]);}$X="<a href='".h(ME.$_)."'>$X</a>";}echo"<td>$X";}}echo($s?"</table>":"<p class='message'>".lang(12))."\n";return$J;}function
  1495. referencable_primary($tg){$J=array();foreach(table_status('',true)as$Tg=>$Q){if($Tg!=$tg&&fk_support($Q)){foreach(fields($Tg)as$o){if($o["primary"]){if($J[$Tg]){unset($J[$Tg]);break;}$J[$Tg]=$o;}}}}return$J;}function
  1496. textarea($C,$Y,$L=10,$ob=80){global$w;echo"<textarea name='$C' rows='$L' cols='$ob' class='sqlarea jush-$w' spellcheck='false' wrap='off'>";if(is_array($Y)){foreach($Y
  1497. as$X)echo
  1498. h($X[0])."\n\n\n";}else
  1499. echo
  1500. h($Y);echo"</textarea>";}function
  1501. edit_type($x,$o,$nb,$Oc=array()){global$Lg,$Bh,$Ih,$Me;$U=$o["type"];echo'<td><select name="',h($x),'[type]" class="type" onfocus="lastType = selectValue(this);" onchange="editingTypeChange(this);"',on_help("getTarget(event).value",1),'>';if($U&&!isset($Bh[$U])&&!isset($Oc[$U]))array_unshift($Lg,$U);if($Oc)$Lg[lang(87)]=$Oc;echo
  1502. optionlist($Lg,$U),'</select>
  1503. <td><input name="',h($x),'[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();"><td class="options">';echo"<select name='".h($x)."[collation]'".(preg_match('~(char|text|enum|set)$~',$U)?"":" class='hidden'").'><option value="">('.lang(88).')'.optionlist($nb,$o["collation"]).'</select>',($Ih?"<select name='".h($x)."[unsigned]'".(!$U||preg_match('~((^|[^o])int|float|double|decimal)$~',$U)?"":" class='hidden'").'><option>'.optionlist($Ih,$o["unsigned"]).'</select>':''),(isset($o['on_update'])?"<select name='".h($x)."[on_update]'".(preg_match('~timestamp|datetime~',$U)?"":" class='hidden'").'>'.optionlist(array(""=>"(".lang(89).")","CURRENT_TIMESTAMP"),$o["on_update"]).'</select>':''),($Oc?"<select name='".h($x)."[on_delete]'".(preg_match("~`~",$U)?"":" class='hidden'")."><option value=''>(".lang(90).")".optionlist(explode("|",$Me),$o["on_delete"])."</select> ":" ");}function
  1504. process_length($y){global$pc;return(preg_match("~^\\s*\\(?\\s*$pc(?:\\s*,\\s*$pc)*+\\s*\\)?\\s*\$~",$y)&&preg_match_all("~$pc~",$y,$de)?"(".implode(",",$de[0]).")":preg_replace('~^[0-9].*~','(\0)',preg_replace('~[^-0-9,+()[\]]~','',$y)));}function
  1505. process_type($o,$mb="COLLATE"){global$Ih;return" $o[type]".process_length($o["length"]).(preg_match('~(^|[^o])int|float|double|decimal~',$o["type"])&&in_array($o["unsigned"],$Ih)?" $o[unsigned]":"").(preg_match('~char|text|enum|set~',$o["type"])&&$o["collation"]?" $mb ".q($o["collation"]):"");}function
  1506. process_field($o,$_h){global$w;$Lb=$o["default"];return
  1507. array(idf_escape(trim($o["field"])),process_type($_h),($o["null"]?" NULL":" NOT NULL"),(isset($Lb)?" DEFAULT ".((preg_match('~time~',$o["type"])&&preg_match('~^CURRENT_TIMESTAMP$~i',$Lb))||($w=="sqlite"&&preg_match('~^CURRENT_(TIME|TIMESTAMP|DATE)$~i',$Lb))||($o["type"]=="bit"&&preg_match("~^([0-9]+|b'[0-1]+')\$~",$Lb))||($w=="pgsql"&&preg_match("~^[a-z]+\\(('[^']*')+\\)\$~",$Lb))?$Lb:q($Lb)):""),(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
  1508. type_class($U){foreach(array('char'=>'text','date'=>'time|year','binary'=>'blob','enum'=>'set',)as$x=>$X){if(preg_match("~$x|$X~",$U))return" class='$x'";}}function
  1509. edit_fields($p,$nb,$U="TABLE",$Oc=array(),$sb=false){global$h,$ud;$p=array_values($p);echo'<thead><tr class="wrap">
  1510. ';if($U=="PROCEDURE"){echo'<td>&nbsp;';}echo'<th>',($U=="TABLE"?lang(91):lang(92)),'<td>',lang(93),'<textarea id="enum-edit" rows="4" cols="12" wrap="off" style="display: none;" onblur="editingLengthBlur(this);"></textarea>
  1511. <td>',lang(94),'<td>',lang(95);if($U=="TABLE"){echo'<td>NULL
  1512. <td><input type="radio" name="auto_increment_col" value=""><acronym title="',lang(57),'">AI</acronym>',doc_link(array('sql'=>"example-auto-increment.html",'sqlite'=>"autoinc.html",'pgsql'=>"datatype.html#DATATYPE-SERIAL",'mssql'=>"ms186775.aspx",)),'<td>',lang(96),(support("comment")?"<td".($sb?"":" class='hidden'").">".lang(97):"");}echo'<td>',"<input type='image' class='icon' name='add[".(support("move_col")?0:count($p))."]' src='".h(preg_replace("~\\?.*~","",ME))."?file=plus.gif&amp;version=4.2.5' alt='+' title='".lang(98)."'>",'<script type="text/javascript">row_count = ',count($p),';</script>
  1513. </thead>
  1514. <tbody onkeydown="return editingKeydown(event);">
  1515. ';foreach($p
  1516. as$s=>$o){$s++;$af=$o[($_POST?"orig":"field")];$Sb=(isset($_POST["add"][$s-1])||(isset($o["field"])&&!$_POST["drop_col"][$s]))&&(support("drop_col")||$af=="");echo'<tr',($Sb?"":" style='display: none;'"),'>
  1517. ',($U=="PROCEDURE"?"<td>".html_select("fields[$s][inout]",explode("|",$ud),$o["inout"]):""),'<th>';if($Sb){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">';}echo'<input type="hidden" name="fields[',$s,'][orig]" value="',h($af),'">
  1518. ';edit_type("fields[$s]",$o,$nb,$Oc);if($U=="TABLE"){echo'<td>',checkbox("fields[$s][null]",1,$o["null"],"","","block"),'<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(); }"></label><td><?php
  1519. echo
  1520. checkbox("fields[$s][has_default]",1,$o["has_default"]),'<input name="fields[',$s,'][default]" value="',h($o["default"]),'" onkeyup="keyupChange.call(this);" onchange="this.previousSibling.checked = true;">
  1521. ',(support("comment")?"<td".($sb?"":" class='hidden'")."><input name='fields[$s][comment]' value='".h($o["comment"])."' maxlength='".($h->server_info>=5.5?1024:255)."'>":"");}echo"<td>",(support("move_col")?"<input type='image' class='icon' name='add[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=plus.gif&amp;version=4.2.5' alt='+' title='".lang(98)."' onclick='return !editingAddRow(this, 1);'>&nbsp;"."<input type='image' class='icon' name='up[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=up.gif&amp;version=4.2.5' alt='^' title='".lang(99)."'>&nbsp;"."<input type='image' class='icon' name='down[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=down.gif&amp;version=4.2.5' alt='v' title='".lang(100)."'>&nbsp;":""),($af==""||support("drop_col")?"<input type='image' class='icon' name='drop_col[$s]' src='".h(preg_replace("~\\?.*~","",ME))."?file=cross.gif&amp;version=4.2.5' alt='x' title='".lang(101)."' onclick=\"return !editingRemoveRow(this, 'fields\$1[field]');\">":""),"\n";}}function
  1522. process_fields(&$p){ksort($p);$D=0;if($_POST["up"]){$Qd=0;foreach($p
  1523. as$x=>$o){if(key($_POST["up"])==$x){unset($p[$x]);array_splice($p,$Qd,0,array($o));break;}if(isset($o["field"]))$Qd=$D;$D++;}}elseif($_POST["down"]){$Qc=false;foreach($p
  1524. as$x=>$o){if(isset($o["field"])&&$Qc){unset($p[key($_POST["down"])]);array_splice($p,$D,0,array($Qc));break;}if(key($_POST["down"])==$x)$Qc=$o;$D++;}}elseif($_POST["add"]){$p=array_values($p);array_splice($p,key($_POST["add"]),0,array(array()));}elseif(!$_POST["drop_col"])return
  1525. false;return
  1526. true;}function
  1527. 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
  1528. grant($Vc,$Gf,$f,$Le){if(!$Gf)return
  1529. true;if($Gf==array("ALL PRIVILEGES","GRANT OPTION"))return($Vc=="GRANT"?queries("$Vc ALL PRIVILEGES$Le WITH GRANT OPTION"):queries("$Vc ALL PRIVILEGES$Le")&&queries("$Vc GRANT OPTION$Le"));return
  1530. queries("$Vc ".preg_replace('~(GRANT OPTION)\\([^)]*\\)~','\\1',implode("$f, ",$Gf).$f).$Le);}function
  1531. drop_create($Yb,$j,$Zb,$fh,$bc,$A,$oe,$me,$ne,$Ie,$ze){if($_POST["drop"])query_redirect($Yb,$A,$oe);elseif($Ie=="")query_redirect($j,$A,$ne);elseif($Ie!=$ze){$Cb=queries($j);queries_redirect($A,$me,$Cb&&queries($Yb));if($Cb)queries($Zb);}else
  1532. queries_redirect($A,$me,queries($fh)&&queries($bc)&&queries($Yb)&&queries($j));}function
  1533. create_trigger($Le,$K){global$w;$kh=" $K[Timing] $K[Event]".($K["Event"]=="UPDATE OF"?" ".idf_escape($K["Of"]):"");return"CREATE TRIGGER ".idf_escape($K["Trigger"]).($w=="mssql"?$Le.$kh:$kh.$Le).rtrim(" $K[Type]\n$K[Statement]",";").";";}function
  1534. create_routine($hg,$K){global$ud;$O=array();$p=(array)$K["fields"];ksort($p);foreach($p
  1535. as$o){if($o["field"]!="")$O[]=(preg_match("~^($ud)\$~",$o["inout"])?"$o[inout] ":"").idf_escape($o["field"]).process_type($o,"CHARACTER SET");}return"CREATE $hg ".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
  1536. remove_definer($H){return
  1537. preg_replace('~^([A-Z =]+) DEFINER=`'.preg_replace('~@(.*)~','`@`(%|\\1)',logged_user()).'`~','\\1',$H);}function
  1538. format_foreign_key($q){global$Me;return" FOREIGN KEY (".implode(", ",array_map('idf_escape',$q["source"])).") REFERENCES ".table($q["table"])." (".implode(", ",array_map('idf_escape',$q["target"])).")".(preg_match("~^($Me)\$~",$q["on_delete"])?" ON DELETE $q[on_delete]":"").(preg_match("~^($Me)\$~",$q["on_update"])?" ON UPDATE $q[on_update]":"");}function
  1539. tar_file($Ic,$ph){$J=pack("a100a8a8a8a12a12",$Ic,644,0,0,decoct($ph->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));$ph->send();echo
  1540. str_repeat("\0",511-($ph->size+511)%512);}function
  1541. ini_bytes($td){$X=ini_get($td);switch(strtolower(substr($X,-1))){case'g':$X*=1024;case'm':$X*=1024;case'k':$X*=1024;}return$X;}function
  1542. doc_link($rf){global$w,$h;$Mh=array('sql'=>"http://dev.mysql.com/doc/refman/".substr($h->server_info,0,3)."/en/",'sqlite'=>"http://www.sqlite.org/",'pgsql'=>"http://www.postgresql.org/docs/".substr($h->server_info,0,3)."/static/",'mssql'=>"http://msdn.microsoft.com/library/",'oracle'=>"http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/",);return($rf[$w]?"<a href='$Mh[$w]$rf[$w]' target='_blank' rel='noreferrer'><sup>?</sup></a>":"");}function
  1543. ob_gzencode($P){return
  1544. gzencode($P);}function
  1545. db_size($m){global$h;if(!$h->select_db($m))return"?";$J=0;foreach(table_status()as$R)$J+=$R["Data_length"]+$R["Index_length"];return
  1546. format_number($J);}function
  1547. set_utf8mb4($j){global$h;static$O=false;if(!$O&&preg_match('~\butf8mb4~i',$j)){$O=true;echo"SET NAMES ".charset($h).";\n\n";}}function
  1548. connect_error(){global$b,$h,$T,$n,$Xb;if(DB!=""){header("HTTP/1.1 404 Not Found");page_header(lang(35).": ".h(DB),lang(102),true);}else{if($_POST["db"]&&!$n)queries_redirect(substr(ME,0,-1),lang(103),drop_databases($_POST["db"]));page_header(lang(104),$n,false);echo"<p class='links'>\n";foreach(array('database'=>lang(105),'privileges'=>lang(64),'processlist'=>lang(106),'variables'=>lang(107),'status'=>lang(108),)as$x=>$X){if(support($x))echo"<a href='".h(ME)."$x='>$X</a>\n";}echo"<p>".lang(109,$Xb[DRIVER],"<b>".h($h->server_info)."</b>","<b>$h->extension</b>")."\n","<p>".lang(110,"<b>".h(logged_user())."</b>")."\n";$l=$b->databases();if($l){$og=support("scheme");$nb=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>&nbsp;":"")."<th>".lang(35)." - <a href='".h(ME)."refresh=1'>".lang(111)."</a>"."<td>".lang(112)."<td>".lang(113)."<td>".lang(114)." - <a href='".h(ME)."dbsize=1' onclick=\"return !ajaxSetHtml('".h(js_escape(ME))."script=connect');\">".lang(115)."</a>"."</thead>\n";$l=($_GET["dbsize"]?count_tables($l):array_flip($l));foreach($l
  1549. as$m=>$S){$gg=h(ME)."db=".urlencode($m);echo"<tr".odd().">".(support("database")?"<td>".checkbox("db[]",$m,in_array($m,(array)$_POST["db"])):""),"<th><a href='$gg'>".h($m)."</a>";$d=nbsp(db_collation($m,$nb));echo"<td>".(support("database")?"<a href='$gg".($og?"&amp;ns=":"")."&amp;database=' title='".lang(60)."'>$d</a>":$d),"<td align='right'><a href='$gg&amp;schema=' id='tables-".h($m)."' title='".lang(63)."'>".($_GET["dbsize"]?$S:"?")."</a>","<td align='right' id='size-".h($m)."'>".($_GET["dbsize"]?db_size($m):"?"),"\n";}echo"</table>\n",(support("database")?"<fieldset><legend>".lang(116)." <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(117)."'".confirm().">\n"."</div></fieldset>\n":""),"<script type='text/javascript'>tableCheck();</script>\n","<input type='hidden' name='token' value='$T'>\n","</form>\n";}}page_footer("db");}if(isset($_GET["status"]))$_GET["variables"]=$_GET["status"];if(isset($_GET["import"]))$_GET["sql"]=$_GET["import"];if(!(DB!=""?$h->select_db(DB):isset($_GET["sql"])||isset($_GET["dump"])||isset($_GET["database"])||isset($_GET["processlist"])||isset($_GET["privileges"])||isset($_GET["user"])||isset($_GET["variables"])||$_GET["script"]=="connect"||$_GET["script"]=="kill")){if(DB!=""||$_GET["refresh"]){restart_session();set_session("dbs",null);}connect_error();exit;}if(support("scheme")&&DB!=""&&$_GET["ns"]!==""){if(!isset($_GET["ns"]))redirect(preg_replace('~ns=[^&]*&~','',ME)."ns=".get_schema());if(!set_schema($_GET["ns"])){header("HTTP/1.1 404 Not Found");page_header(lang(69).": ".h($_GET["ns"]),lang(118),true);page_footer("ns");exit;}}$Me="RESTRICT|NO ACTION|CASCADE|SET NULL|SET DEFAULT";class
  1550. TmpFile{var$handler;var$size;function
  1551. __construct(){$this->handler=tmpfile();}function
  1552. write($xb){$this->size+=strlen($xb);fwrite($this->handler,$xb);}function
  1553. send(){fseek($this->handler,0);fpassthru($this->handler);fclose($this->handler);}}$pc="'(?:''|[^'\\\\]|\\\\.)*'";$ud="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=$Wb->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();$R=table_status1($a,true);page_header(($p&&is_view($R)?lang(119):lang(120)).": ".h($a),$n);$b->selectLinks($R);$rb=$R["Comment"];if($rb!="")echo"<p>".lang(97).": ".h($rb)."\n";if($p){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(121)."<td>".lang(93).(support("comment")?"<td>".lang(97):"")."</thead>\n";foreach($p
  1554. 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(57)."</i>":""),(isset($o["default"])?" <span title='".lang(96)."'>[<b>".h($o["default"])."</b>]</span>":""),(support("comment")?"<td>".nbsp($o["comment"]):""),"\n";}echo"</table>\n";}if(!is_view($R)){if(support("indexes")){echo"<h3 id='indexes'>".lang(122)."</h3>\n";$v=indexes($a);if($v){echo"<table cellspacing='0'>\n";foreach($v
  1555. as$C=>$u){ksort($u["columns"]);$Df=array();foreach($u["columns"]as$x=>$X)$Df[]="<i>".h($X)."</i>".($u["lengths"][$x]?"(".$u["lengths"][$x].")":"").($u["descs"][$x]?" DESC":"");echo"<tr title='".h($C)."'><th>$u[type]<td>".implode(", ",$Df)."\n";}echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'indexes='.urlencode($a).'">'.lang(123)."</a>\n";}if(fk_support($R)){echo"<h3 id='foreign-keys'>".lang(87)."</h3>\n";$Oc=foreign_keys($a);if($Oc){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(124)."<td>".lang(125)."<td>".lang(90)."<td>".lang(89)."<td>&nbsp;</thead>\n";foreach($Oc
  1556. 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(126).'</a>';}echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'foreign='.urlencode($a).'">'.lang(127)."</a>\n";}}if(support(is_view($R)?"view_trigger":"trigger")){echo"<h3 id='triggers'>".lang(128)."</h3>\n";$zh=triggers($a);if($zh){echo"<table cellspacing='0'>\n";foreach($zh
  1557. as$x=>$X)echo"<tr valign='top'><td>".h($X[0])."<td>".h($X[1])."<th>".h($x)."<td><a href='".h(ME.'trigger='.urlencode($a).'&name='.urlencode($x))."'>".lang(126)."</a>\n";echo"</table>\n";}echo'<p class="links"><a href="'.h(ME).'trigger='.urlencode($a).'">'.lang(129)."</a>\n";}}elseif(isset($_GET["schema"])){page_header(lang(63),"",array(),h(DB.($_GET["ns"]?".$_GET[ns]":"")));$Vg=array();$Wg=array();$ea=($_GET["schema"]?$_GET["schema"]:$_COOKIE["adminer_schema-".str_replace(".","_",DB)]);preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~',$ea,$de,PREG_SET_ORDER);foreach($de
  1558. as$s=>$B){$Vg[$B[1]]=array($B[2],$B[3]);$Wg[]="\n\t'".js_escape($B[1])."': [ $B[2], $B[3] ]";}$rh=0;$Qa=-1;$ng=array();$Vf=array();$Ud=array();foreach(table_status('',true)as$Q=>$R){if(is_view($R))continue;$wf=0;$ng[$Q]["fields"]=array();foreach(fields($Q)as$C=>$o){$wf+=1.25;$o["pos"]=$wf;$ng[$Q]["fields"][$C]=$o;}$ng[$Q]["pos"]=($Vg[$Q]?$Vg[$Q]:array($rh,0));foreach($b->foreignKeys($Q)as$X){if(!$X["db"]){$Sd=$Qa;if($Vg[$Q][1]||$Vg[$X["table"]][1])$Sd=min(floatval($Vg[$Q][1]),floatval($Vg[$X["table"]][1]))-1;else$Qa-=.1;while($Ud[(string)$Sd])$Sd-=.0001;$ng[$Q]["references"][$X["table"]][(string)$Sd]=array($X["source"],$X["target"]);$Vf[$X["table"]][$Q][(string)$Sd]=$X["target"];$Ud[(string)$Sd]=true;}}$rh=max($rh,$ng[$Q]["pos"][0]+2.5+$wf);}echo'<div id="schema" style="height: ',$rh,'em;" onselectstart="return false;">
  1559. <script type="text/javascript">
  1560. var tablePos = {',implode(",",$Wg)."\n",'};
  1561. var em = document.getElementById(\'schema\').offsetHeight / ',$rh,';
  1562. document.onmousemove = schemaMousemove;
  1563. document.onmouseup = function (ev) {
  1564.     schemaMouseup(ev, \'',js_escape(DB),'\');
  1565. };
  1566. </script>
  1567. ';foreach($ng
  1568. as$C=>$Q){echo"<div class='table' style='top: ".$Q["pos"][0]."em; left: ".$Q["pos"][1]."em;' onmousedown='schemaMousedown(this, event);'>",'<a href="'.h(ME).'table='.urlencode($C).'"><b>'.h($C)."</b></a>";foreach($Q["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)$Q["references"]as$ch=>$Wf){foreach($Wf
  1569. as$Sd=>$Sf){$Td=$Sd-$Vg[$C][1];$s=0;foreach($Sf[0]as$Dg)echo"\n<div class='references' title='".h($ch)."' id='refs$Sd-".($s++)."' style='left: $Td"."em; top: ".$Q["fields"][$Dg]["pos"]."em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: ".(-$Td)."em;'></div></div>";}}foreach((array)$Vf[$C]as$ch=>$Wf){foreach($Wf
  1570. as$Sd=>$f){$Td=$Sd-$Vg[$C][1];$s=0;foreach($f
  1571. as$bh)echo"\n<div class='references' title='".h($ch)."' id='refd$Sd-".($s++)."' style='left: $Td"."em; top: ".$Q["fields"][$bh]["pos"]."em; height: 1.25em; background: url(".h(preg_replace("~\\?.*~","",ME))."?file=arrow.gif) no-repeat right center;&amp;version=4.2.5'><div style='height: .5em; border-bottom: 1px solid Gray; width: ".(-$Td)."em;'></div></div>";}}echo"\n</div>\n";}foreach($ng
  1572. as$C=>$Q){foreach((array)$Q["references"]as$ch=>$Wf){foreach($Wf
  1573. as$Sd=>$Sf){$se=$rh;$he=-10;foreach($Sf[0]as$x=>$Dg){$xf=$Q["pos"][0]+$Q["fields"][$Dg]["pos"];$yf=$ng[$ch]["pos"][0]+$ng[$ch]["fields"][$Sf[1][$x]]["pos"];$se=min($se,$xf,$yf);$he=max($he,$xf,$yf);}echo"<div class='references' id='refl$Sd' style='left: $Sd"."em; top: $se"."em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: ".($he-$se)."em;'></div></div>\n";}}}echo'</div>
  1574. <p class="links"><a href="',h(ME."schema=".urlencode($ea)),'" id="schema-link">',lang(130),'</a>
  1575. ';}elseif(isset($_GET["dump"])){$a=$_GET["dump"];if($_POST&&!$n){$_b="";foreach(array("output","format","db_style","routines","events","table_style","auto_increment","triggers","data_style")as$x)$_b.="&$x=".urlencode($_POST[$x]);cookie("adminer_export",substr($_b,1));$S=array_flip((array)$_POST["tables"])+array_flip((array)$_POST["data"]);$Ac=dump_headers((count($S)==1?key($S):DB),(DB==""||count($S)>1));$Bd=preg_match('~sql~',$_POST["format"]);if($Bd){echo"-- Adminer $ia ".$Xb[DRIVER]." dump\n\n";if($w=="sql"){echo"SET NAMES utf8;
  1576. SET time_zone = '+00:00';
  1577. ".($_POST["data_style"]?"SET foreign_key_checks = 0;
  1578. SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO';
  1579. ":"")."
  1580. ";$h->query("SET time_zone = '+00:00';");}}$Mg=$_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
  1581. as$m){$b->dumpDatabase($m);if($h->select_db($m)){if($Bd&&preg_match('~CREATE~',$Mg)&&($j=$h->result("SHOW CREATE DATABASE ".idf_escape($m),1))){set_utf8mb4($j);if($Mg=="DROP+CREATE")echo"DROP DATABASE IF EXISTS ".idf_escape($m).";\n";echo"$j;\n";}if($Bd){if($Mg)echo
  1582. use_sql($m).";\n\n";$ff="";if($_POST["routines"]){foreach(array("FUNCTION","PROCEDURE")as$hg){foreach(get_rows("SHOW $hg STATUS WHERE Db = ".q($m),null,"-- ")as$K){$j=remove_definer($h->result("SHOW CREATE $hg ".idf_escape($K["Name"]),2));set_utf8mb4($j);$ff.=($Mg!='DROP+CREATE'?"DROP $hg IF EXISTS ".idf_escape($K["Name"]).";;\n":"")."$j;;\n\n";}}}if($_POST["events"]){foreach(get_rows("SHOW EVENTS",null,"-- ")as$K){$j=remove_definer($h->result("SHOW CREATE EVENT ".idf_escape($K["Name"]),3));set_utf8mb4($j);$ff.=($Mg!='DROP+CREATE'?"DROP EVENT IF EXISTS ".idf_escape($K["Name"]).";;\n":"")."$j;;\n\n";}}if($ff)echo"DELIMITER ;;\n\n$ff"."DELIMITER ;\n\n";}if($_POST["table_style"]||$_POST["data_style"]){$Yh=array();foreach(table_status('',true)as$C=>$R){$Q=(DB==""||in_array($C,(array)$_POST["tables"]));$Eb=(DB==""||in_array($C,(array)$_POST["data"]));if($Q||$Eb){if($Ac=="tar"){$ph=new
  1583. TmpFile;ob_start(array($ph,'write'),1e5);}$b->dumpTable($C,($Q?$_POST["table_style"]:""),(is_view($R)?2:0));if(is_view($R))$Yh[]=$C;elseif($Eb){$p=fields($C);$b->dumpData($C,$_POST["data_style"],"SELECT *".convert_fields($p,$p)." FROM ".table($C));}if($Bd&&$_POST["triggers"]&&$Q&&($zh=trigger_sql($C,$_POST["table_style"])))echo"\nDELIMITER ;;\n$zh\nDELIMITER ;\n";if($Ac=="tar"){ob_end_flush();tar_file((DB!=""?"":"$m/")."$C.csv",$ph);}elseif($Bd)echo"\n";}}foreach($Yh
  1584. as$Xh)$b->dumpTable($Xh,$_POST["table_style"],1);if($Ac=="tar")echo
  1585. pack("x512");}}}if($Bd)echo"-- ".$h->result("SELECT NOW()")."\n";exit;}page_header(lang(66),$n,($_GET["export"]!=""?array("table"=>$_GET["export"]):array()),h(DB));echo'
  1586. <form action="" method="post">
  1587. <table cellspacing="0">
  1588. ';$Ib=array('','USE','DROP+CREATE','CREATE');$Xg=array('','DROP+CREATE','CREATE');$Fb=array('','TRUNCATE+INSERT','INSERT');if($w=="sql")$Fb[]='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(131)."<td>".html_select("output",$b->dumpOutput(),$K["output"],0)."\n";echo"<tr><th>".lang(132)."<td>".html_select("format",$b->dumpFormat(),$K["format"],0)."\n";echo($w=="sqlite"?"":"<tr><th>".lang(35)."<td>".html_select('db_style',$Ib,$K["db_style"]).(support("routine")?checkbox("routines",1,$K["routines"],lang(133)):"").(support("event")?checkbox("events",1,$K["events"],lang(134)):"")),"<tr><th>".lang(113)."<td>".html_select('table_style',$Xg,$K["table_style"]).checkbox("auto_increment",1,$K["auto_increment"],lang(57)).(support("trigger")?checkbox("triggers",1,$K["triggers"],lang(128)):""),"<tr><th>".lang(135)."<td>".html_select('data_style',$Fb,$K["data_style"]),'</table>
  1589. <p><input type="submit" value="',lang(66),'">
  1590. <input type="hidden" name="token" value="',$T,'">
  1591.  
  1592. <table cellspacing="0">
  1593. ';$Af=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(113)."</label>","<th style='text-align: right;'><label class='block'>".lang(135)."<input type='checkbox' id='check-data'$db onclick='formCheck(this, /^data\\[/);'></label>","</thead>\n";$Yh="";$Yg=tables_list();foreach($Yg
  1594. as$C=>$U){$_f=preg_replace('~_.*~','',$C);$db=($a==""||$a==(substr($a,-1)=="%"?"$_f%":$C));$Df="<tr><td>".checkbox("tables[]",$C,$db,$C,"checkboxClick(event, this); formUncheck('check-tables');","block");if($U!==null&&!preg_match('~table~i',$U))$Yh.="$Df\n";else
  1595. echo"$Df<td align='right'><label class='block'><span id='Rows-".h($C)."'></span>".checkbox("data[]",$C,$db,"","checkboxClick(event, this); formUncheck('check-data');")."</label>\n";$Af[$_f]++;}echo$Yh;if($Yg)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
  1596. as$m){if(!information_schema($m)){$_f=preg_replace('~_.*~','',$m);echo"<tr><td>".checkbox("databases[]",$m,$a==""||$a=="$_f%",$m,"formUncheck('check-databases');","block")."\n";$Af[$_f]++;}}}else
  1597. echo"<tr><td><textarea name='databases' rows='10' cols='20'></textarea>";}echo'</table>
  1598. </form>
  1599. ';$Kc=true;foreach($Af
  1600. as$x=>$X){if($x!=""&&$X>1){echo($Kc?"<p>":" ")."<a href='".h(ME)."dump=".urlencode("$x%")."'>".h($x)."</a>";$Kc=false;}}}elseif(isset($_GET["privileges"])){page_header(lang(64));$I=$h->query("SELECT User, Host FROM mysql.".(DB==""?"user":"db WHERE ".q(DB)." LIKE Db")." ORDER BY Host, User");$Vc=$I;if(!$I)$I=$h->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",($Vc?"":"<input type='hidden' name='grant' value=''>\n"),"<table cellspacing='0'>\n","<thead><tr><th>".lang(33)."<th>".lang(32)."<th>&nbsp;</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(!$Vc||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",'<p class="links"><a href="'.h(ME).'user=">'.lang(136)."</a>";}elseif(isset($_GET["sql"])){if(!$n&&$_POST["export"]){dump_headers("sql");$b->dumpTable("","");$b->dumpData("","table",$_POST["query"]);exit;}restart_session();$fd=&get_session("queries");$ed=&$fd[DB];if(!$n&&$_POST["clear"]){$ed=array();redirect(remove_from_uri("history"));}page_header((isset($_GET["import"])?lang(65):lang(56)),$n);if(!$n&&$_POST){$Sc=false;if(!isset($_GET["import"]))$H=$_POST["query"];elseif($_POST["webfile"]){$Sc=@fopen((file_exists("adminer.sql")?"adminer.sql":"compress.zlib://adminer.sql.gz"),"rb");$H=($Sc?fread($Sc,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){$Kf=$H.(preg_match("~;[ \t\r\n]*\$~",$H)?"":";");if(!$ed||reset(end($ed))!=$Kf){restart_session();$ed[]=array($Kf,time());set_session("queries",$fd);stop_session();}}$Eg="(?:\\s|/\\*[\s\S]*?\\*/|(?:#|-- )[^\n]*\n?|--\r?\n)";$Nb=";";$D=0;$mc=true;$i=connect();if(is_object($i)&&DB!="")$i->select_db(DB);$qb=0;$rc=array();$kf='[\'"'.($w=="sql"?'`#':($w=="sqlite"?'`[':($w=="mssql"?'[':''))).']|/\\*|-- |$'.($w=="pgsql"?'|\\$[^$]*\\$':'');$sh=microtime(true);parse_str($_COOKIE["adminer_export"],$xa);$dc=$b->dumpFormat();unset($dc["sql"]);while($H!=""){if(!$D&&preg_match("~^$Eg*+DELIMITER\\s+(\\S+)~i",$H,$B)){$Nb=$B[1];$H=substr($H,strlen($B[0]));}else{preg_match('('.preg_quote($Nb)."\\s*|$kf)",$H,$B,PREG_OFFSET_CAPTURE,$D);list($Qc,$wf)=$B[0];if(!$Qc&&$Sc&&!feof($Sc))$H.=fread($Sc,1e5);else{if(!$Qc&&rtrim($H)=="")break;$D=$wf+strlen($Qc);if($Qc&&rtrim($Qc)!=$Nb){while(preg_match('('.($Qc=='/*'?'\\*/':($Qc=='['?']':(preg_match('~^-- |^#~',$Qc)?"\n":preg_quote($Qc)."|\\\\."))).'|$)s',$H,$B,PREG_OFFSET_CAPTURE,$D)){$lg=$B[0][0];if(!$lg&&$Sc&&!feof($Sc))$H.=fread($Sc,1e5);else{$D=$B[0][1]+strlen($lg);if($lg[0]!="\\")break;}}}else{$mc=false;$Kf=substr($H,0,$wf);$qb++;$Df="<pre id='sql-$qb'><code class='jush-$w'>".shorten_utf8(trim($Kf),1000)."</code></pre>\n";if($w=="sqlite"&&preg_match("~^$Eg*+ATTACH\\b~i",$Kf,$B)){echo$Df,"<p class='error'>".lang(137)."\n";$rc[]=" <a href='#sql-$qb'>$qb</a>";if($_POST["error_stops"])break;}else{if(!$_POST["only_errors"]){echo$Df;ob_flush();flush();}$Hg=microtime(true);if($h->multi_query($Kf)&&is_object($i)&&preg_match("~^$Eg*+USE\\b~i",$Kf))$i->query($Kf);do{$I=$h->store_result();$ih=" <span class='time'>(".format_time($Hg).")</span>".(strlen($Kf)<1000?" <a href='".h(ME)."sql=".urlencode(trim($Kf))."'>".lang(10)."</a>":"");if($h->error){echo($_POST["only_errors"]?$Df:""),"<p class='error'>".lang(138).($h->errno?" ($h->errno)":"").": ".error()."\n";$rc[]=" <a href='#sql-$qb'>$qb</a>";if($_POST["error_stops"])break
  1601. 2;}elseif(is_object($I)){$z=$_POST["limit"];$Ze=select($I,$i,array(),$z);if(!$_POST["only_errors"]){echo"<form action='' method='post'>\n";$Ce=$I->num_rows;echo"<p>".($Ce?($z&&$Ce>$z?lang(139,$z):"").lang(140,$Ce):""),$ih;$jd="export-$qb";$_c=", <a href='#$jd' onclick=\"return !toggle('$jd');\">".lang(66)."</a><span id='$jd' class='hidden'>: ".html_select("output",$b->dumpOutput(),$xa["output"])." ".html_select("format",$dc,$xa["format"])."<input type='hidden' name='query' value='".h($Kf)."'>"." <input type='submit' name='export' value='".lang(66)."'><input type='hidden' name='token' value='$T'></span>\n";if($i&&preg_match("~^($Eg|\\()*+SELECT\\b~i",$Kf)&&($zc=explain($i,$Kf))){$jd="explain-$qb";echo", <a href='#$jd' onclick=\"return !toggle('$jd');\">EXPLAIN</a>$_c","<div id='$jd' class='hidden'>\n";select($zc,$i,$Ze);echo"</div>\n";}else
  1602. echo$_c;echo"</form>\n";}}else{if(preg_match("~^$Eg*+(CREATE|DROP|ALTER)$Eg++(DATABASE|SCHEMA)\\b~i",$Kf)){restart_session();set_session("dbs",null);stop_session();}if(!$_POST["only_errors"])echo"<p class='message' title='".h($h->info)."'>".lang(141,$h->affected_rows)."$ih\n";}$Hg=microtime(true);}while($h->next_result());}$H=substr($H,$D);$D=0;}}}}if($mc)echo"<p class='message'>".lang(142)."\n";elseif($_POST["only_errors"]){echo"<p class='message'>".lang(143,$qb-count($rc))," <span class='time'>(".format_time($sh).")</span>\n";}elseif($rc&&$qb>1)echo"<p class='error'>".lang(138).": ".implode("",$rc)."\n";}else
  1603. echo"<p class='error'>".upload_error($H)."\n";}echo'
  1604. <form action="" method="post" enctype="multipart/form-data" id="form">
  1605. ';$wc="<input type='submit' value='".lang(144)."' title='Ctrl+Enter'>";if(!isset($_GET["import"])){$Kf=$_GET["sql"];if($_POST)$Kf=$_POST["query"];elseif($_GET["history"]=="all")$Kf=$ed;elseif($_GET["history"]!="")$Kf=$ed[$_GET["history"]][0];echo"<p>";textarea("query",$Kf,20);echo($_POST?"":"<script type='text/javascript'>focus(document.getElementsByTagName('textarea')[0]);</script>\n"),"<p>$wc\n",lang(145).": <input type='number' name='limit' class='size' value='".h($_POST?$_POST["limit"]:$_GET["limit"])."'>\n";}else{echo"<fieldset><legend>".lang(146)."</legend><div>",(ini_bool("file_uploads")?"SQL (&lt; ".ini_get("upload_max_filesize")."B): <input type='file' name='sql_file[]' multiple>\n$wc":lang(147)),"</div></fieldset>\n","<fieldset><legend>".lang(148)."</legend><div>",lang(149,"<code>adminer.sql".(extension_loaded("zlib")?"[.gz]":"")."</code>"),' <input type="submit" name="webfile" value="'.lang(150).'">',"</div></fieldset>\n","<p>";}echo
  1606. checkbox("error_stops",1,($_POST?$_POST["error_stops"]:isset($_GET["import"])),lang(151))."\n",checkbox("only_errors",1,($_POST?$_POST["only_errors"]:isset($_GET["import"])),lang(152))."\n","<input type='hidden' name='token' value='$T'>\n";if(!isset($_GET["import"])&&$ed){print_fieldset("history",lang(153),$_GET["history"]!="");for($X=end($ed);$X;$X=prev($ed)){$x=key($ed);list($Kf,$ih,$hc)=$X;echo'<a href="'.h(ME."sql=&history=$x").'">'.lang(10)."</a>"." <span class='time' title='".@date('Y-m-d',$ih)."'>".@date("H:i:s",$ih)."</span>"." <code class='jush-$w'>".shorten_utf8(ltrim(str_replace("\n"," ",str_replace("\r","",preg_replace('~^(#|-- ).*~m','',$Kf)))),80,"</code>").($hc?" <span class='time'>($hc)</span>":"")."<br>\n";}echo"<input type='submit' name='clear' value='".lang(154)."'>\n","<a href='".h(ME."sql=&history=all")."'>".lang(155)."</a>\n","</div></fieldset>\n";}echo'</form>
  1607. ';}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));$Jh=(isset($_GET["select"])?$_POST["edit"]:$Z);foreach($p
  1608. as$C=>$o){if(!isset($o["privileges"][$Jh?"update":"insert"])||$b->fieldName($o)=="")unset($p[$C]);}if($_POST&&!$n&&!isset($_GET["select"])){$A=$_POST["referer"];if($_POST["insert"])$A=($Jh?null:$_SERVER["REQUEST_URI"]);elseif(!preg_match('~^.+&select=.+$~',$A))$A=ME."select=".urlencode($a);$v=indexes($a);$Eh=unique_array($_GET["where"],$v);$Nf="\nWHERE $Z";if(isset($_POST["delete"]))queries_redirect($A,lang(156),$Wb->delete($a,$Nf,!$Eh));else{$O=array();foreach($p
  1609. as$C=>$o){$X=process_input($o);if($X!==false&&$X!==null)$O[idf_escape($C)]=$X;}if($Jh){if(!$O)redirect($A);queries_redirect($A,lang(157),$Wb->update($a,$O,$Nf,!$Eh));if(is_ajax()){page_headers();page_messages($n);exit;}}else{$I=$Wb->insert($a,$O);$Rd=($I?last_id():0);queries_redirect($A,lang(158,($Rd?" $Rd":"")),$I);}}}$K=null;if($_POST["save"])$K=(array)$_POST["fields"];elseif($Z){$M=array();foreach($p
  1610. as$C=>$o){if(isset($o["privileges"]["select"])){$Ga=convert_field($o);if($_POST["clone"]&&$o["auto_increment"])$Ga="''";if($w=="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=$Wb->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=$Wb->select($a,array("*"),$Z,array("*"));$K=($I?$I->fetch_assoc():false);if(!$K)$K=array($Wb->primary=>"");}if($K){foreach($K
  1611. as$x=>$X){if(!$Z)$K[$x]=null;$p[$x]=array("field"=>$x,"null"=>($x!=$Wb->primary),"auto_increment"=>($x==$Wb->primary));}}}edit_form($a,$p,$K,$Jh);}elseif(isset($_GET["create"])){$a=$_GET["create"];$lf=array();foreach(array('HASH','LINEAR HASH','KEY','LINEAR KEY','RANGE','LIST')as$x)$lf[$x]=$x;$Uf=referencable_primary($a);$Oc=array();foreach($Uf
  1612. as$Tg=>$o)$Oc[str_replace("`","``",$Tg)."`".str_replace("`","``",$o["field"])]=$Tg;$cf=array();$R=array();if($a!=""){$cf=fields($a);$R=table_status($a);if(!$R)$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(159),drop_tables(array($a)));else{$p=array();$Da=array();$Nh=false;$Mc=array();ksort($K["fields"]);$bf=reset($cf);$Aa=" FIRST";foreach($K["fields"]as$x=>$o){$q=$Oc[$o["type"]];$_h=($q!==null?$Uf[$q]:$o);if($o["field"]!=""){if(!$o["has_default"])$o["default"]=null;if($x==$K["auto_increment_col"])$o["auto_increment"]=true;$If=process_field($o,$_h);$Da[]=array($o["orig"],$If,$Aa);if($If!=process_field($bf,$bf)){$p[]=array($o["orig"],$If,$Aa);if($o["orig"]!=""||$Aa)$Nh=true;}if($q!==null)$Mc[idf_escape($o["field"])]=($a!=""&&$w!="sqlite"?"ADD":" ").format_foreign_key(array('table'=>$Oc[$o["type"]],'source'=>array($o["field"]),'target'=>array($_h["field"]),'on_delete'=>$o["on_delete"],));$Aa=" AFTER ".idf_escape($o["field"]);}elseif($o["orig"]!=""){$Nh=true;$p[]=array($o["orig"]);}if($o["orig"]!=""){$bf=next($cf);if(!$bf)$Aa="";}}$nf="";if($lf[$K["partition_by"]]){$of=array();if($K["partition_by"]=='RANGE'||$K["partition_by"]=='LIST'){foreach(array_filter($K["partition_names"])as$x=>$X){$Y=$K["partition_values"][$x];$of[]="\n  PARTITION ".idf_escape($X)." VALUES ".($K["partition_by"]=='RANGE'?"LESS THAN":"IN").($Y!=""?" ($Y)":" MAXVALUE");}}$nf.="\nPARTITION BY $K[partition_by]($K[partition])".($of?" (".implode(",",$of)."\n)":($K["partitions"]?" PARTITIONS ".(+$K["partitions"]):""));}elseif(support("partitioning")&&preg_match("~partitioned~",$R["Create_options"]))$nf.="\nREMOVE PARTITIONING";$le=lang(160);if($a==""){cookie("adminer_engine",$K["Engine"]);$le=lang(161);}$C=trim($K["name"]);queries_redirect(ME.(support("table")?"table=":"select=").urlencode($C),$le,alter_table($a,$C,($w=="sqlite"&&($Nh||$Mc)?$Da:$p),$Mc,($K["Comment"]!=$R["Comment"]?$K["Comment"]:null),($K["Engine"]&&$K["Engine"]!=$R["Engine"]?$K["Engine"]:""),($K["Collation"]&&$K["Collation"]!=$R["Collation"]?$K["Collation"]:""),($K["Auto_increment"]!=""?number($K["Auto_increment"]):""),$nf));}}page_header(($a!=""?lang(42):lang(67)),$n,array("table"=>$a),h($a));if(!$_POST){$K=array("Engine"=>$_COOKIE["adminer_engine"],"fields"=>array(array("field"=>"","type"=>(isset($Bh["int"])?"int":(isset($Bh["integer"])?"integer":"")))),"partition_names"=>array(""),);if($a!=""){$K=$R;$K["name"]=$a;$K["fields"]=array();if(!$_GET["auto_increment"])$K["Auto_increment"]="";foreach($cf
  1613. as$o){$o["has_default"]=isset($o["default"]);$K["fields"][]=$o;}if(support("partitioning")){$Tc="FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA = ".q(DB)." AND TABLE_NAME = ".q($a);$I=$h->query("SELECT PARTITION_METHOD, PARTITION_ORDINAL_POSITION, PARTITION_EXPRESSION $Tc ORDER BY PARTITION_ORDINAL_POSITION DESC LIMIT 1");list($K["partition_by"],$K["partitions"],$K["partition"])=$I->fetch_row();$of=get_key_vals("SELECT PARTITION_NAME, PARTITION_DESCRIPTION $Tc AND PARTITION_NAME != '' ORDER BY PARTITION_ORDINAL_POSITION");$of[""]="";$K["partition_names"]=array_keys($of);$K["partition_values"]=array_values($of);}}}$nb=collations();$oc=engines();foreach($oc
  1614. as$nc){if(!strcasecmp($nc,$K["Engine"])){$K["Engine"]=$nc;break;}}echo'
  1615. <form action="" method="post" id="form">
  1616. <p>
  1617. ';if(support("columns")||$a==""){echo
  1618. lang(162),': <input name="name" maxlength="64" value="',h($K["name"]),'" autocapitalize="off">
  1619. ';if($a==""&&!$_POST){?><script type='text/javascript'>focus(document.getElementById('form')['name']);</script><?php }echo($oc?"<select name='Engine' onchange='helpClose();'".on_help("getTarget(event).value",1).">".optionlist(array(""=>"(".lang(163).")")+$oc,$K["Engine"])."</select>":""),' ',($nb&&!preg_match("~sqlite|mssql~",$w)?html_select("Collation",array(""=>"(".lang(88).")")+$nb,$K["Collation"]):""),' <input type="submit" value="',lang(14),'">
  1620. ';}echo'
  1621. ';if(support("columns")){echo'<table cellspacing="0" id="edit-fields" class="nowrap">
  1622. ';$sb=($_POST?$_POST["comments"]:$K["Comment"]!="");if(!$_POST&&!$sb){foreach($K["fields"]as$o){if($o["comment"]!=""){$sb=true;break;}}}edit_fields($K["fields"],$nb,"TABLE",$Oc,$sb);echo'</table>
  1623. <p>
  1624. ',lang(57),': <input type="number" name="Auto_increment" size="6" value="',h($K["Auto_increment"]),'">
  1625. ',checkbox("defaults",1,true,lang(164),"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();\"".($sb?" checked":"").">".lang(97)."</label>".' <input name="Comment" id="Comment" value="'.h($K["Comment"]).'" maxlength="'.($h->server_info>=5.5?2048:60).'"'.($sb?'':' class="hidden"').'>':''),'<p>
  1626. <input type="submit" value="',lang(14),'">
  1627. ';}echo'
  1628. ';if($a!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}if(support("partitioning")){$mf=preg_match('~RANGE|LIST~',$K["partition_by"]);print_fieldset("partition",lang(165),$K["partition_by"]);echo'<p>
  1629. ',"<select name='partition_by' onchange='partitionByChange(this);'".on_help("getTarget(event).value.replace(/./, 'PARTITION BY \$&')",1).">".optionlist(array(""=>"")+$lf,$K["partition_by"])."</select>",'(<input name="partition" value="',h($K["partition"]),'">)
  1630. ',lang(166),': <input type="number" name="partitions" class="size',($mf||!$K["partition_by"]?" hidden":""),'" value="',h($K["partitions"]),'">
  1631. <table cellspacing="0" id="partition-table"',($mf?"":" class='hidden'"),'>
  1632. <thead><tr><th>',lang(167),'<th>',lang(168),'</thead>
  1633. ';foreach($K["partition_names"]as$x=>$X){echo'<tr>','<td><input name="partition_names[]" value="'.h($X).'"'.($x==count($K["partition_names"])-1?' onchange="partitionNameChange(this);"':'').' autocapitalize="off">','<td><input name="partition_values[]" value="'.h($K["partition_values"][$x]).'">';}echo'</table>
  1634. </div></fieldset>
  1635. ';}echo'<input type="hidden" name="token" value="',$T,'">
  1636. </form>
  1637. ';}elseif(isset($_GET["indexes"])){$a=$_GET["indexes"];$pd=array("PRIMARY","UNIQUE","INDEX");$R=table_status($a,true);if(preg_match('~MyISAM|M?aria'.($h->server_info>=5.6?'|InnoDB':'').'~i',$R["Engine"]))$pd[]="FULLTEXT";$v=indexes($a);$Bf=array();if($w=="mongo"){$Bf=$v["_id_"];unset($pd[0]);unset($v["_id_"]);}$K=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["drop_col"]){$c=array();foreach($K["indexes"]as$u){$C=$u["name"];if(in_array($u["type"],$pd)){$f=array();$Wd=array();$Pb=array();$O=array();ksort($u["columns"]);foreach($u["columns"]as$x=>$e){if($e!=""){$y=$u["lengths"][$x];$Ob=$u["descs"][$x];$O[]=idf_escape($e).($y?"(".(+$y).")":"").($Ob?" DESC":"");$f[]=$e;$Wd[]=($y?$y:null);$Pb[]=$Ob;}}if($f){$xc=$v[$C];if($xc){ksort($xc["columns"]);ksort($xc["lengths"]);ksort($xc["descs"]);if($u["type"]==$xc["type"]&&array_values($xc["columns"])===$f&&(!$xc["lengths"]||array_values($xc["lengths"])===$Wd)&&array_values($xc["descs"])===$Pb){unset($v[$C]);continue;}}$c[]=array($u["type"],$C,$O);}}}foreach($v
  1638. as$C=>$xc)$c[]=array($xc["type"],$C,"DROP");if(!$c)redirect(ME."table=".urlencode($a));queries_redirect(ME."table=".urlencode($a),lang(169),alter_indexes($a,$c));}page_header(lang(122),$n,array("table"=>$a),h($a));$p=array_keys(fields($a));if($_POST["add"]){foreach($K["indexes"]as$x=>$u){if($u["columns"][count($u["columns"])]!="")$K["indexes"][$x]["columns"][]="";}$u=end($K["indexes"]);if($u["type"]||array_filter($u["columns"],'strlen'))$K["indexes"][]=array("columns"=>array(1=>""));}if(!$K){foreach($v
  1639. as$x=>$u){$v[$x]["name"]=$x;$v[$x]["columns"][]="";}$v[]=array("columns"=>array(1=>""));$K["indexes"]=$v;}echo'
  1640. <form action="" method="post">
  1641. <table cellspacing="0" class="nowrap">
  1642. <thead><tr>
  1643. <th>',lang(170),'<th><input type="submit" style="left: -1000px; position: absolute;">',lang(171),'<th>',lang(172);?>
  1644. <th><noscript><input type='image' class='icon' name='add[0]' src='" . h(preg_replace("~\\?.*~", "", ME)) . "?file=plus.gif&amp;version=4.2.5' alt='+' title='<?php echo
  1645. lang(98),'\'></noscript>&nbsp;
  1646. </thead>
  1647. ';if($Bf){echo"<tr><td>PRIMARY<td>";foreach($Bf["columns"]as$x=>$e){echo
  1648. select_input(" disabled",$p,$e),"<label><input disabled type='checkbox'>".lang(51)."</label> ";}echo"<td><td>\n";}$Fd=1;foreach($K["indexes"]as$u){if(!$_POST["drop_col"]||$Fd!=key($_POST["drop_col"])){echo"<tr><td>".html_select("indexes[$Fd][type]",array(-1=>"")+$pd,$u["type"],($Fd==count($K["indexes"])?"indexesAddRow(this);":1)),"<td>";ksort($u["columns"]);$s=1;foreach($u["columns"]as$x=>$e){echo"<span>".select_input(" name='indexes[$Fd][columns][$s]' onchange=\"".($s==count($u["columns"])?"indexesAddColumn":"indexesChangeColumn")."(this, '".h(js_escape($w=="sql"?"":$_GET["indexes"]."_"))."');\"",($p?array_combine($p,$p):$p),$e),($w=="sql"||$w=="mssql"?"<input type='number' name='indexes[$Fd][lengths][$s]' class='size' value='".h($u["lengths"][$x])."'>":""),($w!="sql"?checkbox("indexes[$Fd][descs][$s]",1,$u["descs"][$x],lang(51)):"")," </span>";$s++;}echo"<td><input name='indexes[$Fd][name]' value='".h($u["name"])."' autocapitalize='off'>\n","<td><input type='image' class='icon' name='drop_col[$Fd]' src='".h(preg_replace("~\\?.*~","",ME))."?file=cross.gif&amp;version=4.2.5' alt='x' title='".lang(101)."' onclick=\"return !editingRemoveRow(this, 'indexes\$1[type]');\">\n";}$Fd++;}echo'</table>
  1649. <p>
  1650. <input type="submit" value="',lang(14),'">
  1651. <input type="hidden" name="token" value="',$T,'">
  1652. </form>
  1653. ';}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(173),drop_databases(array(DB)));}elseif(DB!==$C){if(DB!=""){$_GET["db"]=$C;queries_redirect(preg_replace('~\bdb=[^&]*&~','',ME)."db=".urlencode($C),lang(174),rename_database($C,$K["collation"]));}else{$l=explode("\n",str_replace("\r","",$C));$Ng=true;$Qd="";foreach($l
  1654. as$m){if(count($l)==1||$m!=""){if(!create_database($m,$K["collation"]))$Ng=false;$Qd=$m;}}restart_session();set_session("dbs",null);queries_redirect(ME."db=".urlencode($Qd),lang(175),$Ng);}}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(176));}}page_header(DB!=""?lang(60):lang(177),$n,array(),h(DB));$nb=collations();$C=DB;if($_POST)$C=$K["name"];elseif(DB!="")$K["collation"]=db_collation(DB,$nb);elseif($w=="sql"){foreach(get_vals("SHOW GRANTS")as$Vc){if(preg_match('~ ON (`(([^\\\\`]|``|\\\\.)*)%`\\.\\*)?~',$Vc,$B)&&$B[1]){$C=stripcslashes(idf_unescape("`$B[2]`"));break;}}}echo'
  1655. <form action="" method="post">
  1656. <p>
  1657. ',($_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".($nb?html_select("collation",array(""=>"(".lang(88).")")+$nb,$K["collation"]).doc_link(array('sql'=>"charset-charsets.html",'mssql'=>"ms187963.aspx",)):"");?>
  1658. <script type='text/javascript'>focus(document.getElementById('name'));</script>
  1659. <input type="submit" value="<?php echo
  1660. lang(14),'">
  1661. ';if(DB!="")echo"<input type='submit' name='drop' value='".lang(117)."'".confirm().">\n";elseif(!$_POST["add_x"]&&$_GET["db"]=="")echo"<input type='image' class='icon' name='add' src='".h(preg_replace("~\\?.*~","",ME))."?file=plus.gif&amp;version=4.2.5' alt='+' title='".lang(98)."'>\n";echo'<input type="hidden" name="token" value="',$T,'">
  1662. </form>
  1663. ';}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(178));else{$C=trim($K["name"]);$_.=urlencode($C);if($_GET["ns"]=="")query_redirect("CREATE SCHEMA ".idf_escape($C),$_,lang(179));elseif($_GET["ns"]!=$C)query_redirect("ALTER SCHEMA ".idf_escape($_GET["ns"])." RENAME TO ".idf_escape($C),$_,lang(180));else
  1664. redirect($_);}}page_header($_GET["ns"]!=""?lang(61):lang(62),$n);if(!$K)$K["name"]=$_GET["ns"];echo'
  1665. <form action="" method="post">
  1666. <p><input name="name" id="name" value="',h($K["name"]);?>" autocapitalize="off">
  1667. <script type='text/javascript'>focus(document.getElementById('name'));</script>
  1668. <input type="submit" value="<?php echo
  1669. lang(14),'">
  1670. ';if($_GET["ns"]!="")echo"<input type='submit' name='drop' value='".lang(117)."'".confirm().">\n";echo'<input type="hidden" name="token" value="',$T,'">
  1671. </form>
  1672. ';}elseif(isset($_GET["call"])){$da=$_GET["call"];page_header(lang(181).": ".h($da),$n);$hg=routine($da,(isset($_GET["callf"])?"FUNCTION":"PROCEDURE"));$nd=array();$ff=array();foreach($hg["fields"]as$s=>$o){if(substr($o["inout"],-3)=="OUT")$ff[$s]="@".idf_escape($o["field"])." AS ".idf_escape($o["field"]);if(!$o["inout"]||substr($o["inout"],0,2)=="IN")$nd[]=$s;}if(!$n&&$_POST){$Ya=array();foreach($hg["fields"]as$x=>$o){if(in_array($x,$nd)){$X=process_input($o);if($X===false)$X="''";if(isset($ff[$x]))$h->query("SET @".idf_escape($o["field"])." = $X");}$Ya[]=(isset($ff[$x])?"@".idf_escape($o["field"]):$X);}$H=(isset($_GET["callf"])?"SELECT":"CALL")." ".idf_escape($da)."(".implode(", ",$Ya).")";echo"<p><code class='jush-$w'>".h($H)."</code> <a href='".h(ME)."sql=".urlencode($H)."'>".lang(10)."</a>\n";if(!$h->multi_query($H))echo"<p class='error'>".error()."\n";else{$i=connect();if(is_object($i))$i->select_db(DB);do{$I=$h->store_result();if(is_object($I))select($I,$i);else
  1673. echo"<p class='message'>".lang(182,$h->affected_rows)."\n";}while($h->next_result());if($ff)select($h->query("SELECT ".implode(", ",$ff)));}}echo'
  1674. <form action="" method="post">
  1675. ';if($nd){echo"<table cellspacing='0'>\n";foreach($nd
  1676. as$x){$o=$hg["fields"][$x];$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>
  1677. <input type="submit" value="',lang(181),'">
  1678. <input type="hidden" name="token" value="',$T,'">
  1679. </form>
  1680. ';}elseif(isset($_GET["foreign"])){$a=$_GET["foreign"];$C=$_GET["name"];$K=$_POST;if($_POST&&!$n&&!$_POST["add"]&&!$_POST["change"]&&!$_POST["change-js"]){$le=($_POST["drop"]?lang(183):($C!=""?lang(184):lang(185)));$A=ME."table=".urlencode($a);$K["source"]=array_filter($K["source"],'strlen');ksort($K["source"]);$bh=array();foreach($K["source"]as$x=>$X)$bh[$x]=$K["target"][$x];$K["target"]=$bh;if($w=="sqlite")queries_redirect($A,$le,recreate_table($a,$a,array(),array(),array(" $C"=>($_POST["drop"]?"":" ".format_foreign_key($K)))));else{$c="ALTER TABLE ".table($a);$Yb="\nDROP ".($w=="sql"?"FOREIGN KEY ":"CONSTRAINT ").idf_escape($C);if($_POST["drop"])query_redirect($c.$Yb,$A,$le);else{query_redirect($c.($C!=""?"$Yb,":"")."\nADD".format_foreign_key($K),$A,$le);$n=lang(186)."<br>$n";}}}page_header(lang(187),$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!=""){$Oc=foreign_keys($a);$K=$Oc[$C];$K["source"][]="";}else{$K["table"]=$a;$K["source"]=array("");}$Dg=array_keys(fields($a));$bh=($a===$K["table"]?$Dg:array_keys(fields($K["table"])));$Tf=array_keys(array_filter(table_status('',true),'fk_support'));echo'
  1681. <form action="" method="post">
  1682. <p>
  1683. ';if($K["db"]==""&&$K["ns"]==""){echo
  1684. lang(188),':
  1685. ',html_select("table",$Tf,$K["table"],"this.form['change-js'].value = '1'; this.form.submit();"),'<input type="hidden" name="change-js" value="">
  1686. <noscript><p><input type="submit" name="change" value="',lang(189),'"></noscript>
  1687. <table cellspacing="0">
  1688. <thead><tr><th>',lang(124),'<th>',lang(125),'</thead>
  1689. ';$Fd=0;foreach($K["source"]as$x=>$X){echo"<tr>","<td>".html_select("source[".(+$x)."]",array(-1=>"")+$Dg,$X,($Fd==count($K["source"])-1?"foreignAddRow(this);":1)),"<td>".html_select("target[".(+$x)."]",$bh,$K["target"][$x]);$Fd++;}echo'</table>
  1690. <p>
  1691. ',lang(90),': ',html_select("on_delete",array(-1=>"")+explode("|",$Me),$K["on_delete"]),' ',lang(89),': ',html_select("on_update",array(-1=>"")+explode("|",$Me),$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>
  1692. <input type="submit" value="',lang(14),'">
  1693. <noscript><p><input type="submit" name="add" value="',lang(190),'"></noscript>
  1694. ';}if($C!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1695. </form>
  1696. ';}elseif(isset($_GET["view"])){$a=$_GET["view"];$K=$_POST;if($_POST&&!$n){$C=trim($K["name"]);$Ga=" AS\n$K[select]";$A=ME."table=".urlencode($C);$le=lang(191);if($_GET["materialized"])$U="MATERIALIZED VIEW";else{$U="VIEW";if($w=="pgsql"){$Ig=table_status($C);$U=($Ig?strtoupper($Ig["Engine"]):$U);}}if(!$_POST["drop"]&&$a==$C&&$w!="sqlite"&&$U!="MATERIALIZED VIEW")query_redirect(($w=="mssql"?"ALTER":"CREATE OR REPLACE")." VIEW ".table($C).$Ga,$A,$le);else{$dh=$C."_adminer_".uniqid();drop_create("DROP $U ".table($a),"CREATE $U ".table($C).$Ga,"DROP $U ".table($C),"CREATE $U ".table($dh).$Ga,"DROP $U ".table($dh),($_POST["drop"]?substr(ME,0,-1):$A),lang(192),$le,lang(193),$a,$C);}}if(!$_POST&&$a!=""){$K=view($a);$K["name"]=$a;if(!$n)$n=error();}page_header(($a!=""?lang(41):lang(194)),$n,array("table"=>$a),h($a));echo'
  1697. <form action="" method="post">
  1698. <p>',lang(172),': <input name="name" value="',h($K["name"]),'" maxlength="64" autocapitalize="off">
  1699. <p>';textarea("select",$K["select"]);echo'<p>
  1700. <input type="submit" value="',lang(14),'">
  1701. ';if($_GET["view"]!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1702. </form>
  1703. ';}elseif(isset($_GET["event"])){$aa=$_GET["event"];$xd=array("YEAR","QUARTER","MONTH","DAY","HOUR","MINUTE","WEEK","SECOND","YEAR_MONTH","DAY_HOUR","DAY_MINUTE","DAY_SECOND","HOUR_MINUTE","HOUR_SECOND","MINUTE_SECOND");$Jg=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(195));elseif(in_array($K["INTERVAL_FIELD"],$xd)&&isset($Jg[$K["STATUS"]])){$mg="\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(196):lang(197)),queries(($aa!=""?"ALTER EVENT ".idf_escape($aa).$mg.($aa!=$K["EVENT_NAME"]?"\nRENAME TO ".idf_escape($K["EVENT_NAME"]):""):"CREATE EVENT ".idf_escape($K["EVENT_NAME"]).$mg)."\n".$Jg[$K["STATUS"]]." COMMENT ".q($K["EVENT_COMMENT"]).rtrim(" DO\n$K[EVENT_DEFINITION]",";").";"));}}page_header(($aa!=""?lang(198).": ".h($aa):lang(199)),$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'
  1704. <form action="" method="post">
  1705. <table cellspacing="0">
  1706. <tr><th>',lang(172),'<td><input name="EVENT_NAME" value="',h($K["EVENT_NAME"]),'" maxlength="64" autocapitalize="off">
  1707. <tr><th title="datetime">',lang(200),'<td><input name="STARTS" value="',h("$K[EXECUTE_AT]$K[STARTS]"),'">
  1708. <tr><th title="datetime">',lang(201),'<td><input name="ENDS" value="',h($K["ENDS"]),'">
  1709. <tr><th>',lang(202),'<td><input type="number" name="INTERVAL_VALUE" value="',h($K["INTERVAL_VALUE"]),'" class="size"> ',html_select("INTERVAL_FIELD",$xd,$K["INTERVAL_FIELD"]),'<tr><th>',lang(108),'<td>',html_select("STATUS",$Jg,$K["STATUS"]),'<tr><th>',lang(97),'<td><input name="EVENT_COMMENT" value="',h($K["EVENT_COMMENT"]),'" maxlength="64">
  1710. <tr><th>&nbsp;<td>',checkbox("ON_COMPLETION","PRESERVE",$K["ON_COMPLETION"]=="PRESERVE",lang(203)),'</table>
  1711. <p>';textarea("EVENT_DEFINITION",$K["EVENT_DEFINITION"]);echo'<p>
  1712. <input type="submit" value="',lang(14),'">
  1713. ';if($aa!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1714. </form>
  1715. ';}elseif(isset($_GET["procedure"])){$da=$_GET["procedure"];$hg=(isset($_GET["function"])?"FUNCTION":"PROCEDURE");$K=$_POST;$K["fields"]=(array)$K["fields"];if($_POST&&!process_fields($K["fields"])&&!$n){$dh="$K[name]_adminer_".uniqid();drop_create("DROP $hg ".idf_escape($da),create_routine($hg,$K),"DROP $hg ".idf_escape($K["name"]),create_routine($hg,array("name"=>$dh)+$K),"DROP $hg ".idf_escape($dh),substr(ME,0,-1),lang(204),lang(205),lang(206),$da,$K["name"]);}page_header(($da!=""?(isset($_GET["function"])?lang(207):lang(208)).": ".h($da):(isset($_GET["function"])?lang(209):lang(210))),$n);if(!$_POST&&$da!=""){$K=routine($da,$hg);$K["name"]=$da;}$nb=get_vals("SHOW CHARACTER SET");sort($nb);$ig=routine_languages();echo'
  1716. <form action="" method="post" id="form">
  1717. <p>',lang(172),': <input name="name" value="',h($K["name"]),'" maxlength="64" autocapitalize="off">
  1718. ',($ig?lang(19).": ".html_select("language",$ig,$K["language"]):""),'<input type="submit" value="',lang(14),'">
  1719. <table cellspacing="0" class="nowrap">
  1720. ';edit_fields($K["fields"],$nb,$hg);if(isset($_GET["function"])){echo"<tr><td>".lang(211);edit_type("returns",$K["returns"],$nb);}echo'</table>
  1721. <p>';textarea("definition",$K["definition"]);echo'<p>
  1722. <input type="submit" value="',lang(14),'">
  1723. ';if($da!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1724. </form>
  1725. ';}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(212));elseif($fa=="")query_redirect("CREATE SEQUENCE ".idf_escape($C),$_,lang(213));elseif($fa!=$C)query_redirect("ALTER SEQUENCE ".idf_escape($fa)." RENAME TO ".idf_escape($C),$_,lang(214));else
  1726. redirect($_);}page_header($fa!=""?lang(215).": ".h($fa):lang(216),$n);if(!$K)$K["name"]=$fa;echo'
  1727. <form action="" method="post">
  1728. <p><input name="name" value="',h($K["name"]),'" autocapitalize="off">
  1729. <input type="submit" value="',lang(14),'">
  1730. ';if($fa!="")echo"<input type='submit' name='drop' value='".lang(117)."'".confirm().">\n";echo'<input type="hidden" name="token" value="',$T,'">
  1731. </form>
  1732. ';}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(217));else
  1733. query_redirect("CREATE TYPE ".idf_escape(trim($K["name"]))." $K[as]",$_,lang(218));}page_header($ga!=""?lang(219).": ".h($ga):lang(220),$n);if(!$K)$K["as"]="AS ";echo'
  1734. <form action="" method="post">
  1735. <p>
  1736. ';if($ga!="")echo"<input type='submit' name='drop' value='".lang(117)."'".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="',$T,'">
  1737. </form>
  1738. ';}elseif(isset($_GET["trigger"])){$a=$_GET["trigger"];$C=$_GET["name"];$yh=trigger_options();$K=(array)trigger($C)+array("Trigger"=>$a."_bi");if($_POST){if(!$n&&in_array($_POST["Timing"],$yh["Timing"])&&in_array($_POST["Event"],$yh["Event"])&&in_array($_POST["Type"],$yh["Type"])){$Le=" ON ".table($a);$Yb="DROP TRIGGER ".idf_escape($C).($w=="pgsql"?$Le:"");$A=ME."table=".urlencode($a);if($_POST["drop"])query_redirect($Yb,$A,lang(221));else{if($C!="")queries($Yb);queries_redirect($A,($C!=""?lang(222):lang(223)),queries(create_trigger($Le,$_POST)));if($C!="")queries(create_trigger($Le,$K+array("Type"=>reset($yh["Type"]))));}}$K=$_POST;}page_header(($C!=""?lang(224).": ".h($C):lang(225)),$n,array("table"=>$a));echo'
  1739. <form action="" method="post" id="form">
  1740. <table cellspacing="0">
  1741. <tr><th>',lang(226),'<td>',html_select("Timing",$yh["Timing"],$K["Timing"],"triggerChange(/^".preg_quote($a,"/")."_[ba][iud]$/, '".js_escape($a)."', this.form);"),'<tr><th>',lang(227),'<td>',html_select("Event",$yh["Event"],$K["Event"],"this.form['Timing'].onchange();"),(in_array("UPDATE OF",$yh["Event"])?" <input name='Of' value='".h($K["Of"])."' class='hidden'>":""),'<tr><th>',lang(93),'<td>',html_select("Type",$yh["Type"],$K["Type"]),'</table>
  1742. <p>',lang(172),': <input name="Trigger" value="',h($K["Trigger"]);?>" maxlength="64" autocapitalize="off">
  1743. <script type="text/javascript">document.getElementById('form')['Timing'].onchange();</script>
  1744. <p><?php textarea("Statement",$K["Statement"]);echo'<p>
  1745. <input type="submit" value="',lang(14),'">
  1746. ';if($C!=""){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1747. </form>
  1748. ';}elseif(isset($_GET["user"])){$ha=$_GET["user"];$Gf=array(""=>array("All privileges"=>""));foreach(get_rows("SHOW PRIVILEGES")as$K){foreach(explode(",",($K["Privilege"]=="Grant option"?"":$K["Context"]))as$yb)$Gf[$yb][$K["Privilege"]]=$K["Comment"];}$Gf["Server Admin"]+=$Gf["File access on server"];$Gf["Databases"]["Create routine"]=$Gf["Procedures"]["Create routine"];unset($Gf["Procedures"]["Create routine"]);$Gf["Columns"]=array();foreach(array("Select","Insert","Update","References")as$X)$Gf["Columns"][$X]=$Gf["Tables"][$X];unset($Gf["Server Admin"]["Usage"]);foreach($Gf["Tables"]as$x=>$X)unset($Gf["Databases"][$x]);$ye=array();if($_POST){foreach($_POST["objects"]as$x=>$X)$ye[$X]=(array)$ye[$X]+(array)$_POST["grants"][$x];}$Wc=array();$Je="";if(isset($_GET["host"])&&($I=$h->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],$de,PREG_SET_ORDER)){foreach($de
  1749. as$X){if($X[1]!="USAGE")$Wc["$B[2]$X[2]"][$X[1]]=true;if(preg_match('~ WITH GRANT OPTION~',$K[0]))$Wc["$B[2]$X[2]"]["GRANT OPTION"]=true;}}if(preg_match("~ IDENTIFIED BY PASSWORD '([^']+)~",$K[0],$B))$Je=$B[1];}}if($_POST&&!$n){$Ke=(isset($_GET["host"])?q($ha)."@".q($_GET["host"]):"''");if($_POST["drop"])query_redirect("DROP USER $Ke",ME."privileges=",lang(228));else{$_e=q($_POST["user"])."@".q($_POST["host"]);$pf=$_POST["pass"];if($pf!=''&&!$_POST["hashed"]){$pf=$h->result("SELECT PASSWORD(".q($pf).")");$n=!$pf;}$Cb=false;if(!$n){if($Ke!=$_e){$Cb=queries(($h->server_info<5?"GRANT USAGE ON *.* TO":"CREATE USER")." $_e IDENTIFIED BY PASSWORD ".q($pf));$n=!$Cb;}elseif($pf!=$Je)queries("SET PASSWORD FOR $_e = ".q($pf));}if(!$n){$eg=array();foreach($ye
  1750. as$Ee=>$Vc){if(isset($_GET["grant"]))$Vc=array_filter($Vc);$Vc=array_keys($Vc);if(isset($_GET["grant"]))$eg=array_diff(array_keys(array_filter($ye[$Ee],'strlen')),$Vc);elseif($Ke==$_e){$He=array_keys((array)$Wc[$Ee]);$eg=array_diff($He,$Vc);$Vc=array_diff($Vc,$He);unset($Wc[$Ee]);}if(preg_match('~^(.+)\\s*(\\(.*\\))?$~U',$Ee,$B)&&(!grant("REVOKE",$eg,$B[2]," ON $B[1] FROM $_e")||!grant("GRANT",$Vc,$B[2]," ON $B[1] TO $_e"))){$n=true;break;}}}if(!$n&&isset($_GET["host"])){if($Ke!=$_e)queries("DROP USER $Ke");elseif(!isset($_GET["grant"])){foreach($Wc
  1751. as$Ee=>$eg){if(preg_match('~^(.+)(\\(.*\\))?$~U',$Ee,$B))grant("REVOKE",array_keys($eg),$B[2]," ON $B[1] FROM $_e");}}}queries_redirect(ME."privileges=",(isset($_GET["host"])?lang(229):lang(230)),!$n);if($Cb)$h->query("DROP USER $_e");}}page_header((isset($_GET["host"])?lang(33).": ".h("$ha@$_GET[host]"):lang(136)),$n,array("privileges"=>array('',lang(64))));if($_POST){$K=$_POST;$Wc=$ye;}else{$K=$_GET+array("host"=>$h->result("SELECT SUBSTRING_INDEX(CURRENT_USER, '@', -1)"));$K["pass"]=$Je;if($Je!="")$K["hashed"]=true;$Wc[(DB==""||$Wc?"":idf_escape(addcslashes(DB,"%_\\"))).".*"]=array();}echo'<form action="" method="post">
  1752. <table cellspacing="0">
  1753. <tr><th>',lang(32),'<td><input name="host" maxlength="60" value="',h($K["host"]),'" autocapitalize="off">
  1754. <tr><th>',lang(33),'<td><input name="user" maxlength="16" value="',h($K["user"]),'" autocapitalize="off">
  1755. <tr><th>',lang(34),'<td><input name="pass" id="pass" value="',h($K["pass"]),'">
  1756. ';if(!$K["hashed"]){echo'<script type="text/javascript">typePassword(document.getElementById(\'pass\'));</script>';}echo
  1757. checkbox("hashed",1,$K["hashed"],lang(231),"typePassword(this.form['pass'], this.checked);"),'</table>
  1758.  
  1759. ';echo"<table cellspacing='0'>\n","<thead><tr><th colspan='2'>".lang(64).doc_link(array('sql'=>"grant.html#priv_level"));$s=0;foreach($Wc
  1760. as$Ee=>$Vc){echo'<th>'.($Ee!="*.*"?"<input name='objects[$s]' value='".h($Ee)."' 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(120),"Columns"=>lang(121),"Procedures"=>lang(232),)as$yb=>$Ob){foreach((array)$Gf[$yb]as$Ff=>$rb){echo"<tr".odd()."><td".($Ob?">$Ob<td":" colspan='2'").' lang="en" title="'.h($rb).'">'.h($Ff);$s=0;foreach($Wc
  1761. as$Ee=>$Vc){$C="'grants[$s][".h(strtoupper($Ff))."]'";$Y=$Vc[strtoupper($Ff)];if($yb=="Server Admin"&&$Ee!=(isset($Wc["*.*"])?"*.*":".*"))echo"<td>&nbsp;";elseif(isset($_GET["grant"]))echo"<td><select name=$C><option><option value='1'".($Y?" selected":"").">".lang(233)."<option value='0'".($Y=="0"?" selected":"").">".lang(234)."</select>";else
  1762. echo"<td align='center'><label class='block'><input type='checkbox' name=$C value='1'".($Y?" checked":"").($Ff=="All privileges"?" id='grants-$s-all'":($Ff=="Grant option"?"":" onclick=\"if (this.checked) formUncheck('grants-$s-all');\""))."></label>";$s++;}}}echo"</table>\n",'<p>
  1763. <input type="submit" value="',lang(14),'">
  1764. ';if(isset($_GET["host"])){echo'<input type="submit" name="drop" value="',lang(117),'"',confirm(),'>';}echo'<input type="hidden" name="token" value="',$T,'">
  1765. </form>
  1766. ';}elseif(isset($_GET["processlist"])){if(support("kill")&&$_POST&&!$n){$Md=0;foreach((array)$_POST["kill"]as$X){if(kill_process($X))$Md++;}queries_redirect(ME."processlist=",lang(235,$Md),$Md||!$_POST["kill"]);}page_header(lang(106),$n);echo'
  1767. <form action="" method="post">
  1768. <table cellspacing="0" onclick="tableClick(event);" ondblclick="tableClick(event, true);" class="nowrap checkable">
  1769. ';$s=-1;foreach(process_list()as$s=>$K){if(!$s){echo"<thead><tr lang='en'>".(support("kill")?"<th>&nbsp;":"");foreach($K
  1770. as$x=>$X)echo"<th>$x".doc_link(array('sql'=>"show-processlist.html#processlist_".strtolower($x),'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[$w=="sql"?"Id":"pid"],0):"");foreach($K
  1771. as$x=>$X)echo"<td>".(($w=="sql"&&$x=="Info"&&preg_match("~Query|Killed~",$K["Command"])&&$X!="")||($w=="pgsql"&&$x=="current_query"&&$X!="<IDLE>")||($w=="oracle"&&$x=="sql_text"&&$X!="")?"<code class='jush-$w'>".shorten_utf8($X,100,"</code>").' <a href="'.h(ME.($K["db"]!=""?"db=".urlencode($K["db"])."&":"")."sql=".urlencode($X)).'">'.lang(236).'</a>':nbsp($X));echo"\n";}echo'</table>
  1772. <script type=\'text/javascript\'>tableCheck();</script>
  1773. <p>
  1774. ';if(support("kill")){echo($s+1)."/".lang(237,max_connections()),"<p><input type='submit' value='".lang(238)."'>\n";}echo'<input type="hidden" name="token" value="',$T,'">
  1775. </form>
  1776. ';}elseif(isset($_GET["select"])){$a=$_GET["select"];$R=table_status1($a);$v=indexes($a);$p=fields($a);$Oc=column_foreign_keys($a);$Ge="";if($R["Oid"]){$Ge=($w=="sqlite"?"rowid":"oid");$v[]=array("type"=>"PRIMARY","columns"=>array($Ge));}parse_str($_COOKIE["adminer_import"],$ya);$fg=array();$f=array();$hh=null;foreach($p
  1777. as$x=>$o){$C=$b->fieldName($o);if(isset($o["privileges"]["select"])&&$C!=""){$f[$x]=html_entity_decode(strip_tags($C),ENT_QUOTES);if(is_shortable($o))$hh=$b->selectLengthProcess();}$fg+=$o["privileges"];}list($M,$Xc)=$b->selectColumnsProcess($f,$v);$Ad=count($Xc)<count($M);$Z=$b->selectSearchProcess($p,$v);$We=$b->selectOrderProcess($p,$v);$z=$b->selectLimitProcess();$Tc=($M?implode(", ",$M):"*".($Ge?", $Ge":"")).convert_fields($f,$p,$M)."\nFROM ".table($a);$Yc=($Xc&&$Ad?"\nGROUP BY ".implode(", ",$Xc):"").($We?"\nORDER BY ".implode(", ",$We):"");if($_GET["val"]&&is_ajax()){header("Content-Type: text/plain; charset=utf-8");foreach($_GET["val"]as$Fh=>$K){$Ga=convert_field($p[key($K)]);$M=array($Ga?$Ga:idf_escape(key($K)));$Z[]=where_check($Fh,$p);$J=$Wb->select($a,$M,$Z,$M);if($J)echo
  1778. reset($J->fetch_row());}exit;}if($_POST&&!$n){$ci=$Z;if(!$_POST["all"]&&is_array($_POST["check"])){$eb=array();foreach($_POST["check"]as$bb)$eb[]=where_check($bb,$p);$ci[]="((".implode(") OR (",$eb)."))";}$ci=($ci?"\nWHERE ".implode(" AND ",$ci):"");$Bf=$Hh=null;foreach($v
  1779. as$u){if($u["type"]=="PRIMARY"){$Bf=array_flip($u["columns"]);$Hh=($M?$Bf:array());break;}}foreach((array)$Hh
  1780. as$x=>$X){if(in_array(idf_escape($x),$M))unset($Hh[$x]);}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"])||$Hh===array())$H="SELECT $Tc$ci$Yc";else{$Dh=array();foreach($_POST["check"]as$X)$Dh[]="(SELECT".limit($Tc,"\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p).$Yc,1).")";$H=implode(" UNION ALL ",$Dh);}$b->dumpData($a,"table",$H);exit;}if(!$b->selectEmailProcess($Z,$Oc)){if($_POST["save"]||$_POST["delete"]){$I=true;$za=0;$O=array();if(!$_POST["delete"]){foreach($f
  1781. 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"]||($Hh===array()&&is_array($_POST["check"]))||$Ad){$I=($_POST["delete"]?$Wb->delete($a,$ci):($_POST["clone"]?queries("INSERT $H$ci"):$Wb->update($a,$O,$ci)));$za=$h->affected_rows;}else{foreach((array)$_POST["check"]as$X){$bi="\nWHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($X,$p);$I=($_POST["delete"]?$Wb->delete($a,$bi,1):($_POST["clone"]?queries("INSERT".limit1($H,$bi)):$Wb->update($a,$O,$bi)));if(!$I)break;$za+=$h->affected_rows;}}}$le=lang(239,$za);if($_POST["clone"]&&$I&&$za==1){$Rd=last_id();if($Rd)$le=lang(158," $Rd");}queries_redirect(remove_from_uri($_POST["all"]&&$_POST["delete"]?"page":""),$le,$I);if(!$_POST["delete"]){edit_form($a,$p,(array)$_POST["fields"],!$_POST["clone"]);page_footer();exit;}}elseif(!$_POST["import"]){if(!$_POST["val"])$n=lang(240);else{$I=true;$za=0;foreach($_POST["val"]as$Fh=>$K){$O=array();foreach($K
  1782. as$x=>$X){$x=bracket_escape($x,1);$O[idf_escape($x)]=(preg_match('~char|text~',$p[$x]["type"])||$X!=""?$b->processInput($p[$x],$X):"NULL");}$I=$Wb->update($a,$O," WHERE ".($Z?implode(" AND ",$Z)." AND ":"").where_check($Fh,$p),!($Ad||$Hh===array())," ");if(!$I)break;$za+=$h->affected_rows;}queries_redirect(remove_from_uri(),lang(239,$za),$I);}}elseif(!is_string($Hc=get_file("csv_file",true)))$n=upload_error($Hc);elseif(!preg_match('~~u',$Hc))$n=lang(241);else{cookie("adminer_import","output=".urlencode($ya["output"])."&format=".urlencode($_POST["separator"]));$I=true;$ob=array_keys($p);preg_match_all('~(?>"[^"]*"|[^"\\r\\n]+)+~',$Hc,$de);$za=count($de[0]);$Wb->begin();$ug=($_POST["separator"]=="csv"?",":($_POST["separator"]=="tsv"?"\t":";"));$L=array();foreach($de[0]as$x=>$X){preg_match_all("~((?>\"[^\"]*\")+|[^$ug]*)$ug~",$X.$ug,$ee);if(!$x&&!array_diff($ee[1],$ob)){$ob=$ee[1];$za--;}else{$O=array();foreach($ee[1]as$s=>$lb)$O[idf_escape($ob[$s])]=($lb==""&&$p[$ob[$s]]["null"]?"NULL":q(str_replace('""','"',preg_replace('~^"|"$~','',$lb))));$L[]=$O;}}$I=(!$L||$Wb->insertUpdate($a,$L,$Bf));if($I)$Wb->commit();queries_redirect(remove_from_uri("page"),lang(242,$za),$I);$Wb->rollback();}}}$Tg=$b->tableName($R);if(is_ajax()){page_headers();ob_start();}else
  1783. page_header(lang(45).": $Tg",$n);$O=null;if(isset($fg["insert"])||!support("table")){$O="";foreach((array)$_GET["where"]as$X){if(count($Oc[$X["col"]])==1&&($X["op"]=="="||(!$X["op"]&&!preg_match('~[_%]~',$X["val"]))))$O.="&set".urlencode("[".bracket_escape($X["col"])."]")."=".urlencode($X["val"]);}}$b->selectLinks($R,$O);if(!$f&&support("table"))echo"<p class='error'>".lang(243).($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,$f);$b->selectSearchPrint($Z,$f,$v);$b->selectOrderPrint($We,$f,$v);$b->selectLimitPrint($z);$b->selectLengthPrint($hh);$b->selectActionPrint($v);echo"</form>\n";$E=$_GET["page"];if($E=="last"){$Rc=$h->result(count_rows($a,$Z,$Ad,$Xc));$E=floor(max(0,$Rc-1)/$z);}$rg=$M;if(!$rg){$rg[]="*";if($Ge)$rg[]=$Ge;}$zb=convert_fields($f,$p,$M);if($zb)$rg[]=substr($zb,2);$I=$Wb->select($a,$rg,$Z,$Xc,$We,$z,$E,true);if(!$I)echo"<p class='error'>".error()."\n";else{if($w=="mssql"&&$E)$I->seek($z*$E);$lc=array();echo"<form action='' method='post' enctype='multipart/form-data'>\n";$L=array();while($K=$I->fetch_assoc()){if($E&&$w=="oracle")unset($K["RNUM"]);$L[]=$K;}if($_GET["page"]!="last"&&+$z&&$Xc&&$Ad&&$w=="sql")$Rc=$h->result(" SELECT FOUND_ROWS()");if(!$L)echo"<p class='message'>".lang(12)."\n";else{$Pa=$b->backwardKeys($a,$Tg);echo"<table id='table' cellspacing='0' class='nowrap checkable' onclick='tableClick(event);' ondblclick='tableClick(event, true);' onkeydown='return editingKeydown(event);'>\n","<thead><tr>".(!$Xc&&$M?"":"<td><input type='checkbox' id='all-page' onclick='formCheck(this, /check/);'> <a href='".h($_GET["modify"]?remove_from_uri("modify"):$_SERVER["REQUEST_URI"]."&modify=1")."'>".lang(244)."</a>");$xe=array();$Uc=array();reset($M);$Pf=1;foreach($L[0]as$x=>$X){if($x!=$Ge){$X=$_GET["columns"][key($M)];$o=$p[$M?($X?$X["col"]:current($M)):$x];$C=($o?$b->fieldName($o,$Pf):($X["fun"]?"*":$x));if($C!=""){$Pf++;$xe[$x]=$C;$e=idf_escape($x);$id=remove_from_uri('(order|desc)[^=]*|page').'&order%5B0%5D='.urlencode($x);$Ob="&desc%5B0%5D=1";echo'<th onmouseover="columnMouse(this);" onmouseout="columnMouse(this, \' hidden\');">','<a href="'.h($id.($We[0]==$e||$We[0]==$x||(!$We&&$Ad&&$Xc[0]==$e)?$Ob:'')).'">';echo
  1784. apply_sql_function($X["fun"],$C)."</a>";echo"<span class='column hidden'>","<a href='".h($id.$Ob)."' title='".lang(51)."' class='text'> ↓</a>";if(!$X["fun"])echo'<a href="#fieldset-search" onclick="selectSearch(\''.h(js_escape($x)).'\'); return false;" title="'.lang(48).'" class="text jsonly"> =</a>';echo"</span>";}$Uc[$x]=$X["fun"];next($M);}}$Wd=array();if($_GET["modify"]){foreach($L
  1785. as$K){foreach($K
  1786. as$x=>$X)$Wd[$x]=max($Wd[$x],min(40,strlen(utf8_decode($X))));}}echo($Pa?"<th>".lang(245):"")."</thead>\n";if(is_ajax()){if($z%2==1&&$E%2==1)odd();ob_end_clean();}foreach($b->rowDescriptions($L,$Oc)as$we=>$K){$Eh=unique_array($L[$we],$v);if(!$Eh){$Eh=array();foreach($L[$we]as$x=>$X){if(!preg_match('~^(COUNT\\((\\*|(DISTINCT )?`(?:[^`]|``)+`)\\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\\(`(?:[^`]|``)+`\\))$~',$x))$Eh[$x]=$X;}}$Fh="";foreach($Eh
  1787. as$x=>$X){if(($w=="sql"||$w=="pgsql")&&strlen($X)>64){$x=(strpos($x,'(')?$x:idf_escape($x));$x="MD5(".($w=='sql'&&preg_match("~^utf8_~",$p[$x]["collation"])?$x:"CONVERT($x USING ".charset($h).")").")";$X=md5($X);}$Fh.="&".($X!==null?urlencode("where[".bracket_escape($x)."]")."=".urlencode($X):"null%5B%5D=".urlencode($x));}echo"<tr".odd().">".(!$Xc&&$M?"":"<td>".checkbox("check[]",substr($Fh,1),in_array(substr($Fh,1),(array)$_POST["check"]),"","this.form['all'].checked = false; formUncheck('all-page');").($Ad||information_schema(DB)?"":" <a href='".h(ME."edit=".urlencode($a).$Fh)."'>".lang(246)."</a>"));foreach($K
  1788. as$x=>$X){if(isset($xe[$x])){$o=$p[$x];if($X!=""&&(!isset($lc[$x])||$lc[$x]!=""))$lc[$x]=(is_mail($X)?$xe[$x]:"");$_="";if(preg_match('~blob|bytea|raw|file~',$o["type"])&&$X!="")$_=ME.'download='.urlencode($a).'&field='.urlencode($x).$Fh;if(!$_&&$X!==null){foreach((array)$Oc[$x]as$q){if(count($Oc[$x])==1||end($q["source"])==$x){$_="";foreach($q["source"]as$s=>$Dg)$_.=where_link($s,$q["target"][$s],$L[$we][$Dg]);$_=($q["db"]!=""?preg_replace('~([?&]db=)[^&]+~','\\1'.urlencode($q["db"]),ME):ME).'select='.urlencode($q["table"]).$_;if(count($q["source"])==1)break;}}}if($x=="COUNT(*)"){$_=ME."select=".urlencode($a);$s=0;foreach((array)$_GET["where"]as$W){if(!array_key_exists($W["col"],$Eh))$_.=where_link($s++,$W["col"],$W["val"],$W["op"]);}foreach($Eh
  1789. as$Gd=>$W)$_.=where_link($s++,$Gd,$W);}$X=select_value($X,$_,$o,$hh);$jd=h("val[$Fh][".bracket_escape($x)."]");$Y=$_POST["val"][$Fh][bracket_escape($x)];$gc=!is_array($K[$x])&&is_utf8($X)&&$L[$we][$x]==$K[$x]&&!$Uc[$x];$gh=preg_match('~text|lob~',$o["type"]);if(($_GET["modify"]&&$gc)||$Y!==null){$ad=h($Y!==null?$Y:$K[$x]);echo"<td>".($gh?"<textarea name='$jd' cols='30' rows='".(substr_count($K[$x],"\n")+1)."'>$ad</textarea>":"<input name='$jd' value='$ad' size='$Wd[$x]'>");}else{$ae=strpos($X,"<i>...</i>");echo"<td id='$jd' onclick=\"selectClick(this, event, ".($ae?2:($gh?1:0)).($gc?"":", '".h(lang(247))."'").");\">$X";}}}if($Pa)echo"<td>";$b->backwardKeysPrint($Pa,$L[$we]);echo"</tr>\n";}if(is_ajax())exit;echo"</table>\n";}if(($L||$E)&&!is_ajax()){$vc=true;if($_GET["page"]!="last"){if(!+$z)$Rc=count($L);elseif($w!="sql"||!$Ad){$Rc=($Ad?false:found_rows($R,$Z));if($Rc<max(1e4,2*($E+1)*$z))$Rc=reset(slow_query(count_rows($a,$Z,$Ad,$Xc)));else$vc=false;}}if(+$z&&($Rc===false||$Rc>$z||$E)){echo"<p class='pages'>";$ge=($Rc===false?$E+(count($L)>=$z?2:1):floor(($Rc-1)/$z));if($w!="simpledb"){echo'<a href="'.h(remove_from_uri("page"))."\" onclick=\"pageClick(this.href, +prompt('".lang(248)."', '".($E+1)."'), event); return false;\">".lang(248)."</a>:",pagination(0,$E).($E>5?" ...":"");for($s=max(1,$E-4);$s<min($ge,$E+5);$s++)echo
  1790. pagination($s,$E);if($ge>0){echo($E+5<$ge?" ...":""),($vc&&$Rc!==false?pagination($ge,$E):" <a href='".h(remove_from_uri("page")."&page=last")."' title='~$ge'>".lang(249)."</a>");}echo(($Rc===false?count($L)+1:$Rc-$E*$z)>$z?' <a href="'.h(remove_from_uri("page")."&page=".($E+1)).'" onclick="return !selectLoadMore(this, '.(+$z).', \''.lang(250).'...\');" class="loadmore">'.lang(251).'</a>':'');}else{echo
  1791. lang(248).":",pagination(0,$E).($E>1?" ...":""),($E?pagination($E,$E):""),($ge>$E?pagination($E+1,$E).($ge>$E+1?" ...":""):"");}}echo"<p class='count'>\n",($Rc!==false?"(".($vc?"":"~ ").lang(140,$Rc).") ":"");$Tb=($vc?"":"~ ").$Rc;echo
  1792. checkbox("all",1,0,lang(252),"var checked = formChecked(this, /check/); selectCount('selected', this.checked ? '$Tb' : checked); selectCount('selected2', this.checked || !checked ? '$Tb' : checked);")."\n";if($b->selectCommandPrint()){echo'<fieldset',($_GET["modify"]?'':' class="jsonly"'),'><legend>',lang(244),'</legend><div>
  1793. <input type="submit" value="',lang(14),'"',($_GET["modify"]?'':' title="'.lang(240).'"'),'>
  1794. </div></fieldset>
  1795. <fieldset><legend>',lang(116),' <span id="selected"></span></legend><div>
  1796. <input type="submit" name="edit" value="',lang(10),'">
  1797. <input type="submit" name="clone" value="',lang(236),'">
  1798. <input type="submit" name="delete" value="',lang(18),'"',confirm(),'>
  1799. </div></fieldset>
  1800. ';}$Pc=$b->dumpFormat();foreach((array)$_GET["columns"]as$e){if($e["fun"]){unset($Pc['sql']);break;}}if($Pc){print_fieldset("export",lang(66)." <span id='selected2'></span>");$gf=$b->dumpOutput();echo($gf?html_select("output",$gf,$ya["output"])." ":""),html_select("format",$Pc,$ya["format"])," <input type='submit' name='export' value='".lang(66)."'>\n","</div></fieldset>\n";}echo(!$Xc&&$M?"":"<script type='text/javascript'>tableCheck();</script>\n");}if($b->selectImportPrint()){print_fieldset("import",lang(65),!$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(65)."'>","</div></fieldset>\n";}$b->selectEmailPrint(array_filter($lc,'strlen'),$f);echo"<p><input type='hidden' name='token' value='$T'></p>\n","</form>\n";}}if(is_ajax()){ob_end_clean();exit;}}elseif(isset($_GET["variables"])){$Ig=isset($_GET["status"]);page_header($Ig?lang(108):lang(107));$Uh=($Ig?show_status():show_variables());if(!$Uh)echo"<p class='message'>".lang(12)."\n";else{echo"<table cellspacing='0'>\n";foreach($Uh
  1801. as$x=>$X){echo"<tr>","<th><code class='jush-".$w.($Ig?"status":"set")."'>".h($x)."</code>","<td>".nbsp($X);}echo"</table>\n";}}elseif(isset($_GET["script"])){header("Content-Type: text/javascript; charset=utf-8");if($_GET["script"]=="db"){$Qg=array("Data_length"=>0,"Index_length"=>0,"Data_free"=>0);foreach(table_status()as$C=>$R){json_row("Comment-$C",nbsp($R["Comment"]));if(!is_view($R)){foreach(array("Engine","Collation")as$x)json_row("$x-$C",nbsp($R[$x]));foreach($Qg+array("Auto_increment"=>0,"Rows"=>0)as$x=>$X){if($R[$x]!=""){$X=format_number($R[$x]);json_row("$x-$C",($x=="Rows"&&$X&&$R["Engine"]==($Fg=="pgsql"?"table":"InnoDB")?"~ $X":$X));if(isset($Qg[$x]))$Qg[$x]+=($R["Engine"]!="InnoDB"||$x!="Data_free"?$R[$x]:0);}elseif(array_key_exists($x,$R))json_row("$x-$C");}}}foreach($Qg
  1802. as$x=>$X)json_row("sum-$x",format_number($X));json_row("");}elseif($_GET["script"]=="kill")$h->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{$Zg=array_merge((array)$_POST["tables"],(array)$_POST["views"]);if($Zg&&!$n&&!$_POST["search"]){$I=true;$le="";if($w=="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"]);$le=lang(253);}elseif($_POST["move"]){$I=move_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$le=lang(254);}elseif($_POST["copy"]){$I=copy_tables((array)$_POST["tables"],(array)$_POST["views"],$_POST["target"]);$le=lang(255);}elseif($_POST["drop"]){if($_POST["views"])$I=drop_views($_POST["views"]);if($I&&$_POST["tables"])$I=drop_tables($_POST["tables"]);$le=lang(256);}elseif($w!="sql"){$I=($w=="sqlite"?queries("VACUUM"):apply_queries("VACUUM".($_POST["optimize"]?"":" ANALYZE"),$_POST["tables"]));$le=lang(257);}elseif(!$_POST["tables"])$le=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())$le.="<b>".h($K["Table"])."</b>: ".h($K["Msg_text"])."<br>";}queries_redirect(substr(ME,0,-1),$le,$I);}page_header(($_GET["ns"]==""?lang(35).": ".h(DB):lang(69).": ".h($_GET["ns"])),$n,true);if($b->homepage()){if($_GET["ns"]!==""){echo"<h3 id='tables-views'>".lang(258)."</h3>\n";$Yg=tables_list();if(!$Yg)echo"<p class='message'>".lang(9)."\n";else{echo"<form action='' method='post'>\n";if(support("table")){echo"<fieldset><legend>".lang(259)." <span id='selected2'></span></legend><div>","<input type='search' name='query' value='".h($_POST["query"])."'> <input type='submit' name='search' value='".lang(48)."'>\n","</div></fieldset>\n";if($_POST["search"]&&$_POST["query"]!="")search_tables();}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)\[/);">';$Ub=doc_link(array('sql'=>'show-table-status.html'));echo'<th>'.lang(120),'<td>'.lang(260).doc_link(array('sql'=>'storage-engines.html')),'<td>'.lang(112).doc_link(array('sql'=>'charset-mysql.html')),'<td>'.lang(261).$Ub,'<td>'.lang(262).$Ub,'<td>'.lang(263).$Ub,'<td>'.lang(57).doc_link(array('sql'=>'example-auto-increment.html')),'<td>'.lang(264).$Ub,(support("comment")?'<td>'.lang(97).$Ub:''),"</thead>\n";$S=0;foreach($Yg
  1803. as$C=>$U){$Xh=($U!==null&&!preg_match('~table~i',$U));echo'<tr'.odd().'><td>'.checkbox(($Xh?"views[]":"tables[]"),$C,in_array($C,$Zg,true),"","formUncheck('check-all');"),'<th>'.(support("table")||support("indexes")?'<a href="'.h(ME).'table='.urlencode($C).'" title="'.lang(40).'">'.h($C).'</a>':h($C));if($Xh){echo'<td colspan="6"><a href="'.h(ME)."view=".urlencode($C).'" title="'.lang(41).'">'.(preg_match('~materialized~i',$U)?lang(265):lang(119)).'</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(123)),"Data_free"=>array("edit",lang(43)),"Auto_increment"=>array("auto_increment=1&create",lang(42)),"Rows"=>array("select",lang(39)),)as$x=>$_){$jd=" id='$x-".h($C)."'";echo($_?"<td align='right'>".(support("table")||$x=="Rows"||(support("indexes")&&$x!="Data_length")?"<a href='".h(ME."$_[0]=").urlencode($C)."'$jd title='$_[1]'>?</a>":"<span$jd>?</span>"):"<td id='$x-".h($C)."'>&nbsp;");}$S++;}echo(support("comment")?"<td id='Comment-".h($C)."'>&nbsp;":"");}echo"<tr><td>&nbsp;<th>".lang(237,count($Yg)),"<td>".nbsp($w=="sql"?$h->result("SELECT @@storage_engine"):""),"<td>".nbsp(db_collation(DB,collations()));foreach(array("Data_length","Index_length","Data_free")as$x)echo"<td align='right' id='sum-$x'>&nbsp;";echo"</table>\n";if(!information_schema(DB)){$Rh="<input type='submit' value='".lang(266)."'".on_help("'VACUUM'")."> ";$Se="<input type='submit' name='optimize' value='".lang(267)."'".on_help($w=="sql"?"'OPTIMIZE TABLE'":"'VACUUM OPTIMIZE'")."> ";echo"<fieldset><legend>".lang(116)." <span id='selected'></span></legend><div>".($w=="sqlite"?$Rh:($w=="pgsql"?$Rh.$Se:($w=="sql"?"<input type='submit' value='".lang(268)."'".on_help("'ANALYZE TABLE'")."> ".$Se."<input type='submit' name='check' value='".lang(269)."'".on_help("'CHECK TABLE'")."> "."<input type='submit' name='repair' value='".lang(270)."'".on_help("'REPAIR TABLE'")."> ":"")))."<input type='submit' name='truncate' value='".lang(271)."'".confirm().on_help($w=="sqlite"?"'DELETE'":"'TRUNCATE".($w=="pgsql"?"'":" TABLE'"))."> "."<input type='submit' name='drop' value='".lang(117)."'".confirm().on_help("'DROP TABLE'").">\n";$l=(support("scheme")?$b->schemas():$b->databases());if(count($l)!=1&&$w!="sqlite"){$m=(isset($_POST["target"])?$_POST["target"]:(support("scheme")?$_GET["ns"]:DB));echo"<p>".lang(272).": ",($l?html_select("target",$l,$m):'<input name="target" value="'.h($m).'" autocapitalize="off">')," <input type='submit' name='move' value='".lang(273)."'>",(support("copy")?" <input type='submit' name='copy' value='".lang(274)."'>":""),"\n";}echo"<input type='hidden' name='all' value='' onclick=\"selectCount('selected', formChecked(this, /^(tables|views)\[/));".(support("table")?" selectCount('selected2', formChecked(this, /^tables\[/) || $S);":"")."\">\n";echo"<input type='hidden' name='token' value='$T'>\n","</div></fieldset>\n";}echo"</form>\n","<script type='text/javascript'>tableCheck();</script>\n";}echo'<p class="links"><a href="'.h(ME).'create=">'.lang(67)."</a>\n",(support("view")?'<a href="'.h(ME).'view=">'.lang(194)."</a>\n":""),(support("materializedview")?'<a href="'.h(ME).'view=&amp;materialized=1">'.lang(275)."</a>\n":"");if(support("routine")){echo"<h3 id='routines'>".lang(133)."</h3>\n";$jg=routines();if($jg){echo"<table cellspacing='0'>\n",'<thead><tr><th>'.lang(172).'<td>'.lang(93).'<td>'.lang(211)."<td>&nbsp;</thead>\n";odd('');foreach($jg
  1804. 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(126)."</a>";}echo"</table>\n";}echo'<p class="links">'.(support("procedure")?'<a href="'.h(ME).'procedure=">'.lang(210).'</a>':'').'<a href="'.h(ME).'function=">'.lang(209)."</a>\n";}if(support("sequence")){echo"<h3 id='sequences'>".lang(276)."</h3>\n";$vg=get_vals("SELECT sequence_name FROM information_schema.sequences WHERE sequence_schema = current_schema() ORDER BY sequence_name");if($vg){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(172)."</thead>\n";odd('');foreach($vg
  1805. 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(216)."</a>\n";}if(support("type")){echo"<h3 id='user-types'>".lang(23)."</h3>\n";$Ph=types();if($Ph){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(172)."</thead>\n";odd('');foreach($Ph
  1806. 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(220)."</a>\n";}if(support("event")){echo"<h3 id='events'>".lang(134)."</h3>\n";$L=get_rows("SHOW EVENTS");if($L){echo"<table cellspacing='0'>\n","<thead><tr><th>".lang(172)."<td>".lang(277)."<td>".lang(200)."<td>".lang(201)."<td></thead>\n";foreach($L
  1807. as$K){echo"<tr>","<th>".h($K["Name"]),"<td>".($K["Execute at"]?lang(278)."<td>".$K["Execute at"]:lang(202)." ".$K["Interval value"]." ".$K["Interval field"]."<td>$K[Starts]"),"<td>$K[Ends]",'<td><a href="'.h(ME).'event='.urlencode($K["Name"]).'">'.lang(126).'</a>';}echo"</table>\n";$tc=$h->result("SELECT @@event_scheduler");if($tc&&$tc!="ON")echo"<p class='error'><code class='jush-sqlset'>event_scheduler</code>: ".h($tc)."\n";}echo'<p class="links"><a href="'.h(ME).'event=">'.lang(199)."</a>\n";}if($Yg)echo"<script type='text/javascript'>ajaxSetHtml('".js_escape(ME)."script=db');</script>\n";}}}page_footer();
RAW Paste Data